0
0
Fork 0
mirror of https://codeberg.org/forgejo/docs.git synced 2024-11-28 18:42:51 -05:00
forgejo-docs/docs/user/packages/chef.md
Earl Warren b77359bfb1
sync with the latest changes from Gitea
git log --patch faa28b5a44912f1c63afddab9396bae9e6fe061c..8d9e2d07f3f84a86265fdbe0ab7fcf63cc34ddbd . ':(glob)docs/**/*.en-us.md'
2023-09-22 19:20:11 +02:00

2.5 KiB

title license origin_url
Chef Package Registry Apache-2.0 8d9e2d07f3/docs/content/usage/packages/chef.en-us.md

Publish Chef cookbooks for your user or organization.

Requirements

To work with the Chef package registry, you have to use knife.

Authentication

The Chef package registry does not use an username:password authentication but signed requests with a private:public key pair. Visit the package owner settings page to create the necessary key pair. Only the public key is stored inside Forgejo. if you loose access to the private key you must re-generate the key pair. Configure knife to use the downloaded private key with your Forgejo username as client_name.

Configure the package registry

To configure knife to use the Forgejo package registry add the url to the ~/.chef/config.rb file.

knife[:supermarket_site] = 'https://forgejo.example.com/api/packages/{owner}/chef'
Parameter Description
owner The owner of the package.

Publish a package

To publish a Chef package execute the following command:

knife supermarket share {package_name}
Parameter Description
package_name The package name.

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 package from the package registry, execute the following command:

knife supermarket install {package_name}

Optional you can specify the package version:

knife supermarket install {package_name} {package_version}
Parameter Description
package_name The package name.
package_version The package version.

Delete a package

If you want to remove a package from the registry, execute the following command:

knife supermarket unshare {package_name}

Optional you can specify the package version:

knife supermarket unshare {package_name}/versions/{package_version}
Parameter Description
package_name The package name.
package_version The package version.