diff --git a/docs/versioned_docs/version-v2.2.4/configuration.md b/docs/versioned_docs/version-v2.2.4/configuration.md new file mode 100644 index 0000000..7cdbdf8 --- /dev/null +++ b/docs/versioned_docs/version-v2.2.4/configuration.md @@ -0,0 +1,283 @@ +--- +sidebar_position: 3 +--- + +# Configuration + +Gilt uses [Viper][] to load configuation through multiple methods. + +## Config File + +Create the giltfile (`Giltfile.yaml`). + +Clone the specified `url`@`version` to the configurable path `--gilt-dir`. +Extract the repo the `dstDir` when `dstDir` is provided. Otherwise, copy files +and/or directories to the desired destinations. + +```yaml +--- +giltDir: ~/.gilt/clone +debug: false +parallel: true +repositories: + - git: https://github.com/retr0h/ansible-etcd.git + version: 77a95b7 + dstDir: roles/retr0h.ansible-etcd + - git: https://github.com/retr0h/ansible-etcd.git + version: 1.1 + dstDir: roles/retr0h.ansible-etcd-tag + - git: https://github.com/lorin/openstack-ansible-modules.git + version: 2677cc3 + sources: + - src: '*_manage' + dstDir: library + - src: nova_quota + dstDir: library + - src: neutron_router + dstFile: library/neutron_router.py + - src: tests + dstDir: tests + commands: + - cmd: ansible-playbook + args: + - -i, + - playbook.yml + - cmd: bash + args: + - -c + - who | grep tty +``` + +### Configuration Options + +#### `debug` + +- Type: boolean +- Default: `false` +- Required: no + +Enable / disable debug output + +#### `parallel` + +- Type: boolean +- Default: `true` +- Required: no + +Enable / disable fetching clones concurrently. The default is to fetch clones in +parallel, with one fetch per CPU, and a maximum of 8 concurrent processes. +Setting `parallel: false` will cause Gilt to fetch each clone one-at-a-time. + +#### `giltDir` + +- Type: string +- Default: `~/.gilt/clone` +- Required: no + +Specifies the directory to use for storing cached clones for use by Gilt. The +directory will be created if it does not exist. + +#### `repositories` + +- Type: list +- Default: `[]` +- Required: no + +The list of repositories for Gilt to vendor in. They will be processed in the +order they are defined. + +##### `repositories[].git` + +- Type: string +- Default: None +- Required: yes + +The Git URL of the repository to clone. Any URL format supported by Git may be +used. + +##### `repositories[].version` + +- Type: string +- Default: None +- Required: yes + +The Git commit-ish to use as the source. Any valid branch name, tag name, or +commit hash may be used. + +##### `repositories[].dstDir` + +- Type: string +- Default: None +- Required: no + +The local directory to copy files into. All files in the repository will be +copied. Relative paths will be installed into the directory where `gilt` was +invoked. If `dstDir` already exists, it will be destroyed and overwritten; as +such, `.` and `..` are not allowed. + +To copy only a subset of files, use the `repositories.sources` option instead. + +This option cannot be used with `repositories.sources`. + +##### `repositories[].sources` + +- Type: list +- Default: `[]` +- Required: no + +A list of subtrees and their targets for Gilt to copy. Relative paths will +read/write into the directory where `gilt` was invoked. + +This option cannot be used with `repositories.dstDir`. + +###### `repositories[].sources[].src` + +- Type: string +- Default: None +- Required: yes + +The pathname of the source file/directory to copy. + +###### `repositories[].sources[].dstDir` + +- Type: string +- Default: None +- Required: no + +The pathname of the destination directory. If `src` is a file, it will be placed +inside the named directory. If `src` is a directory, its contents will be copied +into the named directory. All parent directories will be created if they do not +exist. If `dstDir` already exists, it will be destroyed and overwritten; as +such, `.` and `..` are not allowed. + +This option cannot be used with `repositories[].sources[].dstFile`. + +###### `repositories[].sources[].dstFile` + +- Type: string +- Default: None +- Required: no + +The pathname of the destination file. If `src` is a directory, an error is +thrown. All parent directories will be created if they do not exist, with an +equivalent set of permissions, i.e., a `src` file with mode `0640` will create +all nonexistant intermediate directories with mode `0750`. + +This option cannot be used with `repositories[].sources[].dstDir`. + +##### `repositories[].commands` + +- Type: list +- Default: `[]` +- Required: no + +A list of commands to run after overlaying files. These commands are run in the +same directory used to invoke `gilt`. They will be executed in the order they +are defined, and a non-zero exit status will cause Gilt to abort. + +###### `repositories[].commands[].cmd` + +- Type: string +- Default: None +- Required: yes + +The name of the command to run. The current value of `$PATH` will be used to +find it. This does **NOT** invoke a shell, so variable interpolation, output +redirection, etc., is not supported. + +###### `repositories[].commands[].args` + +- Type: list of strings +- Default: `[]` +- Required: no + +Any and all arguments to the given command. This does **NOT** invoke a shell, so +variable interpolation, output redirection, etc. is not supported. Similarly, +arguments are not split on spaces, so each argument must be a separate list +entry. + +## Env Vars + +The config file can be overriden/defined through env vars. + +```bash +GILT_GILTFILE=Giltfile.yaml \ +GILT_GILTDIR=~/.gilt/clone \ +GILT_DEBUG=false \ +GILT_PARALLEL=false \ +gilt overlay +``` + +### `GILT_DEBUG` + +- Default: `false` + +Enable/disable debug output. + +### `GILT_PARALLEL` + +- Default: `true` + +Enable / disable fetching clones concurrently. The default is to fetch clones in +parallel, with one fetch per CPU, and a maximum of 8 concurrent processes. +Setting `GIT_PARALLEL=false` will cause Gilt to fetch each clone one-at-a-time. + +### `GILT_GILTFILE` + +- Default: `./Giltfile.yaml` + +Configuration file to use. + +### `GILT_GILTDIR` + +- Default: `~/.gilt/clone` + +Specifies the directory to use for storing cached clones for use by Gilt. The +directory will be created if it does not exist. + +### `GILT_SKIPCOMMANDS` + +- Default: `false` + +If set, Gilt will skip running any post-commands when overlaying files. This can +be useful when debugging. + +## Command Flags + +The config file and/or env vars can be overriden/defined through cli flags. + +```bash +gilt \ + --gilt-file=Giltfile.yaml \ + --gilt-dir=~/.gilt/clone \ + --debug \ + --parallel=false \ + overlay +``` + +### `-d`, `--debug` + +Enable debug output. + +### `-c`, `--gilt-dir` + +Path to Gilt's clone dir. (default `~/.gilt/clone`) + +### `-f`, `--gilt-file` + +Path to config file. (default `./Giltfile.yaml`) + +### `--no-commands` + +If set, Gilt will skip running any post-commands when overlaying files. This can +be useful when debugging. + +### `-p`, `--parallel` + +Enable / disable fetching clones concurrently. The default is to fetch clones in +parallel, with one fetch per CPU, and a maximum of 8 concurrent processes. +Setting `--parallel=false` will cause Gilt to fetch each clone one-at-a-time. + + +[Viper]: https://github.com/spf13/viper + diff --git a/docs/versioned_docs/version-v2.2.4/contributing.md b/docs/versioned_docs/version-v2.2.4/contributing.md new file mode 100644 index 0000000..14e9906 --- /dev/null +++ b/docs/versioned_docs/version-v2.2.4/contributing.md @@ -0,0 +1,120 @@ +--- +sidebar_position: 6 +--- + +# Contributing + +Contributions to Gilt are very welcome, but we ask that you read this document +before submitting a PR. + +:::note + +This document applies to the [Gilt][] repository. + +::: + +## Before you start + +- **Check existing work** - Is there an existing PR? Are there issues discussing + the feature/change you want to make? Please make sure you consider/address + these discussions in your work. +- **Backwards compatibility** - Will your change break existing Giltfiles? It is + much more likely that your change will merged if it backwards compatible. Is + there an approach you can take that maintains this compatibility? If not, + consider opening an issue first so that API changes can be discussed before + you invest your time into a PR. + +## 1. Setup + +- **Go** - Gilt is written in [Go][]. We always support the latest two major Go + versions, so make sure your version is recent enough. +- **Node.js** - [Node.js][] is used to host Gilt's documentation server and is + required if you want to run this server locally. + +## 2. Making changes + +- **Code style** - Try to maintain the existing code style where possible. Go + code should be formatted by [`gofumpt`][gofumpt] and linted using + [`golangci-lint`][golangci-lint]. Any Markdown or TypeScript files should be + formatted and linted by [Prettier][]. This style is enforced by our CI to + ensure that we have a consistent style across the project. You can use the + `task fmt:check` command to lint the code locally and the `task fmt` command + to automatically fix any issues that are found. +- **Documentation** - Ensure that you add/update any relevant documentation. See + the [updating documentation](#updating-documentation) section below. +- **Tests** - Ensure that you add/update any relevant tests and that all tests + are passing before submitting the PR. See the [writing tests](#writing-tests) + section below. + +### Running your changes + +To run Gilt with working changes, you can use `go run main.go overlay`. + +### Updating documentation + +Gilt uses [Docusaurus][] to host a documentation server. The code for this is +located in the Gilt repository. This can be setup and run locally by using +`task docs:start` (requires `nodejs` & `yarn`). All content is written in +Markdown and is located in the `docs/docs` directory. All Markdown documents +should have an 80 character line wrap limit (enforced by Prettier). + +### Writing tests + +When making changes, consider whether new tests are required. These tests should +ensure that the functionality you are adding will continue to work in the +future. Existing tests may also need updating if you have changed Gilt's +behavior. + +You may also consider adding unit tests for any new functions you have added. +The unit tests should follow the Go convention of being location in a file named +`*_test.go` in the same package as the code being tested. + +Integration tests are located in the `tests` directory and executed by [Bats][]. + +## 3. Committing your code + +Try to write meaningful commit messages and avoid having too many commits on the +PR. Most PRs should likely have a single commit (although for bigger PRs it may +be reasonable to split it in a few). Git squash and rebase is your friend! + +If you're not sure how to format your commit message, check out [Conventional +Commits][]. This style is enforced, and is a good way to make your commit +messages more readable and consistent. + +## 4. Submitting a PR + +- **Describe your changes** - Ensure that you provide a comprehensive + description of your changes. +- **Issue/PR links** - Link any previous work such as related issues or PRs. + Please describe how your changes differ to/extend this work. +- **Examples** - Add any examples or screenshots that you think are useful to + demonstrate the effect of your changes. +- **Draft PRs** - If your changes are incomplete, but you would like to discuss + them, open the PR as a draft and add a comment to start a discussion. Using + comments rather than the PR description allows the description to be updated + later while preserving any discussions. + +## FAQ + +> I want to contribute, where do I start? + +All kinds of contributions are welcome, whether its a typo fix or a shiny new +feature. You can also contribute by upvoting/commenting on issues or helping to +answer questions. + +> I'm stuck, where can I get help? + +If you have questions, feel free open a [Discussion][] on GitHub. + + +[Gilt]: https://github.com/retr0h/gilt +[Go]: https://go.dev +[Node.js]: https://nodejs.org/en/ +[gofumpt]: https://github.com/mvdan/gofumpt +[golangci-lint]: https://golangci-lint.run +[Prettier]: https://prettier.io/ +[Docusaurus]: https://docusaurus.io +[Discussion]: https://github.com/retr0h/gilt/discussions +[Conventional Commits]: https://www.conventionalcommits.org +[Bats]: https://github.com/bats-core/bats-core + diff --git a/docs/versioned_docs/version-v2.2.4/installation.md b/docs/versioned_docs/version-v2.2.4/installation.md new file mode 100644 index 0000000..28e67ca --- /dev/null +++ b/docs/versioned_docs/version-v2.2.4/installation.md @@ -0,0 +1,23 @@ +--- +sidebar_position: 2 +--- + +# Installation + +## Homebrew Tap + +```bash +brew install retr0h/tap/gilt +``` + +## Go Install + +```bash +go install github.com/retr0h/gilt/v2@latest +``` + +## Python + +```bash +pip3 install python-gilt +``` diff --git a/docs/versioned_docs/version-v2.2.4/intro.md b/docs/versioned_docs/version-v2.2.4/intro.md new file mode 100644 index 0000000..2110442 --- /dev/null +++ b/docs/versioned_docs/version-v2.2.4/intro.md @@ -0,0 +1,42 @@ +--- +slug: / +sidebar_position: 1 +title: Home +--- + +# Gilt + + + +Gilt is a tool which aims to make repo management, manageable. Gilt clones +repositories at a particular version, then overlays the repository to the +provided destination. An alternate approach to "vendoring". + +What makes Gilt interesting, is the ability to overlay particular files and/or +directories from the specified repository to given destinations. Originally, +this was quite helpful for those using Ansible, since libraries, plugins, and +playbooks are often shared, but Ansible's [Galaxy][] has no mechanism to handle +this. Currently, this is proving useful for overlaying [Helm charts][]. + +
+ +## Alternatives + +- [Repo][] +- [Git submodules][] +- [Git subtree][] + +## History + +This project is a golang port of [Gilt][py-gilt], and aims to correct poor +decisions made in the python version, primarially around config syntax, +portability, and reproducibility. + + +[Galaxy]: https://docs.ansible.com/ansible/latest/reference_appendices/galaxy.html +[Helm charts]: https://helm.sh/docs/topics/charts/ +[Repo]: https://gerrit.googlesource.com/git-repo/+/refs/heads/master/README.md +[Git submodules]: https://git-scm.com/book/en/v2/Git-Tools-Submodules +[Git subtree]: https://github.com/git/git/blob/master/contrib/subtree/git-subtree.txt +[py-gilt]: http://gilt.readthedocs.io/en/latest/ + diff --git a/docs/versioned_docs/version-v2.2.4/testing.md b/docs/versioned_docs/version-v2.2.4/testing.md new file mode 100644 index 0000000..2fac839 --- /dev/null +++ b/docs/versioned_docs/version-v2.2.4/testing.md @@ -0,0 +1,29 @@ +--- +sidebar_position: 5 +--- + +# Testing + +Check installed dependencies: + +```bash +task deps:check +``` + +To execute tests: + +```bash +task test +``` + +Auto format code: + +```bash +task fmt +``` + +List helpful targets: + +```bash +task +``` diff --git a/docs/versioned_docs/version-v2.2.4/usage.md b/docs/versioned_docs/version-v2.2.4/usage.md new file mode 100644 index 0000000..4f9468c --- /dev/null +++ b/docs/versioned_docs/version-v2.2.4/usage.md @@ -0,0 +1,67 @@ +--- +sidebar_position: 4 +--- + +# Usage + +## CLI + +### Init Configuration + +Initializes config file in the shell's current working directory: + +```bash +gilt init +``` + +### Overlay Repository + +Overlay a remote repository into the destination provided. + +```bash +gilt overlay +``` + +### Debug + +Display the git commands being executed. + +```bash +gilt --debug overlay +``` + +### Skipping post-commands + +Overlay files only, but run no other commands. + +```bash +gilt overlay --no-commands +``` + +## Package + +### Overlay Repository + +See example client in `examples/go-client/`. + +```go +func main() { + debug := true + logger := getLogger(debug) + + c := config.Repositories{ + Debug: debug, + GiltDir: "~/.gilt", + Repositories: []config.Repository{ + { + Git: "https://github.com/retr0h/ansible-etcd.git", + Version: "77a95b7", + DstDir: "../tmp/retr0h.ansible-etcd", + }, + }, + } + + var r repositoriesManager = repositories.New(c, logger) + r.Overlay() +} +``` diff --git a/docs/versioned_sidebars/version-v2.2.4-sidebars.json b/docs/versioned_sidebars/version-v2.2.4-sidebars.json new file mode 100644 index 0000000..39332bf --- /dev/null +++ b/docs/versioned_sidebars/version-v2.2.4-sidebars.json @@ -0,0 +1,8 @@ +{ + "docsSidebar": [ + { + "type": "autogenerated", + "dirName": "." + } + ] +} diff --git a/docs/versions.json b/docs/versions.json index 612d68f..16ad5fd 100644 --- a/docs/versions.json +++ b/docs/versions.json @@ -1,4 +1,5 @@ [ + "v2.2.4", "2.2.3", "2.2.2", "2.2.1",