Was this helpful?
[//]: # "Weight: 2"
In certain integrations, collection locations may originate in a remote system, such as an existing website or CRM platform. It may be necessary to consider an import of locations into an Alpaca collection.
To assist this process, this topic covers the use of external-source
and
external-id
attributes. These attributes can assist in the tracking and
querying of data based on the identifiers within the source of the import.
Alpaca provides a method to be able to store custom or extended data through attributes. These allow you to push in additional data that can be queried in future calls. The two mentioned attribute ID's are specially recognised, in order to suit the use case of importing data with references to foriegn keys outside of the platform.
Private API Key for querying and mutations
The collection ID for where we will be syncing information
When creating a collection location, it may be beneficial to store your own record identifier against the collection location in order to be able to find this record again in the future to test whether the record exists.
1# Creates a collection location with a reference to an external primary key
2# reference, so that we can track ID's to synchronize data between platforms.
3# We leverage a named attribute that is supported for querying items and
4# obtaining locations from a collection based on their external references.
5
6mutation CreateCollectionLocationWithExternalReference {
7 # use the standard createCollectionLocation
8 createCollectionLocation(
9 # Supply the collection to place the location within
10 collectionId: "collection/ABC123"
11 # Supply the collection location
12 location: {
13 # Content about the location
14 title: "Dr. Morse Cafe"
15 # Supply the place data
16 place: {
17 # Supply the place position coordinates (mandatory)
18 position: { lon: 144.99414682388306, lat: -37.79990202116163 }
19 # Optionally relate to a known place, such as a place from ATDW if you
20 # are leveraging place information to be updated automatically without
21 # a re-import.
22 id: "place/atdw:product:5cae80be57a096cd7084b6ab"
23 }
24 # Leverage Attributes to extend the data stored and accessible for the
25 # location
26 attrs: [
27 # Track the ID from my platform into the "custom://external-id". This
28 # is a recognised attribute that can be later used to find the matching
29 # collection location based on your own IDs
30 { id: "custom://external-ref", value: "my-external-UUID" }
31 # Support for external sources, also for grouping together multiple
32 # different sources. Can be used to query all records from a specific
33 # source later using the query collectionItems()
34 { id: "custom://external-source", value: "example.com" }
35 ]
36 }
37 ) {
38 # Confirm the ID that is created
39 location {
40 id
41 __typename
42 }
43 }
44}
Sandbox: Configure | Try Operation
Note: These values are treated as string
values. They can contain your own
values as you see fit. We recommend the external-source
to indicate the source
of the data, which could be a label to differentiate multiple sources of data.
When you query, you can query by external-source to see records just from that
source.
You can optionally query for collection locations by supplying query criteria
using the externalIds
or externalSources
parameters you have supplied when
creating the collection location.
The current value per collection location can also be accessed using the
attr(id="custom://external-ref") { value }
or
attr(id="custom://external-source") { value }
attribute selector.
This can make it effective to query the platform for specific entries or to create a map of all values that are present in the platform currently, in order to identify what needs to be sync'd or removed.
1# Queries collection items based on a ID within an external platform. When
2# creating locations, you can set the attributes custom://external-ref and
3# custom://external-source in order to store identifiers and sources of your
4# platform. This enables you to reference and query items through your own
5# ID scheme. External Ref is intended to be used on a 'per record' ID, where
6# External source is to reference the source of all records, and can therefore
7# differentiate multiple sources of data and potentially overlapping IDs
8
9query QueryCollectionLocationWithExternalReference {
10 collectionItems(
11 # Query the collection
12 collectionIds: "collection/ABC123"
13 # Optionally query the external ID's supplied
14 externalIds: ["my-external-UUID", "my-other-external-UUID"]
15 # Optionally query a specific website source
16 externalSources: ["example.com"]
17 # Pagination controls for relay "cursor connections"
18 # See: https://relay.dev/graphql/connections.htm
19 first: 10 #, after: <cursor>
20 ) {
21 edges {
22 node {
23 # Matching collection item
24 id
25 __typename
26
27 # Timestamps
28 created
29 modified
30
31 # Obtain the values for the external refs
32 externalId: attr(id: "custom://external-ref") {
33 value
34 }
35 externalSource: attr(id: "custom://external-source") {
36 value
37 }
38 }
39 # Use the cursor and supply to "after" in operation to paginate
40 cursor
41 }
42 pageInfo {
43 hasNextPage
44 }
45 totalCount
46 }
47}
Sandbox: Configure | Try Operation
Note: The collectionItems
query returns a cursor connection in order to
paginate through the returned edges. You can read about
Paginating using cursor connections
If you choose to later associate an external reference to an existing location, you can do so via a mutation similar to below. This mutation will insert or update an attribute value as required.
You can also use the same updateCollectionLocation
operation to update your
content, such as title, etc.
1# Update a record to store a corresponding identifier in an external system
2
3mutation UpdateCollectionLocationAddExternalReference {
4 # use the updateCollectionItem
5 updateCollectionLocation(
6 # Supply the ID for the record
7 id: "item/ABC123"
8 # Update the location data
9 location: {
10 # Update our title, description or any other content here...
11 # ...
12 # Use upsert to insert/update a record
13 upsertAttrs: [
14 # Supply an external ID for this record
15 { id: "custom/external-ref", value: "my-reference-UUID" }
16 ]
17 }
18 ) {
19 # Query back the location updated
20 location {
21 id
22 __typename
23 # Attribute will now exist on the collection item
24 externalId: attr(id: "custom://external-ref") {
25 value
26 }
27 }
28 }
29}
Sandbox: Configure | Try Operation
You can also remove locations from a collection using the following.
1# Removes a collection item from a collection
2
3mutation DeleteCollectionItem {
4 # Use the deleteCollectionItem() operation
5 deleteCollectionItem(
6 # Supply the ID of the record to remove
7 id: "item/ABC123"
8 ) {
9 # select back a response of the ID of the removed item
10 id
11 }
12}
Sandbox: Configure | Try Operation
Copyright © 2025 - Made with love ❤️ in Australia.