#registry #proxy #environment #io #freighter #private #company

app freighter-registry

The Freighter's purpose is to help the community and company to build the proxy for crates.io and the registry for the development environment

1 unstable release

0.3.0 Dec 25, 2023

#1489 in Development tools

MIT license

125KB
2.5K SLoC

Freighter - Rust Proxy and Registry

The Freighter's purpose is to help the community and company to build the proxy for crates.io and the registry for the development environment.

Why need the Freighter?

When developing a program using Rust in a company, we need to host a proxy for crates.io and private crates registry for the following reasons:

  • The developers will only be allowed use crates of the company with security and complete evaluation.
  • Some crates need to upgrade functions or fix bugs, and the new version does not allow developers to contribute upstream.
  • Some private crates share with different teams and products in the development process.

What are the features?

  • The Freighter is a crate registry for private crates, public crates index and crates sync from crates.io. The registry can store the files in the local disk or storage service compliance S3.
  • The Freighter has an analytics engine for rating public crates.
  • The Freighter has a blacklist and whitelist of evaluated crates used in DevOps.

How to use the Freighter?

Freighter's functionality mainly consists of four parts: synchronizing crates index and crates; syncing the rustup-init files; syncing the rust toolchain files; providing a HTTP server that support static file server, parse the Git protocol, and offering API services such as crate publication.

Freighter can be executed as a standalone executable program. You can build it using the cargo build --release command and then copy it to your /usr/local/bin directory.

1. Synchronizing Crates Index and Crates

To sync crate files, Freighter needs to first sync the crates index. You can use the following command to sync the index file:

freighter crates pull

This command will create a crates.io-index directory in the default path /Users/${USERNAME}/freighter and fetch the index. If the index already exists, it will attempt to update it. You can also use the -c parameter to specify a working directory to change the storage location of the index and crates:

freighter -c /path/to/wokring_dir crates pull

Full download: Next, you can use the download command with the init parameter to download the full set of crates files:

freighter -c /path/to/wokring_dir crates download --init

Incremental update: Without the init parameter, Freighter will compare log records in the working directory to determine the index and crates that need incremental updates:

freighter -c /path/to/wokring_dir crates download

2.Syncing the rustup-init Files

3.Syncing the Rust Toolchain Files

4.Http Server

How to contribute?

This project enforce the DCO.

Contributors sign-off that they adhere to these requirements by adding a Signed-off-by line to commit messages.

This is my commit message

Signed-off-by: Random J Developer <random@developer.example.org>

Git even has a -s command line option to append this automatically to your commit message:

$ git commit -s -m 'This is my commit message'

License

Freighter is licensed under this Licensed:

Acknowledgements

Dependencies

~34–51MB
~1M SLoC