A simple nodejs utility to update yaml files in github.
In our GitOps process, the docker tags in our infrastructure git repos need to be updated whenever there's a new container build. We created Ocommit as a way of automating this process.
This package exposes both an CLI interface, and a NodeJS connector.
GITHUB_ACCESS_TOKEN
is the only required env var. This is the personal access token
for a github user/bot
Lists available octommit
commands
octommit help
Used to update a yaml file in github
octommit update \
--set \[path:to:var\]=new_value \
--set \[foo:bar\[\]\]=yawn \
--remove \[some:arrayValue\[\]\]=yawn \
--remove \[some:property\] \
--o \
--pr \
--repo <reponame> \
--org Stockopedia \
--sourcePath path/to/file.yaml \
--outputPath /path/to/outputfile.yaml \
--sourceBranch main \
--outputBranch some-other-branch \
--message "commit message"
| name | type | desc | env | cli |
| ------------ | -------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------- | ---------------------------------------------------------------------- | ---------------------------- |
| repo | string | The name of the github repository. | REPO=<name>
| --repo <name>
|
| pr | boolean | Whether or not to open a PR. Will only do so if the target branch it different to the output branch. | CREATE_PR=true
| --pr
|
| output | boolean | Whether or not to output the command response | | --o
|
| set | string[] | Key/value pairs to replace in the output file. Can either add a unique item to an array (will create if does not exist), add a property, or update a property. | | --set [path.to.var]=replacement
--set [path.to.array[]]=new_value
|
| remove | string[] | key/value pairs of items to remove. Can be an array item, or a property | | --remove [path.to.prop]
--remove [path.to.array[]]=value_to_remove
|
| org | string | Name of github organisation | ORG=Stockopedia
| --org Stockopedia
|
| sourcePath | string | Path to yaml file | SOURCE_FILE=path/to/file.yaml
| --sourcePath path/to/file.yaml
|
| outputPath | string | The output path for the resulting yaml. Can be the same file, or a new file | OUTPUT_PATH=path/to/output.yaml
| --outputPath path/to/output.yaml
|
| sourceBranch | string | The name of the branch in which to find the file | SOURCE_BRANCH=branch-name
| --sourceBranch branch-name
|
| outputBranch | string | The branch name for the resulting yaml | Can be the same as the source branch. If the outputBranch already exists, it will use that/ If it does not, it will create a new branch | OUTPUT_BRANCH=branch-name
| --outputBranch branch-name
|
| message | string | The desired github commit message | MESSAGE=chore(some-scope): some useful message
| --message "chore(some-scope): some useful message"
|
See the example
directory.
At the moment, this library only supports updating one file per commit.