diff options
author | jaseg <git@jaseg.de> | 2023-03-19 18:58:10 +0100 |
---|---|---|
committer | jaseg <git@jaseg.de> | 2023-03-19 18:58:10 +0100 |
commit | 1cf2411d4e021c010a3ddbb01764776db254c92a (patch) | |
tree | 747e304c7f55a3f328def721d0941e9b0f380bdb /deploy.py | |
parent | 3c6957467fc401648369905efae98c0a228af752 (diff) | |
parent | 520b18c751b20e96059d4bda84df011d81f76eb7 (diff) | |
download | blog-1cf2411d4e021c010a3ddbb01764776db254c92a.tar.gz blog-1cf2411d4e021c010a3ddbb01764776db254c92a.tar.bz2 blog-1cf2411d4e021c010a3ddbb01764776db254c92a.zip |
deploy.py auto-commit
Diffstat (limited to 'deploy.py')
-rw-r--r-- | deploy.py | 29 |
1 files changed, 0 insertions, 29 deletions
diff --git a/deploy.py b/deploy.py deleted file mode 100644 index c960fbc..0000000 --- a/deploy.py +++ /dev/null @@ -1,29 +0,0 @@ -#!/usr/bin/env python3 - -import os -import tempfile -import subprocess -from pathlib import Path - -if __name__ == '__main__': - with tempfile.TemporaryDirectory() as tmpdir: - - current_branch = subprocess.run(['git', 'symbolic-ref', '-q', 'HEAD'], check=False, capture_output=True).stdout.strip() - if current_branch == 'refs/heads/deploy': - raise SystemError('This script cannot be run from the deploy branch (run from main instead)') - - subprocess.run(['git', 'worktree', 'add', '--detach', tmpdir], check=True) - try: - env = dict(os.environ) - env['PATH'] = f'{Path("hack").absolute()}:{env["PATH"]}' - subprocess.run(['hugo'], cwd=tmpdir, check=True, env=env) - subprocess.run(['git', 'add', '--force', 'public'], cwd=tmpdir, check=True) - write_tree = subprocess.run(['git', 'write-tree', '--prefix=public/'], cwd=tmpdir, check=True, capture_output=True) - tree = write_tree.stdout.strip() - - commit = subprocess.run(['git', 'commit-tree', '-p', 'HEAD', '-p', 'refs/heads/deploy', '-m', 'deploy.py auto-commit', tree], cwd=tmpdir, check=True, capture_output=True).stdout.strip() - subprocess.run(['git', 'update-ref', '-m', f'deploy.sh update deploy branch to {commit}', 'refs/heads/deploy', commit], cwd=tmpdir, check=True) - - subprocess.run(['git', 'push', 'git@git.jaseg.de:blog.git', 'deploy'], cwd=tmpdir, check=True) - finally: - subprocess.run(['git', 'worktree', 'remove', '-f', tmpdir], check=True) |