blob: b3727923223d75c5d1e57380f7b6370c69d608f1 (
plain) (
tree)
|
|
# This derivation configures a 'cgit' instance to serve repositories
# from a different source.
#
# In the first round this will just serve my GitHub repositories until
# I'm happy with the display.
{ pkgs, ... }:
with pkgs.third_party;
let
cgitConfig = writeText "cgitrc" ''
# Global configuration
virtual-root=/cgit.cgi/
enable-http-clone=1
# Repository configuration
repo.url=depot
repo.path=/srv/git/depot
repo.desc=tazjin's personal monorepo
repo.owner=tazjin <tazjin@google.com>
repo.clone-url=https://git.tazj.in ssh://source.developers.google.com:2022/p/tazjins-infrastructure/r/depot
'';
thttpdConfig = writeText "thttpd.conf" ''
port=8080
dir=${cgit}/cgit
nochroot
novhost
logfile=/dev/stdout
cgipat=**.cgi
'';
# Patched version of thttpd that serves cgit.cgi as the index and
# sets the environment variable for pointing cgit at the correct
# configuration.
#
# Things are done this way because recompilation of thttpd is much
# faster than cgit and I don't want to wait long when iterating on
# config.
thttpdConfigPatch = writeText "thttpd_cgit_conf.patch" ''
diff --git a/libhttpd.c b/libhttpd.c
index c6b1622..eef4b73 100644
--- a/libhttpd.c
+++ b/libhttpd.c
@@ -3055,4 +3055,6 @@ make_envp( httpd_conn* hc )
envn = 0;
+ // force cgit to load the correct configuration
+ envp[envn++] = "CGIT_CONFIG=${cgitConfig}";
envp[envn++] = build_env( "PATH=%s", CGI_PATH );
#ifdef CGI_LD_LIBRARY_PATH
'';
thttpdCgit = thttpd.overrideAttrs(old: {
patches = [ ./cgit_idx.patch thttpdConfigPatch ];
});
in writeShellScriptBin "cgit-launch" ''
${coreutils}/bin/mkdir -p /srv/git
# The SSH keys are placed in the container by Kubernetes.
export GIT_SSH_COMMAND="${openssh}/bin/ssh -F /var/cgit/ssh_config"
${git}/bin/git clone --mirror \
-c http.sslcainfo=${cacert}/etc/ssl/certs/ca-bundle.crt \
ssh://source.developers.google.com:2022/p/tazjins-infrastructure/r/depot \
/srv/git/depot
exec ${thttpdCgit}/bin/thttpd -D -C ${thttpdConfig}
# ''
|