Add concepts in bulk

Create up to 50 concepts in a single request.

Recent Requests
Log in to see full request history
TimeStatusUser Agent
Retrieving recent requests…
LoadingLoading…

Add concepts in bulk

Create up to 50 concepts in a single request. Each concept is validated and persisted independently — a failure in one item doesn't block the others. The response reflects the outcome of each item individually, and the HTTP status reflects the overall result: 201 if all items succeeded, 207 if some failed, or 400 if all failed.

Note: Only users with the ADMIN_USER entity type can call this endpoint. Requests from non-admin users return HTTP 400 for every item.

Example request

curl -X POST "https://{host}/v2/locations/concepts" \
  -H "Authorization: Basic {base64-encoded-credentials}" \
  -H "Content-Type: application/json" \
  -d '[
    {
      "code": "concept-north",
      "name": "North Concept",
      "groupParentCode": "concept-root",
      "language": "en-IN",
      "currency": "INR",
      "timezone": "Asia/Kolkata",
      "description": "Northern region concept",
      "isActive": true
    }
  ]'

Prerequisites

  • Authenticate using Basic authentication (Base64-encoded username:password).
  • The authenticated user must have the ADMIN_USER entity type.
  • When inheritLocale is false (the default), the org must have the specified language, currency, and timezone values configured.
  • When inheritLocale is true, a valid groupParentCode must be provided so that locale settings can be inherited from the parent concept.

Query parameters

FieldTypeRequiredDescription
inheritLocalebooleanOptionalWhen true, a concept inherits language, currency, and timezone from its parent concept. A valid groupParentCode must be provided for inheritance to work. If the parent concept also lacks locale settings, the request fails. Defaults to false.

Body parameters

Pass a JSON array of concept objects. Maximum 50 items per request.

FieldTypeRequiredDescription
codestringRequiredUnique code for the concept in the org. Accepts lowercase letters, digits, periods (.), underscores (_), and hyphens (-). Must start with a lowercase letter or digit. Max 50 characters.
namestringRequiredDisplay name for the concept. Accepts letters, digits, underscores, and spaces. Cannot equal root (any case).
groupParentCodestringOptionalCode of the parent concept this concept belongs to. When provided, must be an existing active concept in the org. Omit to create a root-level concept.
languagestringConditionalIETF BCP 47 language code for the concept (for example, en-IN). Required when inheritLocale is false. Must be enabled for the org.
currencystringConditionalISO 4217 currency code for the concept (for example, INR). Required when inheritLocale is false. Must be enabled for the org.
timezonestringConditionalIANA timezone name for the concept (for example, Asia/Kolkata). Required when inheritLocale is false. Must be enabled for the org.
descriptionstringOptionalFree-text description of the concept.
isActivebooleanOptionalWhether the concept is active. Defaults to true. A warning is returned when this field is omitted.
isOrgUnitbooleanOptionalWhether this concept acts as an organizational unit. When omitted, the field is not set.
externalIdarrayOptionalExternal IDs for the concept. Max five entries. Each value must be non-blank, unique within the request, and not already assigned to another entity in the org.
attributesobjectOptionalCustom field values for the concept. Keys must match fields configured for the org (matched case-insensitively).

Example response

{
  "response": [
    {
      "entityId": 50826309,
      "result": {
        "code": "concept-north",
        "name": "North Concept",
        "description": "Northern region concept",
        "isActive": true,
        "language": "en-IN",
        "currency": "INR",
        "timezone": "Asia/Kolkata",
        "groupParentCode": "concept-root"
      },
      "errors": [],
      "warnings": []
    }
  ],
  "totalCount": 1,
  "failureCount": 0
}

Partial failure example (HTTP 207):

{
  "response": [
    {
      "entityId": 50826311,
      "result": {
        "code": "concept-north",
        "name": "North Concept",
        "isActive": true,
        "language": "en-IN",
        "currency": "INR",
        "timezone": "Asia/Kolkata"
      },
      "errors": [],
      "warnings": []
    },
    {
      "result": {
        "code": "concept-north",
        "name": "North Concept Duplicate",
        "isActive": true,
        "language": "en-IN",
        "currency": "INR",
        "timezone": "Asia/Kolkata"
      },
      "errors": [
        {
          "status": false,
          "message": "Code already Exists Orgs",
          "code": 1220
        }
      ],
      "warnings": []
    }
  ],
  "totalCount": 2,
  "failureCount": 1
}

Response parameters

FieldTypeDescription
responsearrayOne entry per input item, in the same order as the request.
.entityIdintegerSystem-assigned ID of the created concept. Absent when the item failed.
.resultobjectEcho of the submitted concept object. Always present for all items, whether the item succeeded or failed.
.errorsarrayErrors for this item. Empty when the item succeeded.
..codeintegerNumeric error code.
..messagestringError message.
..statusbooleanStatus flag for the error entry.
.warningsarrayNon-fatal warnings for this item.
..codeintegerNumeric warning code.
..messagestringWarning message.
..statusbooleanStatus flag for the warning entry.
totalCountintegerTotal number of items in the request.
failureCountintegerNumber of items that failed to create.

Error & warning codes

CodeError numberTypeDescription
NOT_AN_ADMIN_USER1209ErrorThe authenticated user is not an admin. HTTP 400.
BULK_REQUEST_LIMIT_EXCEEDED1246ErrorThe request contains more than 50 items. Maximum allowed is 50. HTTP 400.
CODE_NOT_SET1247Errorcode is missing or blank. HTTP 400.
NAME_NOT_SET1200Errorname is missing or blank. HTTP 400.
REGEX_MATCH_FAILED1219Errorcode or name failed format validation. HTTP 400.
NAME_LENGHT_NOT_VALID1218Errorcode exceeds 50 characters. HTTP 400.
NAME_ROOT_NOT_ALLOWED1210Errorname cannot equal root (any case). HTTP 400.
CODE_ALREADY_EXISTS_ORG1220ErrorA concept with this code already exists in the org, or a duplicate code appears in the same request. HTTP 400.
NAME_ALREADY_EXISTS_ORG1206ErrorA concept with this name already exists in the org. HTTP 400.
GLOBAL_ERR_MISSING_MANDATORY_FIELD403ErrorA required field is missing. Applies to locale fields (when inheritLocale is false) and blank externalId entries. HTTP 400.
PARAM_TYPE_IS_NOT_VALID1217ErrorA field value is invalid. Applies to a groupParentCode that does not match an active concept, locale values not enabled for the org, more than five externalId entries, and invalid attributes key names. HTTP 400.
EXTERNAL_ID_ALREADY_EXISTS_ORG1245ErrorOne or more externalId values are already assigned to another entity in the org. HTTP 400.
DUPLICATE_EXTERNAL_ID_IN_REQUEST1248ErrorDuplicate externalId values in the same request. HTTP 400.
ORG_ENTITY_TYPE_LIMIT_EXCEEDED1225ErrorThe org has reached its configured limit for concepts. HTTP 400.
PARAM_TYPE_SET_TO_DEFAULT1215WarningisActive was not provided and defaulted to true.
Query Params
boolean
Defaults to false

When true, inherits missing locale fields from the parent concept. Requires a valid groupParentCode.

Body Params
Headers
string
string
Responses
201

All concepts created successfully.

207

Partial success — some concepts created, some failed.

400

All items failed, non-admin user, batch size limit exceeded, or empty request body.

Language
Credentials
Basic
base64
:
URL
LoadingLoading…
Response
Click Try It! to start a request and see the response here!