Note: After adding new nodes in the Latenode chain of a project, to access the data from the previous nodes, you need to run the project and call the chain with all the necessary data. Data substituted from "JavaScript" node into "HTTP request" node often needs to be escaped with double quotes. Complex objects or arrays received in response to request from remote servers and coming as string must be processed by JSON.parse in order to work with them in "JavaScript" nodes as with corresponding data type.
First, be sure to get the token according to the instructions in our article, only in the list of servers select "Google Calendar Api v..." and in the scope "www.googleapis.com/auth/calendar ";
Next, create a new calendar in Calendar, we can call it for example "LatenodeTest";
Let's prepare a request for our rest client;
REQ01: Request for rest client
curl --request POST --url 'https://webhook.latenode.com/00/dev/some_hash'
--header 'Accept: application/json'
--header 'Content-Type: application/x-www-form-urlencoded'
--data 'token=[Replace the square brackets with the content of your token]'
--data 'summary=Event created from Latenode'
--data 'location=https://app.latenode.com'
--data 'description=Adding an event to the calendar from Latenode using the API'
--data 'startDate=2022-12-21T09:00:00-07:00 Change to the nearest date'
--data 'startTZ=Europe/Moscow'
--data 'endDate=2022-12-22T09:00:00-07:00 Change to the nearest date'
--data 'endTZ=Europe/Moscow'
Let's substitute our token obtained from the step at the beginning;
Change the start date "startDate" and end date "endDate" to the nearest, you can also change the time zone if it does not fit is startTZ and endTZ;
Let's check in all constructions like "data["{{1.body.name}}"]" that the number of Webhook corresponds to the one we are getting data from, if not replace it with the necessary one (let me remind you that 1 is the node number written just below the node name above the node type, then if it is a query then the object field responsible for the type of sent/received data is selected - body for forms or query for query parameters);
Let's start and call the chain to transfer data between the nodes;
Let's copy the content into it, to find the desired calendar from the list obtained from the previous query:
const tempCalendarsList = JSON.parse(data["{{3.body.items}}"]); // Make sure the information is from the correct node from the calendar list query
const targetCalendar = tempCalendarsList.find((calendar) => calendar.summary === "LatenodeTest"); // Here instead of "LatenodeTest" you can write the name of the desired calendar
return {
targetCalendar
}
Check the data that are specified in the comments to the code;
Let's start and call the chain to transfer data between the nodes;
In the "Url" field at the beginning we substitute the variable "apiURL" from the first "JavaScrtipt" node, after it we add: /calendars/, then we substitute the variable "targetCalendar.id" from "JavaScrtipt" with the calendar list processing, and at the end: /events;
Change the method to the "Post" method;
In the body of "raw": let's substitute the variable containing the object with the new event from the first of the first "JavaScrtipt" node;
Let's add the "Autorization" header and in its value the variable "bToken" from the first "JavaScrtipt" node;
Click "Save";
Tie the nodes together;
Let's start and call the chain to transfer data between the nodes;
After that, a new event should appear in the calendar;
At the end of the whole chain in Latenode will look like this: