mirror of
https://gitea.com/gitea/docs.git
synced 2026-06-23 20:55:55 +00:00
This adds explanations, that were missing regarding Token scopes and the packages feature requiring a token with said scope. Also added a missing explanation, that tokens can be created in the user interface, not just the API. The reason this PR is created was due to misunderstandings around the package feature, that arose during the discussion in https://github.com/go-gitea/gitea/issues/32048 . This PR aims to clarify the misunderstood points around tokens, scopes and the package feature. During the creation of this PR bug https://github.com/go-gitea/gitea/issues/32078 was found, the scopes are always reported as `null` during the response of the initial `POST` to create the token. Co-authored-by: Wladislav ヴラド Artsimovich <wladislav.artsimovich@dmgmori.co.jp> Co-authored-by: Lunny Xiao <xiaolunwen@gmail.com> Reviewed-on: https://gitea.com/gitea/docs/pulls/72 Reviewed-by: Lunny Xiao <xiaolunwen@gmail.com> Co-authored-by: FrostKiwi <frostkiwi@noreply.gitea.com> Co-committed-by: FrostKiwi <frostkiwi@noreply.gitea.com>
103 lines
4.2 KiB
Markdown
103 lines
4.2 KiB
Markdown
---
|
|
date: "2021-07-20T00:00:00+00:00"
|
|
slug: "overview"
|
|
sidebar_position: 1
|
|
---
|
|
|
|
# Overview
|
|
|
|
Starting with Gitea **1.17**, the Package Registry can be used as a public or private registry for common package managers.
|
|
|
|
## Supported package managers
|
|
|
|
The following package managers are currently supported:
|
|
|
|
| Name | Language | Package client |
|
|
| ---- | -------- | -------------- |
|
|
| [Alpine](usage/packages/alpine.md) | - | `apk` |
|
|
| [Arch](usage/packages/arch.md) | - | `pacman` |
|
|
| [Cargo](usage/packages/cargo.md) | Rust | `cargo` |
|
|
| [Chef](usage/packages/chef.md) | - | `knife` |
|
|
| [Composer](usage/packages/composer.md) | PHP | `composer` |
|
|
| [Conan](usage/packages/conan.md) | C++ | `conan` |
|
|
| [Conda](usage/packages/conda.md) | - | `conda` |
|
|
| [Container](usage/packages/container.md) | - | any OCI compliant client |
|
|
| [CRAN](usage/packages/cran.md) | R | - |
|
|
| [Debian](usage/packages/debian.md) | - | `apt` |
|
|
| [Generic](usage/packages/generic.md) | - | any HTTP client |
|
|
| [Go](usage/packages/go.md) | Go | `go` |
|
|
| [Helm](usage/packages/helm.md) | - | any HTTP client, `cm-push` |
|
|
| [Maven](usage/packages/maven.md) | Java | `mvn`, `gradle` |
|
|
| [npm](usage/packages/npm.md) | JavaScript | `npm`, `yarn`, `pnpm` |
|
|
| [NuGet](usage/packages/nuget.md) | .NET | `nuget` |
|
|
| [Pub](usage/packages/pub.md) | Dart | `dart`, `flutter` |
|
|
| [PyPI](usage/packages/pypi.md) | Python | `pip`, `twine` |
|
|
| [RPM](usage/packages/rpm.md) | - | `yum`, `dnf`, `zypper` |
|
|
| [RubyGems](usage/packages/rubygems.md) | Ruby | `gem`, `Bundler` |
|
|
| [Swift](usage/packages/swift.md) | Swift | `swift` |
|
|
| [Vagrant](usage/packages/vagrant.md) | - | `vagrant` |
|
|
|
|
**The following paragraphs only apply if Packages are not globally disabled!**
|
|
|
|
## Repository-Packages
|
|
|
|
A package always belongs to an owner (a user or organisation), not a repository.
|
|
To link an (already uploaded) package to a repository, open the settings page
|
|
on that package and choose a repository to link this package to.
|
|
The entire package will be linked, not just a single version.
|
|
|
|
Linking a package results in showing that package in the repository's package list,
|
|
and shows a link to the repository on the package site (as well as a link to the repository issues).
|
|
|
|
## Access Restrictions
|
|
|
|
| Package owner type | User | Organization |
|
|
|--------------------|------|--------------|
|
|
| **read** access | public, if user is public too; otherwise for this user only | public, if org is public, otherwise for org members only |
|
|
| **write** access | owner only | org members with admin or write access to the org |
|
|
|
|
Please note, that your respective package manager needs to have a [personal access token](development/api-usage.md#authentication) with the permissions `package` set to either Read or Read & Write to download and publish packages respectively.
|
|
|
|
N.B.: These access restrictions are [subject to change](https://github.com/go-gitea/gitea/issues/19270), where more finegrained control will be added via a dedicated organization team permission.
|
|
|
|
## Create or upload a package
|
|
|
|
Depending on the type of package, use the respective package-manager for that. Check out the sub-page of a specific package manager for instructions.
|
|
|
|
## View packages
|
|
|
|
You can view the packages of a repository on the repository page.
|
|
|
|
1. Go to the repository.
|
|
1. Go to **Packages** in the navigation bar.
|
|
|
|
To view more details about a package, select the name of the package.
|
|
|
|
## Download a package
|
|
|
|
To download a package from your repository:
|
|
|
|
1. Go to **Packages** in the navigation bar.
|
|
1. Select the name of the package to view the details.
|
|
1. In the **Assets** section, select the name of the package file you want to download.
|
|
|
|
## Delete a package
|
|
|
|
You cannot edit a package after you have published it in the Package Registry. Instead, you
|
|
must delete and recreate it.
|
|
|
|
To delete a package from your repository:
|
|
|
|
1. Go to **Packages** in the navigation bar.
|
|
1. Select the name of the package to view the details.
|
|
1. Click **Delete package** to permanently delete the package.
|
|
|
|
## Disable the Package Registry
|
|
|
|
The Package Registry is automatically enabled. To disable it for a single repository:
|
|
|
|
1. Go to **Settings** in the navigation bar.
|
|
1. Disable **Enable Repository Packages Registry**.
|
|
|
|
Previously published packages are not deleted by disabling the Package Registry.
|