Catalog JSON API Documentation

So, you want to develop some tooling around the Catalog API - perhaps some custom reports? Great! This API gives you everything that Catalog has to offer.

Authentication

Visit this page to create an API key. Once you’ve received your key, treat it like a password.

Use SSL for all requests to the API. Non-SSL requests will result in redirects, and your API key will be sent in the clear.

To authenticate, send the API key as a request header. Here’s an example using cURL:

curl https://www.my-catalog.edu/api/v1/products -H 'Authorization: Token token="my-api-key"'

Pagination

All index endpoints support pagination. Specifically, we implement RFC5988.

Pagination Options

You can use ?page= to set the page of data you want to retrieve. If no items exist for that page, the response will be a root key with an empty array.

curl https://www.my-catalog.edu/api/v1/courses?page=2

{
  "courses": []
}

To change the number of items returned for each page, you can use ?per_page=. This defaults to 20 and has a max of 100.

curl https://www.my-catalog.edu/api/v1/courses?per_page=40&page=2

Information about pagination is provided in the Link header. Here is an example of what the header could look like

curl -I https://www.my-catalog.edu/api/v1/courses?page=3

Link: <https://www.my-catalog.edu/api/v1/courses?page=4>; rel="next",  
      <https://www.my-catalog.edu/api/v1/courses?page=15>; rel="last",
      <https://www.my-catalog.edu/api/v1/courses?page=1>; rel="first",
      <https://www.my-catalog.edu/api/v1/courses?page=2>; rel="prev"

Let’s talk about what each link means. rel="next" lets us know that the next page of data is page=4. This make sense given that we requested page 3. rel="prev" lets us know that the page previous to the one we requested is page=2. rel="next" indicates the next page of data to request. rel="last" tells us the last and total number of pages of data that currently exist.

Not all rel= links will exist on every response. For instance, the response for the first page of data will not have rel="first" or rel="prev". The same is true for the last page of data. This means that you can programmatically traverse all pages of data by requesting the first page and continuing to request the rel="next" until the response does not contain a rel="next".

It’s important to note that altering the per_page= will change the total number of pages.

Listing Image

If you are uploading a product image in SVG format. You will need to specify the file type.

curl https://www.my-catalog.edu/api/v1/products -F "course[listing_image]=@somefile.svg;type=image/svg+xml"'

Analytics

The POST request parameters should be sent as JSON in the request body.
If the request is unfiltered, an empty JSON object should be sent as the filter.

Getting enrollments analytics

Endpoint

POST https://www.my-catalog.edu/api/v1/analytics/enrollments

Parameters

Name Description Type
account_ids List of account ids Array
product_ids List of product ids Array
product_statuses List of product statuses (OPEN, CLOSED, and/or DELETED) Array
student_ids List of student ids(catalog user id) Array
student_canvas_user_ids List of student ids(canvas user id) Array
enrollment_date_from Enrollment date from Datetime
enrollment_date_to Enrollment date to Datetime
enrollment_statuses List of enrollment statuses (ACTIVE, COMPLETED, DROPPED and/or CONCLUDED) Array
completion_date_from Completion date from Datetime
completion_date_to Completion date to Datetime

Request

Route

POST https://www.my-catalog.edu/api/v1/analytics/enrollments

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "account_ids": [
    1,
    2,
    3
  ],
  "product_ids": [
    1,
    2,
    3
  ],
  "product_statuses": [
    "OPEN",
    "CLOSED",
    "DELETED"
  ],
  "student_ids": [
    1,
    2,
    3
  ],
  "student_canvas_user_ids": [
    1,
    2,
    3
  ],
  "enrollment_date_from": "2023-06-05T14:46:59.944581+02:00",
  "enrollment_date_to": "2023-06-06T14:46:59.944581+02:00",
  "enrollment_statuses": [
    "ACTIVE",
    "COMPLETED",
    "DROPPED",
    "CONCLUDED"
  ],
  "completion_date_from": "2023-06-05T14:46:59.944581+02:00",
  "completion_date_to": "2023-06-06T14:46:59.944581+02:00"
}

Response

Response Fields

Name Description Type
id Enrollment id Integer
account_id Account id Integer
account_name Account name String
product[name] Product name String
product[id] Product id Integer
product[url] Product url (null if product is deleted) String
product[sku] Product sku String
product_status Product status (OPEN, CLOSED, or DELETED) String
canvas_course_id Canvas course id Integer
student[canvas_user_id] Student Canvas user id Integer
student[name] Student name String
student[email] Student email String
student[canvas_user_id_string] Canvas user id in string format String
created_at Creation date Datetime
completed_at Completion date Datetime
enrollment_status Enrollment status (ACTIVE, COMPLETED, DROPPED or CONCLUDED) String
certificate_attainable Product has a certificate Boolean
certificate_offered Certificate offered/earned Boolean
custom_fields List of custom fields (consist of key and value) Array
certificate_url Certificate url String

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: 7jUq2d5ztBpVnnW6uM1Lqk9f16yeNJ4CTI6Ke8jrw+0LyWmZHawtQ7C8Fv30A1AF2Si+3ES3JyXuU3UQQOv9Bw==
ETag: W/"97a734a5750ae8512b5a732ee4a6dce6"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=NFBEeFlaOWIwSHdiMS93VnUvUVloUEltYktHeEQvSnl0TVpobnE5RmU0ejFsMGZUZFlINnI0MWlia2h2ZnFCVGRidmZLOUxEeU14bWVwbEQrY0RUSkVZZE5xR1FrQ282QllFc3M1LzN4K0doam83SC9USTYzNUpoTllKMzBsbUViZEJDQkpXSmJUMWhDVGdRSzFUcnFvd3ZQdlpZdWtwU09qOU9STW54ZDFlZ0YzcXN0KzlSajk3dXZDamllcU5GLS1vRWVpZDRlSGx0UHQyUUFKVVA3bXZnPT0%3D--42d7e1665ba25592b3559ccaa6f16c9e157b4314; path=/; HttpOnly
X-Request-Id: 7e903686-1f6b-4858-8883-6e42a802a910
X-Runtime: 0.024500
Content-Length: 690

Body

{
  "enrollments": [
    {
      "id": 25,
      "account_id": 3,
      "account_name": "Sub-Account 1",
      "product": {
        "name": "Course 1",
        "id": 5,
        "url": "https://www.my-catalog.edu/admin/products/1/edit",
        "sku": "sku"
      },
      "product_status": "OPEN",
      "canvas_course_id": 11,
      "student": {
        "canvas_user_id": 1,
        "name": "User 15",
        "email": "user15@instructure.com",
        "canvas_user_id_string": "1"
      },
      "created_at": "2023-06-05T14:46:59.944581+02:00",
      "completed_at": "2023-06-29T12:13:27+02:00",
      "enrollment_status": "COMPLETED",
      "certificate_attainable": true,
      "certificate_offered": true,
      "custom_fields": [
        {
          "key": "text_udf",
          "value": "awesome udf"
        },
        {
          "key": "checkbox_udf",
          "value": "1"
        }
      ],
      "certificate_url": "https://www.my-catalog.edu/admin/certificates/1.pdf?user_id=1"
    }
  ]
}

Getting orders analytics

Endpoint

POST https://www.my-catalog.edu/api/v1/analytics/orders

Parameters

Name Description Type
account_ids List of account ids Array
product_ids List of product ids Array
product_statuses List of product statuses (OPEN, CLOSED, and/or DELETED) Array
student_ids List of student ids(catalog user id) Array
student_canvas_user_ids List of student ids(canvas user id) Array
purchaser_ids List of purchaser ids(catalog user id) Array
purchaser_canvas_user_ids List of purchaser ids(canvas user id) Array
bulk_purchases_only Bulk purchases only Boolean
purchase_date_from Purchase date from Datetime
purchase_date_to Purchase date to Datetime
order_fee List of order fee types (FREE and/or PAID) Array
listing_price_min Listing price minimum Decimal
listing_price_max Listing price maximum Decimal
promo_codes List of promotion code states (APPLIED and/or NOT_APPLIED) Array
revenue_min Revenue minimum Decimal
revenue_max Revenue maximum Decimal

Request

Route

POST https://www.my-catalog.edu/api/v1/analytics/orders

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "account_ids": [
    1,
    2,
    3
  ],
  "product_ids": [
    1,
    2,
    3
  ],
  "product_statuses": [
    "OPEN",
    "CLOSED",
    "DELETED"
  ],
  "student_ids": [
    1,
    2,
    3
  ],
  "student_canvas_user_ids": [
    1,
    2,
    3
  ],
  "purchaser_ids": [
    1,
    2,
    3
  ],
  "purchaser_canvas_user_ids": [
    1,
    2,
    3
  ],
  "bulk_purchases_only": true,
  "purchase_date_from": "2023-06-05T14:46:59.944581+02:00",
  "purchase_date_to": "2023-06-06T14:46:59.944581+02:00",
  "order_fee": 10.0,
  "listing_price_min": 5.0,
  "listing_price_max": 100.6,
  "promo_codes": [
    "APPLIED",
    "NOT_APPLIED"
  ],
  "revenue_min": 5.0,
  "revenue_max": 1000.1
}

Response

Response Fields

Name Description Type
account_id Account id Integer
account_name Account name String
product[name] Product name String
product[id] Product id Integer
product[url] Product url (null if product is deleted) String
product[sku] Product sku String
product_status Product status (OPEN, CLOSED, or DELETED) String
canvas_course_id Canvas course id Integer
purchaser[id] Purchaser Catalog user id Integer
purchaser[canvas_user_id] Purchaser Canvas user id Integer
purchaser[name] Purchaser name String
purchaser[email] Purchaser email String
purchaser[canvas_user_id_string] Purchaser Canvas user id in string format String
purchased_at Purchase date Datetime
order_id Order id Integer
order_item_id Order item id Integer
reference_id Reference id String
list_price Listing price Decimal
currency Currency String
promo_codes List of promotion codes Array
discount Discount Decimal
revenue Revenue Decimal
bulk_purchase Bulk purchase Boolean
seat_count Seat count Integer
bulk_enrollments List of bulk enrolled students Array
bulk_enrollments[id] Bulk enrolled Catalog user id Integer
bulk_enrollments[canvas_user_id] Bulk enrolled Canvas user id Integer
bulk_enrollments[name] Bulk enrolled student name String
bulk_enrollments[email] Bulk enrolled student email String
bulk_enrollments[canvas_user_id_string] Bulk enrolled Canvas user id in string format String
last_modification_date Last modification date of revenue Datetime
revenue_change_history Revenue change history list Array
revenue_change_history[modification_date] Modification date of revenue update Datetime
revenue_change_history[new_value] New revenue value Decimal
revenue_change_history[new_value_currency] New revenue value currency String
revenue_change_history[old_value] Old revenue value Decimal
revenue_change_history[old_value_currency] Old revenue value currency String
revenue_change_history[reason] Reason of revenue update String
revenue_change_history[user_name] Name of the user who updated the revenue String
revenue_change_history[user_profile_link] Link to the user profile String

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: Iu6BM288K6871TUmpZw6UJTNqkEmF36Z1+fVaFQvGIYK1q/lFoyJkLWco3Fy1P9PoAACOIPZsew7FwSSvSxSww==
ETag: W/"2bc151db8614f69f334f1698f64f13bf"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=STErbVBSeW40dTVlSGk2Ly9rbUVSUUgwV0ZLSUk4S0FqMGlZT09udlhLc3BDZjc4RjN4MEhLZkxLY2JDQkg4QXhGMG02UnQ1YVhoTzFXcTN2anVsV0k2MEhRMGlSREFyWk9qeG5NSld4b3lCY2x3UVZCYndpQTloM09IVXVoWEJmZ1FmWUMrRXl6M3NhOEV6Q3UrMEt0Z2s0QnBZOUJqY09yZjZNMzUrYTloZjNRYUxFcXdObXdxVmJxUGdIaXJZLS1OMDc1N2lBU0VMR25za3djS3hxM1NRPT0%3D--9b95d24a2a2b0618733beba9fe625dfeb114e9ce; path=/; HttpOnly
X-Request-Id: 699bb4d3-92d3-43c9-8c63-226406744e4c
X-Runtime: 0.034990
Content-Length: 1470

Body

{
  "orders": [
    {
      "account_id": 3,
      "account_name": "Sub-Account 1",
      "product": {
        "name": "Course 1",
        "id": 5,
        "url": "https://www.my-catalog.edu/admin/products/1/edit",
        "sku": "sku"
      },
      "product_status": "OPEN",
      "canvas_course_id": 11,
      "purchaser": {
        "id": 1,
        "canvas_user_id": 1,
        "name": "Purchaser 1",
        "email": "purchaser1@instructure.com",
        "canvas_user_id_string": "1"
      },
      "purchased_at": "2023-07-02T23:30:59.052239+02:00",
      "order_id": 81,
      "order_item_id": 123,
      "reference_id": "PR-81-82",
      "list_price": 5.0,
      "currency": "USD",
      "promo_codes": [
        "PROMO1",
        "PROMO2"
      ],
      "discount": 10.0,
      "revenue": 5.0,
      "bulk_purchase": true,
      "seat_count": 3,
      "bulk_enrollments": [
        {
          "id": 141,
          "canvas_user_id": 74,
          "name": "User 17",
          "email": "user17@instructure.com",
          "canvas_user_id_string": "74"
        },
        {
          "id": 138,
          "canvas_user_id": 73,
          "name": "User 16",
          "email": "user16@instructure.com",
          "canvas_user_id_string": "73"
        }
      ],
      "last_modification_date": "2023-07-09T23:30:59.052239+02:00",
      "revenue_change_history": [
        {
          "modification_date": "2023-07-09T23:30:59.052239+02:00",
          "new_value": 5.0,
          "new_value_currency": "USD",
          "old_value": 2.0,
          "old_value_currency": "USD",
          "reason": "This is very important",
          "user_name": "user19@instructure.com",
          "user_profile_link": "https://www.my-catalog.edu/accounts/2/users/1"
        },
        {
          "modification_date": "2023-07-08T23:30:59.052239+02:00",
          "new_value": 2.0,
          "new_value_currency": "USD",
          "old_value": 11.0,
          "old_value_currency": "USD",
          "reason": "This is important",
          "user_name": "user20@instructure.com",
          "user_profile_link": "https://www.my-catalog.edu/accounts/2/users/2"
        }
      ]
    }
  ]
}

Getting products analytics

Endpoint

POST https://www.my-catalog.edu/api/v1/analytics/products

Parameters

Name Description Type
account_ids List of account ids Array
product_ids List of product ids Array
product_statuses List of product statuses (OPEN, CLOSED, and/or DELETED) Array
creation_date_from Creation date from Datetime
creation_date_to Creation date to Datetime
enrollment_count_min Enrollment count minimum Integer
enrollment_count_max Enrollment count maximum Integer
completion_count_min Completion count minimum Integer
completion_count_max Completion count maximum Integer
dropped_count_min Dropped count minimum Integer
dropped_count_max Dropped count maximum Integer
listing_price_min Listing price minimum Decimal
listing_price_max Listing price maximum Decimal
promo_codes List of promotion code states (APPLIED and/or NOT_APPLIED) Array
revenue_min Revenue minimum Decimal
revenue_max Revenue maximum Decimal
certificate_offered Certificate offered for the product Boolean

Request

Route

POST https://www.my-catalog.edu/api/v1/analytics/products

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "account_ids": [
    1,
    2,
    3
  ],
  "product_ids": [
    1,
    2,
    3
  ],
  "product_statuses": [
    "OPEN",
    "CLOSED",
    "DELETED"
  ],
  "creation_date_from": "2023-06-05T14:46:59.944581+02:00",
  "creation_date_to": "2023-06-06T14:46:59.944581+02:00",
  "enrollment_count_min": 0,
  "enrollment_count_max": 5,
  "completion_count_min": 0,
  "completion_count_max": 5,
  "dropped_count_min": 0,
  "dropped_count_max": 5,
  "listing_price_min": 10.1,
  "listing_price_max": 1000.5,
  "promo_codes": [
    "APPLIED",
    "NOT_APPLIED"
  ],
  "revenue_min": 10.1,
  "revenue_max": 500.5,
  "certificate_offered": true
}

Response

Response Fields

Name Description Type
account_id Account id Integer
account_name Account name String
product[name] Product name String
product[id] Product id Integer
product[url] Product url (null if product is deleted) String
product[sku] Product sku String
product_status Product status (OPEN, CLOSED, or DELETED) String
created_at Product creation date Datetime
canvas_course_id Canvas course id Integer
enrollment_count Enrollment count Integer
dropped_count Dropped count Integer
completion_count Completion count Integer
currency Currency String
list_price Listing price Decimal
promo_codes List of promotion codes Array
discount Discount Decimal
revenue Revenue Decimal
points Points (null if account measurement is not point) Decimal
ceus CEUs (null if account measurement is not CEU) Decimal
credits Credits (null if account measurement is not credit) Decimal
certificate_offered Certificate offered for this product Boolean

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: wdg2vwQ8Z3rXDPa0aj780rD7fdBZk/e9iFMzl08CuMTcPQcPnMLpzQnuksLoprAGE/HMXFqpfiS8YMhTbYLXMA==
ETag: W/"5a2f0129ae43f07ed8a378bdee3c6555"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=UHFKeU14ZEVSSDlTajVLRUJJUSs1WGJWSGF5MS9pMGgwZ1RCUnlCaFhxU1pBM3UwSTNFVmp1WFplM2tqbUhCam1ucHVJand4K1hXY0o1WkdKTUt0a0d3MEF5bjRBTTNMWEJpV0JoVTNHYWVkdFZiNGFTQkNxWWFtaXRlcXZzK25Ubm51RHJRVUJnY3dhKzUyQ3d0WXRuQUc5bVNBOTAvWlZuTXNQYWR5MXdnTU9FSkV2RGZwOVNySXZBUk90YkEzLS1zZVpqZlY1V2J1ZlNDcG1ZWjNWSS9RPT0%3D--81b26c02d5d3c36d8f2f67668b342730e245d496; path=/; HttpOnly
X-Request-Id: 3c229d9a-823d-40ec-b769-944932c240d9
X-Runtime: 0.025069
Content-Length: 463

Body

{
  "products": [
    {
      "account_id": 3,
      "account_name": "Sub-Account 1",
      "product": {
        "name": "Course 1",
        "id": 5,
        "url": "https://www.my-catalog.edu/admin/products/1/edit",
        "sku": "sku"
      },
      "product_status": "OPEN",
      "created_at": "2023-06-05T14:46:59.944581+02:00",
      "canvas_course_id": 11,
      "enrollment_count": 7,
      "dropped_count": 3,
      "completion_count": 2,
      "currency": "USD",
      "list_price": 10.0,
      "promo_codes": [
        "PROMO1",
        "PROMO2"
      ],
      "discount": 10.0,
      "revenue": 60.0,
      "credits": 5.0,
      "certificate_offered": true
    }
  ]
}

Getting users analytics

Endpoint

POST https://www.my-catalog.edu/api/v1/analytics/users

Parameters

Name Description Type
account_ids List of account ids Array
student_ids List of student ids(catalog user id) Array
student_canvas_user_ids List of student ids(canvas user id) Array
enrollment_count_min Enrollment count minimum Integer
enrollment_count_max Enrollment count maximum Integer
last_enrollment_date_from Last enrollment date from Datetime
last_enrollment_date_to Last enrollment date to Datetime
registration_date_from Registration date from Datetime
registration_date_to Registration date to Datetime
registered_through List of registration sources (CANVAS and/or CATALOG) Array

Request

Route

POST https://www.my-catalog.edu/api/v1/analytics/users

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "account_ids": [
    1,
    2,
    3
  ],
  "student_ids": [
    1,
    2,
    3
  ],
  "student_canvas_user_ids": [
    1,
    2,
    3
  ],
  "enrollment_count_min": 0,
  "enrollment_count_max": 5,
  "last_enrollment_date_from": "2023-06-05T14:46:59.944581+02:00",
  "last_enrollment_date_to": "2023-06-06T14:46:59.944581+02:00",
  "registration_date_from": "2023-06-05T14:46:59.944581+02:00",
  "registration_date_to": "2023-06-06T14:46:59.944581+02:00",
  "registered_through": [
    "CANVAS",
    "CATALOG"
  ]
}

Response

Response Fields

Name Description Type
id Catalog user id Integer
canvas_user_id Canvas user id Integer
name User name String
email User email String
account_id Account id Integer
account_name Account name String
registered_through Registration source (CANVAS or CATALOG) String
registered_at Registration date Datetime
enrollment_count Enrollment count Integer
last_enrolled_at Last Enrollment date Datetime
custom_fields List of custom fields (consist of key and value) Array

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: ezVKYU4iHnui9HOIq/ADChGyV/3hTpn32qx7jeFpW2CL81e3NHsfbrL2ZB9Tkauz7T4bX8uCZllQFm9gVKDuVA==
ETag: W/"bd444a5c10a5f6c1b1ca69e53a5d8c30"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=Z2dWUkxDTnNPNTVRUUYzZ1N2Y0V5Z0EvZlIwYkZpcW5GTlVDV215NWI1WE9NS2RmM3BsWTVLck1hUTVpRlo0eGxZL2loRDdmdklqNHl1azlKM01MTUpUUUVoUTlmNzZOTmg4RUgyQlFub1FNak5uK1BicW5qQ2JtemIwK1VROEYzWkpwalM3OVRud0dXMjlXRGxJWjROL1FrQjRlL1ExbXBONHUxMU9SbGFWcXJNMlhGcG56dFRGT1dtU0t1UGdvLS1EYWNrSGM3dk1LOTdvbVZ6aVFBc2RRPT0%3D--33efb855994819505cdf6bef2711a8c397d63ba9; path=/; HttpOnly
X-Request-Id: 7f01edca-0af3-4949-b2ba-64d4d62aa4b4
X-Runtime: 0.026321
Content-Length: 386

Body

{
  "users": [
    {
      "id": 150,
      "canvas_user_id": 77,
      "name": "User 19",
      "email": "user19@instructure.com",
      "account_id": 3,
      "account_name": "Sub-Account 1",
      "registered_through": "CATALOG",
      "registered_at": "2023-07-03T15:03:57.597+02:00",
      "enrollment_count": 2,
      "last_enrolled_at": "2023-07-06T17:30:50.991764+02:00",
      "custom_fields": [
        {
          "key": "text_udf",
          "value": "awesome udf"
        },
        {
          "key": "checkbox_udf",
          "value": "1"
        }
      ]
    }
  ]
}

Bulk enrollments

Getting a specific bulk enrollment

Endpoint

GET https://www.my-catalog.edu/api/v1/order_items/history/bulk_enrollments/:id

Parameters

Name Description Type
id required Order id Integer

Request

Route

GET https://www.my-catalog.edu/api/v1/order_items/history/bulk_enrollments/5

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: 3CXTYQoBSKw/iauSLeNUDbDVLWErPg5idbahpRF8G2oT8+2TcojwD8Z0fWclSTqdY+Ep0P+U+0Mlxw1UtHvb7g==
ETag: W/"34cb52779044b2463421829de8b52dce"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=MGF3RnYwTkxIbjkxWEY0Sy9OQm5DQUFTZ21mZCtmTTVscGM3TGtPc3ZJdVRkbFpmU1NLbVRCTS9pZUtvWDlRbytoSkpyTDFudFJ6NGZJSmFrNnptSGhRYWh2ZHhJZERPWStXUld1VnFodXV5cWRIOW05VHluOWtvMDRPUHFNMUxHWDhGU202TXNFWGlWTzhCSkRVUXBVTXI5QzZqb0hvRzlQMytTSkM4V0pNTXBhbnlnamJ1UHhsdEpucVhNc0JJLS00cU02cTNBblhxdjdGT3M2THczdjJ3PT0%3D--06fbe2afa6c16034bb06a926b56a2a274640b043; path=/; HttpOnly
X-Request-Id: 5dfecdb4-3789-4656-8d1b-81ceb73e3591
X-Runtime: 0.023790
Content-Length: 1177

Body

{
  "bulk_purchase": {
    "order": {
      "id": 5,
      "created_at": "2024-12-20T12:12:29.066827Z",
      "updated_at": "2024-12-20T12:12:30.892895Z",
      "full_id": "5",
      "account_id": 40,
      "user_id": 187,
      "canvas_user_id": 1,
      "canvas_root_account_uuid": "41WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
      "source": "bulk_purchase",
      "currency": "USD",
      "purchased_at": "2024-12-20T12:12:30.892045Z",
      "total": 6.0,
      "email": "bettercall@saul.com",
      "name": "Saul Goodman",
      "items": [
        {
          "id": 61,
          "created_at": "2024-12-20T12:12:29.068419Z",
          "updated_at": "2024-12-20T12:12:29.068433Z",
          "order_id": 5,
          "item_id": 42,
          "amount": 15.0,
          "canvas_root_account_uuid": "41WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
          "discounted_amount": 6.0,
          "quantity": 3,
          "unit_price": 5.0
        }
      ]
    },
    "product": {
      "id": 42,
      "visibility": "listed",
      "enrollment_open": true,
      "title": "Paid program",
      "enrollment_fee": 5,
      "account_id": 40,
      "type": "Program",
      "canvas_root_account_uuid": "41WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
      "waitlist": false,
      "limited": false,
      "started": false,
      "program": true,
      "course": false,
      "ended": false
    },
    "bulk_invitations": [
      {
        "order_item_id": 61,
        "invitation_id": 4,
        "status": "created"
      },
      {
        "order_item_id": 61,
        "invitation_id": 5,
        "status": "created"
      },
      {
        "order_item_id": 61,
        "invitation_id": 6,
        "status": "created"
      }
    ]
  }
}

Listing bulk enrollments

Endpoint

GET https://www.my-catalog.edu/api/v1/order_items/history/bulk_enrollments

Parameters

Name Description Type
from Only include bulk enrollments from this date DateTime
to Only include bulk enrollments to this date DateTime
canvas_user_ids Only include bulk enrollments for the specified canvas user ids Array

Request

Route

GET https://www.my-catalog.edu/api/v1/order_items/history/bulk_enrollments

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: FqLPZwKhd42niXkojK0Znz4kPEP7QDjolzK+tUidAZaK1ZAx5RgxUryPfG2thB9zdt0a/3yzDPWJVCqY/petTQ==
ETag: W/"c8158f802b87509afa577c2b72a104d5"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=YkQ3SGNKVFVaakJHbkw2NnpKNDI0Qkw2aURaNFJWNnRHdmZxQytRVEYzRW13bXlmZHNJalNaREx6cFYyTFJCSGpsWG94SnVLMCtpcTdKbFFPYVZ3RFArYTlHSmc3MS9LaFBXdlFNVzZ3U2c5WU5xcjZHSmkwWGwreXF5OHVySGJRQllqZ2pwUUN3dDRzd0hURS9hWk9idmF2S3JFQ1R1b09SZFgyZU5RWGNmL1NvL3JDYzJsSlRxVWpabm9iKzErLS00b3FQd2hYaW1vUjBxeHdLdVZNTEh3PT0%3D--8a1fb75fede6c62fa41f7bc3c4329fd0647cae25; path=/; HttpOnly
X-Request-Id: c2ca3117-938f-4efc-8ffd-f7a5917153b9
X-Runtime: 0.024741
Content-Length: 1200

Body

{
  "bulk_enrollments": [
    {
      "bulk_purchase": {
        "order": {
          "id": 4,
          "created_at": "2024-12-20T12:12:29.066827Z",
          "updated_at": "2024-12-20T12:12:30.892895Z",
          "full_id": "4",
          "account_id": 38,
          "user_id": 187,
          "canvas_user_id": 1,
          "canvas_root_account_uuid": "39WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
          "source": "bulk_purchase",
          "currency": "USD",
          "purchased_at": "2024-12-20T12:12:30.892045Z",
          "total": 6.0,
          "email": "bettercall@saul.com",
          "name": "Saul Goodman",
          "items": [
            {
              "id": 61,
              "created_at": "2024-12-20T12:12:29.068419Z",
              "updated_at": "2024-12-20T12:12:29.068433Z",
              "order_id": 4,
              "item_id": 42,
              "amount": 15.0,
              "canvas_root_account_uuid": "39WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
              "discounted_amount": 6.0,
              "quantity": 3,
              "unit_price": 5.0
            }
          ]
        },
        "product": {
          "id": 42,
          "visibility": "listed",
          "enrollment_open": true,
          "title": "Paid program",
          "enrollment_fee": 5,
          "account_id": 38,
          "type": "Program",
          "canvas_root_account_uuid": "39WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
          "waitlist": false,
          "limited": false,
          "started": false,
          "program": true,
          "course": false,
          "ended": false
        },
        "bulk_invitations": [
          {
            "order_item_id": 61,
            "invitation_id": 4,
            "status": "created"
          },
          {
            "order_item_id": 61,
            "invitation_id": 5,
            "status": "created"
          },
          {
            "order_item_id": 61,
            "invitation_id": 6,
            "status": "created"
          }
        ]
      }
    }
  ]
}

Catalogs

Getting a specific catalog

Endpoint

GET https://www.my-catalog.edu/api/v1/catalogs/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/catalogs/53

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this catalog. Integer
created_at The creation date for the catalog. Datetime
updated_at The last time the catalog was updated. Datetime
name The name of the catalog. String
canvas_domain Domain for the corresponding canvas account. String
canvas_id Id for the corresponding canvas account. String
logo URL for the catalog logo. String
locale Three character locale for the catalog. String
url Url for the catalog String
user_defined_fields An array of serialized user defined field records provided to the catalog either through direct assignment or inheritance. Array
user_defined_field[name] Name of the user defined field String
user_defined_field[label] Label that will be shown with the field String
user_defined_field[field_type] HTML input type of the field String
user_defined_field[required] Indicates if the custom field is required Boolean
parent[id] The id of the parent catalog Integer
parent[name] The name of the parent catalog Integer
settings[privacy_policy_url] Url of the privacy policy for this catalog. String
settings[terms_url] Url of the terms used for this catalog. String
settings[currency] Three character currency code. String
settings[time_zone] Timezone configured for this catalog. String
settings[country] Two character country code. String
settings[email_from_name] Name that appears as the sender in emails. String
settings[allow_user_registration] Indicates if new users allowed to enroll classes. Boolean
settings[title_tag] Used for custom titles in HTML. String
settings[meta_description] Used to a meta tag description in HTML. String
settings[custom_head_content] Used to add custom head content to HTML. String
settings[custom_body_content] Used to add custom body content to HTML. String
settings[show_listings_in_parent] Indicates if this catalogs listings will show in a parent catalog. Boolean
settings[skus_enabled] Indicates if the course displays the sku field. Boolean

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: MqO+P4I4znH7ePXKklCJvYTsK3R443wROjW+/BkVWj106yKQjcHyIdYTVC8BrAvxyFWZy2VXUDXtu99gUdz8Rw==
ETag: W/"b023e0d589a77f9aa5976da654ad1ccd"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=M3cyZ2lxZTR4WW1jRkNxL3NrSVpodTdnSS9GMDJwcTliNzFMb3FBblN0OXYvTmFRbVdxWUk1Tkt0SXRJcVdZazVTeUE5N2JWMEpydHR0NDF2dHZOTWJWVEt3MGE2OEFRQ0ZrZFVZdmc0RUFYUytBc2J6amM1UkdudEhjcWJoYzNPRC83OTZ2MVFEeDNyTGxBYnJHUUg3SS96WXdZNnNINjJMcWo5WTJHQ0hCelJuNTVCKzVreC9kMFFESVdJK0grLS1QQjRxOHZzdnpGSVArNkxLMWdPNHRnPT0%3D--fec8164d041034d0fc68c803f0fd7a5db3a1e99c; path=/; HttpOnly
X-Request-Id: 5e854e52-84f3-4721-a7b3-0534aef847a7
X-Runtime: 0.033749
Content-Length: 2347

Body

{
  "account": {
    "id": 53,
    "name": "Domain Account 58",
    "parent": null,
    "created_at": "2025/01/06 14:09:58 +0000",
    "updated_at": "2025/01/06 14:09:58 +0000",
    "canvas_domain": "www.canvas-domain-58.com",
    "canvas_id": 58,
    "settings": {
      "privacy_policy_url": "https://www.instructure.com/policies/privacy/",
      "terms_url": "https://www.instructure.com/policies/acceptable-use",
      "currency": "USD",
      "supported_payment_types": "standard",
      "time_zone": null,
      "country": "US",
      "measurement": "credit",
      "email_from_name": "Canvas Catalog",
      "email_from_address": "notifications@instructure.com",
      "allow_user_registration": true,
      "title_tag": null,
      "meta_description": null,
      "custom_head_content": null,
      "custom_body_content": null,
      "show_listings_in_parent": true,
      "order_id_prefix": null,
      "inherit_categories": false,
      "inherit_user_defined_fields": false,
      "beta_canvas_domain": null,
      "skus_enabled": false,
      "canvas_enrollment_events": false,
      "include_noncatalog_courses_in_dashboard": true,
      "external_idp_logout_workflow": false,
      "private_catalog": false,
      "bulk_purchase_disabled": false,
      "enroll_button_behavior": "cart",
      "shopping_cart_enabled": true,
      "external_registration_url": null,
      "external_registration_public_key": null,
      "redirect_external_registration_condition": "authenticated",
      "include_captcha": false,
      "user_registration_domain_restriction_type": "inherit",
      "user_registration_domain_deny_list": "",
      "user_registration_domain_allow_list": "",
      "frame_ancestors": "",
      "email_reply_to": "",
      "has_sso_warning": false,
      "measurement_id": null,
      "redirect_non_admins_to_root_url": false,
      "canvas_feature_send_usage_metrics": false,
      "disable_passive_login": false,
      "new_storefront": false,
      "tags_permission_default_value": true,
      "cross_listing_permission_default_value": false,
      "inherit_storefront_theme": false,
      "canvas_authentication_provider_id": "CANVAS_FIRST",
      "udf_collection_level": "registration",
      "disable_drop_course_button": false,
      "google_tag_manager_id": null,
      "linkedin_partner_id": null,
      "enable_credentials": false,
      "enable_pathways": false,
      "hide_missing_pathway": false,
      "storefront_product_recommendation_behavior": "popular",
      "storefront_product_recommendation_count": 4,
      "enable_recommendations": false,
      "hide_self_paced_label": false
    },
    "user_defined_fields": [

    ],
    "logo": "https://test-bucket.s3.amazonaws.com/test/logos/083cc666bb09d581fc3d7f1816b6a0e332e84b70.jpeg",
    "locale": "en",
    "url": "https://www.my-catalog.edu",
    "measurement": "credit",
    "storefront_theme_id": null
  }
}

Listing catalogs

Endpoint

GET https://www.my-catalog.edu/api/v1/catalogs

Request

Route

GET https://www.my-catalog.edu/api/v1/catalogs

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this catalog. Integer
created_at The creation date for the catalog. Datetime
updated_at The last time the catalog was updated. Datetime
name The name of the catalog. String
canvas_domain Domain for the corresponding canvas account. String
canvas_id Id for the corresponding canvas account. String
logo URL for the catalog logo. String
locale Three character locale for the catalog. String
url Url for the catalog String
user_defined_fields An array of serialized user defined field records provided to the catalog either through direct assignment or inheritance. Array
user_defined_field[name] Name of the user defined field String
user_defined_field[label] Label that will be shown with the field String
user_defined_field[field_type] HTML input type of the field String
user_defined_field[required] Indicates if the custom field is required Boolean
parent[id] The id of the parent catalog Integer
parent[name] The name of the parent catalog Integer
settings[privacy_policy_url] Url of the privacy policy for this catalog. String
settings[terms_url] Url of the terms used for this catalog. String
settings[currency] Three character currency code. String
settings[time_zone] Timezone configured for this catalog. String
settings[country] Two character country code. String
settings[email_from_name] Name that appears as the sender in emails. String
settings[allow_user_registration] Indicates if new users allowed to enroll classes. Boolean
settings[title_tag] Used for custom titles in HTML. String
settings[meta_description] Used to a meta tag description in HTML. String
settings[custom_head_content] Used to add custom head content to HTML. String
settings[custom_body_content] Used to add custom body content to HTML. String
settings[show_listings_in_parent] Indicates if this catalogs listings will show in a parent catalog. Boolean
settings[skus_enabled] Indicates if the course displays the sku field. Boolean

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: lBldAJBo/xJu0p3l+APfmarcxm0NMg4raRIKXqmLBLa3Qup/FymfYWdhL7/kGzA/0Jch7CWP0lE0uWkJ5Yyo4w==
ETag: W/"8f72c4537d2a7a647c16014bf72c3d12"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=ZkxTUTdzT2JJQ2NDbnVDeFJBdVpqTWYvTHR2SEpyNU4vU3U3c1FYWDlhRDM0VGI1dFhWSTJnRDh6UC9QR1QxSTB0bkZaMUl4MmRJZDcyYmluK1k4OVIvQ05mbGFnMDg3emEwYVpuekxHeXJ3am45OXJBWkpJeGhnY3RxMHB5c1NCWWxpYUVpSXdTT1o5L29WV1dIZXNKUG1ZTDdzU0ZHOXFXU1I1bVNXOE1DM3QydjZqU2NiTU1odzJHYjZMQUhJLS0vSVNNTkhpa1ROOWZxbGpCbHBqK1R3PT0%3D--79135e3374b9a7e8e5749753d95e679a6ff83b49; path=/; HttpOnly
X-Request-Id: 62482862-9ac3-46f9-b7d6-58eef91c82e5
X-Runtime: 0.029238
Content-Length: 3005

Body

{
  "catalogs": [
    {
      "id": 52,
      "name": "Domain Account 53",
      "parent": null,
      "created_at": "2025/01/06 14:09:58 +0000",
      "updated_at": "2025/01/06 14:09:58 +0000",
      "canvas_domain": "www.canvas-domain-53.com",
      "canvas_id": 53,
      "settings": {
        "privacy_policy_url": "https://www.instructure.com/policies/privacy/",
        "terms_url": "https://www.instructure.com/policies/acceptable-use",
        "currency": "USD",
        "supported_payment_types": "standard",
        "time_zone": null,
        "country": "US",
        "measurement": "credit",
        "email_from_name": "Canvas Catalog",
        "email_from_address": "notifications@instructure.com",
        "allow_user_registration": true,
        "title_tag": null,
        "meta_description": null,
        "custom_head_content": null,
        "custom_body_content": null,
        "show_listings_in_parent": true,
        "order_id_prefix": null,
        "inherit_categories": false,
        "inherit_user_defined_fields": false,
        "beta_canvas_domain": null,
        "skus_enabled": false,
        "canvas_enrollment_events": false,
        "include_noncatalog_courses_in_dashboard": true,
        "external_idp_logout_workflow": false,
        "private_catalog": false,
        "bulk_purchase_disabled": false,
        "enroll_button_behavior": "cart",
        "shopping_cart_enabled": true,
        "external_registration_url": null,
        "external_registration_public_key": null,
        "redirect_external_registration_condition": "authenticated",
        "include_captcha": false,
        "user_registration_domain_restriction_type": "inherit",
        "user_registration_domain_deny_list": "",
        "user_registration_domain_allow_list": "",
        "frame_ancestors": "",
        "email_reply_to": "",
        "has_sso_warning": false,
        "measurement_id": null,
        "redirect_non_admins_to_root_url": false,
        "canvas_feature_send_usage_metrics": false,
        "disable_passive_login": false,
        "new_storefront": false,
        "tags_permission_default_value": true,
        "cross_listing_permission_default_value": false,
        "inherit_storefront_theme": false,
        "canvas_authentication_provider_id": "CANVAS_FIRST",
        "udf_collection_level": "registration",
        "disable_drop_course_button": false,
        "google_tag_manager_id": null,
        "linkedin_partner_id": null,
        "enable_credentials": false,
        "enable_pathways": false,
        "hide_missing_pathway": false,
        "storefront_product_recommendation_behavior": "popular",
        "storefront_product_recommendation_count": 4,
        "enable_recommendations": false,
        "hide_self_paced_label": false
      },
      "user_defined_fields": [
        {
          "list_order": 0,
          "name": "favorite_color",
          "label": "Favorite Color",
          "field_type": "text",
          "required": false,
          "required_message": "Favorite Color is required",
          "metadata": {
          }
        },
        {
          "list_order": 1,
          "name": "code_of_conduct",
          "label": "Code of Conduct",
          "field_type": "checkbox",
          "required": true,
          "required_message": "You must accept the Code of Conduct.",
          "metadata": {
          }
        },
        {
          "list_order": 2,
          "name": "age",
          "label": "Age",
          "field_type": "text",
          "required": true,
          "required_message": "You must provide an Age.",
          "metadata": {
          }
        },
        {
          "list_order": 3,
          "name": "yes_no",
          "label": "Yes or No",
          "field_type": "select",
          "required": false,
          "required_message": "Yes or No is required",
          "metadata": {
            "options": [
              "Yes",
              "No"
            ]
          }
        }
      ],
      "logo": "https://test-bucket.s3.amazonaws.com/test/logos/014dba6df13c5d96e123834252d6cfe1021b184f.jpeg",
      "locale": "en",
      "url": "https://www.my-catalog.edu",
      "measurement": "credit",
      "storefront_theme_id": null
    }
  ]
}

Certificates

Creating a certificate

Endpoint

POST https://www.my-catalog.edu/api/v1/certificates

Parameters

Name Description Type
certificate[listing_id] required Id of the Listing Integer
certificate[name] required Name of the Certificate String
certificate[active] State of the Certificate, defaults to true Boolean
certificate[template] required Template for Certificate contents String
certificate[pdf_settings][orientation] 'Landscape' or 'Portrait' mode for PDF. Defaults to Landscape. String
days_to_expire Days until the certificate expires after it is awarded. Defaults to null. Must not be present when expires_at is present. Integer
expires_at Date of certificate expiration. Defaults to null. Must not be present when days_to_expire is present. Datetime

Request

Route

POST https://www.my-catalog.edu/api/v1/certificates

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "certificate": {
    "listing_id": 26,
    "name": "API Name",
    "active": true,
    "template": "<H1>This is a template</h1>",
    "pdf_settings": {
      "orientation": "Landscape"
    }
  }
}

Response

Response Fields

Name Description Type
certificate[id] Certificate ID Integer
certificate[listing_id] Corresponding listing ID Integer
certificate[name] Certificate name String
certificate[active] Whether the certificate is enabled String
certificate[template] HTML template used to generate issued certificates String
certificate[pdf_settings] An object containing extra params for PDF generation Object
certificate[created_at] The creation date of the certificate Datetime
certificate[updated_at] The last time the certificate was updated Datetime
certificate[days_to_expire] Number of days for which issued certificates remain valide Integer
certificate[expires_at] A fixed datetime when issued certificates expire Datetime

Status

201

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: 0zJ68zpNVNBWX62BtGYRoe2RljbFnaIsTp74JLGn+T6zKKQTNbLLee5umneu/c5k3XnhUrI8nv4JGyTJzd87vw==
ETag: W/"ea171506003a6155b91faf0adf0b6471"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=Qzk0dU5VaExHeG9venBna3NTRmV6ZjVBSnE5cHdIVGNqZFZEUGNOQml6NE5HdVZzUGRjc3cwTmNMc3VmRFpQT3RCanRsTTBrLzlGK0xnQ2dnWUtEMVFyNmEvNGgvZUdGcWFVdm5mQkxpdURHekdubnhoSHNuSXVNc1psZyszUUZySU5wNlhxeThlS1lIQWpFT2JFQ0RxWmlwMVFGS1dNMmlJMDZxMHVPY01GNDhSM0ZtelRveGhYbEdYZmh6bFFxLS1pUXNZK3E4eTZNTU93TjNXL216KzJBPT0%3D--3dbd0b44d2805d14fc3153f693de52e500524071; path=/; HttpOnly
X-Request-Id: cfbce34c-ea08-4fe8-bfbe-5bebf5a4c3cb
X-Runtime: 0.289520
Content-Length: 298

Body

{
  "certificate": {
    "id": 2,
    "listing_id": 26,
    "name": "API Name",
    "active": true,
    "template": "<H1>This is a template</h1>",
    "pdf_settings": {
      "orientation": "Landscape"
    },
    "created_at": "2025/01/06 14:09:56 +0000",
    "updated_at": "2025/01/06 14:09:56 +0000",
    "days_to_expire": null,
    "expires_at": null
  }
}

Deleting a certificate

Endpoint

DELETE https://www.my-catalog.edu/api/v1/certificates

Parameters

Name Description Type
certificate[listing_id] required Id of the Listing Integer
nullify_requirements_completed_at Should nullify the requirements_completed_at for the enrollments, defaults to false Boolean

Request

Route

DELETE https://www.my-catalog.edu/api/v1/certificates

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "certificate": {
    "listing_id": 28
  },
  "nullify_requirements_completed_at": true
}

Response

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: 3CSjjCvLWc0RhwXXKOXyEtpI0hLoCPBOrneIPDGlCQx2PLk8Y2gBKVBKPsmuY8/JCBN/5+T1zcbThL7MOjH+Fg==
Cache-Control: no-cache
Set-Cookie: _gallery_session=WURldm5QQTlvNFlHU3BlZm1GVmVvWUFXSzFYcXFCckgwNkhOK2t6V1gxM09uTFI0MDV6andKaERNUTNxbXUySmZvK2JCSUYxYm9HTkl6SUk0TUlxUjg3NDNBZEVDdzMxRkk2SjdpY1RsTllySjBVbmJxbWp4WXRDNnRUcEg3R3p4aGpmSjZZeFRaRzM5Y1RBUjU2cGdFWGZ5aGZxTmJPbTJkZEw2SHJPbG4wcitFcENGR0VBMGRBNXdtcHFrN0VKLS1GM2JjUktYVDBITzJMYlJyZE1BVk5nPT0%3D--f581f5f46285f003df05ca9a95b6a7cbce4cc000; path=/; HttpOnly
X-Request-Id: 8c8bd7bb-2215-432d-aa00-0e5080b195f8
X-Runtime: 0.030918

Getting a listing certificate

Endpoint

GET https://www.my-catalog.edu/api/v1/certificates

Parameters

Name Description Type
certificate[listing_id] required Id of the Listing Integer

Request

Route

GET https://www.my-catalog.edu/api/v1/certificates?certificate[listing_id]=27

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Query Parameters

certificate={"listing_id"=>"27"}

Response

Response Fields

Name Description Type
certificate[id] Certificate ID Integer
certificate[listing_id] Corresponding listing ID Integer
certificate[name] Certificate name String
certificate[active] Whether the certificate is enabled String
certificate[template] HTML template used to generate issued certificates String
certificate[pdf_settings] An object containing extra params for PDF generation Object
certificate[created_at] The creation date of the certificate Datetime
certificate[updated_at] The last time the certificate was updated Datetime
certificate[days_to_expire] Number of days for which issued certificates remain valide Integer
certificate[expires_at] A fixed datetime when issued certificates expire Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: NtuAkeJxgh12SHmEbc8RupKDLKdw3h7fuJ4chOrrehAqN/MIqxseH7kpCPqocOnCV8L0Vfq4f9FVzzg5+dEYkg==
ETag: W/"2b8e7d8cd0baafce38eeec13caf99fb5"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=M1Y3b1l5ZkpoTE5vZnQ1ZHBpSElYd2RrZE5RUzdQbVZkUkMyYWMxUUFHNWVWUDlFNThKTWVLVHA1QnF3d1NQdXVYTGxzU3ZJUHRSVFFPM3ZDcFRqcSt3SjNBVXRTUFUzb3A1VXVxVTFtNEZTYlpXclZUT0I1d1JhQUx1cGJySXh0Vk9oQU50Z1BuQW1YdUtUME5mZi9Eb1N0YU9HZzRoVHNoM09lK1p4OWwxQkNIWG9vOWIyN1paRjNFbXZacE5OLS0yWHVwTURGTlJha0F1cDdyYklOV1pnPT0%3D--616df779b25f819df2451744ab7a03a6ae5da208; path=/; HttpOnly
X-Request-Id: 76f1ea4e-d5af-40f7-9f35-425a86b22439
X-Runtime: 0.033268
Content-Length: 268

Body

{
  "certificate": {
    "id": 3,
    "listing_id": 27,
    "name": "Certificate of Training",
    "active": true,
    "template": "Congrats, {{student_name}}!",
    "pdf_settings": {
    },
    "created_at": "2025/01/06 14:09:56 +0000",
    "updated_at": "2025/01/06 14:09:56 +0000",
    "days_to_expire": null,
    "expires_at": null
  }
}

Request

Route

GET https://www.my-catalog.edu/api/v1/certificates?certificate[listing_id]=27

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: _gallery_session=M1Y3b1l5ZkpoTE5vZnQ1ZHBpSElYd2RrZE5RUzdQbVZkUkMyYWMxUUFHNWVWUDlFNThKTWVLVHA1QnF3d1NQdXVYTGxzU3ZJUHRSVFFPM3ZDcFRqcSt3SjNBVXRTUFUzb3A1VXVxVTFtNEZTYlpXclZUT0I1d1JhQUx1cGJySXh0Vk9oQU50Z1BuQW1YdUtUME5mZi9Eb1N0YU9HZzRoVHNoM09lK1p4OWwxQkNIWG9vOWIyN1paRjNFbXZacE5OLS0yWHVwTURGTlJha0F1cDdyYklOV1pnPT0%3D--616df779b25f819df2451744ab7a03a6ae5da208

Query Parameters

certificate={"listing_id"=>"27"}

Response

Response Fields

Name Description Type
certificate[id] Certificate ID Integer
certificate[listing_id] Corresponding listing ID Integer
certificate[name] Certificate name String
certificate[active] Whether the certificate is enabled String
certificate[template] HTML template used to generate issued certificates String
certificate[pdf_settings] An object containing extra params for PDF generation Object
certificate[created_at] The creation date of the certificate Datetime
certificate[updated_at] The last time the certificate was updated Datetime
certificate[days_to_expire] Number of days for which issued certificates remain valide Integer
certificate[expires_at] A fixed datetime when issued certificates expire Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: VCUUxFL+oyMlYcNm1QNds4OI4zMtqMBvO+rJIwTWtJJIyWddG5Q/IeoAshgQvKXLRsk7wafOoWHWu+2eF+zWEA==
ETag: W/"2b8e7d8cd0baafce38eeec13caf99fb5"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=MlErWlpjQmM0VHpxMEZ2aWRMTmFCV3AraUJqek1BbU45aURMSTAra0lNLzNMcXg5V1ZOcERSNzZSdGV5OXo0dmlVeENVMUFJdklsY1BWVDBkcmlVRDZQZHpTaVJLb2JET0M4ek5DMXhDODg2MTFkNUlpMGRvUVBJcm1IYUxPL3Z4WmpZTFNZOTBUOXRUVlk0M0tUekNPYno0eE8rK29NUmJBTkRpeSt0RSttbXZOWCtUVnFnKzhVWFUrVnRvZGwwLS1ZWTRhMU1KcXExL1BzMUFWa2dGUDNnPT0%3D--9b311e3a172f6989497cb7f60ee61028cff3a39f; path=/; HttpOnly
X-Request-Id: b5aba459-3d1a-4092-8920-a7ff78b6883d
X-Runtime: 0.024774
Content-Length: 268

Body

{
  "certificate": {
    "id": 3,
    "listing_id": 27,
    "name": "Certificate of Training",
    "active": true,
    "template": "Congrats, {{student_name}}!",
    "pdf_settings": {
    },
    "created_at": "2025/01/06 14:09:56 +0000",
    "updated_at": "2025/01/06 14:09:56 +0000",
    "days_to_expire": null,
    "expires_at": null
  }
}

Revoking users certificate

Endpoint

PUT https://www.my-catalog.edu/api/v1/certificates/revoke_users_certificate

Parameters

Name Description Type
certificate[listing_id] required Id of the Listing Integer
certificate[canvas_user_ids] required List of Canvas User Id's Array

Request

Route

PUT https://www.my-catalog.edu/api/v1/certificates/revoke_users_certificate

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "certificate": {
    "listing_id": 25,
    "canvas_user_ids": [
      1
    ]
  }
}

Response

Response Fields

Name Description Type
revoked_certificates[canvas_user_id] Canvas User ID Integer
revoked_certificates[canvas_course_id] Canvas Course ID Integer
revoked_certificates[listing_id] Catalog Product Listing ID Integer

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: d34l09fGGyZGE7Horn1oxGO6p0XKdNBPC8ZmlZ1XJJJjGVOtWsQ2k+sEet336dLV+aAz1yXNJZ9H/g6LwRK8hg==
ETag: W/"275e27646eb1ad5e6ff67297c3625e2f"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=MnBsRmxoMTBPK3hxOUMwUUIvaWJpcEUrVWdWTUE1REY2Z01vSXJuUm9yQTBMbW1IV3pEcUswYWtMRlFtUWwzeTBYUTRHUFFldk1EcGZuVHVRUkdMVDFGWmlTVGVyUjE4V2tXcnk5T0FwdXlsK1lyU1dPdXdIeUJpMUZUMFhNVE55MEVkT2VWSmx0dVV2SnVuUU9tdy96M3F4U2VBRnVsNkFWcUIrMVJxb2dvODIvVStETzFNUVZaT1dIVlBnT1pELS1acTVEWGxiWW9DZTB1TUVPRzgxdVZBPT0%3D--3ab44bf5613a8634559add3ad6f8ff909c0298fd; path=/; HttpOnly
X-Request-Id: 0bc18053-48c7-4cef-9a38-0808169629f6
X-Runtime: 0.034300
Content-Length: 87

Body

{
  "revoked_certificates": [
    {
      "canvas_user_id": 1,
      "canvas_course_id": 1001,
      "listing_id": 25
    }
  ]
}

Completed certificates

Listing user's completions with a certificate

Endpoint

GET https://www.my-catalog.edu/api/v1/completed_certificates

Parameters

Name Description Type
user_id required Canvas Id of the user Integer
only_certificates Indicates if the courses without certificates should be included, default is to include all courses Boolean

Request

Route

GET https://www.my-catalog.edu/api/v1/completed_certificates?user_id=1&only_certificates=true

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Query Parameters

user_id=1
only_certificates=true

Response

Response Fields

Name Description Type
canvas_course_id Canvas Course ID Integer
catalog_title catalog course title String
canvas_course_name Canvas Course name String
certificate_url URL for Course Certificate String
canvas_course_workflow_state Canvas Course Workflow State String
completed_at Canvas Course Completion Date Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: iflWDwBczH5C5E4B/Ycm7oVcgTQRXmKa7H35CQI/+1LyClVxfd/649DSq3RQL1Rzf7fSiWC2Bf/rwpvTgnWqXA==
ETag: W/"938b5ae4b7560f5c22b120736bce08e5"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=d3JWVS84cmszNjQ4bllTMkpBTVpFRmFFNmRab1ZvOVE4WU8yekJOaTRTcGFJaDRkWDYzQmVxTEdkb2FlNlU2OVRvNE5XZzdWTVorRmo0cXNnb1lScTBycms2NVpFR0VXczdrZFNBUnFtQXprNTB2OWc3bGx1WDU5cWtRV3lSSU5JQUdsVXNJcHFlVWVxU3BKYXo5U2hhN2R1T01BVTNOOEJXNFFiaUVMK3NhNjA3RVl4L21iWGRUYTBZelRFcjdJLS15MnIrMHZUd3R2VkJyalNId2Ewd1N3PT0%3D--58096512f3e98ac33601a5c0d12bc2f4e0a7be83; path=/; HttpOnly
X-Request-Id: 6143b3f0-90fe-4037-9811-99c556cae953
X-Runtime: 0.047399
Content-Length: 262

Body

{
  "completed_certificates": [
    {
      "canvas_course_id": 23,
      "catalog_title": "Course 37",
      "canvas_course_name": "Course 37",
      "certificate_url": "https://www.domain-51.com/certificates/certificate-numero-1-5.pdf",
      "canvas_course_workflow_state": "available",
      "completed_at": null
    }
  ]
}

Courses

Creating a course

Endpoint

POST https://www.my-catalog.edu/api/v1/courses

Parameters

Name Description Type
course[title] required Listing title String
course[description] required Full listing description String
course[path] required Path to the listing. Used in URLs String
course[teaser] required A shorter description of the listing String
course[enrollment_open] Indicates if the listing is current accepting new students Boolean
course[enrollment_open_from] If specified, enrollment is open only from this date-time Datetime
course[enrollment_open_to] If specified, enrollment is open only to this date-time Datetime
course[visibility] Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
course[enrollment_cap] A limit for the total number of enrollments Integer
course[enrollment_fee] Enrollment fee Decimal
course[allowed_payment_types] Allowed payment methods Array
course[days_to_complete] The number of days a student has to complete the requirements Integer
course[account_id] The id of the account to associate the listing to. Can be an id of any subcatalog of the catalog making the API request. Defaults to the catalog making the API request. Integer
course[list_order] Order in which the listing is shown in the catalog Integer
course[waitlist] Waitlist enabled (defaults to false) Boolean
course[waitlist_cap] Wait List Limit for the total number of wait listed enrollments Integer
course[listing_image] URL or file upload for the image to be shown with this listing. String
course[tag_names] List of tags applied to this listing Array
course[show_free_banner] Show the 'FREE' mark on the card of the listing if free Boolean
course[associated_account_ids] Other account ids where this product should be listed Array
course[canvas_course_id] required Id of the related canvas course Integer
course[credits] Credit value of the course Decimal
sku Listing SKU for a course String

Request

Route

POST https://www.my-catalog.edu/api/v1/courses

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "course": {
    "title": "Course 1",
    "description": "This is a very important course.",
    "path": "course-1",
    "canvas_course_id": 10010010,
    "teaser": "This is an example teaser",
    "enrollment_open": true,
    "visibility": "listed",
    "enrollment_cap": 150,
    "waitlist": true,
    "waitlist_cap": 25,
    "enrollment_fee": 49.99,
    "days_to_complete": 45,
    "list_order": 123,
    "credits": 4,
    "sku": "abc1234",
    "tag_names": [
      "Tag",
      "Another Tag"
    ]
  }
}

Response

Response Fields

Name Description Type
id Identifier for this listing. Integer
visibility Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
enrollment_open Open for enrollment Boolean
enrollment_open_from If specified, enrollment is open only from this date-time Datetime
enrollment_open_to If specified, enrollment is open only to this date-time Datetime
enrollment_cap A limit for the total number of enrollments Integer
waitlist Waitlist enabled Boolean
waitlist_cap Wait List Limit for the total number of wait listed enrollments Integer
title Title of the listing String
enrollment_fee Enrollment fee Decimal
currency The three digit currency code associated to the enrollment fee String
listing_path Path to the listing. Used in URLs String
listing_url The URL of the listing String
short_description A short description for this listing String
list_order Order in which the listing is listed in the catalog Integer
tag_names List of tags applied to this listing Array
detail_code Payment detail code for a course (only if enabled with :payment_detail_code_enabled feature flag) String
show_free_banner Show the 'FREE' mark on the card of the listing if free Boolean
associated_account_ids Other account ids where this product should be listed Array
start_date When the Canvas course starts if specified Datetime
end_date When the Canvas course ends if specified Datetime
canvas_section_id The Canvas course's section's id Integer
catalog[id] Id for the catalog that owns this listing Integer
catalog[name] Name for the catalog that owns this listing String
created_at The creation date for the listing. Datetime
updated_at The last time the listing was updated. Datetime
canvas_course[id] Corresponding Canvas id Integer
credits Credit value of the course Decimal
sku Listing SKU for a course String

Status

201

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Location: https://www.my-catalog.edu/api/v1/courses/35
Content-Type: application/json; charset=utf-8
X-CSRF-Token: GDB2hU2OY9Yk578XR4FP/bHV2a0YCgUrziD2uRZ0ZbYcWSbpPcxvmlYQl7Xp85fY2txgxvJ7ojuv1HK55uGW5g==
ETag: W/"8f28ed2fef81f809ee88fad3a32e03f8"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=d0Nac00yalg5NUV6Z3Q5NHZ4UnBlYjFZc0JLWjFmMlErWk9UUlAyMjBqUFJZUEpCcStKd0JkVVlrMndOT1RWMGJZaWYwRGViem9Rc3I3K1R4dlAvZzNIeDdpRnRLTGpyU3FQeWQ1Z25kd0VXTEFmbUtoekpRaFZTbHJPd0VKR2pvL3RreThrdjJkRjVKSXpvU0YyOEk3WllhZTBQM1BYaU5mZ3YyR0dHdlFpdlZsN0hWbGVoR0hUUk50R2VxcE11LS1MOEd5N2hxY1VxSU9aNmd1clNCcERRPT0%3D--0b7ae0fcac9139c779639d5f49cfae1aeef38dec; path=/; HttpOnly
X-Request-Id: 0f05925a-1b51-4153-a788-6a8a0099d957
X-Runtime: 0.047569
Content-Length: 887

Body

{
  "course": {
    "id": 35,
    "visibility": "listed",
    "enrollment_open": true,
    "enrollment_open_from": null,
    "enrollment_open_to": null,
    "enrollment_cap": 150,
    "description": "This is a very important course.",
    "enrollment_fee": 49.99,
    "created_at": "2025/01/06 14:09:57 +0000",
    "credits": 4.0,
    "measurement": "credit",
    "updated_at": "2025/01/06 14:09:57 +0000",
    "short_description": "This is an example teaser",
    "listing_path": "course-1",
    "listing_image": null,
    "currency": "USD",
    "catalog": {
      "id": 33,
      "name": "Domain Account 34"
    },
    "type": "Course",
    "title": "Course 1",
    "list_order": 123,
    "waitlist": true,
    "waitlist_cap": 25,
    "sku": "abc1234",
    "show_free_banner": true,
    "image_alt_text": null,
    "allowed_payment_types": [
      "standard"
    ],
    "tag_names": [
      "Tag",
      "Another Tag"
    ],
    "listing_url": "http://www.my-catalog.edu/courses/course-1",
    "start_date": null,
    "end_date": null,
    "canvas_section_id": null,
    "associated_account_ids": [

    ],
    "canvas_course": {
      "id": 10010010
    }
  }
}

Deleting a specific course

Endpoint

DELETE https://www.my-catalog.edu/api/v1/courses/:id

Request

Route

DELETE https://www.my-catalog.edu/api/v1/courses/37

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Content-Type: application/x-www-form-urlencoded
Cookie: 

Response

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: vRGiBzZ3Z7/iIeA4NP7cwYdhe5TTHoqU4A3l0YGsN4Mlx9PfxiXzWBfK8Sva9X8qv9QK4L2kLmnRNkEy7uvzKw==
Cache-Control: no-cache
Set-Cookie: _gallery_session=eURldytSdjI4WGp2a2FqQUJaaWJSUWo1QkQzQTBKcUp2WnlVS0EzQ1k5WTdtbjhud2lUOXlaZ1VKUVlUMHh2MXhhSUdHWE1scU92SXFMSXBrSTl0MFU4ais5cm5ubVJiaDRURWFBdTFiYkdCQSsxK1MxckRjZURuVnNqam5TZE5ubVQ2VlQxL2txWGZaREJvaEhzVDhpblVwV3NoTDQxbnh4cHZSeUMrQ0g4b0JZUTZCRkUzWHcwc2p1TmdPcGorLS1sVVg5WDgxbU9tb2tyWDdtUTRtemd3PT0%3D--9e04cee4654f05cc8f0822ddedca7895b9dce484; path=/; HttpOnly
X-Request-Id: f966934a-0d53-4293-af37-f64c6d02c089
X-Runtime: 0.031382

Getting a specific course

Endpoint

GET https://www.my-catalog.edu/api/v1/courses/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/courses/38

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this listing. Integer
visibility Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
enrollment_open Open for enrollment Boolean
enrollment_open_from If specified, enrollment is open only from this date-time Datetime
enrollment_open_to If specified, enrollment is open only to this date-time Datetime
enrollment_cap A limit for the total number of enrollments Integer
waitlist Waitlist enabled Boolean
waitlist_cap Wait List Limit for the total number of wait listed enrollments Integer
title Title of the listing String
enrollment_fee Enrollment fee Decimal
currency The three digit currency code associated to the enrollment fee String
listing_path Path to the listing. Used in URLs String
listing_url The URL of the listing String
short_description A short description for this listing String
list_order Order in which the listing is listed in the catalog Integer
tag_names List of tags applied to this listing Array
detail_code Payment detail code for a course (only if enabled with :payment_detail_code_enabled feature flag) String
show_free_banner Show the 'FREE' mark on the card of the listing if free Boolean
associated_account_ids Other account ids where this product should be listed Array
start_date When the Canvas course starts if specified Datetime
end_date When the Canvas course ends if specified Datetime
canvas_section_id The Canvas course's section's id Integer
catalog[id] Id for the catalog that owns this listing Integer
catalog[name] Name for the catalog that owns this listing String
created_at The creation date for the listing. Datetime
updated_at The last time the listing was updated. Datetime
canvas_course[id] Corresponding Canvas id Integer
credits Credit value of the course Decimal
sku Listing SKU for a course String

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: q8rbV0yrBfc5raGkqEIvEmPhWgpSFEik2SqvkRgA0DcgIsW5PvOCNtNkcz9QUGBg0moHIqowfVHHjcZgYtm6aQ==
ETag: W/"d4be45acfe777af4dac7ce89872f56a6"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=MktLUDdDcG9CUGpRN2M2VDhQMThCTVZESUZJYmw0c0NnbVdYQWI2U09DUXBTcTNzWFg1SHBZbXlxa3JxeUlNdWthTitpWWJ4SDB0N1ZicXVsSExTRXRlbFRSTVVLRk1uNkZacElHWlE5UkZFSnRTVkVZNVNQbCtXRTc3SnRSOW9JMXB1Ri9EcWRiTnM3cnVGS1NrMDc0NEt5Q0FBOGVqWjdXbGVlRWsrUGZXS1BrcVAvUkp1bzJkRzYzOXJ2TGFSLS1hdDBTUDFVRFZKamZFTTBzNkRTTVdRPT0%3D--c5ba9d8976bc30087bba924c6a7da15a082f7004; path=/; HttpOnly
X-Request-Id: 7691f89f-115c-4f5a-babc-c2c26ce41f89
X-Runtime: 0.026989
Content-Length: 908

Body

{
  "course": {
    "id": 38,
    "visibility": "listed",
    "enrollment_open": true,
    "enrollment_open_from": null,
    "enrollment_open_to": null,
    "enrollment_cap": null,
    "description": "description_36",
    "enrollment_fee": 0.0,
    "created_at": "2025/01/06 14:09:58 +0000",
    "credits": 3.0,
    "measurement": "credit",
    "updated_at": "2025/01/06 14:09:58 +0000",
    "short_description": "teaser_36",
    "listing_path": "course-path-36",
    "listing_image": null,
    "currency": "USD",
    "catalog": {
      "id": 36,
      "name": "Domain Account 37"
    },
    "type": "Course",
    "title": "Course 36",
    "list_order": null,
    "waitlist": false,
    "waitlist_cap": null,
    "sku": "sku_22",
    "show_free_banner": true,
    "image_alt_text": null,
    "allowed_payment_types": [
      "standard"
    ],
    "tag_names": [
      "Another Tag",
      "Tag"
    ],
    "listing_url": "http://www.my-catalog.edu/courses/course-path-36",
    "start_date": "2024/12/30 14:09:58 +0000",
    "end_date": "2025/01/13 14:09:58 +0000",
    "canvas_section_id": null,
    "associated_account_ids": [

    ],
    "canvas_course": {
      "id": 22
    }
  }
}

Listing courses

Endpoint

GET https://www.my-catalog.edu/api/v1/courses

Request

Route

GET https://www.my-catalog.edu/api/v1/courses

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: W7DHonoGMyzvU6Z7qkCpc7N7112RMr50KaPyrZTcaNxm5Xa7Nab45u3lvYNNeCRN/M8dWpHi1EVZtWHWXDHnXw==
ETag: W/"58248862196f2db56fce200f036afb5f"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=ZnA0aGpsSTJJZzhzS1RnQjlaaU9xc1JXSy8vQlJPdkM5NDBzMGw0dHVWMktUWDE2aHNocmpPR3g1MnZIQmxCYjV5LzNRZjQyakVwNEVQd3VjYzNaclV2RlVrWHlaOGdBYXlMNy84YUNGT1p5bjcyWWRGSFFyNlFrQzQ3N2ZNZ0FTNkYzcmRnbmhRaityZzl0bjBvdm9ITjNOcm5HQUhCVGFoYVZ1a3ZVbFJpaUxyZGRMRmw2R2FUQ0ljbDNuNzFkLS15ckExVDdqanZVZ0ttMFFKTGxTYjdRPT0%3D--da11abb754cb99e824edd28634e4a5997c067fc5; path=/; HttpOnly
X-Request-Id: 55d0e162-9ab4-4230-9189-46d5f2bbfd70
X-Runtime: 0.027989
Content-Length: 911

Body

{
  "courses": [
    {
      "id": 36,
      "visibility": "listed",
      "enrollment_open": true,
      "enrollment_open_from": null,
      "enrollment_open_to": null,
      "enrollment_cap": null,
      "description": "description_34",
      "enrollment_fee": 0.0,
      "created_at": "2025/01/06 14:09:57 +0000",
      "credits": 3.0,
      "measurement": "credit",
      "updated_at": "2025/01/06 14:09:57 +0000",
      "short_description": "teaser_34",
      "listing_path": "course-path-34",
      "listing_image": null,
      "currency": "USD",
      "catalog": {
        "id": 34,
        "name": "Domain Account 35"
      },
      "type": "Course",
      "title": "Course 34",
      "list_order": null,
      "waitlist": false,
      "waitlist_cap": null,
      "sku": "sku_20",
      "show_free_banner": true,
      "image_alt_text": null,
      "allowed_payment_types": [
        "standard"
      ],
      "tag_names": [
        "Another Tag",
        "Tag"
      ],
      "listing_url": "http://www.my-catalog.edu/courses/course-path-34",
      "start_date": "2024/12/30 14:09:57 +0000",
      "end_date": "2025/01/13 14:09:57 +0000",
      "canvas_section_id": null,
      "associated_account_ids": [

      ],
      "canvas_course": {
        "id": 20
      }
    }
  ]
}

Updating a course

Endpoint

PUT https://www.my-catalog.edu/api/v1/courses/:id

Parameters

Name Description Type
course[title] Listing title String
course[description] Full listing description String
course[path] Path to the listing. Used in URLs String
course[teaser] A shorter description of the listing String
course[enrollment_open] Indicates if the listing is current accepting new students Boolean
course[enrollment_open_from] If specified, enrollment is open only from this date-time Datetime
course[enrollment_open_to] If specified, enrollment is open only to this date-time Datetime
course[visibility] Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
course[enrollment_cap] A limit for the total number of enrollments Integer
course[enrollment_fee] Enrollment fee Decimal
course[allowed_payment_types] Allowed payment methods Array
course[days_to_complete] The number of days a student has to complete the requirements Integer
course[account_id] The id of the account to associate the listing to. Can be an id of any subcatalog of the catalog making the API request. Defaults to the catalog making the API request. Integer
course[list_order] Order in which the listing is shown in the catalog Integer
course[waitlist] Waitlist enabled (defaults to false) Boolean
course[waitlist_cap] Wait List Limit for the total number of wait listed enrollments Integer
course[listing_image] URL or file upload for the image to be shown with this listing. String
course[tag_names] List of tags applied to this listing Array
course[show_free_banner] Show the 'FREE' mark on the card of the listing if free Boolean
course[associated_account_ids] Other account ids where this product should be listed Array
course[canvas_course_id] Id of the related canvas course Integer
course[credits] Credit value of the course Decimal
sku Listing SKU for a course String

Request

Route

PUT https://www.my-catalog.edu/api/v1/courses/34

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "course": {
    "title": "Course 1",
    "description": "This is a very important course.",
    "path": "course-1",
    "canvas_course_id": 10010010,
    "teaser": "This is an example teaser",
    "enrollment_open": true,
    "visibility": "listed",
    "enrollment_cap": 150,
    "waitlist": true,
    "waitlist_cap": 25,
    "enrollment_fee": 49.99,
    "days_to_complete": 45,
    "list_order": 123,
    "credits": 4,
    "sku": "abc1234",
    "tag_names": [
      "Tag",
      "Another Tag"
    ]
  }
}

Response

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: Io33CbTxpWWWMXW5fqC3l/i/g8Kn1Fke6HpL+6mg4GGFAhYlSJgrrlBp2EuQahfbkXe4BsujSyAgYM6KK7H1Ew==
Cache-Control: no-cache
Set-Cookie: _gallery_session=SWdNUGpCZkdUcWZ0dktQTmJ2Wk1SNkNKMzUyeGlHd1VidW9ZVmpkOFdNNFhSY2hkMUIwajYxbWJYbzhMSG9xMStVK2UwaC85NE5Rb1RTbHk0NHhDNVVXQk0vSTB5eXd3Ry81aTMwV2IwOTFpRStGbEs2Wm1jVEtiNDlKalF5SzMyVFZDWndhU1k1aS9VU1pEcEZjWjdCVTBvQ1VFcVZLS0lOYWY1aFRBQ3hXZWJNYXFPMnlrUjNqdHJUQjVJbGpWLS1IMkNRS2NuYmFsa043MVV0NVlwK2JnPT0%3D--d64f893663afe6fec70da00c51c34d7cf0faea66; path=/; HttpOnly
X-Request-Id: 1a082252-fee7-48bf-ac55-1c2b9173dce2
X-Runtime: 0.049483

Updating course sku

Endpoint

PUT https://www.my-catalog.edu/api/v1/courses/update_skus

Parameters

Name Description Type
attachment required CSV containing a Catalog Course ID and Catalog Course SKU header file

Request

Route

PUT https://www.my-catalog.edu/api/v1/courses/update_skus

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: multipart/form-data; boundary=----------XnJLe9ZIbbGUYtzPQJ16u1
Host: www.my-catalog.edu
Cookie: 

Body

------------XnJLe9ZIbbGUYtzPQJ16u1
content-disposition: form-data; name="attachment"; filename="missing_header1.csv"
content-type: text/plain
content-length: 69

[uploaded data]
------------XnJLe9ZIbbGUYtzPQJ16u1--

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: tl938D4fg8vtcJBFmeuAOAxFzplOY8dHPsRpfmYAQCgFz7lTcWDXptpQBiXMexrDChYkLGyicD9HRKfP7AmoKQ==
ETag: W/"7da1fe79d9fe0e15859ac5ff34481a8e"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=M1NsSFZmL2QzWTR3eEF3VHBURGJYa1ZhNFd1Zjh6Uyt4cHlVenNwSW1qaDVuR3NiYkxYSlFXVkIzUE8xakxHSUFkSGorS1MvZllOMnl1cVU4SnNvbUNmaWMzbyt0Z09sRG9qcVczOHFvbGVmeWVjQlgxU3NmTEIrZElGYWlwcjRON09FTjF3UGF6emtyQWhGakhXalkyQkJjSDIyU1VEb1gwVEZVOGNsTHBraUNrVCthTE53SXJCSFcxUVgySWVRLS1NSUIya09DUWFXVE5LYVBpMmVnSkZRPT0%3D--d4c88db10b1d7df71e4937d60fc7d66ab1030ccd; path=/; HttpOnly
X-Request-Id: f65d926d-74b2-41ab-848d-0cefc305a4fa
X-Runtime: 0.049291
Content-Length: 206

Body

{
  "progress": {
    "id": 1,
    "account_id": 32,
    "canvas_user_id": null,
    "completion_percent": null,
    "workflow_state": "queued",
    "payload": {
    },
    "created_at": "2025/01/06 14:09:57 +0000",
    "updated_at": "2025/01/06 14:09:57 +0000"
  }
}

Email domain set

Getting a specific email domain set

Endpoint

GET https://www.my-catalog.edu/api/v1/email_domain_sets/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/email_domain_sets/1

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
email_domain_set[id] Email Domain Set ID Integer
email_domain_set[name] Certificate name String
email_domain_set[email_domains] An an array of email domains Array
email_domain_set[account_id] The account ID of the email domain set Integer
email_domain_set[created_at] The creation date of the email domain set Datetime
email_domain_set[updated_at] The last time the email domain set was updated Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: ODgYQ3MIdKCxVBQEc7ceORqpYDiDnDOd1esXXsSseW35c+rXEA/y3fMK5N7gtvSQVDogUwjZOdqa2bpKja5iJw==
ETag: W/"67343003a6d3a763d58ae7006eb1ef17"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=OTdoSldZWmxzNU56bUI0NThidUNSQ25IRXZTUXlPWFRVQ0cvQ0dYV1NVaXhjcGIwc3ZwdllNSFJSZExZTFgxdmw3YUd1Vlh6ODVLWEVwSWlhQ1JEamI2OXA2VWYySmtrRXRralBjc2dkV2sxVDI1Tm1HOVVUVjhXWDBRMDV2Z2k2b2tpTTYzVmJkdVkwQnJpVFRCWTFRTnkxdXpTLzVuKzhHTzNpZ3ZFOFNrWlUra05lL2ZNdzJZTElOd2krNml4LS1VV2xOK0Qwc204Y25MTUdPM3VoV2hRPT0%3D--42c3a92c750f679ea81d7534d85bca3c8358dc75; path=/; HttpOnly
X-Request-Id: 15917a77-791c-4353-a49f-f66fe8d6a745
X-Runtime: 0.033303
Content-Length: 212

Body

{
  "id": 1,
  "name": "Example",
  "account_id": 42,
  "canvas_root_account_uuid": "43WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
  "created_at": "2025/01/06 14:09:58 +0000",
  "updated_at": "2025/01/06 14:09:58 +0000",
  "deleted_at": null
}

List promotions by email domain set

Endpoint

GET https://www.my-catalog.edu/api/v1/email_domain_sets/:id/promotions

Request

Route

GET https://www.my-catalog.edu/api/v1/email_domain_sets/3/promotions

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
promotion[id] Promotion ID Integer
promotion[account_id] Account ID Integer
promotion[amount] The number representing the discount amount. Integer
promotion[discount_type] The type of discount. String
promotion[code] The code used to apply the discount. String
promotion[name] The name of the promotion. String
promotion[description] The description of the promotion. String
promotion[active] Whether the promotion is active. Boolean
promotion[start_date] When the promotion starts. Datetime
promotion[end_date] When the promotion ends. Datetime
promotion[created_at] When the promotion was created. Datetime
promotion[updated_at] When the promotion was updated. Datetime
promotion[deleted_at] When the promotion was deleted. Datetime
promotion[usage_type] What the promotions usage type is. String
promotion[canvas_root_account_uuid] The unique canvas account ID. String
promotion[email_domain_set_id] The Email Domain Set ID the promotion is restricted to. Integer

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: TYiy3C8JuhO9iZ7BaNgSSgsDIaFj+gnXcueAgDDD0+f17ttWZX1k+6709rlSVQ9h6FePgIzd/KAy8Qaw4rwIlw==
ETag: W/"72ba39048646efe6f723f9f60a8ea1b4"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=aWZzY3JuN09sSmlOZHZzWHZXN1hHVFdaREY2dVN0WDdTZER3ZmFmZFYwaXBUb013REgzZGNsR1lEUkNQRElnQjlvcWJPUnU5a3dvelBZS1B0WFZ3aFlhK1ZBa2R4WDFPdnJXNGsrYkpBRmVSMTNub2g4Sk5vb3d5cWt6UGVwdERwalFMeWhqc1ZBSVBUR09xQXpZZjQ1ZUNTV0hrK2lOb3pGdDk1dDIwTk5ZZ2NjTGh3akVyckNzS1RobTNOTXlhLS1wNUpKdEoxQUJpWDZqMCsrSUUvejZBPT0%3D--7d6f1a7e2f32d8e9b35a82795ce0f2002fffef9b; path=/; HttpOnly
X-Request-Id: 70e01163-106b-4829-a058-83c5c2bed9ce
X-Runtime: 0.028932
Content-Length: 797

Body

{
  "promotions": [
    {
      "id": 5,
      "account_id": 47,
      "product_id": null,
      "product_title": null,
      "account_name": "Domain Account 48",
      "currency": "USD",
      "amount": "10.0",
      "discount_type": "flat",
      "code": "PROMO5",
      "name": "Product 5",
      "description": null,
      "active": false,
      "start_date": null,
      "end_date": null,
      "created_at": "2025/01/06 14:09:58 +0000",
      "updated_at": "2025/01/06 14:09:58 +0000",
      "deleted_at": null,
      "usage_type": "once-per-user",
      "canvas_root_account_uuid": "48WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
      "email_domain_set_id": 3,
      "email_domain_set_name": "Example",
      "email_domains": [
        {
          "id": 5,
          "domain": "example.com",
          "email_domain_set_id": 3,
          "canvas_root_account_uuid": "47WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
          "created_at": "2025/01/06 14:09:58 +0000",
          "updated_at": "2025/01/06 14:09:58 +0000",
          "deleted_at": null
        }
      ],
      "status": "inactive"
    }
  ]
}

Listing email domain sets

Endpoint

GET https://www.my-catalog.edu/api/v1/email_domain_sets

Parameters

Name Description Type
email_domain_set[search] A value to filter the Email Domain Sets by name String
email_domain_set[exact] A boolean to set whether the search should only include results that match exactly String

Request

Route

GET https://www.my-catalog.edu/api/v1/email_domain_sets

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: MDupkb7zfZAhVLHjrnBrASxUNdgrP8WBxIKidkdhKjQckl+vFz23h5o7UKJB877CogmgG1IgC/lK1PI56b6BEQ==
ETag: W/"a37bb8f9cfac493a7242961e282fc75a"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=aWI5bjFVT3k4RkE2SUR3ODBCbjVwL1J0djhtZHNtYU56QXY2WWxaMWFYTDFpSll3T2V5azVaUEFueFJHUHJqQ3ZwMUtMb3FTV1JNeTVzbjhqM0Ezd0dCOEcrRDhmdlNJQXNLcStjMDliNWRKSjIwS21OdVlZTlJReitUWWY3OVhjei9kdTR2cVBKVWNyN0xIVkt0OXhIakpOK0xKM1A5QllyUm1rUklVVEFoUXN4aVBySVhDdmc1RitBdmRZUHNzLS1sdDBUMmI3eWlHSzZTa2dYTmRXU3RnPT0%3D--587f41e8cb308b55382865ea6a52681fe8700733; path=/; HttpOnly
X-Request-Id: 426ea885-bd35-4443-b7c7-02d8a865f9bf
X-Runtime: 0.021930
Content-Length: 335

Body

{
  "email_domain_sets": [
    {
      "id": 4,
      "name": "Example",
      "account_id": 48,
      "email_domains": [
        {
          "id": 6,
          "domain": "example.com",
          "email_domain_set_id": 4,
          "canvas_root_account_uuid": "49WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
          "created_at": "2025/01/06 14:09:58 +0000",
          "updated_at": "2025/01/06 14:09:58 +0000",
          "deleted_at": null
        }
      ]
    }
  ],
  "meta": {
    "total_pages": 0
  }
}

Updating an email domain set

Endpoint

PUT https://www.my-catalog.edu/api/v1/email_domain_sets/:id

Parameters

Name Description Type
email_domain_set[name] The name of the Email Domain Set String
email_domain_set[email_domains_attributes] An array of email domains Array

Request

Route

PUT https://www.my-catalog.edu/api/v1/email_domain_sets/2

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "email_domain_set": {
    "name": "API Name",
    "email_domains_attributes": [
      {
        "domain": "example1.com"
      },
      {
        "domain": "example2.org"
      }
    ]
  }
}

Response

Response Fields

Name Description Type
email_domain_set[id] Email Domain Set ID Integer
email_domain_set[name] Certificate name String
email_domain_set[email_domains] An an array of email domains Array
email_domain_set[account_id] The account ID of the email domain set Integer
email_domain_set[created_at] The creation date of the email domain set Datetime
email_domain_set[updated_at] The last time the email domain set was updated Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: WX6PHjIliVFpKX2+mOjbXfLEo82CNxUFRhqUaWQGUaCNc9gFO5NmK9Ic5VbUG2riZWf5VNYrpG9WlbW5j/dL/w==
ETag: W/"e139ff1e1bfc2e415d508b433bfdad3d"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=SUxhcjlsZ1dvRDYrYWxvdy96VWw5S2w2Z1ZuRVVkR1Y4bVVJdmpwTVUzU2hCbXFDRHRTWS9UcnlNM2xQMThMRTJYRGVUYWVtYzQzNXBncGFEbGw0SVVoNWV5ejZZOWNQZVdQdGxsUFRLeTQrVnV5aGlyOGIrQWI2am9Mb2l2c1NsM0lXakZ2NVVTV003OWoyUWtQRzRYc283NzBYWWxoVzl3bkZGaGxZMkViYXhjRnhuSFdGc2pkM3RZcXMxQ1JQLS0zYmZRaGxCYVNSSDJQR284cWZSaXBRPT0%3D--a02c636549f7d50ecb17008b93a72baf69055737; path=/; HttpOnly
X-Request-Id: d9f7d21d-3776-4994-98fe-ecf5b715fac2
X-Runtime: 0.034522
Content-Length: 764

Body

{
  "email_domain_set": {
    "id": 2,
    "name": "API Name",
    "account_id": 44,
    "email_domains": [
      {
        "id": 3,
        "domain": "example1.com",
        "email_domain_set_id": 2,
        "canvas_root_account_uuid": "45WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
        "created_at": "2025/01/06 14:09:58 +0000",
        "updated_at": "2025/01/06 14:09:58 +0000",
        "deleted_at": null
      },
      {
        "id": 4,
        "domain": "example2.org",
        "email_domain_set_id": 2,
        "canvas_root_account_uuid": "45WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
        "created_at": "2025/01/06 14:09:58 +0000",
        "updated_at": "2025/01/06 14:09:58 +0000",
        "deleted_at": null
      },
      {
        "id": 2,
        "domain": "example.com",
        "email_domain_set_id": 2,
        "canvas_root_account_uuid": "45WLEJdzBmd8nsrZdf5jIATelBOYIMHeY6uuIAEmx",
        "created_at": "2025/01/06 14:09:58 +0000",
        "updated_at": "2025/01/06 14:09:58 +0000",
        "deleted_at": null
      }
    ]
  }
}

Enrollments

Creating an enrollment

Endpoint

POST https://www.my-catalog.edu/api/v1/enrollments

Parameters

Name Description Type
create_order Create an order record for this enrollment, defaults to true Boolean
send_email Send an enrollment email to the user, defaults to true Boolean
enrollment[listing_id] required Id of the Listing Integer
enrollment[canvas_user_id] required Id of the Canvas user Integer

Request

Route

POST https://www.my-catalog.edu/api/v1/enrollments

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "enrollment": {
    "listing_id": 22,
    "canvas_user_id": 1
  }
}

Response

Response Fields

Name Description Type
id Identifier for this enrollment Integer
user[id] Corresponding Canvas user id for this enrollment. Integer
listing[id] Identifier for the listing Integer
listing[title] The name of the listing String
listing[type] The type of listing (Course or Program) String
listing[canvas_course_id] Canvas course ID (nil for Program enrollments) String
enrolled_at The time of enrollment (UTC) Datetime
status Enrollment status (active, dropped or concluded) String

Status

201

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: qRi7uUsxACNYtL3hW0R7AgJZhDg4Sy63X4MFv18PzY2SOSbb2qJ10k7/eZKcFY+gs6O0RNpYelEig4oDnnBMuQ==
ETag: W/"b0ad4fc9315c8d145a0f35cc92194827"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=cmtQSnZ6SDBtVjRjdk11YndjSGVjZU4ybXgxQng3R3k3WldjdDBsQ2ZJckdFeW5rSzVxeFFDazJvemVTem8wOXNHQ1RyNmUwdWxvUCtaTnFVNVpITHVwT2hmRUUxZnI0bXRybWpwajRjRFcvOTFubUlva3NDaWYycXlNKzA4NGRGeTNVZzNYQW5iUk44d2VyYmFOdnZpbkFtMWgydlU4VkJhM3pLVEJ1Szc2N1I3L3JCL0dpRnIrL1JPVUljamNaLS1tRlZoakFpeXpsb3lVQmdFemh2L1dRPT0%3D--22319f700a223cef86652ed04b8aa7ce94fd1b1c; path=/; HttpOnly
X-Request-Id: 4472fb4b-2631-4b1f-85bd-490d2bd6ac9d
X-Runtime: 0.030278
Content-Length: 177

Body

{
  "enrollment": {
    "id": 2,
    "user": {
      "id": 1
    },
    "listing": {
      "id": 22,
      "title": "Course 21",
      "type": "Course",
      "canvas_course_id": 11
    },
    "enrolled_at": "2025/01/06 14:09:56 +0000",
    "status": "active"
  }
}

Deleting an enrollment

An additional request must be made to Canvas to delete the enrollment and remove it from the Catalog Student Dashboard

Endpoint

DELETE https://www.my-catalog.edu/api/v1/enrollments/:id

Request

Route

DELETE https://www.my-catalog.edu/api/v1/enrollments/1

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Content-Type: application/x-www-form-urlencoded
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this enrollment Integer
user[id] Corresponding Canvas user id for this enrollment. Integer
listing[id] Identifier for the listing Integer
listing[title] The name of the listing String
listing[type] The type of listing (Course or Program) String
listing[canvas_course_id] Canvas course ID (nil for Program enrollments) String
enrolled_at The time of enrollment (UTC) Datetime
status Enrollment status (active, dropped or concluded) String

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: Vd7oDFfxClb+YEw2Hc7wHebH5fg3Q8NGwgWnYjn6nrF0z7a00wHJ/qctLNZMmC4sZ9NJSubG0lKL3EigWbL9kw==
Cache-Control: no-cache
Set-Cookie: _gallery_session=eU5WN3N1WmN1c2N3anBtaTRZMmFUODlQOERyTXQ0aU9NYldkNVlrT2RrcVlxL3RGOExVZjczK1pKK1FEM0gvVC9QOTNPVlZkL29SemJlNURUeW5xT2FudUh3MEphMFA5NnhHK25jWlNkRWJlMENMdjVzKzJsWWpwRmtNbzdFck8rQ3Frd3dmcGM4RDExaUQvSnM0MlZrM3J1YkllcVd2MVBQdnFZUStqTm1Mc1BsWVhaK1dUbXY0L2pFYXprNUsrLS1CcjBSQUtzSnY0Mjc5azd2RW9kTmpRPT0%3D--337482d6e875c56b0882ca74df0e044357c2ae9e; path=/; HttpOnly
X-Request-Id: 357a5afe-c3ad-433f-8d26-a0f4b7e9edbb
X-Runtime: 0.026913

Getting a specific enrollment

Endpoint

GET https://www.my-catalog.edu/api/v1/enrollments/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/enrollments/4

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this enrollment Integer
user[id] Corresponding Canvas user id for this enrollment. Integer
listing[id] Identifier for the listing Integer
listing[title] The name of the listing String
listing[type] The type of listing (Course or Program) String
listing[canvas_course_id] Canvas course ID (nil for Program enrollments) String
enrolled_at The time of enrollment (UTC) Datetime
status Enrollment status (active, dropped or concluded) String

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: S6dO2f5oikqDU/FzaYmvuYvoM0RTZg9d2mznaVT665QIi5sAZsDh271ztA5EK9wRx7fTyDM9w3cIbCSNy1YU8w==
ETag: W/"a80d3a098a0136907a3ec1102f0c571b"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=N2hOaVI0ckozN1hZL0hveVdacFZRNnVnT1dub29DSzlyZU02N0Y2RXlXMzF3SXZVcmtiNjg5MHRadG5nOWdsRTJlanZQMmhLK3AvSm1uMlZjazl0TXhlRXcyREt1YUlldFJod1pxbktKRDdGUXFDbisrMjc1Uk53ZzJ2M2ZHK3VCL3VCNTlKL29kQVMrc1NhSllqaEh4Wi82TE92amk1RVFQaTllT3NkbzNHa21qOVUvOEthNTFCdUtiWmRKKytaLS1mWVZGeTg3N2wzQlFWTTlGV0YwTWFRPT0%3D--928084d3265b9568d88214a19146ee1e6362c75b; path=/; HttpOnly
X-Request-Id: 0ede415e-7453-4ee8-ba42-bfd8c2223898
X-Runtime: 0.024539
Content-Length: 177

Body

{
  "enrollment": {
    "id": 4,
    "user": {
      "id": 1
    },
    "listing": {
      "id": 24,
      "title": "Course 23",
      "type": "Course",
      "canvas_course_id": 13
    },
    "enrolled_at": "2025/01/06 14:09:56 +0000",
    "status": "active"
  }
}

Listing enrollments

Endpoint

GET https://www.my-catalog.edu/api/v1/enrollments

Parameters

Name Description Type
listing_id Only include enrollments for the specified listing Integer

Request

Route

GET https://www.my-catalog.edu/api/v1/enrollments

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: yknhrfrcMJ8jFeAlOsr/MVuVV+DAAy77cZX28RbRZUgkF6IguokkkrlfNiQ1gdEH9gMsJNqR1R18/CGPxWxvuw==
ETag: W/"1f40513a45de2f1810a13371313ec2f3"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=WVYxb0hmc3ZsQTc1L1hOQWJjVzZkd3IwU3lpcndLM1BOczRPMlVIbTRQNlRiM2pPTWJYY3FLa1FLbVk1TllCa3pLakphYTFxeG96ME5NcEJNVmxwbWNOZzhpUTVSY0dvR1VUWXpobzhubVhyWkhjR2QzbEcrWC9ISnNQNXBYQk9aNlZBTlRXTUh0U2pJRXVQK1ovTlo4aXVwaVFsWm9iQjc1ZDJuRXJVa1pVaHRjS1BMaW9FaU1VWWJ0Rk81NmFTLS1NZmRjWDVvWHR2bUdkdHR5dUdhdVB3PT0%3D--8e5cde64b37c083804addf02d7dc1e3c0d37311c; path=/; HttpOnly
X-Request-Id: 4c0d5761-6636-4427-9fcf-d96006365461
X-Runtime: 0.024600
Content-Length: 180

Body

{
  "enrollments": [
    {
      "id": 3,
      "user": {
        "id": 1
      },
      "listing": {
        "id": 23,
        "title": "Course 22",
        "type": "Course",
        "canvas_course_id": 12
      },
      "enrolled_at": "2025/01/06 14:09:56 +0000",
      "status": "active"
    }
  ]
}

Orders

Getting a specific order

Endpoint

GET https://www.my-catalog.edu/api/v1/orders/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/orders/2

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this order. Integer
full_id Full ID for this order, including prefix. String
catalog_id DEPRECATED: Use catalog['id'] instead. Integer
catalog[id] Identifier for the catalog the order is linked to Integer
catalog[name] Name of the catalog this order is linked to String
user[id] Canvas ID of the user who placed the order Integer
user[name] Name of the user who placed the order String
user[email] E-mail address of the user who placed the order String
listings Array of purchased listings (courses and programs). Fields below: Array
listing[id] Identifier for a listing purchased with this order Integer
listing[catalog_id] Catalog ID associated to this listing Integer
listing[canvas_course_id] Canvas course ID associated to this listing Integer|null
listing[title] The name of the listing String
listing[amount] Listing price at the time of purchase Decimal
listing[discounted_amount] Discounted price by promotions Decimal
promotions Array of promotions used. Fields below: Array
promotion[id] Identifier for a promotion used with this order Integer
promotion[listing_id] Identifier for the listing this promotion is used for Integer
promotion[code] Promo code used for this order String
promotion[amount] Discount amount Decimal
payments Array of payments. Fields below: Array
payment[reference_id] Identifier from the payment redirector String
payment[status] Status of the payment. Can be success, error, or pending. String
payment[amount] Amount of the payment Decimal
total Total cost charged to the user Decimal
currency Currency used for the transaction String
purchased_at Time the transaction was successfully completed. This field is nil for unsuccessful or unpaid orders. Datetime
created_at Time the order was initiated. Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: vWXMUcAjehmtQrDpmR/XT0B+KsJJaAQCrBIHzY8ma+vH/l6mMSRUS0UWGYaANX1ZeDa3B0NcNPF6riSwTpYa6A==
ETag: W/"41618bb870ee0ca5352ef019ff3c4c9d"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=a3hFbVhTNmFQYVoyZmcxV3BvSDZFTUlTOWZwMXE1MEdKd1BFWWtHWkFteHFHVkdDc2dRRmhoVFVvc2VrdFNQelIvQ3dMbVIwamxyWWFQZjhGYnB6YThqZXBwelowV3kwbkV1a052dU54QjByaG9ucFJTVGhwY1VYMCt6OU9zWkdzYVZMYTByZXpNZXdiM1FiSHRDNmRMc2l5ZlVlVDBBUUFONktiazk1dzJIalB3dm16dmpTR1poOWJLbXltdjZYLS1lU3I4SEpZZ0VvR1ZzdCtTNzJmVFZBPT0%3D--a7c93c0a32eb5bcfd6209afa707ea0efc2bb53bb; path=/; HttpOnly
X-Request-Id: b48cb40f-9ad2-4331-a145-9a0ccf89e8de
X-Runtime: 0.031518
Content-Length: 548

Body

{
  "order": {
    "id": 2,
    "full_id": "2",
    "catalog_id": 26,
    "catalog": {
      "id": 26,
      "name": "Domain Account 26"
    },
    "user": {
      "id": 1,
      "name": "Saul Goodman",
      "email": "bettercall@saul.com"
    },
    "listings": [
      {
        "id": 29,
        "canvas_course_id": 14,
        "title": "Course 28",
        "amount": "100.0",
        "discounted_amount": "90.0",
        "catalog_id": 26
      }
    ],
    "promotions": [
      {
        "id": 1,
        "listing_id": 29,
        "code": "PROMO1",
        "amount": "-10.0"
      }
    ],
    "payments": [
      {
        "reference_id": "123",
        "status": "success",
        "amount": "90.0"
      }
    ],
    "total": "90.0",
    "currency": "USD",
    "purchased_at": "2025/01/06 14:09:57 +0000",
    "created_at": "2025/01/06 14:09:57 +0000"
  }
}

Listing orders

Endpoint

GET https://www.my-catalog.edu/api/v1/orders

Parameters

Name Description Type
from Earliest date/time to return. Suggested format YYYY-MM-DDTHH:MM:SSZ, e.g. 2018-01-01T00:00:00Z. System time zone is UTC. DateTime
to Latest date/time to return. See 'from' above for format. DateTime
canvas_user_id Return only orders for the specified Canvas user ID Integer
completed When set, only return orders that were completed successfully Boolean

Request

Route

GET https://www.my-catalog.edu/api/v1/orders

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: yBRoPtUZDJS6EYg0kiJqmUpfVipGLkTyxiiW7bTqwLGNjjYZ0BjovQPIkz2uj1b0rwEESSaK5acOpERLh1LLbg==
ETag: W/"d768a1bcfe392e3e1b743bb43905337b"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=aXhQa1B2MnJncElkSFdhUi9uZ0lvNU5nVFpaOExXZjUrdmZKOFdpOXphVGh1MmJQeUYxTkxISU1HTnY3Z1A2Z21uSWgvdkhQakFYdkFhSmQ2ZisxR3Y5QXNNVktmdGlrcHIyZlY0TS9mQWIyK0UxTDN5YjFTdVZuUjhYRlhIUmhueG5ZTTA4MEl2anB4ZEU2U2thYkxWZXJpdVJ0Y05ZY1FLdk5VQTBIWEdFWC9ZMi9CY1V1MXA0aStvNFVMcHdWLS05RlZvajBwQStJaURoSlF1ZlYwTlVRPT0%3D--a18a17e2914aa20f6a051dd941f7efa3c457e9f7; path=/; HttpOnly
X-Request-Id: 5394038c-24fb-4985-a1c3-7e624ffcc1af
X-Runtime: 0.027519
Content-Length: 551

Body

{
  "orders": [
    {
      "id": 3,
      "full_id": "3",
      "catalog_id": 27,
      "catalog": {
        "id": 27,
        "name": "Domain Account 27"
      },
      "user": {
        "id": 1,
        "name": "Saul Goodman",
        "email": "bettercall@saul.com"
      },
      "listings": [
        {
          "id": 30,
          "canvas_course_id": 15,
          "title": "Course 29",
          "amount": "100.0",
          "discounted_amount": "90.0",
          "catalog_id": 27
        }
      ],
      "promotions": [
        {
          "id": 2,
          "listing_id": 30,
          "code": "PROMO2",
          "amount": "-10.0"
        }
      ],
      "payments": [
        {
          "reference_id": "123",
          "status": "success",
          "amount": "90.0"
        }
      ],
      "total": "90.0",
      "currency": "USD",
      "purchased_at": "2025/01/06 14:09:57 +0000",
      "created_at": "2025/01/06 14:09:57 +0000"
    }
  ]
}

Programs

Creating a program

Endpoint

POST https://www.my-catalog.edu/api/v1/programs

Parameters

Name Description Type
program[title] required Listing title String
program[description] required Full listing description String
program[path] required Path to the listing. Used in URLs String
program[teaser] required A shorter description of the listing String
program[enrollment_open] Indicates if the listing is current accepting new students Boolean
program[enrollment_open_from] If specified, enrollment is open only from this date-time Datetime
program[enrollment_open_to] If specified, enrollment is open only to this date-time Datetime
program[visibility] Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
program[enrollment_cap] A limit for the total number of enrollments Integer
program[enrollment_fee] Enrollment fee Decimal
program[allowed_payment_types] Allowed payment methods Array
program[days_to_complete] The number of days a student has to complete the requirements Integer
program[account_id] The id of the account to associate the listing to. Can be an id of any subcatalog of the catalog making the API request. Defaults to the catalog making the API request. Integer
program[list_order] Order in which the listing is shown in the catalog Integer
program[waitlist] Waitlist enabled (defaults to false) Boolean
program[waitlist_cap] Wait List Limit for the total number of wait listed enrollments Integer
program[listing_image] URL or file upload for the image to be shown with this listing. String
program[tag_names] List of tags applied to this listing Array
program[show_free_banner] Show the 'FREE' mark on the card of the listing if free Boolean
program[associated_account_ids] Other account ids where this product should be listed Array
program[requirement_ids] Ordered array of listing IDs that represent requirements for completing the program Array
program[sequential] Indicates if students are required to complete requirements in order Boolean

Request

Route

POST https://www.my-catalog.edu/api/v1/programs

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "program": {
    "title": "Program 1",
    "description": "This is a very awesome program.",
    "path": "program-1",
    "teaser": "This is an example teaser",
    "enrollment_open": true,
    "visibility": "listed",
    "enrollment_cap": 150,
    "waitlist": true,
    "waitlist_cap": 12,
    "enrollment_fee": 49.99,
    "days_to_complete": 45,
    "list_order": 123,
    "requirement_ids": [

    ],
    "sequential": true,
    "tag_names": [
      "Tag",
      "Another Tag"
    ]
  }
}

Response

Response Fields

Name Description Type
id Identifier for this listing. Integer
visibility Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
enrollment_open Open for enrollment Boolean
enrollment_open_from If specified, enrollment is open only from this date-time Datetime
enrollment_open_to If specified, enrollment is open only to this date-time Datetime
enrollment_cap A limit for the total number of enrollments Integer
waitlist Waitlist enabled Boolean
waitlist_cap Wait List Limit for the total number of wait listed enrollments Integer
title Title of the listing String
enrollment_fee Enrollment fee Decimal
currency The three digit currency code associated to the enrollment fee String
listing_path Path to the listing. Used in URLs String
listing_url The URL of the listing String
short_description A short description for this listing String
list_order Order in which the listing is listed in the catalog Integer
tag_names List of tags applied to this listing Array
detail_code Payment detail code for a course (only if enabled with :payment_detail_code_enabled feature flag) String
show_free_banner Show the 'FREE' mark on the card of the listing if free Boolean
associated_account_ids Other account ids where this product should be listed Array
start_date When the Canvas course starts if specified Datetime
end_date When the Canvas course ends if specified Datetime
canvas_section_id The Canvas course's section's id Integer
catalog[id] Id for the catalog that owns this listing Integer
catalog[name] Name for the catalog that owns this listing String
created_at The creation date for the listing. Datetime
updated_at The last time the listing was updated. Datetime
sequential Indicates if students are required to complete requirements in order Boolean
requirements A nested array of the programs requirements. This includes courses and subprograms which can be distinguished by the type key. Array
credits Cumulative credit value of the program's requirements Decimal

Status

201

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Location: https://www.my-catalog.edu/api/v1/programs/20
Content-Type: application/json; charset=utf-8
X-CSRF-Token: CDPWrcfqtdWLFb0PPd692xmSEgwbY/jZkLGg8FDiK52hdo6vXiAQaU+qmCKBmubSHkIvaSx6hTC1H/OFmnjqGw==
ETag: W/"033f2fdf65d14ff14e6e61f583948892"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=cUtXeDR5b2l1NFcyZWhNeXhNUzluSm1sbTd5Q0N1VnlwSFFVdGFkdWdZbnluTFVsN0dSSUozRS8veU1ham9wZHVRWEtpVkRiQ3pDM25VbldhWWRwWHVDL3lCS3pqRjEybWxzMVBpcFBTbUswbFE1MkVNa1ZyTEVwaS9JNjFYQmVaMmorYVhieUw0dEVLclFld0dKOFZPMThjRGZmSEduTUVXQjB6TFFpUUxKTVB2dHgraUpaNUpGRndqWjNWSmRpLS1kenhZS21vVllRZGVQcGYyaXZ3bWhnPT0%3D--f69c335b19a96e4cad1cbb8a311e7746696b1439; path=/; HttpOnly
X-Request-Id: 3edf384c-ba89-47ff-b960-b92427c4a92f
X-Runtime: 0.046808
Content-Length: 890

Body

{
  "program": {
    "id": 20,
    "visibility": "listed",
    "enrollment_open": true,
    "enrollment_open_from": null,
    "enrollment_open_to": null,
    "enrollment_cap": 150,
    "description": "This is a very awesome program.",
    "enrollment_fee": 49.99,
    "created_at": "2025/01/06 14:09:56 +0000",
    "credits": null,
    "measurement": "credit",
    "updated_at": "2025/01/06 14:09:56 +0000",
    "short_description": "This is an example teaser",
    "listing_path": "program-1",
    "listing_image": null,
    "currency": "USD",
    "catalog": {
      "id": 5,
      "name": "Domain Account 5"
    },
    "type": "Program",
    "title": "Program 1",
    "list_order": 123,
    "waitlist": true,
    "waitlist_cap": 12,
    "sku": null,
    "show_free_banner": true,
    "image_alt_text": null,
    "allowed_payment_types": [
      "standard"
    ],
    "tag_names": [
      "Tag",
      "Another Tag"
    ],
    "listing_url": "http://www.my-catalog.edu/programs/program-1",
    "start_date": null,
    "end_date": null,
    "canvas_section_id": null,
    "associated_account_ids": [

    ],
    "sequential": true,
    "requirements": [

    ]
  }
}

Deleting a specific program

Endpoint

DELETE https://www.my-catalog.edu/api/v1/programs/:id

Request

Route

DELETE https://www.my-catalog.edu/api/v1/programs/2

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Content-Type: application/x-www-form-urlencoded
Cookie: 

Response

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: uSNr/NjBNk9C8mpxNXTzIKVMI3nJHXGXEn+QRcw4CrruVH9jqD9jj06Xd9ZRJmUXmAYWmw+oZBFqZAdnBe+unQ==
Cache-Control: no-cache
Set-Cookie: _gallery_session=dWFYWTBDa2pmM0lMYm5SMjFZUGFhcWZaU2V1UWRPc3NQdEVoQmR6cFhvcjhWVE5PbTRkK0VtTDNXLzFRYlpVdWFmRzVSS2hURWtNU2FzM0pWV1R3MWRDK0ZMYlVzeUNDYnAyY3M1SnhyV0w2R0I4SURFbzU2TjNTTXJWSmpSWkNnTDZxY3dha0htMjY5YmJaS2dpYTF0TDZqc1BYeklRRVovdElzeGVYQWlBM1EyMDNOODh1VHNvQjdNbnlBRzFlLS13U3o2S253RFViWkU4clVWSTRMMzJ3PT0%3D--2e7f2a900fc9a2bbaadf6cbe384aca53932b1796; path=/; HttpOnly
X-Request-Id: cf9fe700-5e67-42ee-a3d7-8927366d1b4a
X-Runtime: 0.054542

Getting a specific program

Endpoint

GET https://www.my-catalog.edu/api/v1/programs/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/programs/14

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this listing. Integer
visibility Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
enrollment_open Open for enrollment Boolean
enrollment_open_from If specified, enrollment is open only from this date-time Datetime
enrollment_open_to If specified, enrollment is open only to this date-time Datetime
enrollment_cap A limit for the total number of enrollments Integer
waitlist Waitlist enabled Boolean
waitlist_cap Wait List Limit for the total number of wait listed enrollments Integer
title Title of the listing String
enrollment_fee Enrollment fee Decimal
currency The three digit currency code associated to the enrollment fee String
listing_path Path to the listing. Used in URLs String
listing_url The URL of the listing String
short_description A short description for this listing String
list_order Order in which the listing is listed in the catalog Integer
tag_names List of tags applied to this listing Array
detail_code Payment detail code for a course (only if enabled with :payment_detail_code_enabled feature flag) String
show_free_banner Show the 'FREE' mark on the card of the listing if free Boolean
associated_account_ids Other account ids where this product should be listed Array
start_date When the Canvas course starts if specified Datetime
end_date When the Canvas course ends if specified Datetime
canvas_section_id The Canvas course's section's id Integer
catalog[id] Id for the catalog that owns this listing Integer
catalog[name] Name for the catalog that owns this listing String
created_at The creation date for the listing. Datetime
updated_at The last time the listing was updated. Datetime
sequential Indicates if students are required to complete requirements in order Boolean
requirements A nested array of the programs requirements. This includes courses and subprograms which can be distinguished by the type key. Array
credits Cumulative credit value of the program's requirements Decimal

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: QDeTgE8CJ+NzI3zCLR5cp3lgJCMDsgWgXjb5sYDhZXc9CWgZ42P3HyeqofXkN02BiqhCQDAPSFhD78p0KNx9Yg==
ETag: W/"58fb9e7a3db6bdc3ba4778f5ca70314f"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=TUdRa0E5SjRYbkUxOS80QVBjM3RUU2RrL2UyTWdhL2tnR2dyRUM5MFdodkFKVkNKTktjZHM1dVZLSUVrTC9Ca0E0VWV1NTRUS3hHODFoakhZc2Fwbk1ySEdRY2NrbHlmcjJrdzFzOGJ1V3RWMml6azZQK09BVWN0eEFza2swTEg1Qit4OEljRUZSN0xJb1U4bmJDaVpxKzcwdTZaOVQwYks3RDdCSnhIT2RkQlpmNS9RbERVUGdPQkJDbmJQWGEwLS1xek0zQkl0dlo4NlZieXl4MmtJaE1nPT0%3D--98ba9371ce385e420c00a2dd0e50ca0c8415f966; path=/; HttpOnly
X-Request-Id: 81f870b1-4afc-415e-8304-8a324c22ecc4
X-Runtime: 0.056957
Content-Length: 5247

Body

{
  "program": {
    "id": 14,
    "visibility": "listed",
    "enrollment_open": true,
    "enrollment_open_from": null,
    "enrollment_open_to": null,
    "enrollment_cap": null,
    "description": "description_14",
    "enrollment_fee": 0.0,
    "created_at": "2025/01/06 14:09:55 +0000",
    "credits": 9.0,
    "measurement": "credit",
    "updated_at": "2025/01/06 14:09:55 +0000",
    "short_description": "teaser_14",
    "listing_path": "program-path-14",
    "listing_image": null,
    "currency": "USD",
    "catalog": {
      "id": 4,
      "name": "Domain Account 4"
    },
    "type": "Program",
    "title": "Program 14",
    "list_order": null,
    "waitlist": false,
    "waitlist_cap": null,
    "sku": null,
    "show_free_banner": true,
    "image_alt_text": null,
    "allowed_payment_types": [
      "standard"
    ],
    "tag_names": [
      "Another Tag",
      "Tag"
    ],
    "listing_url": "http://www.my-catalog.edu/programs/program-path-14",
    "start_date": "2024/12/30 14:09:55 +0000",
    "end_date": null,
    "canvas_section_id": null,
    "associated_account_ids": [

    ],
    "sequential": true,
    "requirements": [
      {
        "id": 15,
        "visibility": "listed",
        "enrollment_open": true,
        "enrollment_open_from": null,
        "enrollment_open_to": null,
        "enrollment_cap": null,
        "description": "description_15",
        "enrollment_fee": 0.0,
        "created_at": "2025/01/06 14:09:55 +0000",
        "credits": 3.0,
        "measurement": "credit",
        "updated_at": "2025/01/06 14:09:55 +0000",
        "short_description": "teaser_15",
        "listing_path": "program-path-15",
        "listing_image": null,
        "currency": "USD",
        "catalog": {
          "id": 4,
          "name": "Domain Account 4"
        },
        "type": "Program",
        "title": "Program 15",
        "list_order": null,
        "waitlist": false,
        "waitlist_cap": null,
        "sku": null,
        "show_free_banner": true,
        "image_alt_text": null,
        "allowed_payment_types": [
          "standard"
        ],
        "tag_names": [

        ],
        "listing_url": "http://www.my-catalog.edu/programs/program-path-15",
        "start_date": "2024/12/30 14:09:55 +0000",
        "end_date": null,
        "canvas_section_id": null,
        "associated_account_ids": [

        ],
        "sequential": true,
        "requirements": [
          {
            "id": 17,
            "visibility": "listed",
            "enrollment_open": true,
            "enrollment_open_from": null,
            "enrollment_open_to": null,
            "enrollment_cap": null,
            "description": "description_17",
            "enrollment_fee": 0.0,
            "created_at": "2025/01/06 14:09:55 +0000",
            "credits": 3.0,
            "measurement": "credit",
            "updated_at": "2025/01/06 14:09:55 +0000",
            "short_description": "teaser_17",
            "listing_path": "course-path-17",
            "listing_image": null,
            "currency": "USD",
            "catalog": {
              "id": 4,
              "name": "Domain Account 4"
            },
            "type": "Course",
            "title": "Course 17",
            "list_order": null,
            "waitlist": false,
            "waitlist_cap": null,
            "sku": "sku_7",
            "show_free_banner": true,
            "image_alt_text": null,
            "allowed_payment_types": [
              "standard"
            ],
            "tag_names": [

            ],
            "listing_url": "http://www.my-catalog.edu/courses/course-path-17",
            "start_date": "2024/12/30 14:09:55 +0000",
            "end_date": "2025/01/13 14:09:55 +0000",
            "canvas_section_id": null,
            "associated_account_ids": [

            ],
            "canvas_course": {
              "id": 7
            }
          }
        ]
      },
      {
        "id": 16,
        "visibility": "listed",
        "enrollment_open": true,
        "enrollment_open_from": null,
        "enrollment_open_to": null,
        "enrollment_cap": null,
        "description": "description_16",
        "enrollment_fee": 0.0,
        "created_at": "2025/01/06 14:09:55 +0000",
        "credits": 6.0,
        "measurement": "credit",
        "updated_at": "2025/01/06 14:09:55 +0000",
        "short_description": "teaser_16",
        "listing_path": "program-path-16",
        "listing_image": null,
        "currency": "USD",
        "catalog": {
          "id": 4,
          "name": "Domain Account 4"
        },
        "type": "Program",
        "title": "Program 16",
        "list_order": null,
        "waitlist": false,
        "waitlist_cap": null,
        "sku": null,
        "show_free_banner": true,
        "image_alt_text": null,
        "allowed_payment_types": [
          "standard"
        ],
        "tag_names": [

        ],
        "listing_url": "http://www.my-catalog.edu/programs/program-path-16",
        "start_date": "2024/12/30 14:09:55 +0000",
        "end_date": null,
        "canvas_section_id": null,
        "associated_account_ids": [

        ],
        "sequential": true,
        "requirements": [
          {
            "id": 18,
            "visibility": "listed",
            "enrollment_open": true,
            "enrollment_open_from": null,
            "enrollment_open_to": null,
            "enrollment_cap": null,
            "description": "description_18",
            "enrollment_fee": 0.0,
            "created_at": "2025/01/06 14:09:55 +0000",
            "credits": 3.0,
            "measurement": "credit",
            "updated_at": "2025/01/06 14:09:55 +0000",
            "short_description": "teaser_18",
            "listing_path": "course-path-18",
            "listing_image": null,
            "currency": "USD",
            "catalog": {
              "id": 4,
              "name": "Domain Account 4"
            },
            "type": "Course",
            "title": "Course 18",
            "list_order": null,
            "waitlist": false,
            "waitlist_cap": null,
            "sku": "sku_8",
            "show_free_banner": true,
            "image_alt_text": null,
            "allowed_payment_types": [
              "standard"
            ],
            "tag_names": [

            ],
            "listing_url": "http://www.my-catalog.edu/courses/course-path-18",
            "start_date": "2024/12/30 14:09:55 +0000",
            "end_date": "2025/01/13 14:09:55 +0000",
            "canvas_section_id": null,
            "associated_account_ids": [

            ],
            "canvas_course": {
              "id": 8
            }
          },
          {
            "id": 19,
            "visibility": "listed",
            "enrollment_open": true,
            "enrollment_open_from": null,
            "enrollment_open_to": null,
            "enrollment_cap": null,
            "description": "description_19",
            "enrollment_fee": 0.0,
            "created_at": "2025/01/06 14:09:55 +0000",
            "credits": 3.0,
            "measurement": "credit",
            "updated_at": "2025/01/06 14:09:55 +0000",
            "short_description": "teaser_19",
            "listing_path": "course-path-19",
            "listing_image": null,
            "currency": "USD",
            "catalog": {
              "id": 4,
              "name": "Domain Account 4"
            },
            "type": "Course",
            "title": "Course 19",
            "list_order": null,
            "waitlist": false,
            "waitlist_cap": null,
            "sku": "sku_9",
            "show_free_banner": true,
            "image_alt_text": null,
            "allowed_payment_types": [
              "standard"
            ],
            "tag_names": [

            ],
            "listing_url": "http://www.my-catalog.edu/courses/course-path-19",
            "start_date": "2024/12/30 14:09:55 +0000",
            "end_date": "2025/01/13 14:09:55 +0000",
            "canvas_section_id": null,
            "associated_account_ids": [

            ],
            "canvas_course": {
              "id": 9
            }
          }
        ]
      }
    ]
  }
}

Listing programs

Endpoint

GET https://www.my-catalog.edu/api/v1/programs

Request

Route

GET https://www.my-catalog.edu/api/v1/programs

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 3
Content-Type: application/json; charset=utf-8
X-CSRF-Token: 9rgcAHp98g2k+a95Xmtlb5T+REQ7J1BCcgs7mI0X17YYRf1RvpVlBlTmiBuCdLAil4E6wY6Yaj2XZZeY/9BRbw==
ETag: W/"a0670ac4452a56f1c0db523a2a73ee8e"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=U1kxRzhHMjdoOENMbmxHTUNiYmtEY0FLdlBueTU5Y0ZOaG44b1ZMaS95dGYvTGw2Y2xqbDRyRTFabnlIUFNpVjNPbjlOR2UrWEkxOGxJZldQRWxpYzQwSmF6aXhxQjJiZ2Zqc1R1aUFIKzVsMEZFb1RCRFRmNnJGMWdkMGt0Q2tTcW1ueGlrVm9pWGJmQW1QVHoweVcyckpoTHpNQUtUU2tHQkFOWFpUMHdrclFrZlZReEpnTFBPb0I4Tms1ZFpqLS1UT2RvT0VmeHFiL092TE1DOW0wVmx3PT0%3D--bf00bb83494548b5e70fb513a535ae65a58215c3; path=/; HttpOnly
X-Request-Id: 3d0a3b2d-a78e-4391-95c0-a9a51bb4f63d
X-Runtime: 0.069899
Content-Length: 9585

Body

{
  "programs": [
    {
      "id": 8,
      "visibility": "listed",
      "enrollment_open": true,
      "enrollment_open_from": null,
      "enrollment_open_to": null,
      "enrollment_cap": null,
      "description": "description_8",
      "enrollment_fee": 0.0,
      "created_at": "2025/01/06 14:09:55 +0000",
      "credits": 9.0,
      "measurement": "credit",
      "updated_at": "2025/01/06 14:09:55 +0000",
      "short_description": "teaser_8",
      "listing_path": "program-path-8",
      "listing_image": null,
      "currency": "USD",
      "catalog": {
        "id": 3,
        "name": "Domain Account 3"
      },
      "type": "Program",
      "title": "Program 8",
      "list_order": null,
      "waitlist": false,
      "waitlist_cap": null,
      "sku": null,
      "show_free_banner": true,
      "image_alt_text": null,
      "allowed_payment_types": [
        "standard"
      ],
      "tag_names": [
        "Another Tag",
        "Tag"
      ],
      "listing_url": "http://www.my-catalog.edu/programs/program-path-8",
      "start_date": "2024/12/30 14:09:55 +0000",
      "end_date": null,
      "canvas_section_id": null,
      "associated_account_ids": [

      ],
      "sequential": true,
      "requirements": [
        {
          "id": 9,
          "visibility": "listed",
          "enrollment_open": true,
          "enrollment_open_from": null,
          "enrollment_open_to": null,
          "enrollment_cap": null,
          "description": "description_9",
          "enrollment_fee": 0.0,
          "created_at": "2025/01/06 14:09:55 +0000",
          "credits": 3.0,
          "measurement": "credit",
          "updated_at": "2025/01/06 14:09:55 +0000",
          "short_description": "teaser_9",
          "listing_path": "program-path-9",
          "listing_image": null,
          "currency": "USD",
          "catalog": {
            "id": 3,
            "name": "Domain Account 3"
          },
          "type": "Program",
          "title": "Program 9",
          "list_order": null,
          "waitlist": false,
          "waitlist_cap": null,
          "sku": null,
          "show_free_banner": true,
          "image_alt_text": null,
          "allowed_payment_types": [
            "standard"
          ],
          "tag_names": [

          ],
          "listing_url": "http://www.my-catalog.edu/programs/program-path-9",
          "start_date": "2024/12/30 14:09:55 +0000",
          "end_date": null,
          "canvas_section_id": null,
          "associated_account_ids": [

          ],
          "sequential": true,
          "requirements": [
            {
              "id": 11,
              "visibility": "listed",
              "enrollment_open": true,
              "enrollment_open_from": null,
              "enrollment_open_to": null,
              "enrollment_cap": null,
              "description": "description_11",
              "enrollment_fee": 0.0,
              "created_at": "2025/01/06 14:09:55 +0000",
              "credits": 3.0,
              "measurement": "credit",
              "updated_at": "2025/01/06 14:09:55 +0000",
              "short_description": "teaser_11",
              "listing_path": "course-path-11",
              "listing_image": null,
              "currency": "USD",
              "catalog": {
                "id": 3,
                "name": "Domain Account 3"
              },
              "type": "Course",
              "title": "Course 11",
              "list_order": null,
              "waitlist": false,
              "waitlist_cap": null,
              "sku": "sku_4",
              "show_free_banner": true,
              "image_alt_text": null,
              "allowed_payment_types": [
                "standard"
              ],
              "tag_names": [

              ],
              "listing_url": "http://www.my-catalog.edu/courses/course-path-11",
              "start_date": "2024/12/30 14:09:55 +0000",
              "end_date": "2025/01/13 14:09:55 +0000",
              "canvas_section_id": null,
              "associated_account_ids": [

              ],
              "canvas_course": {
                "id": 4
              }
            }
          ]
        },
        {
          "id": 10,
          "visibility": "listed",
          "enrollment_open": true,
          "enrollment_open_from": null,
          "enrollment_open_to": null,
          "enrollment_cap": null,
          "description": "description_10",
          "enrollment_fee": 0.0,
          "created_at": "2025/01/06 14:09:55 +0000",
          "credits": 6.0,
          "measurement": "credit",
          "updated_at": "2025/01/06 14:09:55 +0000",
          "short_description": "teaser_10",
          "listing_path": "program-path-10",
          "listing_image": null,
          "currency": "USD",
          "catalog": {
            "id": 3,
            "name": "Domain Account 3"
          },
          "type": "Program",
          "title": "Program 10",
          "list_order": null,
          "waitlist": false,
          "waitlist_cap": null,
          "sku": null,
          "show_free_banner": true,
          "image_alt_text": null,
          "allowed_payment_types": [
            "standard"
          ],
          "tag_names": [

          ],
          "listing_url": "http://www.my-catalog.edu/programs/program-path-10",
          "start_date": "2024/12/30 14:09:55 +0000",
          "end_date": null,
          "canvas_section_id": null,
          "associated_account_ids": [

          ],
          "sequential": true,
          "requirements": [
            {
              "id": 12,
              "visibility": "listed",
              "enrollment_open": true,
              "enrollment_open_from": null,
              "enrollment_open_to": null,
              "enrollment_cap": null,
              "description": "description_12",
              "enrollment_fee": 0.0,
              "created_at": "2025/01/06 14:09:55 +0000",
              "credits": 3.0,
              "measurement": "credit",
              "updated_at": "2025/01/06 14:09:55 +0000",
              "short_description": "teaser_12",
              "listing_path": "course-path-12",
              "listing_image": null,
              "currency": "USD",
              "catalog": {
                "id": 3,
                "name": "Domain Account 3"
              },
              "type": "Course",
              "title": "Course 12",
              "list_order": null,
              "waitlist": false,
              "waitlist_cap": null,
              "sku": "sku_5",
              "show_free_banner": true,
              "image_alt_text": null,
              "allowed_payment_types": [
                "standard"
              ],
              "tag_names": [

              ],
              "listing_url": "http://www.my-catalog.edu/courses/course-path-12",
              "start_date": "2024/12/30 14:09:55 +0000",
              "end_date": "2025/01/13 14:09:55 +0000",
              "canvas_section_id": null,
              "associated_account_ids": [

              ],
              "canvas_course": {
                "id": 5
              }
            },
            {
              "id": 13,
              "visibility": "listed",
              "enrollment_open": true,
              "enrollment_open_from": null,
              "enrollment_open_to": null,
              "enrollment_cap": null,
              "description": "description_13",
              "enrollment_fee": 0.0,
              "created_at": "2025/01/06 14:09:55 +0000",
              "credits": 3.0,
              "measurement": "credit",
              "updated_at": "2025/01/06 14:09:55 +0000",
              "short_description": "teaser_13",
              "listing_path": "course-path-13",
              "listing_image": null,
              "currency": "USD",
              "catalog": {
                "id": 3,
                "name": "Domain Account 3"
              },
              "type": "Course",
              "title": "Course 13",
              "list_order": null,
              "waitlist": false,
              "waitlist_cap": null,
              "sku": "sku_6",
              "show_free_banner": true,
              "image_alt_text": null,
              "allowed_payment_types": [
                "standard"
              ],
              "tag_names": [

              ],
              "listing_url": "http://www.my-catalog.edu/courses/course-path-13",
              "start_date": "2024/12/30 14:09:55 +0000",
              "end_date": "2025/01/13 14:09:55 +0000",
              "canvas_section_id": null,
              "associated_account_ids": [

              ],
              "canvas_course": {
                "id": 6
              }
            }
          ]
        }
      ]
    },
    {
      "id": 9,
      "visibility": "listed",
      "enrollment_open": true,
      "enrollment_open_from": null,
      "enrollment_open_to": null,
      "enrollment_cap": null,
      "description": "description_9",
      "enrollment_fee": 0.0,
      "created_at": "2025/01/06 14:09:55 +0000",
      "credits": 3.0,
      "measurement": "credit",
      "updated_at": "2025/01/06 14:09:55 +0000",
      "short_description": "teaser_9",
      "listing_path": "program-path-9",
      "listing_image": null,
      "currency": "USD",
      "catalog": {
        "id": 3,
        "name": "Domain Account 3"
      },
      "type": "Program",
      "title": "Program 9",
      "list_order": null,
      "waitlist": false,
      "waitlist_cap": null,
      "sku": null,
      "show_free_banner": true,
      "image_alt_text": null,
      "allowed_payment_types": [
        "standard"
      ],
      "tag_names": [

      ],
      "listing_url": "http://www.my-catalog.edu/programs/program-path-9",
      "start_date": "2024/12/30 14:09:55 +0000",
      "end_date": null,
      "canvas_section_id": null,
      "associated_account_ids": [

      ],
      "sequential": true,
      "requirements": [
        {
          "id": 11,
          "visibility": "listed",
          "enrollment_open": true,
          "enrollment_open_from": null,
          "enrollment_open_to": null,
          "enrollment_cap": null,
          "description": "description_11",
          "enrollment_fee": 0.0,
          "created_at": "2025/01/06 14:09:55 +0000",
          "credits": 3.0,
          "measurement": "credit",
          "updated_at": "2025/01/06 14:09:55 +0000",
          "short_description": "teaser_11",
          "listing_path": "course-path-11",
          "listing_image": null,
          "currency": "USD",
          "catalog": {
            "id": 3,
            "name": "Domain Account 3"
          },
          "type": "Course",
          "title": "Course 11",
          "list_order": null,
          "waitlist": false,
          "waitlist_cap": null,
          "sku": "sku_4",
          "show_free_banner": true,
          "image_alt_text": null,
          "allowed_payment_types": [
            "standard"
          ],
          "tag_names": [

          ],
          "listing_url": "http://www.my-catalog.edu/courses/course-path-11",
          "start_date": "2024/12/30 14:09:55 +0000",
          "end_date": "2025/01/13 14:09:55 +0000",
          "canvas_section_id": null,
          "associated_account_ids": [

          ],
          "canvas_course": {
            "id": 4
          }
        }
      ]
    },
    {
      "id": 10,
      "visibility": "listed",
      "enrollment_open": true,
      "enrollment_open_from": null,
      "enrollment_open_to": null,
      "enrollment_cap": null,
      "description": "description_10",
      "enrollment_fee": 0.0,
      "created_at": "2025/01/06 14:09:55 +0000",
      "credits": 6.0,
      "measurement": "credit",
      "updated_at": "2025/01/06 14:09:55 +0000",
      "short_description": "teaser_10",
      "listing_path": "program-path-10",
      "listing_image": null,
      "currency": "USD",
      "catalog": {
        "id": 3,
        "name": "Domain Account 3"
      },
      "type": "Program",
      "title": "Program 10",
      "list_order": null,
      "waitlist": false,
      "waitlist_cap": null,
      "sku": null,
      "show_free_banner": true,
      "image_alt_text": null,
      "allowed_payment_types": [
        "standard"
      ],
      "tag_names": [

      ],
      "listing_url": "http://www.my-catalog.edu/programs/program-path-10",
      "start_date": "2024/12/30 14:09:55 +0000",
      "end_date": null,
      "canvas_section_id": null,
      "associated_account_ids": [

      ],
      "sequential": true,
      "requirements": [
        {
          "id": 12,
          "visibility": "listed",
          "enrollment_open": true,
          "enrollment_open_from": null,
          "enrollment_open_to": null,
          "enrollment_cap": null,
          "description": "description_12",
          "enrollment_fee": 0.0,
          "created_at": "2025/01/06 14:09:55 +0000",
          "credits": 3.0,
          "measurement": "credit",
          "updated_at": "2025/01/06 14:09:55 +0000",
          "short_description": "teaser_12",
          "listing_path": "course-path-12",
          "listing_image": null,
          "currency": "USD",
          "catalog": {
            "id": 3,
            "name": "Domain Account 3"
          },
          "type": "Course",
          "title": "Course 12",
          "list_order": null,
          "waitlist": false,
          "waitlist_cap": null,
          "sku": "sku_5",
          "show_free_banner": true,
          "image_alt_text": null,
          "allowed_payment_types": [
            "standard"
          ],
          "tag_names": [

          ],
          "listing_url": "http://www.my-catalog.edu/courses/course-path-12",
          "start_date": "2024/12/30 14:09:55 +0000",
          "end_date": "2025/01/13 14:09:55 +0000",
          "canvas_section_id": null,
          "associated_account_ids": [

          ],
          "canvas_course": {
            "id": 5
          }
        },
        {
          "id": 13,
          "visibility": "listed",
          "enrollment_open": true,
          "enrollment_open_from": null,
          "enrollment_open_to": null,
          "enrollment_cap": null,
          "description": "description_13",
          "enrollment_fee": 0.0,
          "created_at": "2025/01/06 14:09:55 +0000",
          "credits": 3.0,
          "measurement": "credit",
          "updated_at": "2025/01/06 14:09:55 +0000",
          "short_description": "teaser_13",
          "listing_path": "course-path-13",
          "listing_image": null,
          "currency": "USD",
          "catalog": {
            "id": 3,
            "name": "Domain Account 3"
          },
          "type": "Course",
          "title": "Course 13",
          "list_order": null,
          "waitlist": false,
          "waitlist_cap": null,
          "sku": "sku_6",
          "show_free_banner": true,
          "image_alt_text": null,
          "allowed_payment_types": [
            "standard"
          ],
          "tag_names": [

          ],
          "listing_url": "http://www.my-catalog.edu/courses/course-path-13",
          "start_date": "2024/12/30 14:09:55 +0000",
          "end_date": "2025/01/13 14:09:55 +0000",
          "canvas_section_id": null,
          "associated_account_ids": [

          ],
          "canvas_course": {
            "id": 6
          }
        }
      ]
    }
  ]
}

Updating a program

Endpoint

PUT https://www.my-catalog.edu/api/v1/programs/:id

Parameters

Name Description Type
program[title] Listing title String
program[description] Full listing description String
program[path] Path to the listing. Used in URLs String
program[teaser] A shorter description of the listing String
program[enrollment_open] Indicates if the listing is current accepting new students Boolean
program[enrollment_open_from] If specified, enrollment is open only from this date-time Datetime
program[enrollment_open_to] If specified, enrollment is open only to this date-time Datetime
program[visibility] Indicates if the listing is visible in the web UI. Possible values: listed, unlisted, hidden String
program[enrollment_cap] A limit for the total number of enrollments Integer
program[enrollment_fee] Enrollment fee Decimal
program[allowed_payment_types] Allowed payment methods Array
program[days_to_complete] The number of days a student has to complete the requirements Integer
program[account_id] The id of the account to associate the listing to. Can be an id of any subcatalog of the catalog making the API request. Defaults to the catalog making the API request. Integer
program[list_order] Order in which the listing is shown in the catalog Integer
program[waitlist] Waitlist enabled (defaults to false) Boolean
program[waitlist_cap] Wait List Limit for the total number of wait listed enrollments Integer
program[listing_image] URL or file upload for the image to be shown with this listing. String
program[tag_names] List of tags applied to this listing Array
program[show_free_banner] Show the 'FREE' mark on the card of the listing if free Boolean
program[associated_account_ids] Other account ids where this product should be listed Array
program[requirement_ids] Ordered array of listing IDs that represent requirements for completing the program Array
program[sequential] Indicates if students are required to complete requirements in order Boolean

Request

Route

PUT https://www.my-catalog.edu/api/v1/programs/1

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "program": {
    "title": "Program 1",
    "description": "This is a very awesome program.",
    "path": "program-1",
    "teaser": "This is an example teaser",
    "enrollment_open": true,
    "visibility": "listed",
    "enrollment_cap": 150,
    "waitlist": true,
    "waitlist_cap": 12,
    "enrollment_fee": 49.99,
    "days_to_complete": 45,
    "list_order": 123,
    "requirement_ids": [

    ],
    "sequential": true,
    "tag_names": [
      "Tag",
      "Another Tag"
    ]
  }
}

Response

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: wFJk/C0lF0MHLi8cj+Iwgc0EpICUuDmqSTibD1NZdYHwfYAhjMKhmmklKWDkfdvfetgpgPLmZsWdAcO8Fayxbw==
Cache-Control: no-cache
Set-Cookie: _gallery_session=Y0NxbllWQ0ZrN21kd2p5RVJoL2RQNjc3MDgzUjIwQU5HSXZjeC9pZDAxRDFpeS9uL3NsWFo1akxYSTBvUWduZFZUNXJUVlJOYkZhZlo1V3FVc3Bndm9tM0xPSW00Yk44Z1hCZjhiWWoxZVYzUGZJVW1ZNXpqV2hXUzIrNVQxVkM4NXNiQllleXoyRXdoeWF5YUNGL2E3U2R3d0tyVUNBUmlZL2d2UWFJS1FpOGNXZEduVEVWbTBTSjR3QXNwS2ZILS15K05rMGkvQmpvUWhwOUpodU1vc3dRPT0%3D--4faeaa20f99c3df6cb8cb4998fbddc3054e359d8; path=/; HttpOnly
X-Request-Id: 6a369c98-8ad5-49c2-9d8c-73daa980be5e
X-Runtime: 0.369324

Progresses

Getting a specific progress

Endpoint

GET https://www.my-catalog.edu/api/v1/progresses/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/progresses/2

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Progress ID Integer
account_id Catalog Account ID Integer
canvas_user_id The Canvas User ID of the user who initiated the job Integer
completion_percent The completion percent of the job Integer
workflow_state The status of the progress String
payload Any data or errors returned by the job Array
created_at The creation date for the progress job Datetime
updated_at The last time the progress job was updated Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: LyQJ0wW+OwymbeHnnZ8IRlB0glZjCgpAXzGaNpYZOLALyqs9KpOqRPKAtWcqnyP4F1uXs/azs/j2Dd58ZNkXSQ==
ETag: W/"0407a1a9a90af01ce3bd9105e9aabeae"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=VUV1bDE4S0JZOGM1SGVxQmJQZDAxcmpiZlJ6U0FuOHF6RjlHZ0YyOGVnMmtPYnFZNFdVN0IrMFlZa1dTTnhOMjQ1V2ZMU211V2ZJOFBDOThlSEI4MGliZHZYNWQwQXBrclJ0YlNIL1pTR3l0cTZsZUJMWHJML2N0Z01HQ3hreUlDd2NEMDRnbDVXQlZ1b3pmT2tRWGNBc1pJN2R1ZlhKdHJnYURQZ3BwSktud1pxYTM5R3AyT3gxOHNNeHNLVTlHLS1nSEx1eGV1b1NGcjhVaWhCY09BNHBnPT0%3D--814f4da46168bccb880006e581a7157a044e1c18; path=/; HttpOnly
X-Request-Id: 0ad8c68c-e1a1-4a91-93e7-3b7a04d21bd0
X-Runtime: 0.024473
Content-Length: 206

Body

{
  "progress": {
    "id": 2,
    "account_id": 37,
    "canvas_user_id": null,
    "completion_percent": null,
    "workflow_state": "queued",
    "payload": {
    },
    "created_at": "2025/01/06 14:09:58 +0000",
    "updated_at": "2025/01/06 14:09:58 +0000"
  }
}

Tags

The request parameters should be sent as JSON in the request body.

Creating a tag

Endpoint

POST https://www.my-catalog.edu/api/v1/tags

Parameters

Name Description Type
name required Tag name (minimum 1 and maximum 255 characters) String
product_ids List of product ids associate to this tag Array

Request

Route

POST https://www.my-catalog.edu/api/v1/tags

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "name": "Tag 1",
  "product_ids": [
    1,
    2,
    3
  ]
}

Response

Response Fields

Name Description Type
id Tag id Integer
account_id Account id Integer
name Tag name String
created_at Tag created at Datetime
updated_at Tag updated at Datetime
assigned_listings Products associate to this tag Array
assigned_listings[id] Product id Integer
assigned_listings[title] Product title String
assigned_listings[type] Product type (COURSE or PROGRAM) String
assigned_listings[canvas_course_id] Product Canvas course id Integer
assigned_categories Returns empty list to indicate there are no associated categories to the newly created tag Array

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: w3ckGa23/Se0ke4D7ZPvHfFlIQ5mOpWL2hxV5bT2zPefw9xY1E0x+eiegFg4qYMeG5mm9OrihmfCs9aNGmN/fg==
ETag: W/"729f420efa5ba7de47b211df4fb90865"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=TzBFMG4yQm5RTy8rWXdhZEJMNm9mbVJ1VWo0Tk9UTDNucGc5TU1Wcko0QW01NWtvNzlHaTAyOHBoL3pNQkpLS3VKQ3d1SkdJeEYwa2JVd1RTWEZYU3hUUHBrRXRZRTd5b0hKUkFIL0svbDRvSERWTjJIN3N0VWxscWRWMm8xcnczbGZRdFc5d3NnK2NMWEdycW9pbE8rZUdxRjNubll1bTZlQyt2L0JWcXc0eVc0YmRiaFY4TnNrcGkwK2RrakxDLS10MW1FYnAvOXBSRlNzc3JVbDJGZmpnPT0%3D--9ecb0799881b9d0dfde0fe26293cf7f546028708; path=/; HttpOnly
X-Request-Id: 2cc42cbc-eda8-441d-b7f0-456c67f0ada7
X-Runtime: 0.022423
Content-Length: 347

Body

{
  "id": 9,
  "account_id": 1,
  "name": "Tag 1",
  "assigned_listings": [
    {
      "id": 1,
      "title": "Course 1",
      "type": "COURSE",
      "canvas_course_id": 2
    },
    {
      "id": 2,
      "title": "Course 2",
      "type": "COURSE",
      "canvas_course_id": 3
    },
    {
      "id": 3,
      "title": "Program 1",
      "type": "PROGRAM"
    }
  ],
  "assigned_categories": [

  ],
  "created_at": "2023-08-07T09:45:45.535989Z",
  "updated_at": "2023-08-07T09:45:45.535989Z"
}

Deleting a specific tag

Endpoint

DELETE https://www.my-catalog.edu/api/v1/tags/:id

Request

Route

DELETE https://www.my-catalog.edu/api/v1/tags/9

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Tag id Integer
account_id Account id Integer
name Tag name String
created_at Tag created at Datetime
updated_at Tag updated at Datetime
assigned_listings Returns empty list to indicate associated products to this tag are deleted Array
assigned_categories Returns empty list to indicate associated categories to this tag are deleted Array
is_deleted Returns true to indicate tag is deleted Boolean

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: +p6GoaFrhvD9zYDjzaPZ3IXy8p5X8nOUvXQB+AprA4x1xQicRus54+GMq0iTSveVOr7yvDGrOH+8ik6Pcaz1Nw==
ETag: W/"bb8f9a8b9204f479c86628e6aa1f79a4"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=dXN1VGFKbkp3RmtKTW1tMHZ5NU9FSGNtSVVRTXMrd0pxdFRqak4wLzRIbi9QSjJONkVhK200d1d5eFRxMDh1WWc1QUp0VzVKa3JCY2Uxc1RScDZTNDRWWmpIbE1BWDhCckhybVBFOWR4VFRzbkFyekFlV3EzeGUrb2ZwR2FyU1BXSFd4WVJXSk1Cbk1RYnd5KzdUT21zdU42U0RHci9WSExodVBEK2lvMW5Rb1lIMUo3U1drMElLcWcrNWI0UDhlLS1HZFVpNmtLZ0RIcFB1UEFlejRqUGZ3PT0%3D--739b0e7fd860f6430ed3bece7346e0a3c9cee14c; path=/; HttpOnly
X-Request-Id: aaee5a61-53dd-4cf2-8cda-f737503af9a9
X-Runtime: 0.022656
Content-Length: 190

Body

{
  "id": 9,
  "account_id": 1,
  "name": "Tag 1",
  "assigned_listings": [

  ],
  "assigned_categories": [

  ],
  "created_at": "2023-08-07T09:45:45.535989Z",
  "updated_at": "2023-08-07T09:45:45.535989Z",
  "is_deleted": true
}

Getting a specific tag

Endpoint

GET https://www.my-catalog.edu/api/v1/tags/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/tags/9

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Tag id Integer
account_id Account id Integer
name Tag name String
created_at Tag created at Datetime
updated_at Tag updated at Datetime
assigned_listings Products associate to this tag Array
assigned_listings[id] Product id Integer
assigned_listings[title] Product title String
assigned_listings[type] Product type (COURSE or PROGRAM) String
assigned_listings[canvas_course_id] Product Canvas course id Integer
assigned_categories Categories associate to this tag Array
assigned_categories[id] Category id Integer
assigned_categories[account_id] Account id Integer
assigned_categories[tag_id] Tag id Integer
assigned_categories[created_at] Category created at Datetime
assigned_categories[updated_at] Category updated at Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: qLc9vQ5E/fj8WfXMExzQUiP3OmcRNTed59oUC9vDhLFh6IydkFKBUbO47PipcfuqgOe0VDRD2ip40IElqp4uRw==
ETag: W/"caf9af9a544b5cd6aa0d9c47f1fff7e6"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=aEtOWnVRVDJNaXZ0eGlsQkZPb245K0dZMVNjTnVETjh0WHFBY2ZhRG1udFdlNTRaa2VzQXY5ZXNMTk5heUl2STBkRXpGNUlBdjEwTUtpMktYOHZOZVBybTg2TDRMV1ZXNzJ1VzdtTUIyY3pPU282SHRBOWhRamF4T25BR25TeUZiMnB6OHFWeDJpWHRKQ3JxVmdlb1ZtdlFqdUdmSUhEUDd3NGRDeGd6V05wd3k3dDEvZmJWVTZraVErRzhOclBCLS1nZzNlWmdLOGZRcGwvUXJXcTljVUJRPT0%3D--221fa95e801435b0bbaf0b1e24cda908f6c1d9ea; path=/; HttpOnly
X-Request-Id: 297a1375-2aba-40af-b494-549038eebd15
X-Runtime: 0.023087
Content-Length: 357

Body

{
  "id": 9,
  "account_id": 1,
  "name": "Tag 1",
  "assigned_listings": [
    {
      "id": 3,
      "title": "Course 1",
      "type": "COURSE",
      "canvas_course_id": 4
    }
  ],
  "assigned_categories": [
    {
      "id": 12,
      "account_id": 5,
      "tag_id": 9,
      "created_at": "2023-08-22T06:33:38.991906Z",
      "updated_at": "2023-08-24T06:33:38.991906Z"
    }
  ],
  "created_at": "2023-08-07T09:45:45.535989Z",
  "updated_at": "2023-08-07T09:45:45.535989Z"
}

Listing tags

Endpoint

GET https://www.my-catalog.edu/api/v1/tags

Parameters

Name Description Type
product_ids List of product ids (maximum 20 ids) Array
name Search value which will be searched in tag name and associated products names String
has_category Tag has category or not Boolean
updated_at_from Updated at from Datetime
updated_at_to Updated at to Datetime
created_at_from Created at from Datetime
created_at_to Created at to Datetime

Request

Route

GET https://www.my-catalog.edu/api/v1/tags?product_ids=1%2C2%2C3&name=tag+1&has_category=true&updated_at_from=2023-08-06T14%3A46%3A59.944581%2B02%3A00&updated_at_to=2023-08-10T14%3A46%3A59.944581-05%3A00&created_at_from=2023-08-05T14%3A46%3A59.944581%2B02%3A00&created_at_to=2023-08-09T14%3A46%3A59.944581-05%3A00

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Query Parameters

product_ids=1,2,3
name=tag 1
has_category=true
updated_at_from=2023-08-06T14:46:59.944581+02:00
updated_at_to=2023-08-10T14:46:59.944581-05:00
created_at_from=2023-08-05T14:46:59.944581+02:00
created_at_to=2023-08-09T14:46:59.944581-05:00

Response

Response Fields

Name Description Type
id Tag id Integer
account_id Account id Integer
name Tag name String
created_at Tag created at Datetime
updated_at Tag updated at Datetime
assigned_listings Products associate to this tag Array
assigned_listings[id] Product id Integer
assigned_listings[title] Product title String
assigned_listings[type] Product type (COURSE or PROGRAM) String
assigned_listings[canvas_course_id] Product Canvas course id Integer
assigned_categories Categories associate to this tag Array
assigned_categories[id] Category id Integer
assigned_categories[account_id] Account id Integer
assigned_categories[tag_id] Tag id Integer
assigned_categories[created_at] Category created at Datetime
assigned_categories[updated_at] Category updated at Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: QhdhI3Cgv09BLoMD/4tpibjztRvxT+at4jZKZOI8l6IilQKIy2bbShFqaBaxZ5cTwRx68h7iPrTRsUdhefIUKg==
ETag: W/"05187bc38a68958fdb9df1ee2b495c0a"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=a2Y2N3JkQzFGUWFQMXJoL2pwaDNrRTdWdDhFTmFOWmlhd05hVHJ1Rndac1JzOGFKWkpkUlRoT01aemJnZVYvMEttOW4yaE9ReTRra01iSEVRVW5yamZ0M2h1aGNNWXB6ODRRcXdiVGtrNVdvV2JYSm5BOS9XYlRsMHd1ekhoa2F4aFhLK0ZqcVBqcUY3MHc0ZnhrR0FkdlZuckFrMXh0aFhMRW8wamwxdnMydkQvV3E2cnRIeDA4RmFUbTJpU0hDLS1GSjRrWEtwbVM1SEhZL0s4Qm5PZ0VnPT0%3D--96198de6cb07823ebbbec8b601309a949a11ed33; path=/; HttpOnly
X-Request-Id: 1c6b347e-17b2-4cbf-b4e6-2ecd8b9c38b6
X-Runtime: 0.032938
Content-Length: 368

Body

{
  "tags": [
    {
      "id": 9,
      "account_id": 1,
      "name": "Tag 1",
      "assigned_listings": [
        {
          "id": 3,
          "title": "Course 1",
          "type": "COURSE",
          "canvas_course_id": 4
        }
      ],
      "assigned_categories": [
        {
          "id": 12,
          "account_id": 5,
          "tag_id": 9,
          "created_at": "2023-08-22T06:33:38.991906Z",
          "updated_at": "2023-08-24T06:33:38.991906Z"
        }
      ],
      "created_at": "2023-08-07T09:45:45.535989Z",
      "updated_at": "2023-08-07T09:45:45.535989Z"
    }
  ]
}

Updating a specific tag

Endpoint

PUT https://www.my-catalog.edu/api/v1/tags/:id

Parameters

Name Description Type
name required New tag name (minimum 1 and maximum 255 characters) String

Request

Route

PUT https://www.my-catalog.edu/api/v1/tags/9

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "name": "New tag name"
}

Response

Response Fields

Name Description Type
id Tag id Integer
account_id Account id Integer
name Tag name String
created_at Tag created at Datetime
updated_at Tag updated at Datetime
assigned_listings Products associate to this tag Array
assigned_listings[id] Product id Integer
assigned_listings[title] Product title String
assigned_listings[type] Product type (COURSE or PROGRAM) String
assigned_listings[canvas_course_id] Product Canvas course id Integer
assigned_categories Categories associate to this tag Array
assigned_categories[id] Category id Integer
assigned_categories[account_id] Account id Integer
assigned_categories[tag_id] Tag id Integer
assigned_categories[created_at] Category created at Datetime
assigned_categories[updated_at] Category updated at Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: Qn2bsldl+XH7EQV7zW4VAncKAqwg/6HvQZhpLQf3/eSboiNx8tiypsIS1OoMfUqPnICgRZsXtDcwmzKlrAX8fQ==
ETag: W/"733be57c5f7ab9c54f6d55282af46f1e"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=ZXUzVWpxc0FxUWJYdlE4TjkveGlMNEFxdUVxWE03TTlBUlhZQ2RmOXR6TGg1K0p1aXZsOS9FTUJXS2YrRC9RN28xNlBrUFBybWZYZjFPaXB6ZUNaTU11dHErRlRKVGRTUUEvSlhnKzlMd21XbHFkUThMUzZJb3RDdWdTZ3RpWVh1TnVRU3Y0WnZ0OUNIdDUwL2VacW84eGNObGswLzMxanhIeTZadG1tSk1RcHo0TzRGTTBLWGJZcDZVbnBmTEx2LS1oZGFNVGJWcDNGS3Q4VTEwKzVESURBPT0%3D--fd9adc71da96130bb6fa0678b37b40f5cc55b660; path=/; HttpOnly
X-Request-Id: 8ee924e0-7980-4471-8b04-b97cc21bd9ad
X-Runtime: 0.027157
Content-Length: 364

Body

{
  "id": 9,
  "account_id": 1,
  "name": "New tag name",
  "assigned_listings": [
    {
      "id": 3,
      "title": "Course 1",
      "type": "COURSE",
      "canvas_course_id": 4
    }
  ],
  "assigned_categories": [
    {
      "id": 12,
      "account_id": 5,
      "tag_id": 9,
      "created_at": "2023-08-22T06:33:38.991906Z",
      "updated_at": "2023-08-24T06:33:38.991906Z"
    }
  ],
  "created_at": "2023-08-07T09:45:45.535989Z",
  "updated_at": "2023-08-07T09:45:45.535989Z"
}

User registrations

Getting a specific user registration

DEPRECATED: use users resource instead. It has all data from the current API endpoint.
GET /api/v1/users?canvas_user_id=:id is providing similar data

Endpoint

GET https://www.my-catalog.edu/api/v1/user_registrations/:id

Parameters

Name Description
id Canvas user ID

Request

Route

GET https://www.my-catalog.edu/api/v1/user_registrations/2

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
canvas_user_id Canvas user ID Integer
name Full name String
email E-mail address String
custom_fields Custom field values, e.g. { 'phone': '(999) 123-4567' } Object
created_at Date/time registration was recorded Datetime
updated_at Date/time last updated Datetime
catalog[id] Id for the catalog this user registered for Integer
catalog[name] Name for the catalog this user registered for String

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: IwTd3cSxDbR8ELTPrKNXOysNrkspiJv/XVSQTga5WgsfYskw2RYBxTm5DjjJVb9sX4jsN4X7ixUbyN6lJx39Mg==
ETag: W/"d696df4984a55a9ca87887bc1a33e10d"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=SUtETHV4OXRrN21CNGFpUVBoTkhyN3BOcW93aWdjVEdEQlhOaHRXOTgrSGMzMmN5dVAyVkcxZkIwQXl5R0xFblErTzNERllhbmJBY3RpaDdvNTRrOUJTcGZlaGdLampGZjZldk13RGQ4a2xBdzNZSjVpcmV3dVVJanJ3NWR3YTZObHluNkIyZUhCalNrdDd6cXpPanJKb1l6eUhkdGN4QlUzNjlVNXJWdHlWbjM1NjhhRVlFQTlPUHpIKzNMU21tLS1yT3VCYTEyZjBRSWVLL0lZaTBJWTRnPT0%3D--67b8645d8916ecf45ef285712bdf5e7468b08f00; path=/; HttpOnly
X-Request-Id: c6e6a211-1c59-4c12-b6ee-bedd30832933
X-Runtime: 0.032280
Content-Length: 293

Body

{
  "user_registration": {
    "canvas_user_id": 2,
    "catalog": {
      "id": 59,
      "name": "Domain Account 64"
    },
    "name": "User 2",
    "email": "user2@example.com",
    "custom_fields": {
      "favorite_color": "#BADA55",
      "code_of_conduct": "1",
      "age": "19"
    },
    "created_at": "2025/01/06 14:09:59 +0000",
    "updated_at": "2025/01/06 14:09:59 +0000"
  }
}

Listing user registrations

DEPRECATED: use users resource instead. It has all data from the current API endpoint.
GET /api/v1/users?registered_in_catalog=true is providing similar data

Endpoint

GET https://www.my-catalog.edu/api/v1/user_registrations

Parameters

Name Description
from Earliest date/time to return (optional, String). Suggested format YYYY-MM-DDTHH:MM:SSZ, e.g. 2018-01-01T00:00:00Z. System time zone is UTC.
to Latest date/time to return (optional, String). See 'from' above for format.

Request

Route

GET https://www.my-catalog.edu/api/v1/user_registrations

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: +ETQ9zM6ZZ/qTcyZ2EJNywP3tr0oppvQICA9ZRAzm0VVZtbvNrpJTSWzJC7ReqrGNzKCsa5gTNicIqou65QqVQ==
ETag: W/"c7ed0b15c1ce4264c72ceb3aa2c1e8bb"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=Wlo3UjIxU0Vxa3MvMXM4TlRMVUR2S29QbUVyQUxyY3JUS3kvV0xSRnVTTmJMenVJNUdhTS9Uam8zNHdFSkR1N2RqWGxodndzNWp5bTVTTGFTL1h0YnEvRDB3alN5T2d5Y2RPZXU2ZkhUWC9tWlgrOGJrSFp3WXMraEFUaDBhdFhrWkxIWmg4OWNpRjV3Tnc3cXlyVDNyNVg1UDFyNm9IUUY1NGNnMFdNMDhPOXZUOWhDYzUxdDc4Y0RtNXJMeVJ5LS02TExrenByZCtjQlhQajVJWDdCZkNnPT0%3D--c4e20aad010aab3b5f02206182060aff61e1a1be; path=/; HttpOnly
X-Request-Id: 1cf69439-5d25-478b-be74-f6133818ed78
X-Runtime: 0.034427
Content-Length: 296

Body

{
  "user_registrations": [
    {
      "canvas_user_id": 1,
      "catalog": {
        "id": 58,
        "name": "Domain Account 63"
      },
      "name": "User 1",
      "email": "user1@example.com",
      "custom_fields": {
        "favorite_color": "#BADA55",
        "code_of_conduct": "1",
        "age": "19"
      },
      "created_at": "2025/01/06 14:09:58 +0000",
      "updated_at": "2025/01/06 14:09:58 +0000"
    }
  ]
}

Registering a user

DEPRECATED: use users resource instead. It has all data from the current API endpoint.
POST /api/v1/users is providing similar behavior

Endpoint

POST https://www.my-catalog.edu/api/v1/user_registrations

Parameters

Name Description
name Full name
email E-mail address (will also serve as login)
catalog_id ID of subcatalog to associate with user (optional)
custom_fields Hash of custom field values, e.g. { 'phone': '867-5309' } (optional)

Request

Route

POST https://www.my-catalog.edu/api/v1/user_registrations

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "user_registration": {
    "name": "Barack Obama",
    "email": "barack@obama.com",
    "custom_fields": {
      "phone": "(999) 123-4567"
    }
  }
}

Response

Response Fields

Name Description Type
canvas_user_id Canvas user ID Integer
name Full name String
email E-mail address String
custom_fields Custom field values, e.g. { 'phone': '(999) 123-4567' } Object
created_at Date/time registration was recorded Datetime
updated_at Date/time last updated Datetime
catalog[id] Id for the catalog this user registered for Integer
catalog[name] Name for the catalog this user registered for String

Status

201

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: 4jHVzzeYc06NyYegVwA+h5Z+kiH/6ecV53s8BHlaqCNlZxM4D6eNfRDvm24rC6MKGEmmHaes8UxwNELMmb2AjA==
ETag: W/"dcc1de68faac1f322d7282a2a444ab94"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=bWNoZWdZUENZdEpScS9xU2hjZk9tSE5JZFhNVGdwdDFoQ09GWWs3dzlEWnBrbGJtc0QrZFl6UEpDaG1pWFBRWlhRcEFsWXVmOEhnUHlJQ3ltTTJlOXNUdGx3Rk96NHNTeWduOXVSWkd0SVFLc2YwQzBOYjhMMC82Rm91L1JvZGlLcHdvUGUrQWh3WkJvRkNsVEpwTWpCZEErNFdJMDFwb3JxY00rY0ZJNDZFaVgrTG1LREZhdmdwMThXWEN0MEsyLS1DOFpUYU1LZk9OUTIrd1RiRkJKN3dRPT0%3D--cbf57426e71dc61422e0341769d7bf94742894f0; path=/; HttpOnly
X-Request-Id: 71bc9465-1c48-44bf-8f5d-3e3571b59dfa
X-Runtime: 0.052041
Content-Length: 242

Body

{
  "user_registration": {
    "canvas_user_id": 1234,
    "catalog": {
      "id": 60,
      "name": "Domain Account 65"
    },
    "name": "Barack Obama",
    "email": "barack@obama.com",
    "custom_fields": {
    },
    "created_at": "2025/01/06 14:09:59 +0000",
    "updated_at": "2025/01/06 14:09:59 +0000"
  }
}

Users

Deleting a specific user with dependencies

This endpoint will delete requested existing Catalog user if the user is in the root catalog or one of sub-catalog of the root catalog that api key is generated.
When only_orders_and_enrollments parameter is TRUE, it will delete only user dependencies that are orders, enrollments, payments, bulk invitations that he created, and applicants (wait list) for that user.
When only_orders_and_enrollments is FALSE or not specified, it will delete user dependencies including user itself and its related account admins.

Endpoint

DELETE https://www.my-catalog.edu/api/v1/users/:id?only_orders_and_enrollments=:only_orders_and_enrollments

Parameters

Name Description Type
id required Catalog user id Integer
only_orders_and_enrollments Delete only orders and enrollments (user dependencies) except user and related account admins OR delete user dependencies including user and related account admins Boolean

Request

Route

DELETE https://www.my-catalog.edu/api/v1/users/5?only_orders_and_enrollments=true

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Query Parameters

only_orders_and_enrollments=true

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json
X-CSRF-Token: 684lMnHtWPYJ7xt0xld3D4WubYfTkoKjJTcSs3uMjF0RyfH4ZcAAY5llmUcTv/Nd4cdF21W7DfouTWpufQW+cA==
Cache-Control: no-cache
Set-Cookie: _gallery_session=RFVib2ZUdzVmalUvdGp5Vm5HZlNTcmRJR3FHYnVFWVdTTit3ZmpUZmNnL1ozZTJqV2dPWWZuNnI3ajVNUjJKSFc0WWdXc3hFRUxFUTI1UzdncVplY0xKRmNzdmxXa2tBZ1Zkem1xSnJWU2VZWVJqT0pOeTRyR0NXcVVhTTVZbHhZb0NKNC9nQi9ZSFhsTnYrQ3JjL2FMYmRCK3JCa2tibEs2UVRLYXBRd281R21XSXVlRGVrYThnUmQvdTNTK0FXLS1YKzNBSC9LQjRNQ0F1SldvdS9TcXBnPT0%3D--e52ac52512a05b43f611a83848ea91a87acd9fe8; path=/; HttpOnly
X-Request-Id: f626f0a2-6cd0-459f-b01e-972a9fb88bdb
X-Runtime: 0.022738
Content-Length: 0

Getting a specific user

Endpoint

GET https://www.my-catalog.edu/api/v1/users/:id

Parameters

Name Description Type
id required Catalog user id Integer

Request

Route

GET https://www.my-catalog.edu/api/v1/users/4

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Catalog user id Integer
root_account_id Root account id Integer
canvas_user_id Canvas user id Integer
registered_account_id The account where the user was registered Integer
canvas_root_account_uuid Canvas root account UUID String
canvas_user_uuid Canvas user UUID String
user_name Full name String
first_name First name String
last_name Last name String
email_address E-mail address String
custom_fields Custom field values, e.g. { "phone": "(999) 123-4567" } Object
created_at Date/time of creation Datetime
updated_at Date/time of last update Datetime
time_zone User timezone String
merged_into_user_id The user where the user merged into Integer

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: ZY8DEUW0KGGV+bB3mCiuoE37KMilTENegrE5eLubjsYb14HaofD+WZNpsIXPSfz2cOppI7Bgff9YkMuQAi1KPg==
ETag: W/"0b0fcca7d441bcccb7ca0cd21742f03d"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=RVIzQVU3STdwdHVDRzBpdVIyQTFxYnZSOG9Ed0FOZEQvUVgxYmkxa0VZK3JmSnUxN3VoVVlDTlpJRHZZNFdYRlU2YjJwd1k0SzFET0tkNFJ0N3ZjL3VGa1RneDFzVmVoQWhsSnVmOEMxdlJ1S016UlJNcFJpRllFV2R0YnVjb3pINmVBQVVMaUczVWJNbmsvcm9ZcTQ3blhXZzU0Qk9PNXd2MWExUHQvWFFYb2gvb1B5RmdvRmZHTzBzcGpnQTdZLS1RRy9XZlpBalRXZmdtMVRDbDFWWFd3PT0%3D--862a0c007261a8f02f802918eb744aa275e53e06; path=/; HttpOnly
X-Request-Id: 1321b9b2-3021-415e-9f07-1e3be3989ece
X-Runtime: 0.022343
Content-Length: 540

Body

{
  "user": {
    "id": 4,
    "root_account_id": 24,
    "canvas_user_id": 2,
    "registered_account_id": 24,
    "canvas_root_account_uuid": "GUxMJJhiZ8ugUdRADskc0nJrcMXuYYIwV15aWiMO",
    "canvas_user_uuid": "573SBAKMeMX3pAa6iOcml1a81xzsVaomatXUBhUT",
    "user_name": "Firstname Lastname",
    "first_name": "Firstname",
    "last_name": "Lastname",
    "email_address": "user1@example.com",
    "custom_fields": {
      "favorite_color": "#BADA55",
      "code_of_conduct": "1",
      "age": "19"
    },
    "created_at": "2024-04-11T15:33:45.503Z",
    "updated_at": "2024-04-11T15:33:45.563514Z",
    "merged_into_user_id": 4,
    "time_zone": "Etc/UTC"
  }
}

List users

Endpoint

GET https://www.my-catalog.edu/api/v1/users

Parameters

Name Description Type
registered_in_catalog If true, only queries users registered through Catalog. If false, only queries users registered through Canvas. If not specified, queries all users. Boolean
canvas_user_id Canvas user id Integer
created_at_from Created at from. Suggested format YYYY-MM-DDTHH:MM:SSZ, e.g. 2018-01-01T00:00:00Z. System time zone is UTC. Datetime
created_at_to Created at to. Suggested format YYYY-MM-DDTHH:MM:SSZ, e.g. 2018-01-01T00:00:00Z. System time zone is UTC. Datetime
updated_at_from Updated at from. Suggested format YYYY-MM-DDTHH:MM:SSZ, e.g. 2018-01-01T00:00:00Z. System time zone is UTC. Datetime
updated_at_to Updated at to. Suggested format YYYY-MM-DDTHH:MM:SSZ, e.g. 2018-01-01T00:00:00Z. System time zone is UTC. Datetime

Request

Route

GET https://www.my-catalog.edu/api/v1/users?canvas_user_id=2&registered_in_catalog=true&created_at_from=2018-01-01T00%3A00%3A00Z&created_at_to=2024-05-01T00%3A00%3A00Z&updated_at_from=2018-01-01T00%3A00%3A00Z&updated_at_to=2024-05-01T00%3A00%3A00Z

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Query Parameters

canvas_user_id=2
registered_in_catalog=true
created_at_from=2018-01-01T00:00:00Z
created_at_to=2024-05-01T00:00:00Z
updated_at_from=2018-01-01T00:00:00Z
updated_at_to=2024-05-01T00:00:00Z

Response

Response Fields

Name Description Type
id Catalog user id Integer
root_account_id Root account id Integer
canvas_user_id Canvas user id Integer
registered_account_id The account where the user was registered Integer
canvas_root_account_uuid Canvas root account UUID String
canvas_user_uuid Canvas user UUID String
user_name Full name String
first_name First name String
last_name Last name String
email_address E-mail address String
custom_fields Custom field values, e.g. { "phone": "(999) 123-4567" } Object
created_at Date/time of creation Datetime
updated_at Date/time of last update Datetime
time_zone User timezone String
merged_into_user_id The user where the user merged into Integer

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: nXxeIwJxR2YK+2NFnHRlPspGpIwzQ/fczU1JcpTVJ0R7ipcyatdEcOBNB3igQTEbXMXoLF+XLQMd3MbmF3j22w==
ETag: W/"962daab88be3c0a94aa9e985dbf19575"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=MWVmMXozN21KZ01YczFySjR6S0pkZmpRMTlYSW5wc2kzbGh5Zm9UNHRPN3lqWGVaUXlUd2p3Z1BrK09Yd1VaK0t2ZFFmdHlOTVZ2MGNkTjlic25vVkZVNXdjemFoVDJFU3RVN2x3OGdNcE5sQTAvSllaKzRnUG9DUFQ3bHJVa0lEZzRPdGZIQzU3ODdxQVhaUW03K1BiL0xFL2FtbXFUeElXRHpPWVRLM2VVR1Bpc2lQaFRIaytVdVZZSmhFS1I0LS0yV2VETXliNVFvaVlmaUtDRWNhTlFRPT0%3D--f73ce2c09f2ec7dc45186488c79120a87a89ec8b; path=/; HttpOnly
X-Request-Id: 7960967c-4358-4ca8-a14a-2732d6845a2a
X-Runtime: 0.027643
Content-Length: 543

Body

{
  "users": [
    {
      "id": 1,
      "root_account_id": 21,
      "canvas_user_id": 2,
      "registered_account_id": 21,
      "canvas_root_account_uuid": "GUxMJJhiZ8ugUdRADskc0nJrcMXuYYIwV15aWiMO",
      "canvas_user_uuid": "573SBAKMeMX3pAa6iOcml1a81xzsVaomatXUBhUT",
      "user_name": "Firstname Lastname",
      "first_name": "Firstname",
      "last_name": "Lastname",
      "email_address": "user1@example.com",
      "custom_fields": {
        "favorite_color": "#BADA55",
        "code_of_conduct": "1",
        "age": "19"
      },
      "created_at": "2024-04-11T15:33:45.503Z",
      "updated_at": "2024-04-11T15:33:45.563514Z",
      "merged_into_user_id": 4,
      "time_zone": "Etc/UTC"
    }
  ]
}

Registering a user

Endpoint

POST https://www.my-catalog.edu/api/v1/users

Parameters

Name Description Type
user_name required Full user name String
first_name First name String
last_name Last name String
email_address required E-mail address (will also serve as login) String
registered_account_id ID of subcatalog to associate with user (optional). If not specified, the root account ID used to generate the API key will be registered_account_id Integer
custom_fields Hash of custom field values, e.g. { "phone": "867-5309" } (optional) Object

Request

Route

POST https://www.my-catalog.edu/api/v1/users

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Body

{
  "user_name": "Firstname Lastname",
  "first_name": "Firstname",
  "last_name": "Lastname",
  "email_address": "user1@example.com",
  "registered_account_id": 23,
  "custom_fields": {
    "favorite_color": "#BADA55",
    "code_of_conduct": "1",
    "age": "19"
  }
}

Response

Response Fields

Name Description Type
id Catalog user id Integer
root_account_id Root account id Integer
canvas_user_id Canvas user id Integer
registered_account_id The account where the user was registered Integer
canvas_root_account_uuid Canvas root account UUID String
canvas_user_uuid Canvas user UUID String
user_name Full name String
first_name First name String
last_name Last name String
email_address E-mail address String
custom_fields Custom field values, e.g. { "phone": "(999) 123-4567" } Object
created_at Date/time of creation Datetime
updated_at Date/time of last update Datetime
confirmation_url User confirmation url String
terms_of_use User term of use flag Boolean
locale User locale based on registered account String

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: NvxU1MMiNf2Fl/2jhfVVy6n9my5/vvYj+6Lf5RzOwOr/6Ilzh5H3f4Pzocw4dMD8eQ/oPiIVZEVmrAs870C5Cw==
ETag: W/"eb51d2d740b228ebb2e29fb07f84e4af"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=NTJHZ2dQenkwekZVUlplREd1Q05YR25ib1V5Tjd2TGxiYmZvQXRxRjhPM0JraDU5L0FSN3VUZkRzVmMwMFFsWWRjQStyc2h0VSs3NUFQM0IzUk9wajkxL0NOM2VuQXZQRmRYWUlaTG9NU0N6dmpldUlHK3hDMHRsTWJvS0RXMHV3SFErSjJWQzhBb0dUL2ZNRUxKbkxVcnJtbGZ5UUlJc0J4NlFmMG5nWVFsWStMeWF0dlFpL1dZVlQ4UDNTb25tLS1saUdmekJXa3h0aXc2eC85S0hTOHdBPT0%3D--d8e4cb6317d83ec180dbe6ecb2d17d6e9a04fcb4; path=/; HttpOnly
X-Request-Id: 5fd5a8e3-8b94-4cb4-bd92-72d3cd344676
X-Runtime: 0.062442
Content-Length: 603

Body

{
  "user": {
    "id": 3,
    "root_account_id": 23,
    "canvas_user_id": 2,
    "registered_account_id": 23,
    "canvas_root_account_uuid": "GUxMJJhiZ8ugUdRADskc0nJrcMXuYYIwV15aWiMO",
    "canvas_user_uuid": "573SBAKMeMX3pAa6iOcml1a81xzsVaomatXUBhUT",
    "user_name": "Firstname Lastname",
    "first_name": "Firstname",
    "last_name": "Lastname",
    "email_address": "user1@example.com",
    "custom_fields": {
      "favorite_color": "#BADA55",
      "code_of_conduct": "1",
      "age": "19"
    },
    "created_at": "2024-04-11T15:33:45.503Z",
    "updated_at": "2024-04-11T15:33:45.563514Z",
    "confirmation_url": "http://service.com/register/OBtRMuSPiFUAyStz47cbAiOHM",
    "terms_of_use": true,
    "locale": "en"
  }
}

Updating a specific user

This endpoint can be used to resolve login issues for users who encounter the “Current user has been deleted or merged. Please re-login” error after attempting to log in to the Catalog. To fix this issue, set the clear_merged_into_user_id parameter to true.

Endpoint

PUT https://www.my-catalog.edu/api/v1/users/:id?clear_merged_into_user_id=:clear_merged_into_user_id

Parameters

Name Description Type
id required Catalog user id Integer
clear_merged_into_user_id It will clear merged_into_user_id field of user if set to true Boolean

Request

Route

PUT https://www.my-catalog.edu/api/v1/users/2?clear_merged_into_user_id=true

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Content-Type: application/json
Host: www.my-catalog.edu
Cookie: 

Query Parameters

clear_merged_into_user_id=true

Response

Response Fields

Name Description Type
id Catalog user id Integer
root_account_id Root account id Integer
canvas_user_id Canvas user id Integer
registered_account_id The account where the user was registered Integer
canvas_root_account_uuid Canvas root account UUID String
canvas_user_uuid Canvas user UUID String
user_name Full name String
first_name First name String
last_name Last name String
email_address E-mail address String
custom_fields Custom field values, e.g. { "phone": "(999) 123-4567" } Object
created_at Date/time of creation Datetime
updated_at Date/time of last update Datetime
time_zone User timezone String
merged_into_user_id The user where the user merged into Integer

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: 6adugdY/FawfN/NZ+iQmcyCik45gQD9FeSMsI2WfsBDHEZjyXyOSfZnj2IzMdueo30VjaMffLs6N4QXDLZvxIQ==
ETag: W/"e4c8548aa3c8f4e93142cecfd854e0eb"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=N0JUM1hLb2Q3Q2R3cVZ2UG9EeHpPWlRhaWhYczJibVBDRDJGZTBBcTFTWGlCVGc2Nlh3VGgycm9UTGRpSnV0N2s0WjdxTE9wZnViWTkvTURNV1FDdmhFTVhCTCtQTDIzdmQwT3A3bS81UmxDcExucVpOUjk3NThrY0F3YzdVTG1XWU1yQUhaZ2F4cWxuRWMyR3ErU1hpWFlSR2RtZzdLSFJheWVOcFhQc0JsaDMxaDV1ajgvYU9sVW5WY3ByL0lCLS1KV1BEMHd6VXBOU3Y5MzRiRW0vbjJBPT0%3D--057c28a35be780ab88610d64132043aaf4b4a016; path=/; HttpOnly
X-Request-Id: bede1370-fd82-413a-883f-2dca5ac8ec91
X-Runtime: 0.023230
Content-Length: 543

Body

{
  "user": {
    "id": 2,
    "root_account_id": 22,
    "canvas_user_id": 2,
    "registered_account_id": 22,
    "canvas_root_account_uuid": "GUxMJJhiZ8ugUdRADskc0nJrcMXuYYIwV15aWiMO",
    "canvas_user_uuid": "573SBAKMeMX3pAa6iOcml1a81xzsVaomatXUBhUT",
    "user_name": "Firstname Lastname",
    "first_name": "Firstname",
    "last_name": "Lastname",
    "email_address": "user1@example.com",
    "custom_fields": {
      "favorite_color": "#BADA55",
      "code_of_conduct": "1",
      "age": "19"
    },
    "created_at": "2024-04-11T15:33:45.503Z",
    "updated_at": "2024-04-11T15:33:45.563514Z",
    "merged_into_user_id": null,
    "time_zone": "Etc/UTC"
  }
}

Waitlist applicants

Delete applicants

Endpoint

DELETE https://www.my-catalog.edu/api/v1/applicants

Parameters

Name Description Type
listing_id required Only delete applicants for the specified listing Integer
canvas_user_id Only delete applicants with the specified canvas user id if specified Integer

Request

Route

DELETE https://www.my-catalog.edu/api/v1/applicants

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Content-Type: application/x-www-form-urlencoded
Cookie: 

Body

listing_id=33

Response

Status

204

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
X-CSRF-Token: D3vL7t/gdjtg2I+CgLExY3ufVFJxeaBfk1Hhnxe32Jdt1YNpZ3iKJh0bWYIluf5qHN6rhBRG7r5Wuq5eCDtcYA==
Cache-Control: no-cache
Set-Cookie: _gallery_session=bVZUbTBzSG9ubDF4bW1EUGRYZThETFpFWlRMejJxUmIvTVc2U3FQbTFIUURaUVpjZi9QQXNhek9qQ0hwTGhXbUxaaU56Qi9iRWhXT2JxMnh1QWZoaU5mNThUT3RvZ1NoSHBrN2pIRDd4WlZyQzZqZ1U3V2M3WW51WXA1TTFjTklxQnY2NlZubjBEOVZVUzdLdWFlenRlMk5GbUZjT1MyMXJxRi9qUDZBZkduZVo2SUNpamhFWUE2eHcwdHp0dGNhLS1YelJBRDBPYzdwVUd5ekdwcjMzdTBRPT0%3D--143115be9310e54343febc1cf947283854dee3ff; path=/; HttpOnly
X-Request-Id: d7def759-6ef3-4131-bd1b-2ec6ecc5428d
X-Runtime: 0.025025

Getting a specific applicant record

Endpoint

GET https://www.my-catalog.edu/api/v1/applicants/:id

Request

Route

GET https://www.my-catalog.edu/api/v1/applicants/2

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Response Fields

Name Description Type
id Identifier for this applicant Integer
listing[id] Identifier for listing Integer
listing[title] Listing title String
user[id] User ID Integer
user[name] Full name String
user[email] E-mail address String
status Status (waitlist, accepted, expired, or error) String
notified_of_opening_at Time user was notified of opening Datetime
created_at The creation date for the applicant Datetime
updated_at The last time the applicant was updated Datetime

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Content-Type: application/json; charset=utf-8
X-CSRF-Token: +4Yn/+0xCsRPYR1UU55Dp3uAzpAZukLsw/W52scKGGhtpU2YP08qrN45W1vPz3v/bw3apz/wSoOGFgpJkV2aJA==
ETag: W/"8db04ac46ed839f1c97c8f798d7ce461"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=Y29MSlBEVFp5SDlxM1VCOHJpQTd4YTFYeGp4eURudjFPUnFzeEFLNGZMc2ZRMnRqaWdmTkdUZVBYdENoWlRudXNha055MVk5bjNkWkVOaC92L0dkS2hZQ0RMMnI5SlY3V3RFeVVmc1I2dlJzSGRncUFYTHBnV1hXTGpiRVZFMm1GazZPZy90RTBRWUFlbGF1Y0Q2cEY3YXd2ZXMxOFduamk3Q3pIUytQNk9ueEN1ZGVsa1VEVllJREpQT2RMdW16LS1HNVFJT2ZkS0ZoVEd0MkxXaFZCNGl3PT0%3D--d33030589a3991ace252bec91b12009e113f1f5b; path=/; HttpOnly
X-Request-Id: 241b1287-bdb1-4b03-8192-b1ef132248a1
X-Runtime: 0.026227
Content-Length: 255

Body

{
  "applicant": {
    "id": 2,
    "user": {
      "id": 2,
      "name": "Applicant",
      "email": "plz@letmein.com"
    },
    "listing": {
      "id": 32,
      "title": "Course 31"
    },
    "notified_of_opening_at": null,
    "status": "waitlist",
    "created_at": "2025/01/06 14:09:57 +0000",
    "updated_at": "2025/01/06 14:09:57 +0000"
  }
}

Listing applicants

Endpoint

GET https://www.my-catalog.edu/api/v1/applicants

Parameters

Name Description Type
listing_id Only include applicants for the specified listing Integer
status Only include applicants for the specified status (waitlist, accepted, declined, or expired) String

Request

Route

GET https://www.my-catalog.edu/api/v1/applicants

Headers

Version: HTTP/1.0
Authorization: Token token="my-token"
Host: www.my-catalog.edu
Cookie: 

Response

Status

200

Headers

X-Frame-Options: SAMEORIGIN
X-XSS-Protection: 1; mode=block
X-Content-Type-Options: nosniff
X-Download-Options: noopen
X-Permitted-Cross-Domain-Policies: none
Referrer-Policy: strict-origin-when-cross-origin
Per-Page: 20
Total: 1
Content-Type: application/json; charset=utf-8
X-CSRF-Token: FF3du4Uq96HZ448/34rzimoy2G65cWV2wfIf/nxJJ31jRcrEXF6Um0tmjtuyIwjiMuAuaoCnfnRWAhFhN/oUVg==
ETag: W/"eae986e814399e407cc05b9f00a00899"
Cache-Control: max-age=0, private, must-revalidate
Set-Cookie: _gallery_session=SHNpOWhYSThZUUp2NWhvdEp4R2gyNGpkRmFDaEx6RlFrMVdJREcyWWlCSXg1ZmdMRzB2a2t6TXdLeVVrU1hiTFliVFhxcXZWWFFGNFVjWXpsSkVXeGRmOXhzQktob1NZN3VqNDZFemhIKzJ5a3U3N1g2MVhST2N0TDB6dGZUNndTRlg1SEhXVzFLRlB2dWZXSmw1Sk9XT0tqRE5JbGRQelJvcWNqZTBSSXV3ZERpaWFhU0RpWnZNNkdlcHU5Ymw5LS1ndEFhbFV6U0JYS3dxY0Mzays1QVl3PT0%3D--779f0dd25b0200b04323d48d70365e1f15655ec0; path=/; HttpOnly
X-Request-Id: 0da20d7c-926a-4212-aa1f-f6c4a993e082
X-Runtime: 0.026275
Content-Length: 258

Body

{
  "applicants": [
    {
      "id": 1,
      "user": {
        "id": 1,
        "name": "Applicant",
        "email": "plz@letmein.com"
      },
      "listing": {
        "id": 31,
        "title": "Course 30"
      },
      "notified_of_opening_at": null,
      "status": "waitlist",
      "created_at": "2025/01/06 14:09:57 +0000",
      "updated_at": "2025/01/06 14:09:57 +0000"
    }
  ]
}