Archive Partners API

Archive API allows you to access enriched details about your community. The Archive Community is representative of the social profiles that are captured and tracked through an Archive Community CDP.

This detailed information ranges from profile information to post engagement metrics. This data has been used for enriching ambassador/loyalty programs, automating marketing flows, and performance measurement.

GraphQL

Archive API is built on GraphQL query language: graphql.org. If you already have an API token, you can try it with our API explorer.

Contact

API Support

[email protected]

API Endpoints
POST: https://app.archive.com/api/v1
Headers
# Get token from our team
Authorization: Bearer <YOUR_TOKEN_HERE>
# If you have multiple shops you need to pass Shop ID in header
SHOP-ID: 123

Authentication

All queries require a valid access token. In order to get your access token, contact api@archive.com. Include your token as an Authorization header on all queries.

Webhooks

You can receive webhooks for specific events. List of available events: WebhookSubscriptionsEventsEnum

To start receiving webhooks, you need to subscribe to an event with webhookSubscriptionCreate mutation. Once subscribed, Archive will send MediaItem object with attributes in underscore style to callback_url every time there is an event trigger.

Queries

creator

Description

Returns a Creator resource by ID.

Response

Returns a Creator

Arguments
Name Description
id - Int
accountName - String
provider - IntegrationProviderEnum
fallback - Boolean

Example

Query
query creator(
  $id: Int,
  $accountName: String,
  $provider: IntegrationProviderEnum,
  $fallback: Boolean
) {
  creator(
    id: $id,
    accountName: $accountName,
    provider: $provider,
    fallback: $fallback
  ) {
    accountName
    authorized
    avatarUrl
    biography
    followersCount
    followingCount
    id
    provider
    verified
  }
}
Variables
{
  "id": 987,
  "accountName": "xyz789",
  "provider": "INSTAGRAM",
  "fallback": false
}
Response
{
  "data": {
    "creator": {
      "accountName": "abc123",
      "authorized": false,
      "avatarUrl": "xyz789",
      "biography": "abc123",
      "followersCount": 987,
      "followingCount": 123,
      "id": 123,
      "provider": "INSTAGRAM",
      "verified": false
    }
  }
}

creatorAudienceReport

Description

Returns a Creator audience report.

Response

Returns an AudienceReportResponse!

Arguments
Name Description
id - Int
accountName - String
provider - IntegrationProviderEnum

Example

Query
query creatorAudienceReport(
  $id: Int,
  $accountName: String,
  $provider: IntegrationProviderEnum
) {
  creatorAudienceReport(
    id: $id,
    accountName: $accountName,
    provider: $provider
  ) {
    accountName
    audienceReport
    id
    provider
  }
}
Variables
{
  "id": 123,
  "accountName": "xyz789",
  "provider": "INSTAGRAM"
}
Response
{
  "data": {
    "creatorAudienceReport": {
      "accountName": "xyz789",
      "audienceReport": {},
      "id": 123,
      "provider": "INSTAGRAM"
    }
  }
}

creatorPosts

Description

Returns a Creator posts.

Response

Returns a MediaItemConnection!

Arguments
Name Description
id - Int
accountName - String
provider - IntegrationProviderEnum
after - String Returns the elements in the list that come after the specified cursor.
before - String Returns the elements in the list that come before the specified cursor.
first - Int Returns the first n elements from the list.
last - Int Returns the last n elements from the list.

Example

Query
query creatorPosts(
  $id: Int,
  $accountName: String,
  $provider: IntegrationProviderEnum,
  $after: String,
  $before: String,
  $first: Int,
  $last: Int
) {
  creatorPosts(
    id: $id,
    accountName: $accountName,
    provider: $provider,
    after: $after,
    before: $before,
    first: $first,
    last: $last
  ) {
    additionalFilters
    edges {
      cursor
      node {
        caption
        contents {
          contentUrl
          displayUrl
          height
          id
          type
          width
        }
        creator {
          accountName
          authorized
          avatarUrl
          biography
          followersCount
          followingCount
          id
          provider
          verified
        }
        engagement {
          at
          commentCount
          likeCount
          playCount
          viewCount
        }
        engagementHistory {
          at
          commentCount
          likeCount
          playCount
          viewCount
        }
        externalId
        hashtags
        id
        location {
          address
          city
          lat
          lng
          name
        }
        mentions
        provider
        takenAt
        type
        usageRightsStatus
      }
    }
    filtersQuery
    nodes {
      caption
      contents {
        contentUrl
        displayUrl
        height
        id
        type
        width
      }
      creator {
        accountName
        authorized
        avatarUrl
        biography
        followersCount
        followingCount
        id
        provider
        verified
      }
      engagement {
        at
        commentCount
        likeCount
        playCount
        viewCount
      }
      engagementHistory {
        at
        commentCount
        likeCount
        playCount
        viewCount
      }
      externalId
      hashtags
      id
      location {
        address
        city
        lat
        lng
        name
      }
      mentions
      provider
      takenAt
      type
      usageRightsStatus
    }
    pageInfo {
      endCursor
      hasNextPage
      hasPreviousPage
      startCursor
    }
    totalCount
  }
}
Variables
{
  "id": 987,
  "accountName": "xyz789",
  "provider": "INSTAGRAM",
  "after": "xyz789",
  "before": "xyz789",
  "first": 123,
  "last": 987
}
Response
{
  "data": {
    "creatorPosts": {
      "additionalFilters": {},
      "edges": [MediaItemEdge],
      "filtersQuery": {},
      "nodes": [MediaItem],
      "pageInfo": PageInfo,
      "totalCount": 987
    }
  }
}

creatorTags

Description

Returns a Creator tags by ID or account name.

Response

Returns [ShopLabel!]

Arguments
Name Description
id - Int
accountName - String
provider - IntegrationProviderEnum

Example

Query
query creatorTags(
  $id: Int,
  $accountName: String,
  $provider: IntegrationProviderEnum
) {
  creatorTags(
    id: $id,
    accountName: $accountName,
    provider: $provider
  ) {
    id
    name
    shopId
    type
  }
}
Variables
{
  "id": 123,
  "accountName": "abc123",
  "provider": "INSTAGRAM"
}
Response
{
  "data": {
    "creatorTags": [
      {
        "id": "4",
        "name": "xyz789",
        "shopId": 4,
        "type": "xyz789"
      }
    ]
  }
}

items

Description

Gets portion of media items.

Response

Returns a MediaItemConnection!

Arguments
Name Description
filter - Filter
after - String Returns the elements in the list that come after the specified cursor.
before - String Returns the elements in the list that come before the specified cursor.
first - Int Returns the first n elements from the list.
last - Int Returns the last n elements from the list.

Example

Query
query items(
  $filter: Filter,
  $after: String,
  $before: String,
  $first: Int,
  $last: Int
) {
  items(
    filter: $filter,
    after: $after,
    before: $before,
    first: $first,
    last: $last
  ) {
    additionalFilters
    edges {
      cursor
      node {
        caption
        contents {
          contentUrl
          displayUrl
          height
          id
          type
          width
        }
        creator {
          accountName
          authorized
          avatarUrl
          biography
          followersCount
          followingCount
          id
          provider
          verified
        }
        engagement {
          at
          commentCount
          likeCount
          playCount
          viewCount
        }
        engagementHistory {
          at
          commentCount
          likeCount
          playCount
          viewCount
        }
        externalId
        hashtags
        id
        location {
          address
          city
          lat
          lng
          name
        }
        mentions
        provider
        takenAt
        type
        usageRightsStatus
      }
    }
    filtersQuery
    nodes {
      caption
      contents {
        contentUrl
        displayUrl
        height
        id
        type
        width
      }
      creator {
        accountName
        authorized
        avatarUrl
        biography
        followersCount
        followingCount
        id
        provider
        verified
      }
      engagement {
        at
        commentCount
        likeCount
        playCount
        viewCount
      }
      engagementHistory {
        at
        commentCount
        likeCount
        playCount
        viewCount
      }
      externalId
      hashtags
      id
      location {
        address
        city
        lat
        lng
        name
      }
      mentions
      provider
      takenAt
      type
      usageRightsStatus
    }
    pageInfo {
      endCursor
      hasNextPage
      hasPreviousPage
      startCursor
    }
    totalCount
  }
}
Variables
{
  "filter": Filter,
  "after": "abc123",
  "before": "abc123",
  "first": 123,
  "last": 987
}
Response
{
  "data": {
    "items": {
      "additionalFilters": {},
      "edges": [MediaItemEdge],
      "filtersQuery": {},
      "nodes": [MediaItem],
      "pageInfo": PageInfo,
      "totalCount": 123
    }
  }
}

mediaItem

Description

Returns a MediaItem resource by ID or externalID.

Response

Returns a MediaItem

Arguments
Name Description
id - String
externalId - String

Example

Query
query mediaItem(
  $id: String,
  $externalId: String
) {
  mediaItem(
    id: $id,
    externalId: $externalId
  ) {
    caption
    contents {
      contentUrl
      displayUrl
      height
      id
      type
      width
    }
    creator {
      accountName
      authorized
      avatarUrl
      biography
      followersCount
      followingCount
      id
      provider
      verified
    }
    engagement {
      at
      commentCount
      likeCount
      playCount
      viewCount
    }
    engagementHistory {
      at
      commentCount
      likeCount
      playCount
      viewCount
    }
    externalId
    hashtags
    id
    location {
      address
      city
      lat
      lng
      name
    }
    mentions
    provider
    takenAt
    type
    usageRightsStatus
  }
}
Variables
{
  "id": "abc123",
  "externalId": "xyz789"
}
Response
{
  "data": {
    "mediaItem": {
      "caption": "xyz789",
      "contents": [MediaContent],
      "creator": Creator,
      "engagement": [MediaItemsEngagement],
      "engagementHistory": [MediaItemsEngagement],
      "externalId": "xyz789",
      "hashtags": ["xyz789"],
      "id": "4",
      "location": MediaItemLocation,
      "mentions": ["xyz789"],
      "provider": "INSTAGRAM",
      "takenAt": ISO8601DateTime,
      "type": "POST",
      "usageRightsStatus": "REQUESTED"
    }
  }
}

mediaItems

Description

Gets portion of media items.

Response

Returns a MediaItemConnection!

Arguments
Name Description
filter - Filter
after - String Returns the elements in the list that come after the specified cursor.
before - String Returns the elements in the list that come before the specified cursor.
first - Int Returns the first n elements from the list.
last - Int Returns the last n elements from the list.

Example

Query
query mediaItems(
  $filter: Filter,
  $after: String,
  $before: String,
  $first: Int,
  $last: Int
) {
  mediaItems(
    filter: $filter,
    after: $after,
    before: $before,
    first: $first,
    last: $last
  ) {
    additionalFilters
    edges {
      cursor
      node {
        caption
        contents {
          contentUrl
          displayUrl
          height
          id
          type
          width
        }
        creator {
          accountName
          authorized
          avatarUrl
          biography
          followersCount
          followingCount
          id
          provider
          verified
        }
        engagement {
          at
          commentCount
          likeCount
          playCount
          viewCount
        }
        engagementHistory {
          at
          commentCount
          likeCount
          playCount
          viewCount
        }
        externalId
        hashtags
        id
        location {
          address
          city
          lat
          lng
          name
        }
        mentions
        provider
        takenAt
        type
        usageRightsStatus
      }
    }
    filtersQuery
    nodes {
      caption
      contents {
        contentUrl
        displayUrl
        height
        id
        type
        width
      }
      creator {
        accountName
        authorized
        avatarUrl
        biography
        followersCount
        followingCount
        id
        provider
        verified
      }
      engagement {
        at
        commentCount
        likeCount
        playCount
        viewCount
      }
      engagementHistory {
        at
        commentCount
        likeCount
        playCount
        viewCount
      }
      externalId
      hashtags
      id
      location {
        address
        city
        lat
        lng
        name
      }
      mentions
      provider
      takenAt
      type
      usageRightsStatus
    }
    pageInfo {
      endCursor
      hasNextPage
      hasPreviousPage
      startCursor
    }
    totalCount
  }
}
Variables
{
  "filter": Filter,
  "after": "xyz789",
  "before": "abc123",
  "first": 123,
  "last": 123
}
Response
{
  "data": {
    "mediaItems": {
      "additionalFilters": {},
      "edges": [MediaItemEdge],
      "filtersQuery": {},
      "nodes": [MediaItem],
      "pageInfo": PageInfo,
      "totalCount": 987
    }
  }
}

webhookSubscriptions

Description

Gets list of webhook subscriptions by event.

Response

Returns [WebhookSubscription!]

Arguments
Name Description
event - WebhookSubscriptionsEventsEnum

Example

Query
query webhookSubscriptions($event: WebhookSubscriptionsEventsEnum) {
  webhookSubscriptions(event: $event) {
    callbackUrl
    event
    id
    version
  }
}
Variables
{"event": "MEDIA_ITEM_CREATED"}
Response
{
  "data": {
    "webhookSubscriptions": [
      {
        "callbackUrl": "abc123",
        "event": "MEDIA_ITEM_CREATED",
        "id": 4,
        "version": "v0"
      }
    ]
  }
}

Mutations

creatorAddTag

Description

Add custom tag to influencer.

Response

Returns a ShopLabel

Arguments
Name Description
id - ID!
name - String!

Example

Query
mutation creatorAddTag(
  $id: ID!,
  $name: String!
) {
  creatorAddTag(
    id: $id,
    name: $name
  ) {
    id
    name
    shopId
    type
  }
}
Variables
{"id": 4, "name": "abc123"}
Response
{
  "data": {
    "creatorAddTag": {
      "id": "4",
      "name": "xyz789",
      "shopId": 4,
      "type": "xyz789"
    }
  }
}

mediaItemAddTag

Description

Add custom tag to media item.

Response

Returns a ShopLabel

Arguments
Name Description
id - ID!
name - String!

Example

Query
mutation mediaItemAddTag(
  $id: ID!,
  $name: String!
) {
  mediaItemAddTag(
    id: $id,
    name: $name
  ) {
    id
    name
    shopId
    type
  }
}
Variables
{"id": 4, "name": "xyz789"}
Response
{
  "data": {
    "mediaItemAddTag": {
      "id": "4",
      "name": "xyz789",
      "shopId": 4,
      "type": "abc123"
    }
  }
}

mediaItemAddToCollection

Description

Add media item to collection.

Response

Returns a Boolean

Arguments
Name Description
id - ID!
collectionId - ID
collectionName - String

Example

Query
mutation mediaItemAddToCollection(
  $id: ID!,
  $collectionId: ID,
  $collectionName: String
) {
  mediaItemAddToCollection(
    id: $id,
    collectionId: $collectionId,
    collectionName: $collectionName
  )
}
Variables
{
  "id": "4",
  "collectionId": 4,
  "collectionName": "xyz789"
}
Response
{"data": {"mediaItemAddToCollection": true}}

sendInstagramMessage

Description

Send Instagram direct message.

Response

Returns a Boolean!

Arguments
Name Description
accountName - String!
message - String!

Example

Query
mutation sendInstagramMessage(
  $accountName: String!,
  $message: String!
) {
  sendInstagramMessage(
    accountName: $accountName,
    message: $message
  )
}
Variables
{
  "accountName": "xyz789",
  "message": "abc123"
}
Response
{"data": {"sendInstagramMessage": false}}

webhookSubscriptionCreate

Description

Creates a new webhook subscription.

Response

Returns a WebhookSubscription

Arguments
Name Description
version - WebhookSubscriptionsVersionsEnum!
event - WebhookSubscriptionsEventsEnum!
callbackUrl - String!

Example

Query
mutation webhookSubscriptionCreate(
  $version: WebhookSubscriptionsVersionsEnum!,
  $event: WebhookSubscriptionsEventsEnum!,
  $callbackUrl: String!
) {
  webhookSubscriptionCreate(
    version: $version,
    event: $event,
    callbackUrl: $callbackUrl
  ) {
    callbackUrl
    event
    id
    version
  }
}
Variables
{
  "version": "v0",
  "event": "MEDIA_ITEM_CREATED",
  "callbackUrl": "abc123"
}
Response
{
  "data": {
    "webhookSubscriptionCreate": {
      "callbackUrl": "xyz789",
      "event": "MEDIA_ITEM_CREATED",
      "id": "4",
      "version": "v0"
    }
  }
}

webhookSubscriptionDelete

Description

Deletes a webhook subscription.

Response

Returns a Boolean

Arguments
Name Description
event - WebhookSubscriptionsEventsEnum!

Example

Query
mutation webhookSubscriptionDelete($event: WebhookSubscriptionsEventsEnum!) {
  webhookSubscriptionDelete(event: $event)
}
Variables
{"event": "MEDIA_ITEM_CREATED"}
Response
{"data": {"webhookSubscriptionDelete": false}}

Types

AudienceReportResponse

Fields
Field Name Description
accountName - String! Name of creator account on Instagram or TikTok.
audienceReport - JSON! Audience report.
id - Int! Creator's unique identifier in Archive's system.
provider - IntegrationProviderEnum! Platform where creator exists. INSTAGRAM or TIKTOK.
Example
{
  "accountName": "abc123",
  "audienceReport": {},
  "id": 987,
  "provider": "INSTAGRAM"
}

Boolean

Description

Represents true or false values.

Example
true

Creator

Fields
Field Name Description
accountName - String! Name of creator account on Instagram or TikTok.
authorized - Boolean! Whether the creator has been authorized.
avatarUrl - String URL of the creator's profile picture.
biography - String Creator's bio (if available).
followersCount - Int Number of creator's followers.
followingCount - Int Number of accounts creator is following.
id - Int! Unique identifier in Archive's system.
provider - IntegrationProviderEnum! Platform where creator exists. INSTAGRAM or TIKTOK.
verified - Boolean Whether the creator is verified by the platform.
Example
{
  "accountName": "xyz789",
  "authorized": true,
  "avatarUrl": "xyz789",
  "biography": "xyz789",
  "followersCount": 987,
  "followingCount": 987,
  "id": 123,
  "provider": "INSTAGRAM",
  "verified": false
}

Filter

Fields
Input Field Description
itemProviders - [IntegrationProviderEnum!] Types of the items
itemTypes - [TypesEnum!] Types of the items
creatorAccountName - [String!] Creator Account Names. Default = []
creatorVerified - [Boolean!] Only verified influencers
usageRightsStatus - [StatusesEnum!] Usage Rights request status
Example
{
  "itemProviders": ["INSTAGRAM"],
  "itemTypes": ["POST"],
  "creatorAccountName": ["xyz789"],
  "creatorVerified": [false],
  "usageRightsStatus": ["REQUESTED"]
}

ID

Description

Represents a unique identifier that is Base64 obfuscated. It is often used to refetch an object or as key for a cache. The ID type appears in a JSON response as a String; however, it is not intended to be human-readable. When expected as an input type, any string (such as "VXNlci0xMA==") or integer (such as 4) input value will be accepted as an ID.

Example
4

ISO8601DateTime

Description

An ISO 8601-encoded datetime

Example
ISO8601DateTime

Int

Description

Represents non-fractional signed whole numeric values. Int can represent values between -(2^31) and 2^31 - 1.

Example
987

IntegrationProviderEnum

Values
Enum Value Description

INSTAGRAM

TIKTOK

INTERNAL

YOUTUBE

Example
"INSTAGRAM"

JSON

Description

Represents untyped JSON

Example
{}

MediaContent

Fields
Field Name Description
contentUrl - String URL of image or video file.
displayUrl - String URL of video thumbnail. Will be the same as content_url for images.
height - Int Height of media file in px.
id - Int! Unique identifier in Archive's system.
type - String! Type of media file. IMAGE or VIDEO.
width - Int Width of media file in px.
Example
{
  "contentUrl": "xyz789",
  "displayUrl": "abc123",
  "height": 987,
  "id": 987,
  "type": "xyz789",
  "width": 987
}

MediaItem

Fields
Field Name Description
caption - String Content caption.
contents - [MediaContent!]! Files which represent the content of an item. For carousels, there will be multiple.
creator - Creator! Information about the content creator.
engagement - [MediaItemsEngagement!] We can track posts for X days and gather post engagement dynamics.
engagementHistory - [MediaItemsEngagement!] We can track posts for X days and gather post engagement dynamics.
externalId - String! The ID of an item on Instagram or TikTok.
hashtags - [String!] Hashtags that are used in the content.
id - ID! Unique identifier in Archive's system.
location - MediaItemLocation Content location description.
mentions - [String!] Mentions that are used in the content.
provider - IntegrationProviderEnum! Platform where content exists. INSTAGRAM or TIKTOK.
takenAt - ISO8601DateTime! Timestamp of when content was uploaded to social media (UTC).
type - TypesEnum! Type of archived content. POST, REEL, STORY or TIKTOK.
usageRightsStatus - StatusesEnum Status of usage rights request for content. REQUESTED, APPROVED or REJECTED.
Example
{
  "caption": "xyz789",
  "contents": [MediaContent],
  "creator": Creator,
  "engagement": [MediaItemsEngagement],
  "engagementHistory": [MediaItemsEngagement],
  "externalId": "abc123",
  "hashtags": ["xyz789"],
  "id": "4",
  "location": MediaItemLocation,
  "mentions": ["xyz789"],
  "provider": "INSTAGRAM",
  "takenAt": ISO8601DateTime,
  "type": "POST",
  "usageRightsStatus": "REQUESTED"
}

MediaItemConnection

Description

The connection type for MediaItem.

Fields
Field Name Description
additionalFilters - JSON
edges - [MediaItemEdge!]! A list of edges.
filtersQuery - JSON
nodes - [MediaItem!]! A list of nodes.
pageInfo - PageInfo! Information to aid in pagination.
totalCount - Int!
Example
{
  "additionalFilters": {},
  "edges": [MediaItemEdge],
  "filtersQuery": {},
  "nodes": [MediaItem],
  "pageInfo": PageInfo,
  "totalCount": 123
}

MediaItemEdge

Description

An edge in a connection.

Fields
Field Name Description
cursor - String! A cursor for use in pagination.
node - MediaItem The item at the end of the edge.
Example
{
  "cursor": "abc123",
  "node": MediaItem
}

MediaItemLocation

Fields
Field Name Description
address - String
city - String
lat - String
lng - String
name - String
Example
{
  "address": "xyz789",
  "city": "abc123",
  "lat": "abc123",
  "lng": "abc123",
  "name": "xyz789"
}

MediaItemsEngagement

Fields
Field Name Description
at - ISO8601DateTime! Timestamp of when engagement metrics were captured.
commentCount - Int Number of comments.
likeCount - Int Number of likes.
playCount - Int Number of plays (if available).
viewCount - Int Number of views (if available).
Example
{
  "at": ISO8601DateTime,
  "commentCount": 123,
  "likeCount": 123,
  "playCount": 123,
  "viewCount": 123
}

PageInfo

Description

Information about pagination in a connection.

Fields
Field Name Description
endCursor - String When paginating forwards, the cursor to continue.
hasNextPage - Boolean! When paginating forwards, are there more items?
hasPreviousPage - Boolean! When paginating backwards, are there more items?
startCursor - String When paginating backwards, the cursor to continue.
Example
{
  "endCursor": "xyz789",
  "hasNextPage": false,
  "hasPreviousPage": false,
  "startCursor": "xyz789"
}

ShopLabel

Fields
Field Name Description
id - ID!
name - String!
shopId - ID!
type - String
Example
{
  "id": "4",
  "name": "xyz789",
  "shopId": "4",
  "type": "xyz789"
}

StatusesEnum

Values
Enum Value Description

REQUESTED

APPROVED

REJECTED

Example
"REQUESTED"

String

Description

Represents textual data as UTF-8 character sequences. This type is most often used by GraphQL to represent free-form human-readable text.

Example
"abc123"

TypesEnum

Values
Enum Value Description

POST

REEL

STORY

SHORT

Example
"POST"

WebhookSubscription

Fields
Field Name Description
callbackUrl - String! URL of where we will send webhook payload.
event - WebhookSubscriptionsEventsEnum! Event which triggers webhook.
id - ID! Unique identifier in Archive's system.
version - WebhookSubscriptionsVersionsEnum! Which version of payloads are used.
Example
{
  "callbackUrl": "abc123",
  "event": "MEDIA_ITEM_CREATED",
  "id": "4",
  "version": "v0"
}

WebhookSubscriptionsEventsEnum

Values
Enum Value Description

MEDIA_ITEM_CREATED

Triggers when media item comes to Archive.

MEDIA_ITEM_ENGAGEMENT_UPDATED

Triggers when we add a record into media item engagement history.
Example
"MEDIA_ITEM_CREATED"

WebhookSubscriptionsVersionsEnum

Values
Enum Value Description

v0

v1

Example
"v0"