POSTCreate an event type
Creates a new event type with custom configuration, availability, and settings for the authenticated user or organization.
/v2/event-typesRequest Body
application/jsonRequiredlengthInMinutesRequirednumberlengthInMinutesOptionsarray<string>If you want that user can choose between different lengths of the event you can specify them here. Must include the provided lengthInMinutes.
titleRequiredstringslugRequiredstringdescriptionstringbookingFieldsarray<object | object | object | object | object | object | object | object | object | object | object | object | object | object | object | object | object | object | object>Custom fields that can be added to the booking form when the event is booked by someone. By default booking form has name and email field.
disableGuestsbooleanIf true, person booking this event can't add guests via their emails.
slotIntervalnumberNumber representing length of each slot when event is booked. By default it equal length of the event type. If event length is 60 minutes then we would have slots 9AM, 10AM, 11AM etc. but if it was changed to 30 minutes then we would have slots 9AM, 9:30AM, 10AM, 10:30AM etc. as the available times to book the 60 minute event.
minimumBookingNoticenumberMinimum number of minutes before the event that a booking can be made.
beforeEventBuffernumberExtra time automatically blocked on your calendar before a meeting starts. This gives you time to prepare, review notes, or transition from your previous activity.
afterEventBuffernumberExtra time automatically blocked on your calendar after a meeting ends. This gives you time to wrap up, add notes, or decompress before your next commitment.
scheduleIdnumberIf you want that this event has different schedule than user's default one you can specify it here.
bookingLimitsCountobject | objectLimit how many times this event can be booked
bookerActiveBookingsLimitobject | objectLimit the number of active bookings a booker can make for this event type.
onlyShowFirstAvailableSlotbooleanThis will limit your availability for this event type to one slot per day, scheduled at the earliest available time.
bookingLimitsDurationobject | objectLimit total amount of time that this event can be booked
bookingWindowobject | object | object | objectLimit how far in the future this event can be booked
offsetStartnumberOffset timeslots shown to bookers by a specified number of minutes
bookerLayoutsobjectShould booker have week, month or column view. Specify default layout and enabled layouts user can pick.
confirmationPolicyobject | objectSpecify how the booking needs to be manually confirmed before it is pushed to the integrations and a confirmation mail is sent.
recurrenceobject | objectCreate a recurring event type.
requiresBookerEmailVerificationbooleanhideCalendarNotesbooleanlockTimeZoneToggleOnBookingPagebooleancolorobjectseatsobject | objectCreate an event type with multiple seats.
customNamestringCustomizable event name with valid variables: {Event type title}, {Organiser}, {Scheduler}, {Location}, {Organiser first name}, {Scheduler first name}, {Scheduler last name}, {Event duration}, {LOCATION}, {HOST/ATTENDEE}, {HOST}, {ATTENDEE}, {USER}
destinationCalendarobjectuseDestinationCalendarEmailbooleanhideCalendarEventDetailsbooleansuccessRedirectUrlstringA valid URL where the booker will redirect to, once the booking is completed successfully
hideOrganizerEmailbooleanBoolean to Hide organizer's email address from the booking screen, email notifications, and calendar events
calVideoSettingsobjectCal video settings for the event type. Platform customers can't manage this property because currently we have no way of determining if managed user is a host or an attendee.
hiddenbooleanbookingRequiresAuthenticationbooleanBoolean to require authentication for booking this event type via api. If true, only authenticated users who are the event-type owner or org/team admin/owner can book this event type.
falsedisableCancellingobjectSettings for disabling cancelling of this event type.
disableReschedulingobjectSettings for disabling rescheduling of this event type. Can be always disabled or disabled when less than X minutes before the meeting.
interfaceLanguagestringSet preferred language for the booking interface. Use empty string for visitor's browser language (default).
"" | "en" | "ar" | "az" | "bg" | "bn" | "ca" | "cs" | "da" | "de" | "el" | "es" | "es-419" | "eu" | "et" | "fi" | "fr" | "he" | "hu" | "it" | "ja" | "km" | "ko" | "nl" | "no" | "pl" | "pt-BR" | "pt" | "ro" | "ru" | "sk-SK" | "sr" | "sv" | "tr" | "uk" | "vi" | "zh-CN" | "zh-TW"allowReschedulingPastBookingsbooleanEnabling this option allows for past events to be rescheduled.
falseallowReschedulingCancelledBookingsbooleanWhen enabled, users will be able to create a new booking when trying to reschedule a cancelled booking.
falseshowOptimizedSlotsbooleanArrange time slots to optimize availability.
falselocationsarray<object | object | object | object | object | object | object>Locations where the event will take place. If not provided, cal video link will be used as the location. Note: Setting a location to a conferencing app does not install the app - the app must already be installed. Via API, only Google Meet (google-meet), Microsoft Teams (office365-video), and Zoom (zoom) can be installed. Cal Video (cal-video) is installed by default. All other conferencing apps must be connected via the iCalendly web app and are not available for Platform plan customers. You can only set an event type location to an app that has already been installed or connected.
Header Parameters
cal-api-versionRequiredstringMust be set to 2024-06-14. If not set to this value, the endpoint will default to an older version.
"2024-06-14"AuthorizationRequiredstringvalue must be Bearer <token> where <token> is api key prefixed with cal_ or managed user access token