Update a Shift Hour

Purpose

To update the shift hours for your organization through an API.

Request Details

Request URL

{api-domain}/crm/{version}/settings/business_hours/shift_hours

Header

Authorization: Zoho-oauthtoken d92d4xxxxxxxxxxxxx15f52
X-CRM-ORG:{your_org_id}

Scope

scope=ZohoCRM.settings.business_hours.ALL
(or)
scope=ZohoCRM.settings.business_hours.UPDATE

Sample Request

Copiedcurl "https://www.zohoapis.com/crm/v7/settings/business_hours/shift_hours"
-X PUT
-d "@update.json"
-H "Authorization: Zoho-oauthtoken 1000.8cb99dxxxxxxxxxxxxx9be93.9b8xxxxxxxxxxxxxxxf"
-H "X-CRM-ORG:{your_org_id}"

Input JSON

  • idstring, mandatory

    The unique ID of the shift hours you want to update. Use the Get Shift Hours API to get this ID.

  • timezonestring

    Represents the time zone you want to set the shift hours for.

  • namestring

    The name of the shift hours. Must not contain these special characters: ~ , ` , # , % , & , + , = , [ , ] , { , } , | , ; , < , > , ^

  • shift_daysJSON array

    The days of the week you want to set the shift hours for. Note that you can set shift timing only on the days your business operates on.

  • week_starts_onstring

    The day of the week your business starts. The possible values include Sunday through Saturday.

  • same_as_everydayBoolean

    Represents whether the shift hours are the same everyday. When this value is false, the JSON array custom_timing becomes mandatory. When this value is true, the JSON array daily_timing becomes mandatory.

  • custom_timingJSON array, mandatory when same_as_everyday is false

    Contains the following keys in every JSON object of the array:

    • _delete - To delete a particular custom timing of the shift on a business day. The value for this key is null.
    • days - string - The day of the week that has a custom time for the shift. Example: "days":"Monday".
    • shift_timing - JSON array - The shift timing on that day in the HH:MM format. For example: "shift_timing":["10:00","17:00"].
  • break_hoursJSON array

    Contains the following keys in every JSON object of the array:

    • _delete - To delete a particular break hour in a shift. The value for this key is null.
    • same_as_everyday - Boolean - true represents that the break hours are the same everyday and daily_timing is mandatory. When this value is false, the custom_timing array becomes mandatory.
    • break_days - JSON array - The days of the week break hours are allowed.
    • daily_timing(when same_as_everyday is true) - JSON array - The break timing on that day in the HH:MM format. For example: "daily_timing":["10:00","10:30"]. Note that break hours cannot exceed two hours per day, and a day can have only two breaks.
    • custom_timing(when same_as_everyday is false) - JSON array - The break timing on a day in the HH:MM format. For example: "custom_timing":["11:00","01:00"]. Note that break hours cannot exceed two hours per day, and a day can have only two breaks.


      days - string - The day of the shift the custom break timing applies to.

  • holidaysJSON array, optional

    Use this array to associate an existing holiday or create a new holiday while creating a shift hour.
    This array must contain the following keys:

    • name - string, mandatory - The unique name of the holiday. Note that the special characters ~ , ` , # , % , & , + , = , [ , ] , { , } , | , ; , < , > , ^ are not allowed.
    • date - string, mandatory - The date in the YYYY-MM-DD format that the holiday falls on.
    • id - string, mandatory when you want to associate an existing holiday - The unique ID of the holiday you have already created. Pass the ID of the holiday from the Get Holidays API.
    • _delete - mandatory when you want to delete a holiday from the shift - The value null deletes the holiday from that shift.
  • usersJSON array

    The ID of the user who you want to assign these shift hours to. Use the key effective_from to assign this shift to the user on this date. The format is YYYY-DD-MM.
    When you do not specify this key, the user gets assigned to the shift immediately.

Input JSON

Copied{
    "shift_hours": [
        {
            "id":"3652397000011137072",
            "holidays": [
                {
                    "id": "3652397000011137047",
                    "_delete": null
                }
            ],
            "users": [
                {
                    "id": "554023000002209087"
                }
            ]
        }
    ]
}

Possible Errors

  • INVALID_DATAHTTP 400

    Reasons:

    • One or more of these data is invalid - shift timing, timezone, break timing, effective from date.
    • The input contains more than two break hour timings.
    • The input contains more than seven shift days or break days.
    • The shift name contains the special characters ~ , ` , # , % , & , + , = , [ , ] , { , } , | , ; , < , > , ^.
    • The break hours overlap.
    • The break hours fall outside the shift hours.
    • The effective from date is not greater than the current date.

    Resolution:
    Refer to the "details" key in the response for the API name of the field that has the error in the input.

  • MANDATORY_NOT_FOUNDHTTP 400

    You have not specified the ID of the shift hour you want to update in the input.
    Resolution: ID of the shift hour is mandatory.

  • DEPENDENT_FIELD_MISSINGHTTP 400

    You have not specified one or more of the dependent fields.
    Resolution:

    • For custom shift hours, days is mandatory.
    • When same_as_everyday=true, daily_timing is mandatory.
    • When same_as_everyday=false, custom_timing is mandatory.

    Refer to the sample input for the structure of each of these keys.

  • NOT_ALLOWEDHTTP 400

    You are trying to set shift hours before setting up business hours for your org.
    Resolution: You can add shift hours only after you add business hours.

  • NOT_ALLOWEDHTTP 400

    You are trying to set break hours for more than two hours.
    Resolution: Each shift can have a break timing of a maximum of two hours.

  • INVALID_URL_PATTERNHTTP 404

    Please check if the URL trying to access is a correct one
    Resolution: The request URL specified is incorrect. Specify a valid request URL. Refer to the request URL section above.

  • OAUTH_SCOPE_MISMATCHHTTP 401

    You do not have the right scope to access this API.
    Resolution: Create new token with ZohoCRM.settings.business_hours.ALL or ZohoCRM.settings.business_hours.UPDATE scopes.

Sample Response

Copied{
    "shift_hours": [
        {
            "code": "SUCCESS",
            "details": {
                "id": "3652397000011137072"
            },
            "message": "Shift Hours updated successfully.",
            "status": "success"
        }
    ]
}