The CRM API consists of two sets of endpoints. Compass (v1) hosts the core endpoints for the application and is actively maintained. New endpoint development is being done under Compass-v2 which uses the OpenAPI Swagger specification. Both sets should be examined when looking for a specific endpoint or just exploring. Documentation includes:
Compass accepts a username and password using basic access authentication to identify and authenticate a Cosential user. Compass also requires an API key and a firm access code. The API key and firm access code are sent as HTTP headers. The API key identifies your integration solution and the firm access code identifies the Cosential client. If you need an API key and/or a sandbox account, please sign up.
CURL -X GET -u johndoe:P@ssw0rd! \
-H Content-Type:application/json \
-H x-compass-firm-id:9999 \
-H x-compass-api-key:aa94e735-c5f1-4387-af43-c4effe3436e8 \
https://compass.cosential.com/api/user
[{
"Title": null
"FirstName": "John"
"MI": null
"LastName": "Doe"
"NickName": null
"FirmName": "Cosential Demo Account"
"Gender": null
"UserId": 99999
"UserToken": "b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd"
}]
Compass supports searching on almost all primary elements and uses Lucene query language, an easy to learn, highly dynamic, and powerful search syntax. For simple searches, entering a keyword will search all indexed fields.
Simple searches are performed by appending a query string to an http get request.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=Austin
[{
FirstName: "Austin",
LastName: "Jones",
...
},{
FirstName: "John",
LastName: "Smith",
BusinessEmailAddress: "jsmith@myaustinemail.co",
...
},{
FirstName: "Jane",
LastName: "Doe",
Addresses: [{
type: "Business",
Line1: "123 Anystreet",
Line2: null,
City: "Austin",
State: "TX",
PostalCode: "78701"
}],
...
},...]
Including deleted items in the search result can be acomplished by passing the includeDeleted parameter with the value of true.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?includeDeleted=true&q=Austin
[{
FirstName: "Austin",
LastName: "Kuykendahl",
DeleteRecord: true,
...
},{
FirstName: "George",
LastName: "Smith",
DeleteRecord: true,
BusinessEmailAddress: "gsmith@myaustinemail.co",
...
},...]
To search for a value in a specific property, use the property name followed by a : (colon) followed by the query. To search property data inside complex types use a . (period) as a path delimiter.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=Addresses.City:Austin
[{
FirstName: "Jane",
LastName: "Doe",
Addresses: [{
type: "Business",
Line1: "123 Anystreet",
Line2: null,
City: "Austin",
State: "TX",
PostalCode: "78701"
}],
...
},{
FirstName: "John",
LastName: "Smith",
Addresses: [{
type: "Home",
Line1: "456 Anystreet",
Line2: null,
City: "Austin",
State: "TX",
PostalCode: "78701"
}],
...
}]
Use " (double quote) to search for a phrase.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=CompanyName:"Acme, Inc."
[{
FirstName: "Jane",
LastName: "Doe",
CompanyName: "Acme, Inc.",
...
},{
FirstName: "John",
LastName: "Smith",
CompanyName: "Acme, Inc.",
...
}]
Standard wildcard characters ? and * are also supported. Use ? to match any single character and * to match 0 or more characters.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=CompanyName:"Austin*T?x?s"
[{
FirstName: "Jane",
LastName: "Doe",
CompanyName: "Austin Imports of Texas",
...
},{
FirstName: "John",
LastName: "Smith",
CompanyName: "Austin Taxes",
...
}]
Fuzzy searching can be performed by using ~ (tilda) at the end of the query string. This can be useful when searching for common phonetic mistakes and typos.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=FirstName:Filup~
[{
FirstName: "Phillup",
LastName: "Doe",
...
},{
FirstName: "Fillup",
LastName: "Smith",
...
}]
Word proximity searches also use ~ (tilda). To search for two words within 5 words of each other, append ~ and then 5 to the phase query.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=Description:"Austin Texas"~5
[{
FirstName: "John",
LastName: "Doe",
Description: "He lives in Austin Texas"
...
},{
FirstName: "Jane",
LastName: "Smith",
Description: "She works at Austin Fine Antiques of Texas"
...
}]
To search for a range of items, use [] or {} and the TO operator to specify a set of values. Use [] for inclusive ranges, and {} for exclusive ranges.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=CreateDate:[2014-01-01 TO 2014-12-31]
[{
FirstName: "Jane",
LastName: "Doe",
CompanyName: "Acme, Inc.",
CreateDate: "2014-08-23T13:56:23"
...
},{
FirstName: "John",
LastName: "Smith",
CompanyName: "Acme, Inc.",
CreateDate: "2014-10-14T19:43:29"
...
}]
Predicates can be joined using operators AND, OR, and NOT.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/search?q=CompanyName:Acme AND NOT FirstName:John
[{
FirstName: "Jane",
LastName: "Doe",
CompanyName: "Acme, Inc.",
...
},{
FirstName: "Jack",
LastName: "Smith",
CompanyName: "Acme, Inc.",
...
}]
Queries can also be sent via POST object.
curl -X POST \
https://compass.cosential.com/api/contacts/search \
-H 'Content-Type: application/json' \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
-d '{
"QueryString": "CompanyName:Acme AND NOT FirstName:John",
"Size": 50,
"From": 0,
"Fields": null,
"IncludeDeleted": false
}'
[{
FirstName: "Jane",
LastName: "Doe",
CompanyName: "Acme, Inc.",
...
},{
FirstName: "Jack",
LastName: "Smith",
CompanyName: "Acme, Inc.",
...
}]
In addition to search, Compass offers Find By operators for looking up enitities. These endpoints do not depend on the search engine and can be used for long term integration support.
curl --location --request GET 'https://compass.cosential.com/api/projects/find-by/project-name?projectName=Facility&findByOperator=contains' \
--header 'accept: application/json' \
--header 'Content-Type: application/json' \
--header 'x-compass-firm-id: 9999' \
--header 'x-compass-api-key: aa94e735-c5f1-4387-af43-c4effe3436e8' \
--header 'Authorization: Basic XXXXXXXXXXXXXXXXXXXXXXXXXXX==' \
{
"Response": [
{
"Id": 4168837
},
{
"Id": 4168838
},
{
"Id": 4168863
}
],
"Success": true,
"ValidationErrors": []
}
curl --location --request GET 'https://compass.cosential.com/api/projects/find-by/project-number?projectNumber=9903&findByOperator=contains' \
--header 'accept: application/json' \
--header 'Content-Type: application/json' \
--header 'x-compass-firm-id: 9999' \
--header 'x-compass-api-key: aa94e735-c5f1-4387-af43-c4effe3436e8' \
--header 'Authorization: Basic XXXXXXXXXXXXXXXXXXXXXXXXXXX==' \
{
"Response": [
{
"Id": 4168836
},
{
"Id": 4168837
},
{
"Id": 4168838
},
{
"Id": 4168863
}
],
"Success": true,
"ValidationErrors": []
}
Sending the entire element schema is not necessary. It is possible to "underpost" data. When creating a new element, default values will be used for properties that are not sent. Data is sent to an element endpoint as a JSON encoded array of objects using an HTTP POST method.
Note: Cosential users can specify whether or not a property is required for an element. It is up to you to enforce this requirement in your solution. To discover if a property is required for the authenticated user, use the Schema Discovery interface.
curl -X POST -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
-d '[{
"CompanyId":12345,
"FirstName":"John",
"LastName":"Doe"
},{
"CompanyId":12345,
"FirstName":"Jane",
"LastName":"Smith"
}]' https://compass.cosential.com/api/contacts
[{
"ContactId":54321,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"John",
"MiddleName":null,
"LastName":"Doe",
...
},{
"ContactId":54322,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"Jane",
"MiddleName":null,
"LastName":"Smith",
...
}]
Sub items are created in the same manner as primary objects. They are associated to a primary object, so the top level element needs to exist before you can create a subitem. The id of the primary object is used in the URL when creating a sub item.
curl -X POST -H " x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd"
-H "Content-Type: application/json"
-d '[{
"AddressType": "Office",
"DefaultInd": true,
"Address1": "123 Street Park Way",
"Address2":"Ste 100",
"City": "Any Town",
"PostalCode": "78701",
"State": "TX",
"Country": "United States",
"Phone": "512 555-1212",
"County": "Travis",
},
{
"AddressType": "Home",
"DefaultInd": true,
"Address1": "1 Mockingbird Lane",
"Address2":"PO Box 42",
"City": "Any Town",
"PostalCode": "78701",
"State": "TX",
"Country": "United States",
"Phone": "512 555-1212",
"County": "Travis",
}
]' ' https://compass.cosential.com/api/contacts/54321/addresses'
[
{
"AddressID": 123456,
"ContactId": 54321,
"AddressType": "Office",
"DefaultInd": true,
"CreateDate": "0001-01-01T00:00:00",
"Address1": "123 Street Park Way",
"Address2": "Ste 100",
"Address3": null,
"City": "Any Town",
"PostalCode": "78701",
"State": "TX",
"Country": "United States",
...
},
{
"AddressID": 123457,
"ContactId": 54321,
"AddressType": "Home",
"DefaultInd": true,
"CreateDate": "0001-01-01T00:00:00",
"Address1": "1 Mockingbird Lane",
"Address2": "PO Box 42",
"Address3": null,
"City": "Any Town",
"PostalCode": "78701",
"State": "TX",
"Country": "United States",
...
}
]
Compass enables you to get lists of elements as well as a single element by id. Paging data is available for any endpoint returning multiple elements.
Getting details for an element by id is done using an HTTP GET request. Append the element id to the element endpoint.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/54321
{
"ContactId":54321,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"John",
"MiddleName":null,
"LastName":"Doe",
...
}
Getting a list of all elements can be done with an HTTP GET request to the element endpoint. In general, elements will return a summary version, a subset of common properties. To have list endpoints return full elements instead of the summary version, use the FULL parameter.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts?full=true
[{
"ContactId":54321,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"John",
"MiddleName":null,
"LastName":"Doe",
...
},{
"ContactId":54322,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"Jane",
"MiddleName":null,
"LastName":"Smith",
...
}]
Endpoints exist for getting lists of related data. See Element Endpoints for a complete list of endpoints. For example, to return all contacts for a given company the endpoint /companies/<id>/contacts is used. More information about element associations can be found in Schema Discovery.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/companies/12345/contacts
[{
"ContactId":54321,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"John",
"MiddleName":null,
"LastName":"Doe",
...
},{
"ContactId":54322,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"Jane",
"MiddleName":null,
"LastName":"Smith",
...
}]
Any endpoint returning multiple elements such as search results or lists can be paged. Paging is accomplished using the SIZE and FROM parameters. SIZE specifies the number of elements you would like to receive. SIZE has a maximum value of 500. FROM specifies the number of elements you would like to skip. SIZE has a default value of 50 and FROM has a default value of 0. As such, if paging parameters are not used, the API will return the first 50 elements.
If there are 754 records to pull, 2 API calls would be needed to return all the records. The first call would use parameter values of SIZE = 500 and FROM = 0. If the number of records is unknown then the second call would use SIZE = 500 and FROM = 500 to fetch the remaining 254 records. If the number of records is actually known in advance, then parameter values of SIZE = 254 and FROM = 500 could be used. If the number of records is not known in advance, then subsequent calls to the API should be made until the number of returned records is less than 500.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts?size=2&from=10
[{
"ContactId":54321,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"John",
"MiddleName":null,
"LastName":"Doe",
...
},{
"ContactId":54322,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"Jane",
"MiddleName":null,
"LastName":"Smith",
...
}]
Updates are done by sending a JSON encoded element using an HTTP PUT method to the element endpoint with the id of the element appended. It is possible to "underpost". Values for missing element properties will not be updated.
curl -X PUT -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
-d '{
"CompanyId":12345,
"FirstName":"John",
"LastName":"Smith"
}' https://compass.cosential.com/api/contacts/54321
{
"ContactId":54321,
"CompanyId":12345,
"CompanyName":"Acme, Inc",
"FirstName":"John",
"MiddleName":null,
"LastName":"Smith",
...
}
Subitems can be updated by addressing them in the URL. Values for missing element properties will not be updated.
curl -X PUT -H Content-Type:application/json
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd
-d '{
"Address1":"2 Mockingbird Way",
}' https://compass.cosential.com/api/contacts/54321/addresses/123456
{
"AddressID": 123456,
"ContactId": 54321,
"AddressType": "Office",
"DefaultInd": true,
"CreateDate": "0001-01-01T00:00:00",
"Address1": "2 Mockingbird Way",
"Address2": "Ste 100",
"Address3": null,
"City": "Any Town",
"PostalCode": "78701",
"State": "TX",
"Country": "United States",
...
}
To delete an element, issue an HTTP DELETE request to the element endpoint with the id of the element appended.
curl -X DELETE -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/54321
{
success: true,
message: "Contact 54321 has been deleted."
}
Subitems can be deleted by adding the subitem name to the end of a primary objects url and then adding the unique id of the subitem.
Note: Not all subitems can be deleted. To discover if a subitem can be removed, use the Schema Discovery interface to check if an object is Read Only and can be removed.
curl -X DELETE -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/54321/addresses/123456
{
success: true,
message: "Address 123456 has been deleted."
}
It is also possible to delete all subitems on an object be leaving the unique id off of the URL.
curl -X DELETE -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/contacts/54321/addresses
{
success: true,
message: "All addressed have been deleted."
}
An HTTP GET to an entity's /changes endpoint will give you an array of all entity record change events. The change event properties are:
Deleted
- Indicates if the change was a deleteId
- The primary id for the entity that was changedVersion
- Version key useful in detecting changes over time
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/personnel/changes?includeDeleted=true&reverse=true
[{
"Deleted": false,
"Id": 12345,
"Version": "AAAAABbE/Rc="
},
{
"Deleted": true,
"Id": 12346,
"Version": "AAAAABbE/Rg="
},...]
You can query the API for just the changes that have occurred after a specific change event by using the change event's version key. Change event results are always ordered chronologically, so the last change event in the result set is always the last change that has occurred. It's possible to detect changes that have occurred since a previous call by storing the last change event's version key, and then using that version key at a later time in an API query. The query will return only change events that have occurred since your last query.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/personnel/changes?version=AAAAABbE%2FRg%3D&includeDeleted=true&reverse=true
[{
"Deleted": false,
"Id": 12347,
"Version": "AAAAABbE/Rk="
},
{
"Deleted": false,
"Id": 12345,
"Version": "AAAAABbE/Ro="
},...]
Email attachments in compass works very similar to the way it does in Project Images. Email attachments are created with two or more API calls. The first call is to create one or more email attachment objects using the endpoint /api/emails/<emailId>/attachments with an HTTP POST request. Once the attachment object is created you can use the endpoint /api/emails/<emailId>/attachmentfile/<attachmentId> to read/write the attachment data.
curl -X POST \
https://compass.cosential.com/api/emails/37/attachments \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
-H 'Content-Type: application/json' \
-d '[{
"FileName": "testDoc.doc"
}]'
[
{
"Id": 58,
"FileName": "testDoc.doc",
"DeleteRecord": false,
"AttachmentEndpoint": "/api/emails/37/attachmentfile/58"
}
]
The FileName object in this object will specify the file extension and filename that is received when reading from the attachmentfile endpoint
With the attachment objects created we can now send file data using an HTTP POST or HTTP PUT call to the AttachmentEndpoint found in the object
Sending a HTTP POST or HTTP PUT request to an attachment with file data will overwrite that data
There are four different ways to upload file data
curl -X POST \
'https://compass.cosential.com/api/emails/37/attachmentfile/58?url=https://www.someurl.org/test.doc' \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
curl -X POST \
https://compass.cosential.com/api/emails/37/attachmentfile/58 \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
-H 'Content-Type: application/json' \
-d '{
"Data": "VGhpcyBpcyBhIHRlc3QgdG8gc2VlIGlmIGJhc2U2NCB3b3Jrcw=="
}'
curl -X POST \
https://compass.cosential.com/api/emails/37/attachmentfile/58 \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
-H 'Content-type: multipart/form-data; boundary=----WebKitFormBoundary7MA4YWxkTrZu0gW' \
-F '= C:\Users\user\documents\testDoc.doc'
Attachments are read using the same endpoint with a
Attachments can be read in two different formats
curl -X GET \
https://compass.cosential.com/api/emails/37/attachmentfile/58 \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
curl -X GET \
https://compass.cosential.com/api/emails/37/attachmentfile/58 \
-H 'Accept: application/json' \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
{
"Data": "VGhpcyBpcyBhIHRlc3QgdG8gc2VlIGlmIGJhc2U2NCB3b3Jrcw=="
}
Deleting attachments can be done by deleting the attachment object through the endpoint /api/emails/<emailId>/attachmentfile/<attachmentId> with an HTTP DELETE request
curl -X DELETE \
https://compass.cosential.com/api/emails/37/attachments/58 \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd
Compass provides a read only access to Revenue Projection data from the Goals module.
Get a specific record of revenue data for an opportunity using an HTTP GET request by appending the revenue id after /revenue in the route, which still must include an opportunity id. Note that for us to return the item, the value must be greater than $0, otherwise you will receive a return of null with a 200 OK status.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/goals/opportunities/5555666/revenue/888
{
"RevenueId": 888,
"OpportunityId": 5555666,
"Year": 2021,
"Month": 12,
"Value": 11,
"ROW_VERSION": "AAAAAL9QIgw="
}
Getting a list of revenue projection data for an opportunity can be done using HTTP GET request to the element endpoint. Resource URI should contain an opportunity id. Note that the response would only include a revenue if the value is > $0.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/goals/opportunities/5555666/revenue
[
{
"RevenueId": 888,
"OpportunityId": 5555666,
"Year": 2021,
"Month": 12,
"Value": 11,
"ROW_VERSION": "AAAAAL9QIgw="
},
{
"RevenueId": 777,
"OpportunityId": 5555666,
"Year": 2021,
"Month": 9,
"Value": 4444,
"ROW_VERSION": "AAAAAL9QIgY="
}
]
Getting a list of opportunity change events can be done using HTTP GET request to the /changes endpoint. ParentId indicates the associated opportunity. Use parameter version to filter the results. Note that the parameter includeDeleted is not currently supported for goals.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/goals/opportunities/revenue/changes
[
{
"Deleted": false,
"Id": 888,
"Version": "AAAAAL9QIeg=",
"ParentId": 5555666
},
{
"Deleted": false,
"Id": 444,
"Version": "AAAAAL9QIek=",
"ParentId": 3333222
},
{
"Deleted": false,
"Id": 666,
"Version": "AAAAAL9QIeo=",
"ParentId": 8888999
}
]
Fiscal Year Settings are not currently supported by Compass.
Property metadata is available using an HTTP GET request appending /schema to the element endpoint. The schema endpoints will return user level field customizations such as required, enabled, custom labels, etc.
The IsIncludedInResponse property indicates if something is available in the main call payload or if an additional API call is needed to get the data.
The ObjectEndpoint property is the API endpoint where the data for the property can be retrieved. The SchemaEndpoint property is the API endpoint where the schema of the property can be retrieved.
curl -X GET -H Content-Type:application/json \
-H x-compass-token:b3d83cd6-9cd2-4f2a-a3e5-911e94025ecd \
https://compass.cosential.com/api/companies/schema
[{
PropertyName: "CompanyId"
Group: "Internal"
Label: "Company Id"
Description: "CompanyId"
Enabled: true
ReadOnly: true
Required: false
DefaultValue: null
DataType: "Integer"
MaxLength: null
UnicodeSupported: true
Searchable: true
ArrayType: null
IsPrimaryKey: true
IsExternalId: false
ObjectEndpoint: null
IsIncludedInResponse: true
SchemaEndpoint: null
},{
PropertyName: "Contacts"
Group: "Contacts"
Label: "Contacts"
Description: ""
Enabled: true
ReadOnly: false
Required: false
DefaultValue: null
DataType: "Array"
MaxLength: null
UnicodeSupported: false
Searchable: false
ArrayType: "ValueList"
IsPrimaryKey: false
IsExternalId: false
ObjectEndpoint: "api/contacts"
IsIncludedInResponse: null
SchemaEndpoint: "api/contacts/schema"
IsHidden: false
},...]
Users with administrative access to Cosential can customize element properties to enforce their own data constraints and improve the user experience. Users can customize the following:
The schema interface can be used to discover associations between elements. If a property has a DataType of Array or Object, then associated elements can be accessed using the endpoint for the element, the id for the element, and the property name <endpoint>/<id>/<propertyname>. Using the results above, we can infer an HTTP GET request to /api/companies/12345/contacts will list all contacts associated to the company with an id of 12345.
Because the ObjectEndpoint value for the property Contacts is api/contacts we can:
The following top level endpoints are currently available in the API. The list below is available by making an HTTP GET request to api/entities. Click on an endpoint to view properties for the element.
Element | Endpoint | Search | Schema |
---|---|---|---|
Company | api/companies | api/companies/search | api/companies/schema |
Contact | api/contacts | api/contacts/search | api/contacts/schema |
Project | api/projects | api/projects/search | api/projects/schema |
Opportunity | api/opportunities | api/opportunities/search | api/opportunities/schema |
Personnel | api/personnel | api/personnel/search | api/personnel/schema |
CallLog | api/calllogs | api/calllogs/search | api/calllogs/schema |
Currency | api/currency | api/currency/schema | |
Lead | api/leads | api/leads/search | api/leads/schema |
FirmOrg | api/firmorgs | api/firmorgs/schema | |
api/Emails | api/Emails/search | api/Emails/schema |