npm Package Registry

Publish npm packages for your user or organization.

Requirements

To work with the npm package registry, you need Node.js coupled with a package manager such as Yarn or npm itself.

The registry supports scoped and unscoped packages.

The following examples use the npm tool with the scope @test.

Configuring the package registry

To register the package registry you need to configure a new package source.

  1. npm config set {scope}:registry https://gitea.example.com/api/packages/{owner}/npm/
  2. npm config set -- '//gitea.example.com/api/packages/{owner}/npm/:_authToken' "{token}"
ParameterDescription
scopeThe scope of the packages.
ownerThe owner of the package.
tokenYour personal access token.

For example:

  1. npm config set @test:registry https://gitea.example.com/api/packages/testuser/npm/
  2. npm config set -- '//gitea.example.com/api/packages/testuser/npm/:_authToken' "personal_access_token"

or without scope:

  1. npm config set registry https://gitea.example.com/api/packages/testuser/npm/
  2. npm config set -- '//gitea.example.com/api/packages/testuser/npm/:_authToken' "personal_access_token"

Publish a package

Publish a package by running the following command in your project:

  1. npm publish

You cannot publish a package if a package of the same name and version already exists. You must delete the existing package first.

Unpublish a package

Delete a package by running the following command:

  1. npm unpublish {package_name}[@{package_version}]
ParameterDescription
package_nameThe package name.
package_versionThe package version.

For example:

  1. npm unpublish @test/test_package
  2. npm unpublish @test/test_package@1.0.0

Install a package

To install a package from the package registry, execute the following command:

  1. npm install {package_name}
ParameterDescription
package_nameThe package name.

For example:

  1. npm install @test/test_package

Tag a package

The registry supports version tags which can be managed by npm dist-tag:

  1. npm dist-tag add {package_name}@{version} {tag}
ParameterDescription
package_nameThe package name.
versionThe version of the package.
tagThe tag name.

For example:

  1. npm dist-tag add test_package@1.0.2 release

The tag name must not be a valid version. All tag names which are parsable as a version are rejected.

Search packages

The registry supports searching but does not support special search qualifiers like author:gitea.

Supported commands

  1. npm install
  2. npm ci
  3. npm publish
  4. npm unpublish
  5. npm dist-tag
  6. npm view
  7. npm search