<?xml version="1.0" encoding="utf-16"?>
<berkeResponse status="ok" responseCode="200">
  <departmentBillingRecord Version="3" IsActiveVersion="True" UtcVersionActiveFrom="1761436641.98115" UtcVersionActiveThrough="2147501647" ChangeSummary="Change summary example 3..." ReasonForChange="Increased to higher plan" BillingStatus="Enabled" BillingWarning="None" BillingSummary="Summarizes status, plans, etc." BillingRecordId="35412" SourceDepartmentId="[sourceDepartmentId]" IsBillingEnabled="True" UtcBillingStart="1745884641.98115" UtcBillingThrough="2147483647" BillingPlan="Subscription" BillingPlanId="2" BillingPeriodAmount="500.0" BillingNotes="$500/month" BillingContact="Bilbo Baggins" BillingContactEmail="Bilbo@BagEnd.co.uk" BillingContactPhone="555-555-5555" />
  <departmentBillingRecord Version="2" IsActiveVersion="False" UtcVersionActiveFrom="1745884641.98115" UtcVersionActiveThrough="1761436640.98115" ChangeSummary="Change summary example 2..." ReasonForChange="Subscribed to Basic Plan" BillingStatus="DisabledVersion" BillingWarning="None" BillingSummary="Summarizes status, plans, etc." BillingRecordId="25343" SourceDepartmentId="[sourceDepartmentId]" IsBillingEnabled="True" UtcBillingStart="1745884641.98115" UtcBillingThrough="2147483647" BillingPlan="Subscription" BillingPlanId="2" BillingPeriodAmount="300.0" BillingNotes="$300/month" BillingContact="Bilbo Baggins" BillingContactEmail="Bilbo@BagEnd.co.uk" BillingContactPhone="555-555-5555" />
  <departmentBillingRecord Version="1" IsActiveVersion="False" UtcVersionActiveFrom="1729900641.98115" UtcVersionActiveThrough="1765328240.98115" ChangeSummary="" ReasonForChange="Default. Not Set." BillingStatus="DisabledNoPlanSelected" BillingWarning="None" BillingSummary="Summarizes status, plans, etc." BillingRecordId="542" SourceDepartmentId="[sourceDepartmentId]" IsBillingEnabled="False" UtcBillingStart="0" UtcBillingThrough="2147483647" BillingPlan="Not Set" BillingPlanId="1" BillingPeriodAmount="0.0" BillingNotes="Default. Not Set." BillingContact="Not Set." />
</berkeResponse>
    {
  "departmentBillingRecords": [
    {
      "version": 3,
      "isActiveVersion": true,
      "utcVersionActiveFrom": 1761436641.9811487,
      "utcVersionActiveThrough": 2147501647.0,
      "changeSummary": "Change summary example 3...",
      "reasonForChange": "Increased to higher plan",
      "billingStatus": "Enabled",
      "billingWarning": "None",
      "billingSummary": "Summarizes status, plans, etc.",
      "billingRecordId": 35412,
      "sourceDepartmentId": "[sourceDepartmentId]",
      "isBillingEnabled": true,
      "utcBillingStart": 1745884641.9811487,
      "utcBillingThrough": 2147483647.0,
      "billingPlan": "Subscription",
      "billingPlanId": 2,
      "billingPeriodAmount": 500.0,
      "billingNotes": "$500/month",
      "billingContact": "Bilbo Baggins",
      "billingContactEmail": "Bilbo@BagEnd.co.uk",
      "billingContactPhone": "555-555-5555"
    },
    {
      "version": 2,
      "isActiveVersion": false,
      "utcVersionActiveFrom": 1745884641.9811487,
      "utcVersionActiveThrough": 1761436640.9811487,
      "changeSummary": "Change summary example 2...",
      "reasonForChange": "Subscribed to Basic Plan",
      "billingStatus": "DisabledVersion",
      "billingWarning": "None",
      "billingSummary": "Summarizes status, plans, etc.",
      "billingRecordId": 25343,
      "sourceDepartmentId": "[sourceDepartmentId]",
      "isBillingEnabled": true,
      "utcBillingStart": 1745884641.9811487,
      "utcBillingThrough": 2147483647.0,
      "billingPlan": "Subscription",
      "billingPlanId": 2,
      "billingPeriodAmount": 300.0,
      "billingNotes": "$300/month",
      "billingContact": "Bilbo Baggins",
      "billingContactEmail": "Bilbo@BagEnd.co.uk",
      "billingContactPhone": "555-555-5555"
    },
    {
      "version": 1,
      "isActiveVersion": false,
      "utcVersionActiveFrom": 1729900641.9811487,
      "utcVersionActiveThrough": 1765328240.9811487,
      "changeSummary": "",
      "reasonForChange": "Default. Not Set.",
      "billingStatus": "DisabledNoPlanSelected",
      "billingWarning": "None",
      "billingSummary": "Summarizes status, plans, etc.",
      "billingRecordId": 542,
      "sourceDepartmentId": "[sourceDepartmentId]",
      "isBillingEnabled": false,
      "utcBillingStart": 0.0,
      "utcBillingThrough": 2147483647.0,
      "billingPlan": "Not Set",
      "billingPlanId": 1,
      "billingPeriodAmount": 0.0,
      "billingNotes": "Default. Not Set.",
      "billingContact": "Not Set.",
      "billingContactEmail": null,
      "billingContactPhone": null
    }
  ],
  "status": "ok",
  "response": null,
  "responseCode": "200"
}
    <?xml version="1.0" encoding="utf-16"?>
<berkeResponse status="[!=ok]" response="[Error Message], [Parameter]=[[ParameterValue]]" responseCode="[!=200]" />
    {
  "status": "[!=ok]",
  "response": "[Error Message], [Parameter]=[[ParameterValue]]",
  "responseCode": "[!=200]"
}
 
    
        
    
        |  | 
            
                Most API exceptions are due to invalid parameters. Review the notes below each parameter as well as
                the output and HTTP response code from the error message. If all values
                are appropriate, the failure is likely authentication-related. Authentication failure
                types include, but are not limited to,:
             
            Too many failed callsMaximum per minute or per day API calls reachedAPI call made via insecure connection Invalid API key API is not enabled for target company API is disabled for all companies (typically during maintenance) Company is inactive or expired Invalid usernameUser is inactive or expired  | 
    
        | ) | 
                sourceDepartmentId was not found.
             | 
    |  | 
            
                Most API exceptions are due to invalid parameters. Review the notes below each parameter as well as
                the output and HTTP response code from the error message. If all values
                are appropriate, the failure is likely authentication-related. Authentication failure
                types include, but are not limited to,:
             
            Too many failed callsMaximum per minute or per day API calls reachedAPI call made via insecure connection Invalid API key API is not enabled for target company API is disabled for all companies (typically during maintenance) Company is inactive or expired Invalid usernameUser is inactive or expired Unknown sourceJobId - check your API job assignments in the primary Berke customer siteInvalid assessment complete action 
            <?xml version="1.0" encoding="utf-16"?>
<berkeResponse status="[!=ok]" response="[API Method] API method requests exceeded burst limit of 120 occurrences within 60000 milliseconds. Excess requests occurred 3 times from [2025-10-25T23:57:21.2967564Z] to [2025-10-25T23:57:21.8967564Z]." responseCode="429" callDeniedDateTime="2025-10-25T23:57:21.9967564Z" callExpiresOnCompletion="true" countCallsExceeded="3" estimatedMillisecondsToNextAllowedCall="423" firstCallDeniedDateTime="2025-10-25T23:57:21.6967564Z" isDailyLimit="false" maximumCallsPerTimeFrame="120" timeFrameMilliseconds="60000" /> {
  "callDeniedDateTime": "2025-10-25T23:57:21.9967564Z",
  "callExpiresOnCompletion": true,
  "countCallsExceeded": 3,
  "estimatedMillisecondsToNextAllowedCall": 423,
  "firstCallDeniedDateTime": "2025-10-25T23:57:21.6967564Z",
  "isDailyLimit": false,
  "maximumCallsPerTimeFrame": 120,
  "timeFrameMilliseconds": 60000,
  "status": "[!=ok]",
  "response": "[API Method] API method requests exceeded burst limit of 120 occurrences within 60000 milliseconds. Excess requests occurred 3 times from [2025-10-25T23:57:21.2967564Z] to [2025-10-25T23:57:21.8967564Z].",
  "responseCode": "429"
} 
            API requests exceeded the maximum allowed per time-frame or the maximum allowed at any point in time.
         
                
                    
                        API throttle limits are set per-company. Please login and return to this area to see
                        your company's specific throttle configuration.
                    
                 
        Your application can use the following API method response information to determine its course of action when HTTP status code 429
        is returned by an API method call:
     
        
            callDeniedDateTime: The date and time that the API method call was denied execution.
        
            callExpiresUponCompletion: If this value is true then too many simultaneous calls occurred to a particular group of API methods.
            If this value is false then too many requests occurred for a particular time frame (daily or short-term).
        
            countCallsExceeded: The count of calls that exceeded the maximum number of allowed API calls for the time frame.
        
            estimatedMillisecondsToNextAllowedCall: The estimated number of milliseconds, from the callDeniedDateTime, before an API
            call will be allowed to execute. If callExpiresUponCompletion is true then this value will be zero as the time is dependent on
            numerous factors.
            If callExpiresUponCompletion is false then this value indicates the amount of time your application(s) should wait before
            attempting to make the same API method call. If a daily API call limit has been exceeded the this value indicates the amount of time
            your application(s) should wait before calling any API method.
        
            firstCallDeniedDateTime: The date and time that the first call, of potentially many calls, was denied for the time frame.
            For example, if an application was denied ten calls within a time frame then firstCallDeniedDateTime
            indicates date and time that the first of the ten calls was denied.
        
            isDailyLimit: If this value is true then the response indicates that the maximum number of API methods calls for the current day has been exceeded. If this
            value is false then the response indicates that the maximum number of API method calls for a time frame, other than daily, has been exceeded.
        
            maximumCallsPerTimeFrame: Indicates the maximum number of times an API method can be called for daily, short-term or simultaneous call limits.
        
            timeFrameMilliseconds: Indicates the number of milliseconds in which maximumCallsPerTimeFrame API method calls is allowed.
         |