Endpoints
Every API consists of a set of endpoints. An endpoint
is a command that a caller application can use to request data from or trigger action in
BillingCenter. For example, the
/common/v1/activities
endpoint can be used to either request data about
BillingCenter activities or trigger actions related to BillingCenter activities. When referenced in documentation, endpoints
start with a slash (/), such as the /activities
endpoint. Endpoints are
defined in Swagger schema files.
In Cloud API, the endpoint path (the full name of the endpoint) includes the API and the
version. For convenience sake, the documentation often refers to endpoints using only the last
part of the endpoint path. For example, the /rest/common/v1/activities
endpoint is often referred to simply as "the /activities
endpoint".
Endpoints in Cloud API have four fundamental components: root resources, child resources, methods, and paths.
Root resources
Every endpoint has a root resource. The root resource is the resource which the endpoint creates, updates, deletes, or queries for. Every call to an endpoint makes use of the root resource.
For example, the root resource for the /common/v1/activities
endpoint is
Activity
. This endpoint is used to potentially create, update, delete, or
queries for activities.
Child resources
Most endpoints also include child resources. A child
resource is a resource related to the root resource. Child resources improve the
usability of an endpoint by providing access to information related to the root resource. For
example, the /common/v1/activities
endpoint has one child resource -
Notes
. This means you could use the endpoint to:
- Query for a specific activity (and only the activity)
- Query for a specific activity and its related notes
Every call to an endpoint must make use of the root resource. The use of child resources is optional.
Inline and included resources
Child resources can be declared either as inline resources or included resources.
- An inline resource is a resource that appears in the
attributes
section of the payload inline with the other root resource fields, such as anActivity
resource'sassignedUser
field. These resources may be included in a response by default and can be controlled through thefields
query parameters. - An included resource is a resource that appears in the
included
section at the bottom of the payload, such as anActivity
resource'sNotes
. These resources are not included in a response by default and must be controlled through theincluded
query parameters.
For more information on inline and included resources, see GETs.
Methods
A method is a type of action a caller application can take on a resource through an endpoint. Methods are also referred to as verbs or operations. Cloud API supports the following subset of HTTP methods:
- GET - Used to request resources.
- POST - Used to create resources. Also used to execute business actions, such as quoting a submission or submitting a claim.
- PATCH - Used to update resources.
- DELETE - Used to delete resources.
Every endpoint supports one or more of these methods. For example, in the Common API:
- The
notes/{noteId}
endpoint supports GET, PATCH, and DELETE. - The
/activities
endpoint supports only the GET operation.
The HTTP methods are designed for CRUD operations (Create, Read, Update, Delete). Some business processes in InsuranceSuite applications are available to Cloud API but do not readily map to any of these operations, such as assigning objects, closing objects, or approving objects. As a general rule, the custom actions that trigger these processes use the POST method.
Method mapping to elements and collections
In general:
- You can GET either an element or a collection.
- You POST a collection to create an element.
- You POST to a custom action (to execute a business action).
- You PATCH an element.
- You DELETE an element.
For example:
Method | On endpoint... | Does the following... |
---|---|---|
GET | /activities |
Returns all activities assigned to the current user |
GET | /activities/{activityId} |
Returns the details for the specified activity |
POST | /activities/{activityId}/notes |
Adds a new note to the specified activity |
POST | /activities/{activityId}/assign |
Assigns the activity |
PATCH | /activities/{activityId} |
Updates information on the specified activity |
DELETE | /notes/{NoteId} |
Deletes the specified note |
Contrasting endpoints and methods
Technically speaking, when an endpoint supports multiple methods, it is still a single endpoint. However, in casual discussion, each method is sometimes referred to as a separate endpoint. For example, consider the following:
- GET
/common/v1/activities
- POST
/common/v1/activities
This is a single endpoint (/common/v1/activities
) that supports two
methods (GET and POST). However, in a casual sense, it is sometimes referred to as two
endpoints (the GET /activities
endpoint and the POST
/activities
endpoint).
The PUT method
Within REST API architecture, there are two methods that modify existing resources - PATCH and PUT. PATCH is used to modify a portion of an existing resource (while leaving other aspects of it unmodified). PUT is used to replace the entire contents of an existing resource with new data. Cloud API supports the PATCH operation, but not the PUT operation. This is because nearly every method that modifies an InsuranceSuite object modifies only a portion of it while keeping the rest of the object untouched. This behavior maps to PATCH, but not to PUT.
Paths
Every endpoint has a path. The path is the portion of the URL used by caller applications to identify the specific endpoint.
For Cloud API, every path consist of the following pattern:
rest/<APIname>/<APImajorVersion>/<endpointName>
For example, consider the path: rest/common/v1/activities
:
common
is the name of the API to which the endpoint belongs.v1
is the major version number of the APIactivities
is the endpoint name
The major version number provides information about the backwards compatibility of the endpoint. For more information, see Version numbers for major and minor releases.
A path can also contain a reference to a specific resource. For example, the path
/activities/xc:20/notes
refers to the notes for activity xc:20. When a path
includes a reference to a specific resource, the generic path name is specified using
{typeId}
, where type
is the resource type.
For example, the generic path for /activities/xc:20/notes
is
/activities/{activityID}/notes
. A reference to a specific resource in a
path is known as a path parameter.
For most endpoints, the endpoint name is the same as the resource name, with the following conventions and caveats:
- If the endpoint's root resource is an element, the endpoint name ends in a singular noun
(such as
/activity
) or a resource reference (such as/activity/{activityId}
). - If the endpoint's root resource is a collection, the endpoint name ends in a plural noun
(such as
/activities
). - If the endpoint executes a business action, the endpoint name ends in a verb (such as
/{activityId}/assign
). - The endpoint name is often close to, but not identical to, the resource name.
- Endpoint names use lower case, whereas resource names use mixed case (for example, the
root resource for the
/activity
endpoint isActivity
) - Endpoint names use hyphens to separate words, whereas resource names do
not (for example, the root resource for the
/accounts/{accountId}/activity-patterns
endpoint isActivityPattern
) - In some cases, the endpoint name may differ from the root resource name
(for example, the root resource for the
/accounts/{accountId}/contacts
endpoint isAccountContact
)
- Endpoint names use lower case, whereas resource names use mixed case (for example, the
root resource for the