From eb1605d1557c6650cce7f2dc0dad95aca257658a Mon Sep 17 00:00:00 2001 From: Rob Lewis Date: Sun, 19 Jul 2020 16:19:06 +0200 Subject: [PATCH] GitHub action: Add config option to overwrite history. --- README.md | 9 +++++++++ action.yml | 1 + entrypoint.sh | 27 +++++++++++++++++++++++++-- 3 files changed, 35 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 83c60fce2ab0ed..8c60029896e155 100644 --- a/README.md +++ b/README.md @@ -106,10 +106,19 @@ jobs: zulip_bot_email: ${{ secrets.zulip_bot_email }} zulip_bot_key: ${{ secrets.zulip_bot_key }} github_personal_access_token: ${{ secrets.gh_personal_access_token }} + delete_history: true ``` The above file tells GitHub to run the `zulip-archive` action every 20 minutes. You can adjust the `cron` key to modify the schedule as you feel appropriate. If you Zulip organization history is very large (not the case for most users) we recommend to increase the cron period from running every 30 minutes to maybe run every 1 hour (eg `'0 * * * *'`). This is is because the initial archive run that fetches the messages for the first time takes a lot of time and we don't want the second cron job to start before finishing the first run is over. After the initial run is over you can shorten the cron job period if necessary. +If you are running frequent updates with a busy Zulip organization, +the Git repository that you use to run the action will grow very +quickly. We recommend setting the `delete_history` option to +`true`. This will overwrite the git history in the repository (but +keep all the content). If you are using the repository for more than +just the Zulip archive, you may want to set this to `false`, but be +warned that the repository size may explode. + ### Step 6 - Verify everything works Final step is to verify that everything is working as it is supposed to be. You would have to wait for some time since the action is scheduled to run every 20 minutes (or the time you have configured it to be in above step.) You can track the status of the action by visiting `https://github.com///actions`. Once the action completes running, you would be able to visit the archive by opening the link mentioned in the action run log at the end. The link would be usually be of the form `.github.io/` or `/` if you have configured your own personal domain to point to GitHub pages. diff --git a/action.yml b/action.yml index 62b569c56bfc30..be4d80973e6445 100644 --- a/action.yml +++ b/action.yml @@ -22,3 +22,4 @@ runs: - ${{ inputs.zulip_bot_email }} - ${{ inputs.zulip_bot_key }} - ${{ inputs.github_personal_access_token }} + - ${{ inputs.delete_history }} diff --git a/entrypoint.sh b/entrypoint.sh index d66858b7223fe5..87a8ec48574aca 100755 --- a/entrypoint.sh +++ b/entrypoint.sh @@ -5,6 +5,7 @@ zulip_organization_url=$1 zulip_bot_email=$2 zulip_bot_api_key=$3 github_personal_access_token=$4 +delete_history=$5 checked_out_repo_path="$(pwd)" html_dir_path=$checked_out_repo_path @@ -12,6 +13,7 @@ json_dir_path="${checked_out_repo_path}/zulip_json" _layouts_path="${checked_out_repo_path}/_layouts" img_dir_path="${checked_out_repo_path}/assets/img" streams_config_file_path="${checked_out_repo_path}/streams.yaml" +initial_sha="$(git rev-parse HEAD)" if [ ! -f $streams_config_file_path ]; then echo "Missing streams.yaml file." @@ -75,14 +77,35 @@ cd ${checked_out_repo_path} git checkout master +git fetch origin + +current_sha="$(git rev-parse origin/master)" + +if [[ "$current_sha" != "$initial_sha" ]] +then + echo "Archive update failed, commits have been added while processing" + exit 1 +fi + +echo "delete history: $delete_history" + +if [[ "$delete_history" == "true" ]] +then + echo "resetting" + rm -rf .git + git init +fi + git config --global user.email "zulip-archive-bot@users.noreply.github.com" git config --global user.name "Archive Bot" git add -A git commit -m "Update archive." -git remote set-url --push origin https://${GITHUB_ACTOR}:${github_personal_access_token}@github.com/${GITHUB_REPOSITORY} +git remote add origin2 https://${GITHUB_ACTOR}:${github_personal_access_token}@github.com/${GITHUB_REPOSITORY} + +git push origin2 master -f -git push origin master --force +echo "pushed" echo "Zulip Archive published/updated in ${github_pages_url}"