X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/98d6a7c2db7b8be7050fe7394147df5c5ce392bb..5239de634d8c3277024be6e1c1bf1dc049d2bdf0:/services/arv-git-httpd/server.go diff --git a/services/arv-git-httpd/server.go b/services/arv-git-httpd/server.go index c3c36dac5a..38a018ab3d 100644 --- a/services/arv-git-httpd/server.go +++ b/services/arv-git-httpd/server.go @@ -1,30 +1,36 @@ +// Copyright (C) The Arvados Authors. All rights reserved. +// +// SPDX-License-Identifier: AGPL-3.0 + package main import ( "net/http" - "net/http/cgi" - "git.curoverse.com/arvados.git/sdk/go/httpserver" + "git.arvados.org/arvados.git/sdk/go/arvados" + "git.arvados.org/arvados.git/sdk/go/health" + "git.arvados.org/arvados.git/sdk/go/httpserver" ) type server struct { httpserver.Server + cluster *arvados.Cluster } func (srv *server) Start() error { - gitHandler := &cgi.Handler{ - Path: theConfig.GitCommand, - Dir: theConfig.Root, - Env: []string{ - "GIT_PROJECT_ROOT=" + theConfig.Root, - "GIT_HTTP_EXPORT_ALL=", - }, - InheritEnv: []string{"PATH"}, - Args: []string{"http-backend"}, - } mux := http.NewServeMux() - mux.Handle("/", &authHandler{gitHandler}) + mux.Handle("/", &authHandler{handler: newGitHandler(srv.cluster), cluster: srv.cluster}) + mux.Handle("/_health/", &health.Handler{ + Token: srv.cluster.ManagementToken, + Prefix: "/_health/", + }) + + var listen arvados.URL + for listen = range srv.cluster.Services.GitHTTP.InternalURLs { + break + } + srv.Handler = mux - srv.Addr = theConfig.Addr + srv.Addr = listen.Host return srv.Server.Start() }