Lindenii Project Forge
Commit info | |
---|---|
ID | 3adb46b7e1225e8f339d248f0ef9c32e34b20d9d |
Author | Runxi Yu<me@runxiyu.org> |
Author date | Mon, 17 Feb 2025 11:59:09 +0800 |
Committer | Runxi Yu<me@runxiyu.org> |
Committer date | Mon, 17 Feb 2025 11:59:09 +0800 |
Actions | Get patch |
*_handle_*_pack.go: Pass env LINDENII_FORGE_HOOKS_SOCKET_PATH
package main import ( "io" "net/http"
"os"
"os/exec" ) func handle_upload_pack(w http.ResponseWriter, r *http.Request, params map[string]any) (err error) { group_name, repo_name := params["group_name"].(string), params["repo_name"].(string) var repo_path string err = database.QueryRow(r.Context(), "SELECT r.filesystem_path FROM repos r JOIN groups g ON r.group_id = g.id WHERE g.name = $1 AND r.name = $2;", group_name, repo_name).Scan(&repo_path) if err != nil { return err } w.Header().Set("Content-Type", "application/x-git-upload-pack-result") w.Header().Set("Connection", "Keep-Alive") w.Header().Set("Transfer-Encoding", "chunked") w.WriteHeader(http.StatusOK) cmd := exec.Command("git", "upload-pack", "--stateless-rpc", repo_path)
cmd.Env = append(os.Environ(), "LINDENII_FORGE_HOOKS_SOCKET_PATH="+config.Hooks.Socket)
stdout, err := cmd.StdoutPipe() if err != nil { return err } cmd.Stderr = cmd.Stdout defer func() { _ = stdout.Close() }() stdin, err := cmd.StdinPipe() if err != nil { return err } defer func() { _ = stdin.Close() }() err = cmd.Start() if err != nil { return err } _, err = io.Copy(stdin, r.Body) if err != nil { return err } err = stdin.Close() if err != nil { return err } _, err = io.Copy(w, stdout) if err != nil { return err } err = cmd.Wait() if err != nil { return err } return nil }
package main import ( "errors" "fmt"
"os"
"os/exec" glider_ssh "github.com/gliderlabs/ssh" ) var err_unauthorized_push = errors.New("You are not authorized to push to this repository") func ssh_handle_receive_pack(session glider_ssh.Session, pubkey string, repo_identifier string) (err error) { repo_path, access, err := get_repo_path_perms_from_ssh_path_pubkey(session.Context(), repo_identifier, pubkey) if err != nil { return err } if !access { return err_unauthorized_push } proc := exec.CommandContext(session.Context(), "git-receive-pack", repo_path)
proc.Env = append(os.Environ(), "LINDENII_FORGE_HOOKS_SOCKET_PATH="+config.Hooks.Socket)
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 = 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 err }
package main import ( "fmt"
"os"
"os/exec" glider_ssh "github.com/gliderlabs/ssh" ) 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 } proc := exec.CommandContext(session.Context(), "git-upload-pack", repo_path)
proc.Env = append(os.Environ(), "LINDENII_FORGE_HOOKS_SOCKET_PATH="+config.Hooks.Socket)
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 = 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 err }