Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/iwatakeshi/gitly_ex
An Elixir library for easily downloading and extracting Git repositories from various hosting services.
https://github.com/iwatakeshi/gitly_ex
Last synced: 6 days ago
JSON representation
An Elixir library for easily downloading and extracting Git repositories from various hosting services.
- Host: GitHub
- URL: https://github.com/iwatakeshi/gitly_ex
- Owner: iwatakeshi
- License: mit
- Created: 2024-06-26T19:12:41.000Z (6 months ago)
- Default Branch: main
- Last Pushed: 2024-06-29T23:41:44.000Z (6 months ago)
- Last Synced: 2024-11-20T14:22:53.516Z (about 2 months ago)
- Language: Elixir
- Homepage:
- Size: 71.3 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# Gitly
An Elixir library for easily downloading and extracting Git repositories from various hosting services.
[![codecov](https://codecov.io/gh/iwatakeshi/gitly_ex/graph/badge.svg?token=5XYXSI97PO)](https://codecov.io/gh/iwatakeshi/gitly_ex)
[![Elixir CI](https://github.com/iwatakeshi/gitly_ex/actions/workflows/elixir.yml/badge.svg)](https://github.com/iwatakeshi/gitly_ex/actions/workflows/elixir.yml)
[![Hex.pm](https://img.shields.io/hexpm/v/gitly.svg)](https://hex.pm/packages/gitly)
[![Hex.pm](https://img.shields.io/hexpm/dt/gitly.svg)](https://hex.pm/packages/gitly)
[![Hex.pm](https://img.shields.io/hexpm/l/gitly.svg)](https://hex.pm/packages/gitly)## Features
- Download repositories from popular Git hosts
- Extract downloaded archives
- Flexible options for caching, retrying, and formatting
- Support for various archive formats (zip, tar, tar.gz, tgz) if supported by the provider
- Support for various hosts (GitHub, GitLab, BitBucket)## Installation
Add `gitly` to your list of dependencies in `mix.exs`:
```elixir
def deps do
[
{:gitly, "~> 0.1.0"}
]
end
```Then run `mix deps.get` to install the dependency.
## Usage
### Basic Usage
To download and extract a repository:
```elixir
import Gitly, only: [gitly: 1, gitly: 2]
{:ok, path} = gitly("username/repo")
```This will download the repository and return the path to the extracted contents.
The following inputs are supported:
- `owner/repo`
- `https://host.com/owner/repo`
- `https://host.com/owner/repo.git`
- `host.com/owner/repo`
- `host:owner/repo`#### Note
`gitly` will return the path that includes the root of the extracted directory.
If there are more than one folder in the parent directory, then the path to the parent directory would be returned.
This behavior may change in the future.### Download Only
If you only want to download the repository without extracting:
```elixir
import Gitly, only: [download: 1, download: 2]
{:ok, _path} = download("username/repo")
```### Extract an Existing Archive
To extract an already downloaded archive:
```elixir
import Gitly, only: [extract: 1, extract: 2]
{:ok, _path } = extract("/path/to/archive.zip")
```Or to specify a destination:
```elixir
import Gitly, only: [extract: 1, extract: 2]
{:ok, _path } = extract("/path/to/archive.zip", "/path/to/destination")
```#### Note
`extract` will return the path that you specified.
## Options
Gitly supports various options to customize its behavior:
- `:force` - Force download even if the archive already exists
- `:cache` - Use local cache for downloads
- `:overwrite` - Overwrite existing files when extracting
- `:retry` - Retry options for failed downloads
- `:retry_delay` - Custom function to determine delay between retries
- `:retry_log_level` - Set log level for retry attempts
- `:max_retries` - Maximum number of retry attempts
- `:ref` - Specify a particular Git reference to download
- `:root` - Set the root path for storing archives
- `:format` - Specify the archive format (:zip, :tar, :tar_gz, or :tgz)Example with options:
```elixir
import Gitly, only: [gitly: 1, gitly: 2]
gitly("username/repo", force: true, format: :zip, ref: "main")
```## Documentation
For more detailed documentation, run `mix docs` and open `doc/index.html` in your browser.
This project uses [git-cliff](https://github.com/orhun/git-cliff) for changelog generation.
## Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
## License
This project is licensed under the [MIT License](LICENSE).
## Changelog
See [CHANGELOG.md](CHANGELOG.md) for the latest changes.