X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2dfb886e960cf918e54b5f03477f464afb322a9b..7c3e13d4876a8e37feffee3cdaebc44b20b7b61b:/services/arv-git-httpd/server.go diff --git a/services/arv-git-httpd/server.go b/services/arv-git-httpd/server.go index c3c36dac5a..56c9765b56 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/arvados" + "git.curoverse.com/arvados.git/sdk/go/health" "git.curoverse.com/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() }