> ## Documentation Index
> Fetch the complete documentation index at: https://developer.onetrust.com/llms.txt
> Use this file to discover all available pages before exploring further.

# Publish Application SDK

Use this API to publish the script configuration options for the specified application.

# OpenAPI definition

```json
{
  "openapi": "3.1.0",
  "info": {
    "title": "Consent & Preferences - Cookie Consent",
    "version": "1.0",
    "contact": {
      "name": "OneTrust Support",
      "url": "https://my.onetrust.com/s/contactsupport"
    },
    "license": {
      "name": "Apache 2.0",
      "url": "https://www.apache.org/licenses/LICENSE-2.0"
    },
    "description": "The Cookie Consent APIs are used to integrate external systems and streamline the flow of data with Cookie Consent in the OneTrust Platform."
  },
  "servers": [
    {
      "url": "https://{hostname}",
      "variables": {
        "hostname": {
          "default": "hostname",
          "description": "The OneTrust hostname such as app.onetrust.com, app-eu.onetrust.com, app-de.onetrust.com, app-uk.onetrust.com, app-apac.onetrust.com, trial.onetrust.com, or uat.onetrust.com."
        }
      }
    }
  ],
  "tags": [
    {
      "name": "Scripts",
      "description": "The Scripts APIs are used to manage publishing of scripts to websites.",
      "externalDocs": {
        "description": "OpenAPI 3.1.0 - Download Definition",
        "url": "https://developer.onetrust.com/onetrust/openapi/consent-preferences-cookie-consent.json"
      }
    }
  ],
  "x-onetrust": {
    "spec-label": "OpenAPI 3.1.0"
  },
  "x-readme": {
    "explorer-enabled": false,
    "proxy-enabled": false,
    "metrics-enabled": false
  },
  "paths": {
    "/api/cmp/v1/applications/{id}/publish": {
      "put": {
        "operationId": "publishAppScript",
        "summary": "Publish Application SDK",
        "description": "Use this API to publish the script configuration options for the specified application.",
        "tags": [
          "Scripts"
        ],
        "x-onetrust": {
          "spec-label": "https://developer.onetrust.com/onetrust/openapi/consent-preferences-cookie-consent.json"
        },
        "parameters": [
          {
            "name": "id",
            "in": "path",
            "description": "UUID of the application to publish for",
            "required": true,
            "schema": {
              "type": "string",
              "format": "uuid"
            },
            "example": "f2229953-b4b5-4042-8cb9-b78038cc4c46"
          }
        ],
        "requestBody": {
          "required": true,
          "content": {
            "application/json": {
              "schema": {
                "$ref": "#/components/schemas/PublishGeolocationRuleRequestApplicationPublicDto"
              }
            }
          }
        },
        "responses": {
          "200": {
            "description": "OK"
          },
          "400": {
            "description": "Bad Request"
          },
          "401": {
            "description": "Unauthorized"
          },
          "403": {
            "description": "Forbidden"
          },
          "429": {
            "description": "Too Many Requests. \nFor more information, see [API Rate Limits](https://developer.onetrust.com/onetrust/reference/rate-limits-overview).",
            "headers": {
              "Retry-After": {
                "schema": {
                  "description": "The number of seconds after which requests will be allowed again.",
                  "format": "int32"
                }
              },
              "ot-period": {
                "schema": {
                  "description": "The unit of time for which the rate limit applies",
                  "enum": [
                    "HOUR",
                    "MINUTE"
                  ]
                }
              },
              "ot-ratelimit-event-id": {
                "schema": {
                  "description": "The unique identifier for the rate-limiting event.",
                  "format": "uuid"
                }
              },
              "ot-request-made": {
                "schema": {
                  "description": "The number of requests made within the specified period.",
                  "format": "int32"
                }
              },
              "ot-requests-allowed": {
                "schema": {
                  "description": "The number of requests allowed within the specified period.",
                  "format": "int32"
                }
              }
            }
          },
          "500": {
            "description": "Internal Server Error"
          }
        },
        "security": [
          {
            "OAUTH2": [
              "COOKIE",
              "COOKIE_READ"
            ]
          }
        ]
      }
    }
  },
  "components": {
    "schemas": {
      "PublishGeolocationRuleRequestApplicationPublicDto": {
        "type": "object",
        "properties": {
          "publishVersion": {
            "description": "Version to publish, by default the lastest version will be used.",
            "type": "string",
            "example": "202603.1.0",
            "maxLength": 255,
            "minLength": 1
          },
          "production": {
            "description": "Publish a test (false) or production (true)",
            "type": "boolean",
            "example": true,
            "default": "false"
          },
          "publishType": {
            "description": "The type of SDK being published",
            "type": "string",
            "example": "PUBLISHERS",
            "default": "HEADLESS",
            "enum": [
              "PUBLISHERS",
              "HEADLESS",
              "UNITY",
              "ROKU",
              "XAMARIN",
              "SAMSUNGTV",
              "LGTV",
              "VIZIOTV",
              "HBBTV",
              "PANASONICTV",
              "PS5",
              "YOUVIEW"
            ]
          },
          "requireReconsent": {
            "description": "If users will be required to reconsent once this update is published",
            "type": "boolean",
            "example": false,
            "default": "false"
          },
          "langCodes": {
            "description": "Languages to publish in, by default all languages will be published.",
            "type": "array",
            "items": {
              "type": "string"
            },
            "example": [
              "fr",
              "de",
              "en"
            ],
            "maxItems": 100,
            "minItems": 0
          },
          "regionRules": {
            "description": "Individual geolocation rules",
            "type": "array",
            "items": {
              "$ref": "#/components/schemas/PublishRegionRuleDto"
            },
            "example": [
              {
                "ruleId": "f2229953-b4b5-4042-8cb9-b78038cc4c46",
                "ruleName": "Global"
              },
              {
                "ruleId": "a1b2c3d4-e5f6-7890-abcd-ef1234567890",
                "ruleName": "Europe"
              }
            ],
            "maxItems": 1000,
            "minItems": 0
          }
        }
      },
      "PublishRegionRuleDto": {
        "type": "object",
        "properties": {
          "ruleId": {
            "description": "Unique identifier of the geo rule.",
            "type": "string",
            "format": "uuid",
            "example": "f2229953-b4b5-4042-8cb9-b78038cc4c46"
          },
          "ruleName": {
            "description": "Name of a Geolocation rule",
            "type": "string",
            "example": "Global",
            "maxLength": 255,
            "minLength": 1
          }
        }
      }
    },
    "securitySchemes": {
      "OAUTH2": {
        "type": "oauth2",
        "flows": {
          "clientCredentials": {
            "tokenUrl": "https://{hostname}/api/access/v1/oauth/token",
            "scopes": {
              "COOKIE": "Cookie Scope gives the user access to read/write operations inside the Cookie Consent module.",
              "COOKIE_READ": "Cookie Read Scope gives the user read-only access to the Cookie Consent module."
            }
          }
        }
      }
    }
  }
}
```