Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Update OTP badge to tally with CI version #339

Merged
merged 1 commit into from
Jun 23, 2024
Merged
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
74 changes: 37 additions & 37 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,13 +1,13 @@
# rebar3_hex

[![Build Status](https://github.com/erlef/rebar3_hex/actions/workflows/ci.yml/badge.svg)](https://github.com/erlef/rebar3_hex/actions/workflows/ci.yml)
[![Build Status](https://github.com/erlef/rebar3_hex/actions/workflows/ci.yml/badge.svg)](https://github.com/erlef/rebar3_hex/actions/workflows/ci.yml)
[![Hex pm](https://img.shields.io/hexpm/v/rebar3_hex.svg)](https://hex.pm/packages/rebar3_hex)
[![Docs](https://img.shields.io/badge/hex-docs-green.svg?style=flat)](https://hexdocs.pm/rebar3_hex)
[![Erlang Versions](https://img.shields.io/badge/Supported%20Erlang%2FOTP-22.0%20to%2024.0-blue)](http://www.erlang.org)
[![Erlang Versions](https://img.shields.io/badge/Supported%20Erlang%2FOTP-25.0%20to%2027.0-blue)](http://www.erlang.org)

rebar3_hex is a plugin for [Rebar3](https://www.rebar3.org/) that bundles providers to interact with [Hex](https://hex.pm/).

> 💡 **rebar3_hex is a tool for package authors**
> 💡 **rebar3_hex is a tool for package authors**
> If your Erlang project is not meant to be published on Hex, Rebar3 itself should be enough for you.

## Setup
Expand All @@ -18,22 +18,22 @@ Add to your global rebar3 config in `~/.config/rebar3/rebar.config`:
{plugins, [rebar3_hex]}.
```

Alternatively, you can add to your project's rebar3 config in project plugins :
Alternatively, you can add to your project's rebar3 config in project plugins :

```erlang
{project_plugins, [rebar3_hex]}.
```

**NOTE** : Be sure **not** to add `rebar3_hex` to the plugins section within a projects rebar3 config as this will
**NOTE** : Be sure **not** to add `rebar3_hex` to the plugins section within a projects rebar3 config as this will
become a dependency for others downloading your package from hex.pm

### Documentation

rebar3_hex by default expects you to configure a documentation provider. We recommend using
[rebar3_ex_doc](https://hexdocs.pm/rebar3_ex_doc/) for publishing documentation along with your package for a
consistent format and style on [hex.pm](https://hex.pm/).
[rebar3_ex_doc](https://hexdocs.pm/rebar3_ex_doc/) for publishing documentation along with your package for a
consistent format and style on [hex.pm](https://hex.pm/).

Example :
Example :

```erlang

Expand All @@ -46,16 +46,16 @@ Example :
{hex, [{doc, ex_doc}]}.
```

Alternatively, or on Erlang versions older than OTP-24, you can use the edoc provider that ships with rebar3 :
Alternatively, or on Erlang versions older than OTP-24, you can use the edoc provider that ships with rebar3 :

```erlang
{hex, [{doc, edoc}]}.
```

## Basic usage
## Basic usage

You should read the [docs](https://hexdocs.pm/rebar3_hex/) for a complete over for each provider, but below is a
brief overview of basic usage.
brief overview of basic usage.

### Authenticating User

Expand All @@ -66,8 +66,8 @@ If you already have a user for [hex.pm](https://hex.pm) run:
$ rebar3 hex user auth
```

Note that this will ask for your hex.pm username and password, as well as a password for encrypting your api token that
has write permissions to the repository. When publishing a package you will have to give this password to decrypt the
Note that this will ask for your hex.pm username and password, as well as a password for encrypting your api token that
has write permissions to the repository. When publishing a package you will have to give this password to decrypt the
token in order to publish.

See the [docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_user.html) for more information.
Expand All @@ -76,7 +76,7 @@ See the [docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_user.html) for more info

The `build` provider is very useful for seeing exactly what would be published using either the `publish` or `cut` task
without any chance of actually publishing the package or docs. Tarballs for the package and docs are written to
`_build/<profile>/lib/your_app/hex/` by default.
`_build/<profile>/lib/your_app/hex/` by default.


```
Expand All @@ -85,61 +85,61 @@ $ rebar3 hex build

See the [docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_build.html) for more information.

### Publishing
### Publishing

Two providers are available for publishing packages, `publish` and `cut`
Two providers are available for publishing packages, `publish` and `cut`

By default `publish` builds and pushes your package and docs to a repository. See the
[docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_publish.html) for more information.
By default `publish` builds and pushes your package and docs to a repository. See the
[docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_publish.html) for more information.

``` shell
$ rebar3 hex publish
```

`cut` is available to provide some additional functionality around versioning and git tags. See the
`cut` is available to provide some additional functionality around versioning and git tags. See the
[docs](https://hexdocs.pm/hex/rebar3_hex_cut.html) for more information.

``` shell
$ rebar3 hex cut
```

In either case, both providers will display the details of what is being published
(what files, the version, dependencies) and ask if it should continue, so be sure to read the
In either case, both providers will display the details of what is being published
(what files, the version, dependencies) and ask if it should continue, so be sure to read the
output carefully and make sure it is publishing what you expected.

### Managing package owners
### Managing package owners

Owners can be added, removed, and listed for packages you are an owner of with the `hex owner` command. Packages
can also be transfered to other registered users on hexpm as well.
can also be transfered to other registered users on hexpm as well.

``` shell
$ rebar3 hex owner [add | remove | list | transfer] <package> <email>
```

See the [docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_owner.html) for more information.

### Retiring packages
### Retiring packages

Packages can be flagged as retired on hexpm via the `retire` provider :
Packages can be flagged as retired on hexpm via the `retire` provider :

```
$ rebar3 hex retire PACKAGE VERSION REASON --message
```

They can also be unretired in case a mistake was made :
They can also be unretired in case a mistake was made :

```
$ rebar3 hex retire PACKAGE VERSION --unretire
$ rebar3 hex retire PACKAGE VERSION --unretire
```

See the [docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_retire.html) for more information.

### Organizations

rebar3_hex supports working with organizations via the `organization` provider.
rebar3_hex supports working with organizations via the `organization` provider.

Simply add your organization to either your global rebar.config (i.e., `~/.config/rebar3/rebar.config` ) or a local
project rebar.config.
project rebar.config.

```erlang
{hex, [{repos, [#{name => <<"hexpm:your_org">>}]}]}.
Expand All @@ -149,7 +149,7 @@ You can then authenticate with with the organization repository. Be sure you hav
repository first:

```
$ rebar3 hex auth # make sure you're authenticated to the main repo first
$ rebar3 hex auth # make sure you're authenticated to the main repo first
$ rebar3 hex organization auth hexpm:your_org # authenticate to the org
```

Expand All @@ -160,37 +160,37 @@ See the [docs](https://hexdocs.pm/rebar3_hex/rebar3_hex_organization.html) for m

#### Read-Only Repo Key for CI

If you have a private organization or other private repository it is recommended that you use a repo specific
If you have a private organization or other private repository it is recommended that you use a repo specific
auth token for reading from the repository in CI. To generate a token:

```shell
$ rebar3 hex organization auth hexpm:myrepo
Successfully authenticated to hexpm:myrepo
```

Now you can generate a key to use in CI for your organization
Now you can generate a key to use in CI for your organization

```
$ rebar3 hex organization key hexpm:myrepo generate
abc123
```

Then in CI use whatever method is available for setting an environment variable to the token and add this call at the
Then in CI use whatever method is available for setting an environment variable to the token and add this call at the
beginning of your CI runs to add the token to your rebar3 hex config. Below we'll use the environment `REPO_KEY` as an
example.
example.

```shell
$ rebar3 hex organization auth hexpm:myrepo --key $REPO_KEY
```

### Searching hexpm
### Searching hexpm

A `search` provider is available to search packages across hex.pm as a convenience.

```
$ rebar3 hex search
```

# Further reading
See [Publishing packages](https://hex.pm/docs/rebar3-publish) on hexpm for more setup and usage instructions. See the
# Further reading
See [Publishing packages](https://hex.pm/docs/rebar3-publish) on hexpm for more setup and usage instructions. See the
[docs](https://hexdocs.pm/rebar3_hex) for detailed documentation for all available providers.