-
-
Save varun160490/61f96b54a9b59f44b6e4468751faa525 to your computer and use it in GitHub Desktop.
// This javascript code will alert you and immediately book the slot whenever a slot opens up on the given date within the given pincodes. | |
// **** THIS SCRIPT IS TO MAKE NEW BOOKING FOR DOSE 1 OR DOSE 2. IN CASE OF RESCHEDULE, FIRST CANCEL THE BOOKING AND THEN TRY TO BOOK USING THIS SCRIPT. **** | |
// **** RUN SCRIPT 5 MINUTES BEFORE THE SLOT OPENING TIME. IF THE SESSION IS EXPIRED (EXPIRES IN 10-15 MINUTES), LOG IN AND RERUN THE SCRIPT. **** | |
// Steps to use | |
// 1. Update pincodes,age,district_id,beneficiaries,dose,vaccine & vaccine_date. | |
// 2. Login to https://selfregistration.cowin.gov.in/ | |
// 3. Right Click on the website | |
// 4. Click on Inspect | |
// 5. Switch to the Console Tab on the recently opened Inspect window | |
// 6. Copy paste the contents of this entire file - cowin_vaccination_autobooking.js | |
// 8. Press Enter | |
// 9. This will generate the captcha and show it in a new window. Note the captcha and close the window. | |
// 10. Within few seconds, A prompt will show on screen asking you to enter the Captcha code. Type in the Captcha as noted. | |
// 11. It will run every 3 seconds and check for availability of slots. Once available, it will immediately book the slot. Refresh the page once you get the booking confirmation message. | |
// Change the pincodes as per your city | |
var pincodes = [202001,202280]; | |
// Change the age as per your requirement | |
var age = 18; //45,18 | |
// Change the district id as per the city you are living in | |
var district_id = 623; | |
// Keep the vaccine as per your need. Currently it will look for both the vaccines. | |
var vaccines = ["COVISHIELD","COVAXIN","SPUTNIK V"]; | |
// Enter dose = 1 for first dose, dose = 2 for second dose | |
var dose = 1; | |
// Change the date to the date of slot booking | |
var vaccine_date = "07-06-2021"; | |
// Reference id of the person you are booking a slot for. Can find it written beside your name after you log in. | |
var beneficiaries = [66119476081580,66229455431599]; | |
// Defined API Host endpoint | |
var host = "https://cdn-api.co-vin.in/api"; | |
// Variable to keep track of whether slot is booked | |
var booked = false; | |
// Authorization token needed to book a slot - No Changes required | |
var authorizationToken = "Bearer " + sessionStorage.getItem("userToken").match(/"([^"]+)"/)[1]; | |
var sleepNow = (delay) => new Promise((resolve) => setTimeout(resolve, delay)) | |
var trialCounter = 1; | |
(function () { | |
var newscript = document.createElement('script'); | |
newscript.type = 'text/javascript'; | |
newscript.async = true; | |
newscript.src = 'https://ajax.googleapis.com/ajax/libs/jquery/1.6.1/jquery.min.js'; | |
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(newscript); | |
})(); | |
function httpGet(method, theUrl, isPublic=true) { | |
var xmlHttp = new XMLHttpRequest(); | |
xmlHttp.open(method, theUrl, false); | |
if(!isPublic) | |
xmlHttp.setRequestHeader("authorization", authorizationToken); | |
xmlHttp.send(null); | |
if(xmlHttp.status == 401){ | |
alert('Your session has been expired. Please Login and rerun the script.'); | |
location.reload(); | |
} | |
return xmlHttp.responseText; | |
} | |
function getCaptcha() { | |
var url = host + "/v2/auth/getRecaptcha"; | |
var data = JSON.parse(httpGet("POST", url,false)).captcha; | |
var myWindow = window.open("", "MsgWindow", "width=200,height=100"); | |
myWindow.document.write(data); | |
} | |
async function fetchByDistrict(captcha) { | |
if (captcha.length > 0) { | |
console.log("Check: ", trialCounter++); | |
url = host + "/v2/appointment/sessions/public/calendarByDistrict?district_id=" + district_id + "&date=" + vaccine_date; | |
try { | |
centers = JSON.parse(httpGet("GET", url)).centers; | |
} catch (e) { | |
console.log("error"); | |
} | |
for (i in centers) { | |
center = centers[i]; | |
for (j in center.sessions) { | |
session = center.sessions[j]; | |
var available_capacity = 0; | |
if(dose==1) | |
available_capacity = session.available_capacity_dose1; | |
else if(dose==2) | |
available_capacity = session.available_capacity_dose2; | |
if (!booked && session.min_age_limit == age && available_capacity > 0 && vaccines.includes(session.vaccine) && pincodes.includes(center.pincode) && vaccine_date == session.date) { | |
console.log("Vaccines available at : ", center.pincode, center.name, center.center_id, available_capacity); | |
data = { | |
center_id: center.center_id, | |
session_id: session.session_id, | |
dose: dose, | |
slot: session.slots[0], | |
beneficiaries: beneficiaries, | |
captcha: captcha | |
} | |
bookSlot(data); | |
} | |
} | |
} | |
if (!booked) { | |
await sleepNow(3000); | |
fetchByDistrict(captcha); | |
} | |
} | |
} | |
function bookSlot(data) { | |
console.log('Booking Started'); | |
return $.ajax({ | |
type: "POST", | |
url: host + "/v2/appointment/schedule", | |
async: false, | |
data: JSON.stringify(data), | |
timeout: 10000, | |
beforeSend: function (request) { | |
request.setRequestHeader("authorization", authorizationToken); | |
request.setRequestHeader("Content-Type", "application/json"); | |
}, | |
success: function (result) { | |
booked = true; | |
alert("Your appointment for the vaccine has been booked. \n\nAppointment No: " + result['appointment_confirmation_no']); | |
console.log('Booking Success'); | |
}, | |
error: function (error) { | |
console.log("BOOKING ERROR : ", error.responseText); | |
} | |
}); | |
} | |
// Initiate Booking | |
getCaptcha(); | |
setTimeout(function(){ | |
fetchByDistrict(prompt("Enter Captcha Code below:")); | |
}, 3000); |
Hi varun160490
Thanks for your efforts to resolve that CORS issue but I am still seeing it unfortunately. It is not continuous but every now and then between requests it appears few times and then it starts to work again. COWIN must have some mechanism to stop requests which is suspicious and not having specific headers present with them.@sanjaysen83,
This seems to be a random error. I will check for a fix. Meanwhile, just login 5 minutes before booking; it will do the job for you.
Hello,
I did the same thing. Logged In 5 min before the slot opening, filled up captcha and it started. But somehow after 3 min i.e 2 min before the slot opened, I started getting the same error and was unable to book the slot. Here is the image containing details of same error.
Hey @varun160490. I think the CORS issue can be fixed by changing
xmlHttp.withCredentials
tofalse
. You can try and change the code accordingly.
I cannot find xmlHttp.withCredentials
in the code. can you help us by telling where to add?
I have updated the code. Try now with the latest code.. so far, I didn't get any error. Let me know if you are still getting it.
Thanks, @kaxevgg, for the suggestion.
@varun160490 - thanks for developing this script. I've got friends and family members registered with its help, which was seeming impossible otherwise. Everytime someone books a slot using this script, you've saved a life _/_
Keep up the good work, thanks again!!
@varun160490 - thanks for developing this script. I've got friends and family members registered with its help, which was seeming impossible otherwise. Everytime someone books a slot using this script, you've saved a life /
Keep up the good work, thanks again!!
@ergauravmishra Thanks much buddy... :)
@varun160490
When i am trying to book the slot then always after some tries i am getting an error in all check condition.
Where i made a mistake?
Looks like now after 20 tries it gives HTTP 403 error. Happens exactly on 21st try and even if I change wait/sleep time to 10 seconds
I have already booked many people using this script so looks to be something new with cowin website
looks like they are logging people off after a certain number of tries
Looks like now after 20 tries it gives HTTP 403 error. Happens exactly on 21st try and even if I change wait/sleep time to 10 seconds
I have already booked many people using this script so looks to be something new with cowin website
Hey @varun160490,
I'm also getting the same error and exactly after 20 checks. Here is the image for your reference
Rajtomar, that was easily handled earlier by changing sleep to 5000 ms as it would have ensured less than 100 hits in 5 mins. The new limit seems weird as it logs us out after 20 such requests irrespective of the sleep or any manual activity in portal. In fact, if you try and search manually once you get 403 error code, it will ask you to login (a refresh would still work - almost as if you have been logged off for a search operation)
Captcha is no longer required on CoWin.
Rajtomar, that was easily handled earlier by changing sleep to 5000 ms as it would have ensured less than 100 hits in 5 mins. The new limit seems weird as it logs us out after 20 such requests irrespective of the sleep or any manual activity in portal. In fact, if you try and search manually once you get 403 error code, it will ask you to login (a refresh would still work - almost as if you have been logged off for a search operation)
Yes I observed that in the console when I tried searching for slots manually. Also, If we do this activity too many times, our IP will get blocked under CORS policy. Saw the message of my IP getting blocked in console whereas the cowin website UI was constantly throwing error, "Something went wrong. Try again later".
@singhrajtomar, @khushIdnani, @riteshnarain, @Pawan446, @dilipdhankecha,
Yes, they are blocking the request after few seconds. I have solved the problem by using public API calls. Please use the latest code to book the slot. Let me know if you are still facing the issue.
Cowin removed captcha functionality.
will your script work now?
Cowin removed captcha functionality.
will your script work now?
@atul1357, Yes, it will work.
Hi Varun,
is there any way to book only free one?
Hi Varun,
thank you for this marvelous effort you've put to help people in this time of need. Also, I really appreciate the patient support, immediate bug fixes with code updates as well as warm and courteous behavior you extended towards me while guiding me thoroughly to use these scripts. From my personal experience i completely vouch for their credibility and utility. They have proved extremely helpful in booking slot for my vaccination and all of it seemed effortless. Thanks again Varun...
Thank you so much @digantopaul.. :)
Hi Varun,
is there any way to book only free one?
@klalj86, Not yet.. if you want you can add fee_type: "Free" in the code or only use pincodes with free one..
Hey @varun160490. I think the CORS issue can be fixed by changing
xmlHttp.withCredentials
tofalse
. You can try and change the code accordingly.