Hi… I am well aware that this diff view is very suboptimal. It will be fixed when the refactored server comes along!
ssh_handle_upload_pack: Use system git-upload-pack
package main import (
"fmt" "os/exec"
glider_ssh "github.com/gliderlabs/ssh"
"github.com/go-git/go-billy/v5/osfs" "github.com/go-git/go-git/v5/plumbing/protocol/packp" "github.com/go-git/go-git/v5/plumbing/transport" "github.com/go-git/go-git/v5/plumbing/transport/server"
)
func ssh_handle_upload_pack(session glider_ssh.Session, pubkey string, repo_identifier string) (err error) {
	repo_path, _, err := get_repo_path_perms_from_ssh_path_pubkey(session.Context(), repo_identifier, pubkey)
	if err != nil {
		return err
	}
	endpoint, err := transport.NewEndpoint("/")
	if err != nil {
		return err
	}
	billy_fs := osfs.New(repo_path)
	fs_loader := server.NewFilesystemLoader(billy_fs)
	transport := server.NewServer(fs_loader)
	upload_pack_session, err := transport.NewUploadPackSession(endpoint, nil)
	if err != nil {
		return err
	}
	advertised_references, err := upload_pack_session.AdvertisedReferencesContext(session.Context())
	if err != nil {
		return err
	}
	err = advertised_references.Encode(session)
	if err != nil {
		return err
	}
	reference_update_request := packp.NewUploadPackRequest()
	err = reference_update_request.Decode(session)
	if err != nil {
		return err
	}
	report_status, err := upload_pack_session.UploadPack(session.Context(), reference_update_request)
proc := exec.CommandContext(session.Context(), "git-upload-pack", repo_path) proc.Stdin = session proc.Stdout = session proc.Stderr = session.Stderr() err = proc.Start()
	if err != nil {
fmt.Fprintln(session.Stderr(), "Error while starting process:", err)
return err }
	err = report_status.Encode(session)
	if err != nil {
		return err
	err = proc.Wait()
	if exitError, ok := err.(*exec.ExitError); ok {
		fmt.Fprintln(session.Stderr(), "Process exited with error", exitError.ExitCode())
	} else if err != nil {
		fmt.Fprintln(session.Stderr(), "Error while waiting for process:", err)
}
return nil
return err
}