From 5bfd40f9fdc45ee79b8432544c4ef6ab37cdc200 Mon Sep 17 00:00:00 2001 From: Thomas Miceli Date: Sun, 19 Mar 2023 00:49:06 +0100 Subject: [PATCH] Copy hooks and config files on fork --- internal/git/commands.go | 55 +++++++++++++++++++++++----------------- internal/web/run.go | 2 +- 2 files changed, 33 insertions(+), 24 deletions(-) diff --git a/internal/git/commands.go b/internal/git/commands.go index a5128d2..4532ca6 100644 --- a/internal/git/commands.go +++ b/internal/git/commands.go @@ -33,32 +33,12 @@ func InitRepository(user string, gist string) error { repositoryPath, ) - _, err := cmd.Output() + err := cmd.Run() if err != nil { return err } - f1, err := os.OpenFile(filepath.Join(repositoryPath, "git-daemon-export-ok"), os.O_RDONLY|os.O_CREATE, 0644) - defer f1.Close() - - preReceiveDst, err := os.OpenFile(filepath.Join(repositoryPath, "hooks", "pre-receive"), os.O_APPEND|os.O_WRONLY|os.O_CREATE, 0744) - if err != nil { - return err - } - - preReceiveSrc, err := os.OpenFile(filepath.Join("internal", "resources", "pre-receive"), os.O_RDONLY, os.ModeAppend) - if err != nil { - return err - } - _, err = io.Copy(preReceiveDst, preReceiveSrc) - if err != nil { - return err - } - - defer preReceiveDst.Close() - defer preReceiveSrc.Close() - - return err + return copyFiles(repositoryPath) } func GetNumberOfCommitsOfRepository(user string, gist string) (string, error) { @@ -189,7 +169,12 @@ func ForkClone(userSrc string, gistSrc string, userDst string, gistDst string) e cmd = exec.Command("git", "config", "user.name", userDst) cmd.Dir = repositoryPathDst - return cmd.Run() + err := cmd.Run() + if err != nil { + return err + } + + return copyFiles(repositoryPathDst) } func SetFileContent(gistTmpId string, filename string, content string) error { @@ -274,3 +259,27 @@ func GetGitVersion() (string, error) { return versionFields[2], nil } + +func copyFiles(repositoryPath string) error { + f1, err := os.OpenFile(filepath.Join(repositoryPath, "git-daemon-export-ok"), os.O_RDONLY|os.O_CREATE, 0644) + defer f1.Close() + + preReceiveDst, err := os.OpenFile(filepath.Join(repositoryPath, "hooks", "pre-receive"), os.O_APPEND|os.O_WRONLY|os.O_CREATE, 0744) + if err != nil { + return err + } + + preReceiveSrc, err := os.OpenFile(filepath.Join("internal", "resources", "pre-receive"), os.O_RDONLY, os.ModeAppend) + if err != nil { + return err + } + _, err = io.Copy(preReceiveDst, preReceiveSrc) + if err != nil { + return err + } + + defer preReceiveDst.Close() + defer preReceiveSrc.Close() + + return nil +} diff --git a/internal/web/run.go b/internal/web/run.go index caa25b9..bc00dc8 100644 --- a/internal/web/run.go +++ b/internal/web/run.go @@ -51,7 +51,7 @@ func Start() { return nil }, })) - //e.Use(middleware.Recover()) + e.Use(middleware.Recover()) e.Use(middleware.Secure()) e.Renderer = &Template{