Automatically deploy documentation for your code repositories.
This script does the following:
- clone the docs repository (
DOCS_REPO
,DOCS_BRANCH
) into a working dir (WORKDIR
) - collect documentation from a source directory (
GENERATE_DOCS_DIR
) into a target path in the repository (TARGET_PATH
) - commit updates to repository (
GIT_COMMIT_MESSAGE
,GIT_COMMITTER_NAME
,GIT_COMMITTER_EMAIL
) - push local repository to origin
It can be invoked as an after_success hook on a CI setup or run manually. Most configuration values will work with their default values on Travis-CI or when run from a local copy of a repository at Github. They can also be customized trough environment variables.
# run once (for example in CI):
curl https://raw.githubusercontent.com/straight-shoota/autodeploy-docs/master/autodeploy-docs.sh | bash
# install locally
curl https://raw.githubusercontent.com/straight-shoota/autodeploy-docs/master/autodeploy-docs.sh > /usr/local/bin/autodeploy-docs
local manual run:
create_documentation && autodeploy-docs
On travis-CI (real-world example)
after_success:
- generate_documentation
- curl https://raw.githubusercontent.com/straight-shoota/autodeploy-docs/master/autodeploy-docs.sh | bash
env:
global:
GIT_COMMITTER_NAME: travis-ci
GIT_COMMITTER_EMAIL: travis@travis-ci.org
You need to install an ssh key on travis or define a secret environment variable GH_TOKEN
with a token to push to Github API.
GENERATED_DOCS_DIR
:$(pwd)/doc
BRANCH
:$TRAVIS_BRANCH
or$(git rev-parse --abbrev-ref HEAD)
TAG
:$TRAVIS_TAG
or$(git name-rev --tags --name-only "${BRANCH}")
orlatest
REPO
:$TRAVIS_REPO_SLUG
or$(git ls-remote --get-url origin)
WORKDIR
:${HOME}/${REPO}-docs-${TAG}
DOCS_REPO
:https://${GH_TOKEN}@github.com/${REPO}
orgit@github.com:${REPO}
DOCS_BRANCH
:gh-pages
GH_TOKEN
: (needs to be set if no ssh key is available)TARGET_PATH
:api/${TAG}
- Fork it ( https://github.com/straight-shoota/autodeploy-docs/fork )
- Create your feature branch (git checkout -b my-new-feature)
- Commit your changes (git commit -am 'Add some feature')
- Push to the branch (git push origin my-new-feature)
- Create a new Pull Request
- straight-shoota Johannes Müller - creator, maintainer