REST API Reference for Microsoft Edge Add-ons
This article is the REST endpoint reference for the Microsoft Edge Add-ons API. This API automates publishing updates to add-ons that have been submitted to the Microsoft Edge Add-ons store.
For an overview, see Using the Microsoft Edge Add-ons REST API.
Versions of the REST API
As of September 6, 2024, both v2 and v1 of this REST API are supported. Later, v1 will no longer be supported. The date for ending v1 support is not yet finalized.
Upload a package to update an existing submission
Uploads a package to update an existing draft submission of an add-on product.
Request
Method | Request URI |
---|---|
POST |
/products/{productID}/submissions/draft/package |
URI parameters
URI parameter | Description |
---|---|
productID |
Required. The product ID of the product to which the package must be uploaded. |
Request headers
The following request headers are required:
Request body
<Zip package>
Response
Response headers
- Location:
{operationID}
Status codes
This API has the following expected status codes.
HTTP status code | Description |
---|---|
202 | The request is accepted for processing, but the processing isn't complete. |
4XX | See Error codes, below. |
5XX | See Error codes, below. |
See also:
- Uploading a package to update an existing submission in Using the Microsoft Edge Add-ons REST API.
Check the status of a package upload
Gets the status of the package upload.
Request
Method | Request URI |
---|---|
GET |
/products/{productID}/submissions/draft/package/operations/{operationID} |
URI parameters
URI parameter | Description |
---|---|
operationID |
Required. The operation ID of the upload request submitted in the previous step. This information is available in the response header. |
Request headers
The following request headers are required:
Request body
None.
Response
There are several responses, for different scenarios.
Response when the operation is still in progress
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": "Date Time",
"status": "InProgress",
"message": null,
"errorCode": null,
"errors": null
}
Response when the operation succeeds
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": "Date Time",
"status": "Succeeded",
"message": "Successfully updated package to {fileName}.zip",
"errorCode": "",
"errors": null
}
Response when the operation fails with errors
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": "Date Time",
"status": "Failed",
"message": "Error Message.",
"errorCode": "Error Code",
"errors": ["list of errors"]
}
Response headers
None.
Status codes
This API has the following expected status codes.
HTTP status code | Description |
---|---|
200 | The request is OK. |
4XX | See Error codes, below. |
5XX | See Error codes, below. |
See also:
- Checking the status of a package upload in Using the Microsoft Edge Add-ons REST API.
Publish the product draft submission
Publishes the current draft of the product to Microsoft Edge Add-ons.
Request
Method | Request URI |
---|---|
POST |
/products/{productID}/submissions |
URI parameters
URI parameter | Description |
---|---|
productID |
Required. The product ID of the product whose draft must be published. |
Request headers
The following request headers are required:
Request body
<Notes for certification>
, in plain text format.
Response
Response headers
- Location:
{operationID}
Status codes
This API has the following expected status codes.
HTTP status code | Description |
---|---|
202 | The request is accepted for processing, but the processing isn't complete. |
4XX | See Error codes, below. |
5XX | See Error codes, below. |
See also:
- Publishing the submission in Using the Microsoft Edge Add-ons REST API.
Check the publishing status
Checks the status of the publish operation.
Request
Method | Request URI |
---|---|
GET |
/products/{productID}/submissions/operations/{operationID} |
URI parameters
None.
Request headers
The following request headers are required:
Request body
None.
Response
A GET
operation status API can be called in the following scenarios. In all valid scenarios, 200 OK
is returned, with different status messages.
Response when a new product is published
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "Can't create new extension.",
"errorCode": "CreateNotAllowed",
"errors": null
}
Response when there's nothing new to be published
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "Can't publish extension since there are no updates, please try again after updating the package.",
"errorCode": "NoModulesUpdated",
"errors": null
}
Response when there's an in-review submission for the same product
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "Can't publish extension as your extension submission is in progress. Please try again later.",
"errorCode": "InProgressSubmission",
"errors": null
}
Response when there's an ongoing unpublished submission for the same product
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "Can't publish extension as your extension is being unpublished. Please try after you've unpublished.",
"errorCode": "UnpublishInProgress",
"errors": null
}
Response where any of the modules are invalid
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "Can't publish extension as your extension has modules that are not valid. Fix the modules with errors and try to publish again.",
"errorCode": "ModuleStateUnPublishable",
"errors": [
{
"message": "Invalid module : <Modules>"
}
]
}
Response when there are validation errors in submission
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "Extension can't be published as there are submission validation failures. Fix these errors and try again later.",
"errorCode": "SubmissionValidationError",
"errors": ["{list of errors}"]
}
Response when the publish call succeeds
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": "Date Time",
"status": "Succeeded",
"message": "Successfully created submission with ID {submission.Id}",
"errorCode": "",
"errors": null
}
Response when the publish call fails with an irrecoverable failure
{
"id": "{operationID}",
"createdTime": "Date Time",
"lastUpdatedTime": " Date Time ",
"status": "Failed",
"message": "An error occurred while performing the operation",
"errorCode": null,
"errors": null
}
Response when the publish call fails with an unexpected failure
{
"id": "{operationID}",
"message": "An error occurred while processing the request. Please contact support Correlation ID: {operationID} Timestamp: {timeStamp}",
}
Response headers
None.
Status codes
This API has the following expected status codes.
HTTP status code | Description |
---|---|
200 | The request is OK. |
4XX | See Error codes, below. |
5XX | See Error codes, below. |
See also:
- Checking the publishing status in Using the Microsoft Edge Add-ons REST API.
Error codes
Here's a list of common error codes and possible reasons. For a full list, see Partner Center REST error codes or List of HTTP status codes.
4xx: Client error
Message | Description | Example scenario |
---|---|---|
400 Bad Request | The server didn't understand the request. | There's no package (zip file) in the body. Or, Content-Type header is missing or its value is incorrect. |
401 Unauthorized | The request page needs an authorization. | The auth token is missing, expired, or not valid. |
404 Not Found | The server can't find the requested page. | The specified productID or operationID doesn't have a valid GUID, isn't valid, or doesn't belong to the developer who is making the request. |
408 Request Timeout | The request took longer than the server was prepared to wait. | There was a timeout while uploading a package. |
429 Too many requests | Too many requests were sent by the user. | Too many requests were sent and they got throttled. |
5xx: Server error
Message | Description | Example scenario |
---|---|---|
500 Internal Server Error | The request wasn't completed. | The server met an unexpected condition. |
See also
- Using the Microsoft Edge Add-ons REST API
- Partner Center REST error codes in Partner Center docs.
- List of HTTP status codes at Wikipedia.