2.4 KiB
залил в мастер базовый hbs2-reposync. что он делает: берёт пачку hbs2-git репо и синхронизирует их с git bare repo, которые где-то лежат.
зачем: что бы третьи программы (в первую очередь nix), которые не могут использовать git-remote-helper - могли выкачивать репо и мы могли бы ссылаться в зависимостях на свои репозитории из hbs2-git.
пример использования:
[dmz@minipig:~/w/hbs2]$ cat hbs2-git/reposync/examples/config
rpc unix "/tmp/hbs2-rpc.socket"
; http-port 4017
; root "/home/dmz/.local/share/hbs2-reposync/repo"
;; single reflog
[ reflog "BTThPdHKF8XnEq4m6wzbKHKA6geLFK4ydYhBXAqBdHSP"
;; options may go here if any
]
[ reflog "JCVvyFfj1C21QfFkcjrFN6CoarykfAf6jLFpCNNKjP7E"
(decrypt "/home/dmz/w/hbs2/owner.key")
]
[dmz@minipig:~/w/hbs2]$ ./bin/hbs2-reposync -c hbs2-git/reposync/examples/config run
стартует и слушает на порту 4017 (настраивается в конфиге). далее мы неведомым способом перенаправляем порт 80 на него, и делаем так, что бы какой-то хост указывал на ip, на котором слушает hbs2-reposync. например, у меня так:
[dmz@minipig:~/w/hbs2]$ cat /etc/hosts
127.0.0.1 git.hbs2
cat /nix/store/47wrg18zgwb6sy5p0k1ahapv9i7fiz2n-Caddyfile-formatted/Caddyfile
http://git.hbs2 {
bind
log {
output file /var/log/caddy/access-http://git.hbs2.log
}
reverse_proxy http://git.hbs2:4017
}
теперь будет работать такое:
[dmz@minipig:~/tmp]$ git clone http://git.hbs2/BTThPdHKF8XnEq4m6wzbKHKA6geLFK4ydYhBXAqBdHSP wtf1
Cloning into 'wtf1'...
и можно во флейках ссылаться на
git+http://git.hbs2/BTThPdHKF8XnEq4m6wzbKHKA6geLFK4ydYhBXAqBdHSP
поддержка шифрования репозиториев в каком-то виде: есть, у меня получилось. но при копировании в git bare репозиторий всё будет расшифровано. если важна секретность, надо держать его где-то на шифрованном разделе или типа того.