2023-02-26 18:08:07 -05:00
---
layout: '~/layouts/Markdown.astro'
title: 'Pub Packages Repository'
2023-03-03 01:44:11 -05:00
license: 'Apache-2.0'
2023-04-28 11:53:07 -04:00
origin_url: 'https://github.com/go-gitea/gitea/blob/ad03c6e0a36033c6f59262d8cfd6416ae3cc93d6/docs/content/doc/usage/packages/pub.en-us.md'
2023-02-26 18:08:07 -05:00
---
Publish [Pub ](https://dart.dev/guides/packages ) packages for your user or organization.
## Requirements
To work with the Pub package registry, you need to use the tools [dart ](https://dart.dev/tools/dart-tool ) and/or [flutter ](https://docs.flutter.dev/reference/flutter-cli ).
The following examples use dart.
## Configuring the package registry
To register the package registry and provide credentials, execute:
```shell
dart pub token add https://forgejo.example.com/api/packages/{owner}/pub
```
2023-03-03 01:44:11 -05:00
| Placeholder | Description |
| ----------- | ------------------------- |
| `owner` | The owner of the package. |
2023-02-26 18:08:07 -05:00
You need to provide your [personal access token ]({{< relref "doc/developers/api-usage.en-us.md#authentication" >}} ).
## Publish a package
To publish a package, edit the `pubspec.yaml` and add the following line:
```yaml
publish_to: https://forgejo.example.com/api/packages/{owner}/pub
```
2023-03-03 01:44:11 -05:00
| Placeholder | Description |
| ----------- | ------------------------- |
| `owner` | The owner of the package. |
2023-02-26 18:08:07 -05:00
Now you can publish the package by running the following command:
```shell
dart pub publish
```
You cannot publish a package if a package of the same name and version already exists. You must delete the existing package first.
## Install a package
To install a Pub package from the package registry, execute the following command:
```shell
dart pub add {package_name} --hosted-url=https://forgejo.example.com/api/packages/{owner}/pub/
```
2023-03-03 01:44:11 -05:00
| Parameter | Description |
| -------------- | ------------------------- |
| `owner` | The owner of the package. |
| `package_name` | The package name. |
2023-02-26 18:08:07 -05:00
For example:
```shell
# use latest version
dart pub add mypackage --hosted-url=https://forgejo.example.com/api/packages/testuser/pub/
# specify version
dart pub add mypackage:1.0.8 --hosted-url=https://forgejo.example.com/api/packages/testuser/pub/
```