Skip to content

Getting Started

Introduction⚓︎

Alert

If you currently publish to oss.sonatype.org or s01.oss.sonatype.org, please continue to use our original publishers' guide. If you are interested in migrating to the Central Publisher Portal, please send a message to Central Support, so we can walk you through the migration process. Publishing via the existing workflow and the new workflow to the same namespace is not possible, however migrating back to the OSSRH workflow is supported.

Publishing Your Components⚓︎

After your namespace has been verified, you're finally ready to start uploading components to Maven Central! See the following documentation for further instructions:

Component Validation⚓︎

After your upload is accepted, Central Publisher Portal will begin the validation process:

Publishing Settings - Deployment Submitted

The validation process ensures that your components meet all the requirements for Maven Central. Validation should not take more than a few minutes. Click the "Refresh" button to see the status of the validation process.

If your components do not meet all the requirements your Deployment will fail. The right column of the Deployment card, labeled "Validation Results," will detail which validations failed. Once you address those issues in your local build, you can click "Publish Component" again to start a new Deployment where you can submit the updated zip file.

Once the validation is complete and if there are no errors, you are able to publish your components. Pressing the "Publish" button will sync automatically to Maven Central. Congratulations!

A screenshot of the deployments page that shows the Publish and Drop buttons for a specific deployment

Important

Once released/published, you will not be able to remove/update/modify your components. Please see the Can I change (modify, delete, update) a component on Central? FAQ for more details on this long-standing policy.

Deployments visible on the Deployments Tab will be cleaned up after 90 days.

Adding a Webhook⚓︎

Central Publisher Portal enables publishers to specify a webhook, which will fire after components have passed validation and are approved for sync to Maven Central. Publishers can use webhooks to get notified in their messaging systems or to trigger other workflows within their organizations.

To add a webhook, click the "View Webhooks" link in the top-right menu under your username/email address:

Screenshot of View Webhooks

Provide the required Webhook URL and, if required, a username and password for our service to send when calling your webhook. Click Save button to save your changes:

Screenshot of Update Webhook

If you have provided a valid URL (and optional credentials), your webhook be called as soon as you attempt to deploy a component. The webhook will provide details about the publishing status.

Webhook request details⚓︎

A request to a Webhook will have the following format:

  • a POST request to the given Webhook URL
  • a JSON body with the following fields:
Name Type Description
deploymentId string UUID (36) Unique ID of deployment
deploymentName string Name of the deployment
timestamp long timestamp Timestamp of notification to Webhook
status string State of deployment

VALIDATED: Deployment was successfully validated

PUBLISHING: Deployment is publishing

PUBLISHED: Deployment was successfully published

FAILED: Validation or publishing failed
packageUrls string array PURLs of deployed components
centralPaths string array URLs to repo1 of deployed components

Webhook notification known issues

The VALIDATED notification is not sent when autoPublish is enabled in central-publishing-maven-plugin. The PUBLISHED notification could be duplicated or could be completely missing, depending on publishing conditions.

Sample of the JSON body send

{
  "deploymentId": "abcdefgh-1234-abcd-1234-abcdefghijkl",
  "timestamp": 1710000,
  "status": "VALIDATED",
  "packageUrls": [
    "pkg:maven/org.sonatype.central.test/exampl@1.0.0"
  ],
  "centralPaths": [
    "https://repo1.maven.org/maven2/org/sonatype/central/test/example/1.0.0/example-1.0.0.pom"
  ]
}

A sample request that Sonatype makes to a Webhook, represented in CURL.

curl -X 'POST' '<your webhook url>' \
     -H 'content-type: application/json' \
     -H 'accept: application/json' \
     --data-raw '{"deploymentId":"abcdefgh-1234-abcd-1234-abcdefghijkl","timestamp":1710000000000,"status":"VALIDATED","packageUrls":["pkg:maven/org.sonatype.central.test/exampl@1.0.0"],"centralPaths":["https://repo1.maven.org/maven2/org/sonatype/central/test/example/1.0.0/example-1.0.0.pom"]}'