Dates v0.2.2
Scroll down for code samples, example requests and responses. Select a language for code samples from the tabs above or the mobile navigation menu.
The Dates API provides various operations relating to calendars and dates. For example, the /eventDates method can be used to find upcoming events given one or more schedules and a calendar of exclusions.
Download OpenAPI Definition (YAML)
Base URLs:
Authentication
- API Key (apiKey)- header parameter: API-Key
- API Key based authentication. Each client application must pass its private, unique API key, allocated in the developer portal, via the API-Key: {api-key}request header.
 
API
Endpoints which describe this API.
getApi
Code samples
# You can also use wget
curl -X GET https://api.devbank.apiture.com/dates/ \
  -H 'Accept: application/hal+json' \
  -H 'API-Key: API_KEY'
GET https://api.devbank.apiture.com/dates/ HTTP/1.1
Host: api.devbank.apiture.com
Accept: application/hal+json
var headers = {
  'Accept':'application/hal+json',
  'API-Key':'API_KEY'
};
$.ajax({
  url: 'https://api.devbank.apiture.com/dates/',
  method: 'get',
  headers: headers,
  success: function(data) {
    console.log(JSON.stringify(data));
  }
})
const fetch = require('node-fetch');
const headers = {
  'Accept':'application/hal+json',
  'API-Key':'API_KEY'
};
fetch('https://api.devbank.apiture.com/dates/',
{
  method: 'GET',
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});
require 'rest-client'
require 'json'
headers = {
  'Accept' => 'application/hal+json',
  'API-Key' => 'API_KEY'
}
result = RestClient.get 'https://api.devbank.apiture.com/dates/',
  params: {
  }, headers: headers
p JSON.parse(result)
import requests
headers = {
  'Accept': 'application/hal+json',
  'API-Key': 'API_KEY'
}
r = requests.get('https://api.devbank.apiture.com/dates/', params={
}, headers = headers)
print r.json()
URL obj = new URL("https://api.devbank.apiture.com/dates/");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());
package main
import (
       "bytes"
       "net/http"
)
func main() {
    headers := map[string][]string{
        "Accept": []string{"application/hal+json"},
        "API-Key": []string{"API_KEY"},
        
    }
    data := bytes.NewBuffer([]byte{jsonReq})
    req, err := http.NewRequest("GET", "https://api.devbank.apiture.com/dates/", data)
    req.Header = headers
    client := &http.Client{}
    resp, err := client.Do(req)
    // ...
}
Top-level resources and operations in this API
GET /
Return links to the top-level resources and operations in this API. Links included in this response include:
- apiture:findEventDates- a- POSToperation for finding dates corresponding to recurring scheduled events
Example responses
200 Response
{
  "id": "dates",
  "name": "dates",
  "apiVersion": "0.1.0",
  "_profile": "https://api.apiture.com/schemas/common/root/v1.0.0/profile.json",
  "_links": {}
}
Responses
| Status | Description | 
|---|---|
| 200 | OK | 
| OK | |
| Schema: root | 
getApiDoc
Code samples
# You can also use wget
curl -X GET https://api.devbank.apiture.com/dates/apiDoc \
  -H 'Accept: application/json' \
  -H 'API-Key: API_KEY'
GET https://api.devbank.apiture.com/dates/apiDoc HTTP/1.1
Host: api.devbank.apiture.com
Accept: application/json
var headers = {
  'Accept':'application/json',
  'API-Key':'API_KEY'
};
$.ajax({
  url: 'https://api.devbank.apiture.com/dates/apiDoc',
  method: 'get',
  headers: headers,
  success: function(data) {
    console.log(JSON.stringify(data));
  }
})
const fetch = require('node-fetch');
const headers = {
  'Accept':'application/json',
  'API-Key':'API_KEY'
};
fetch('https://api.devbank.apiture.com/dates/apiDoc',
{
  method: 'GET',
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});
require 'rest-client'
require 'json'
headers = {
  'Accept' => 'application/json',
  'API-Key' => 'API_KEY'
}
result = RestClient.get 'https://api.devbank.apiture.com/dates/apiDoc',
  params: {
  }, headers: headers
p JSON.parse(result)
import requests
headers = {
  'Accept': 'application/json',
  'API-Key': 'API_KEY'
}
r = requests.get('https://api.devbank.apiture.com/dates/apiDoc', params={
}, headers = headers)
print r.json()
URL obj = new URL("https://api.devbank.apiture.com/dates/apiDoc");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("GET");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());
package main
import (
       "bytes"
       "net/http"
)
func main() {
    headers := map[string][]string{
        "Accept": []string{"application/json"},
        "API-Key": []string{"API_KEY"},
        
    }
    data := bytes.NewBuffer([]byte{jsonReq})
    req, err := http.NewRequest("GET", "https://api.devbank.apiture.com/dates/apiDoc", data)
    req.Header = headers
    client := &http.Client{}
    resp, err := client.Do(req)
    // ...
}
Return API definition document
GET /apiDoc
Return the OpenAPI document that describes this API.
Example responses
200 Response
{}
Responses
| Status | Description | 
|---|---|
| 200 | OK | 
| OK | |
| Schema: Inline | 
Response Schema
Event Dates
List of event dates
findEventDates
Code samples
# You can also use wget
curl -X POST https://api.devbank.apiture.com/dates/eventDates \
  -H 'Content-Type: application/hal+json' \
  -H 'Accept: application/json' \
  -H 'API-Key: API_KEY'
POST https://api.devbank.apiture.com/dates/eventDates HTTP/1.1
Host: api.devbank.apiture.com
Content-Type: application/hal+json
Accept: application/json
var headers = {
  'Content-Type':'application/hal+json',
  'Accept':'application/json',
  'API-Key':'API_KEY'
};
$.ajax({
  url: 'https://api.devbank.apiture.com/dates/eventDates',
  method: 'post',
  headers: headers,
  success: function(data) {
    console.log(JSON.stringify(data));
  }
})
const fetch = require('node-fetch');
const inputBody = '{
  "schedules": [
    {
      "label": "Retirement savings transfer",
      "start": "2019-06-10",
      "every": "P14D",
      "count": 5,
      "skippedCount": 0,
      "maximumCount": 10,
      "skipNext": true,
      "end": "2019-08-01"
    }
  ],
  "exclusions": {
    "holidays": [
      "2019-12-24",
      "2019-12-25"
    ],
    "unprocessableDays": [
      "sunday",
      "saturday"
    ]
  }
}';
const headers = {
  'Content-Type':'application/hal+json',
  'Accept':'application/json',
  'API-Key':'API_KEY'
};
fetch('https://api.devbank.apiture.com/dates/eventDates',
{
  method: 'POST',
  body: inputBody,
  headers: headers
})
.then(function(res) {
    return res.json();
}).then(function(body) {
    console.log(body);
});
require 'rest-client'
require 'json'
headers = {
  'Content-Type' => 'application/hal+json',
  'Accept' => 'application/json',
  'API-Key' => 'API_KEY'
}
result = RestClient.post 'https://api.devbank.apiture.com/dates/eventDates',
  params: {
  }, headers: headers
p JSON.parse(result)
import requests
headers = {
  'Content-Type': 'application/hal+json',
  'Accept': 'application/json',
  'API-Key': 'API_KEY'
}
r = requests.post('https://api.devbank.apiture.com/dates/eventDates', params={
}, headers = headers)
print r.json()
URL obj = new URL("https://api.devbank.apiture.com/dates/eventDates");
HttpURLConnection con = (HttpURLConnection) obj.openConnection();
con.setRequestMethod("POST");
int responseCode = con.getResponseCode();
BufferedReader in = new BufferedReader(
    new InputStreamReader(con.getInputStream()));
String inputLine;
StringBuffer response = new StringBuffer();
while ((inputLine = in.readLine()) != null) {
    response.append(inputLine);
}
in.close();
System.out.println(response.toString());
package main
import (
       "bytes"
       "net/http"
)
func main() {
    headers := map[string][]string{
        "Content-Type": []string{"application/hal+json"},
        "Accept": []string{"application/json"},
        "API-Key": []string{"API_KEY"},
        
    }
    data := bytes.NewBuffer([]byte{jsonReq})
    req, err := http.NewRequest("POST", "https://api.devbank.apiture.com/dates/eventDates", data)
    req.Header = headers
    client := &http.Client{}
    resp, err := client.Do(req)
    // ...
}
Return a collection of event dates
POST /eventDates
Finds upcoming event dates given one or more schedules of events and exclusions.  Available parameters include start, limit, startDate, and period. There are two modes of pagination available:
- Indexed pages defined by a startindex and alimit
- periodbased pagination beginning at- startDate
Only one mode of pagination can be used at a time and the default mode is period with a value of P1Y.
To obtain the next page of results, use the next link in the response (if it exists) with a POST verb. Pass the same request body as passed to this operation (this operation is fully stateless). If there is no next link, the collection has been exhausted. Note that some queries may not have a terminating collection (for example, if the schedule does not have a start date). The service will update the query parameters in the link to access the next page, according to the type of pagination in use. Thait is, it will increment the start if initially invoked with  indexed-based pagination, or it will adjust the startDate if  initially invoked with period-based pagination. The limit passed to this operation will also be passed to the next page.
Body parameter
{
  "schedules": [
    {
      "label": "Retirement savings transfer",
      "start": "2019-06-10",
      "every": "P14D",
      "count": 5,
      "skippedCount": 0,
      "maximumCount": 10,
      "skipNext": true,
      "end": "2019-08-01"
    }
  ],
  "exclusions": {
    "holidays": [
      "2019-12-24",
      "2019-12-25"
    ],
    "unprocessableDays": [
      "sunday",
      "saturday"
    ]
  }
}
Parameters
| Parameter | Description | 
|---|---|
| start(query) | integer(int64)The zero-based index of the first event date item to include in this page. The default 0 denotes the beginning of the collection. If startDateis also providedstartwill be ignored. | 
| limit(query) | integer(int32)The maximum number of event dates to return in this page. If periodis also provided,limitwill be ignored. | 
| startDate(query) | string(date)The start date of the period in which to look for events. If periodpagination mode is being used and nostartDateis  provided, the current date will be used. | 
| startDatewill overridestartif both are provided. | |
| period(query) | stringThe length of time used to paginate event date results. periodwill overridelimitif both are provided. | 
| This value is an ISO 8601 duration string of the form P[n]Y[n]M[n]Dto specify the number of years/months/days between dates. For example, useP7Dto paginate by weeks,P2Mto paginate by 2 months.  Time values inperiodare ignored but may be honored in the future. | |
| body(body) | eventDatesRequest(required)The data necessary to find event dates. | 
Example responses
200 Response
{
  "_profile": "https://api.apiture.com/schemas/dates/eventDates/v1.0.0/profile.json",
  "start": 0,
  "limit": 5,
  "count": 28,
  "name": "eventDates",
  "_links": {
    "self": {
      "href": "/dates/eventDates?start=0&limit=5"
    },
    "first": {
      "href": "/dates/eventDates?start=0&limit=5"
    },
    "next": {
      "href": "/dates/eventDates?start=5&limit=5"
    },
    "collection": {
      "href": "/dates/eventDates"
    }
  },
  "_embedded": {
    "items": [
      {
        "labels": [
          "Core Schedule"
        ],
        "date": "2019-06-14"
      },
      {
        "labels": [
          "Core Schedule"
        ],
        "date": "2019-06-16"
      },
      {
        "labels": [
          "Core Schedule"
        ],
        "date": "2019-06-18"
      },
      {
        "labels": [
          "Core Schedule",
          "Second Schedule"
        ],
        "date": "2019-06-20"
      },
      {
        "labels": [
          "Core Schedule",
          "Second Schedule"
        ],
        "date": "2019-06-22"
      }
    ]
  }
}
Responses
| Status | Description | 
|---|---|
| 200 | OK | 
| OK | |
| Schema: eventDates | |
| 400 | Bad Request | 
| Bad Request.  The request body or one or more of the query parameters was not well formed.  The _errorfield in the response will contain details about the request error. | |
| Schema: errorResponse | |
| 422 | Unprocessable Entity | 
| Unprocessable Entity. One or more of the query parameters was well formed but otherwise invalid. The _errorfield in the response will contain details about the request error. | |
| Schema: errorResponse | 
Schemas
abstractResource
{
  "_profile": "https://api.apiture.com/schemas/example/v1.0.0/profile.json",
  "_links": {
    "self": {
      "href": "{uri of current resource}"
    }
  }
}
Abstract Resource
An augmented HAL resource representation. This model contains hypermedia _links, and either optional domain object data with _profile and optional _embedded objects, or an _error object. In responses, if the operation was successful, this object will not include the _error, but if the operation was a 4xx or 5xx error, this object will not include _embedded or any data fields, only _error and optionally _links.
Properties
| Name | Description | 
|---|---|
| _links | linksAn optional map of links, mapping each link relation to a link object. This model defines the _linksobject of HAL representations. | 
| _embedded | objectAn optional map of nested resources, mapping each nested resource name to a nested resource representation. | 
| _profile | string(uri)The URI of a resource profile which describes the representation. | 
| _error | errorAn object which describes an error. This value is omitted if the operation succeeded without error. | 
root
{
  "id": "dates",
  "name": "dates",
  "apiVersion": "0.1.0",
  "_profile": "https://api.apiture.com/schemas/common/root/v1.0.0/profile.json",
  "_links": {}
}
Dates API Root
A HAL response, with hypermedia _links for the top-level resources and operations in API.
Properties
| Name | Description | 
|---|---|
| _links | linksAn optional map of links, mapping each link relation to a link object. This model defines the _linksobject of HAL representations. | 
| _embedded | objectAn optional map of nested resources, mapping each nested resource name to a nested resource representation. | 
| _profile | string(uri)The URI of a resource profile which describes the representation. | 
| _error | errorAn object which describes an error. This value is omitted if the operation succeeded without error. | 
| _id | stringThis API's unique ID. | 
| name | stringThis API's name. | 
| apiVersion | stringThis API's version. | 
errorResponse
{
  "_profile": "https://api.apiture.com/schemas/common/errorResponse/v1.0.0/profile.json",
  "_error": {
    "_id": "2eae46e1-575c-4d69-8a8f-0a7b0115a4b3",
    "_profile": "https://api.apiture.com/schemas/common/errorResponse/v1.0.0/profile.json",
    "message": "The value for deposit must be greater than 0.",
    "statusCode": 422,
    "type": "integer",
    "attributes": {
      "value": -125.5
    },
    "remediation": "Provide a value which is greater than 0",
    "occurredAt": {},
    "_links": {
      "describedby": {
        "href": "http://doc.apiture.com/errors/positiveNumberRequired"
      }
    },
    "_embedded": {
      "errors": []
    }
  }
}
Error Response
Describes an error response, typically returned on 4xx or 5xx errors from API operations. The _error object contains the error details.
Properties
| Name | Description | 
|---|---|
| _links | linksAn optional map of links, mapping each link relation to a link object. This model defines the _linksobject of HAL representations. | 
| _embedded | objectAn optional map of nested resources, mapping each nested resource name to a nested resource representation. | 
| _profile | string(uri)The URI of a resource profile which describes the representation. | 
| _error | errorAn object which describes an error. This value is omitted if the operation succeeded without error. | 
error
{
  "_id": "2eae46e1-575c-4d69-8a8f-0a7b0115a4b3",
  "_profile": "https://api.apiture.com/schemas/common/errorResponse/v1.0.0/profile.json",
  "message": "The value for deposit must be greater than 0.",
  "statusCode": 422,
  "type": "positiveNumberRequired",
  "attributes": {
    "value": -125.5
  },
  "remediation": "Provide a value which is greater than 0",
  "occurredAt": "2018-01-25T05:50:52.375Z",
  "_links": {
    "describedby": {
      "href": "http://doc.apiture.com/errors/positiveNumberRequired"
    }
  },
  "_embedded": {
    "errors": []
  }
}
Error
An error description. Nested source errors are contained in the _embedded object with the key "errors"; this is an array of nested error objects. For example, an API which validates its request body may find multiple errors in the request, which may be detailed here. The _links may contain a describedby link which refers to a web page with details about the error. The attributes field An optional map of name/value pairs which provide structured data about the error. For example, if the error is a value out of range, the attributes may specify the range values min and max. This allows clients to present error messages as they see fit (the API does not assume the client/presentation tier).
Properties
| Name | Description | 
|---|---|
| message | string(required)A localized message string describing the error condition. | 
| _id | stringA unique identifier for this error instance. This may be used as a correlation ID with the root cause error (i.e. this ID may be logged at the source of the error). This is is an opaque string. | 
| statusCode | integerThe HTTP status code associate with this error. minimum: 100maximum: 599 | 
| type | stringAn error identifier which indicates the category of error and associate it with API support documentation or which the UI tier can use to render an appropriate message or hint. This provides a finer level of granularity than the statusCode. For example, instead of just 400 Bad Request, thetypemay be much more specific. such asintegerValueNotInAllowedRangeornumericValueExceedsMaximumorstringValueNotInAllowedSet. | 
| occurredAt | string(date-time)An ISO 8601 UTC time stamp indicating when the error occurred. | 
| attributes | attributesData attribute associated with the error, such as values or constraints. | 
| remediation | stringAn optional localized string which provides hints for how the user or client can resolve the error. | 
| _embedded | objectOptional embedded array of errors. This field may not exist if the error does not have nested errors. | 
| » items | [errorResponse]An array of error objects. | 
attributes
{}
Attributes
An optional map of name/value pairs which contains additional dynamic data about the resource.
Properties
eventDatesRequest
{
  "schedules": [
    {
      "label": "Retirement savings transfer",
      "start": "2019-06-10",
      "every": "P14D",
      "count": 5,
      "skippedCount": 0,
      "maximumCount": 10,
      "skipNext": true,
      "end": "2019-08-01"
    }
  ],
  "exclusions": {
    "holidays": [
      "2019-12-24",
      "2019-12-25"
    ],
    "unprocessableDays": [
      "sunday",
      "saturday"
    ]
  }
}
Event Dates Request
The request body for invoking /eventDates.  Contains an array of scheduled events and a calendar representing excluded dates.
Properties
| Name | Description | 
|---|---|
| schedules | [schedule](required)[A definition for a one-time or recurring scheduled event.] | 
| exclusions | calendarA definition of a calendar | 
eventDates
{
  "_profile": "https://api.apiture.com/schemas/dates/eventDates/v1.0.0/profile.json",
  "start": 0,
  "limit": 5,
  "count": 28,
  "name": "eventDates",
  "_links": {
    "self": {
      "href": "/dates/eventDates?start=0&limit=5"
    },
    "first": {
      "href": "/dates/eventDates?start=0&limit=5"
    },
    "next": {
      "href": "/dates/eventDates?start=5&limit=5"
    },
    "collection": {
      "href": "/dates/eventDates"
    }
  },
  "_embedded": {
    "items": [
      {
        "labels": [
          "Core Schedule"
        ],
        "date": "2019-06-14"
      },
      {
        "labels": [
          "Core Schedule"
        ],
        "date": "2019-06-16"
      },
      {
        "labels": [
          "Core Schedule"
        ],
        "date": "2019-06-18"
      },
      {
        "labels": [
          "Core Schedule",
          "Second Schedule"
        ],
        "date": "2019-06-20"
      },
      {
        "labels": [
          "Core Schedule",
          "Second Schedule"
        ],
        "date": "2019-06-22"
      }
    ]
  }
}
Event Date Collection
Collection of event dates. The items in the collection are ordered in the _embedded object with name items. The top-level _links object may contain pagination links (self, next, prev, first, last, collection). These pagination links require using POST and should pass the same Event Dates Request object as described in the findEventsDate operation.
Properties
| Name | Description | 
|---|---|
| _links | linksAn optional map of links, mapping each link relation to a link object. This model defines the _linksobject of HAL representations. | 
| _embedded | object | 
| » items | [eventDate]An array containing a page of event dates. | 
| _profile | string(uri)The URI of a resource profile which describes the representation. | 
| _error | errorAn object which describes an error. This value is omitted if the operation succeeded without error. | 
| count | integerThe number of items in the full collection. | 
| start | integerThe start index of this page of items. | 
| limit | integerThe maximum number of items per page. | 
| name | stringThe name of the collection. | 
| startDate | stringThe start date of events on this page. | 
| period | stringThe length of time used to paginate event date results. | 
eventDate
{
  "labels": [
    "string"
  ],
  "date": "2019-04-05"
}
Event Date
A date and one or more events that occur on that date. The labels property will reference the associated schedules.
Properties
| Name | Description | 
|---|---|
| labels | [string](required)The text labelfor this event, suitable for presentation to the client.  This label references the one or more associated schedules. | 
| date | string(date)(required)This date is in the ISO 8601 Date format, yyyy-mm-dd. | 
schedule
{
  "label": "Retirement savings transfer",
  "start": "2019-06-10",
  "every": "P14D",
  "count": 5,
  "skippedCount": 0,
  "maximumCount": 10,
  "skipNext": true,
  "end": "2019-08-01"
}
Schedule
A definition for a one-time or recurring scheduled event.
Properties
| Name | Description | 
|---|---|
| label | string(required)The text labelfor this schedule, suitable for presentation to the client.  Events will use this label to reference a schedule. | 
| start | stringWhen the event occurs, or when a recurring event begins. This may be either a date in yyyy-mm-ddformat, or a date-time inyyyy-mm-ddTHH:MM:SSZformat. If present, the time portion is a _hint_; the FI may not be able to schedule events at specific times. Ifstartis omitted, the event will be scheduled for the next processing day. Ifstartis the current day, the event may be scheduled for the next processing day if event processing has stopped for the day. Ifstartis not provided, the current date will be used. | 
| every | stringThe everyperiod indicates the interval at which the event recurs, such as every week, every month, every 3 months. If omitted or empty, this event is a one-time event.everyis required if eithermaximumCountis greater than 1 or ifendis greater thanstart. This value is an ISO 8601 duration string of the formP[n]Y[n]M[n]Dto specify the number of years/months/days between events. For example, useP7Dto schedule every week,P2Mto schedule every other month,P4Yto schedule every four years on the anniversary set bystart. Time values ineveryare ignored but may be honored in the future. (That is, it is not possible to schedule an event every 8 hours; the minimum isP1D). To specify semi-monthly or semi-annually, useP0.5MorP0.5Y.  Fractional values are only allowed for month and year, and0.5is the only allowed fractional value. Some financial institutions may limit recurring events such that the period must be a year (P1Y, 'P12M, 'P365D) or less. Scheduling may adjust event dates ifstartoccurs near boundary dates which do occur not every year/month, such asstart: "2019-01-31", every: "P1M". For example, the next event may occur on the 30th for months which have only 30 days (Apr, Jun, Sep, Nov), or 29th or 28th for February. Actual event dates may also be adjusted to account for holidays or other days when processing does not occur. | 
| count | integerFor a recurring event, this is the number of events which have occurred. It is a derived value and ignored on updates. | 
| skippedCount | integerFor a recurring event, this is the number of events which have been skipped, either because a processing date passed when a recurring event had a value of trueforskipNext, or a recurring event was suspended. It is a derived value and ignored on updates. | 
| maximumCount | integerThe maximum number of events to schedule for a recurring event. (Events in the recurrence will stop if the current date is beyond that set by end, even if fewer thanmaximumCountevents have occurred.) Theeveryperiod is required ifmaximumCountorendis set. It is an error (422) ifmaximumCountis anything other than 0 or 1 andeveryis not set.  If a schedule contains bothendandmaximumCount`, the earliest will determine when the recurrence ends. | 
| skipNext | booleanThis field is ignored for one-time events. If true for recurring schedules, skip (do not schedule) the next event. After that instance is skipped, this field is reset to false (only one instance may be skipped). | 
| end | stringThe date when the recurring event ends (inclusive). Events will occur until the maximumCountof events have occurred or the next scheduled event will be after the date or date-time specified inend. (Earliest ofmaximumCountorendwins).  If specified,endmust be no earlier thanstart. This has the same format as   When scheduling an event, the request should contain either  | 
calendar
{
  "holidays": [
    "2019-12-24",
    "2019-12-25"
  ],
  "unprocessableDays": [
    "sunday",
    "saturday"
  ]
}
Calendar
A definition of a calendar
Properties
| Name | Description | 
|---|---|
| holidays | [string](required)A collection of dates on which events cannot occur. These dates should be in the RFC 3339 format, yyyy-mm-dd.uniqueItems: true | 
| unprocessableDays | [string](required)A collection of days of the week on which events cannot occur. uniqueItems: true | 
collection
{
  "_links": {
    "property1": {
      "href": "http://example.com",
      "type": "string",
      "templated": true,
      "title": "string",
      "deprecation": "http://example.com",
      "profile": "http://example.com"
    },
    "property2": {
      "href": "http://example.com",
      "type": "string",
      "templated": true,
      "title": "string",
      "deprecation": "http://example.com",
      "profile": "http://example.com"
    }
  },
  "_embedded": {},
  "_profile": "http://example.com",
  "_error": {
    "_id": "2eae46e1-575c-4d69-8a8f-0a7b0115a4b3",
    "_profile": "https://api.apiture.com/schemas/common/errorResponse/v1.0.0/profile.json",
    "message": "The value for deposit must be greater than 0.",
    "statusCode": 422,
    "type": "positiveNumberRequired",
    "attributes": {
      "value": -125.5
    },
    "remediation": "Provide a value which is greater than 0",
    "occurredAt": "2018-01-25T05:50:52.375Z",
    "_links": {
      "describedby": {
        "href": "http://doc.apiture.com/errors/positiveNumberRequired"
      }
    },
    "_embedded": {
      "errors": []
    }
  },
  "count": 0,
  "start": 0,
  "limit": 0,
  "name": "string"
}
Collection
A collection of resources. This is an abstract model schema which is extended to define specific resource collections.
Properties
| Name | Description | 
|---|---|
| _links | linksAn optional map of links, mapping each link relation to a link object. This model defines the _linksobject of HAL representations. | 
| _embedded | objectAn optional map of nested resources, mapping each nested resource name to a nested resource representation. | 
| _profile | string(uri)The URI of a resource profile which describes the representation. | 
| _error | errorAn object which describes an error. This value is omitted if the operation succeeded without error. | 
| count | integerThe number of items in the full collection. | 
| start | integerThe start index of this page of items. | 
| limit | integerThe maximum number of items per page. | 
| name | stringThe name of the collection. | 
links
{
  "property1": {
    "href": "http://example.com",
    "type": "string",
    "templated": true,
    "title": "string",
    "deprecation": "http://example.com",
    "profile": "http://example.com"
  },
  "property2": {
    "href": "http://example.com",
    "type": "string",
    "templated": true,
    "title": "string",
    "deprecation": "http://example.com",
    "profile": "http://example.com"
  }
}
Links
An optional map of links, mapping each link relation to a link object. This model defines the _links object of HAL representations.
Properties
| Name | Description | 
|---|---|
| additionalProperties | linkDescribes a hypermedia link within a _linksobject in HAL representations. In Apiture APIs, links are HAL links, but Apiture APIs do not use thenameorhreflangproperties of HAL. Apiture links may include amethodproperty. | 
link
{
  "href": "http://example.com",
  "type": "string",
  "templated": true,
  "title": "string",
  "deprecation": "http://example.com",
  "profile": "http://example.com"
}
Link
Describes a hypermedia link within a _links object in HAL representations. In Apiture APIs, links are HAL links, but Apiture APIs do not use the name or hreflang properties of HAL. Apiture links may include a method property.
Properties
| Name | Description | 
|---|---|
| href | string(uri)(required)The URI or URI template for the resource/operation this link refers to. | 
| type | stringThe media type for the resource. | 
| templated | booleanIf true, the link's href is a URI template. | 
| title | stringAn optional human-readable localized title for the link. | 
| deprecation | string(uri)If present, the containing link is deprecated and the value is a URI which provides human-readable text information about the deprecation. | 
| profile | string(uri)The URI of a profile document, a JSON document which describes the target resource/operation. | 
 
      