Commit 33d583bf authored by Jacob Vosmaer's avatar Jacob Vosmaer

Change signature of logger.Fatal

parent 25a32cfa
...@@ -16,15 +16,15 @@ func init() { ...@@ -16,15 +16,15 @@ func init() {
func main() { func main() {
if err := handler.Prepare(); err != nil { if err := handler.Prepare(); err != nil {
logger.Fatal(err) logger.Fatal("preparation failed", err)
} }
var request pb.SSHReceivePackRequest var request pb.SSHReceivePackRequest
if err := json.Unmarshal([]byte(os.Args[2]), &request); err != nil { if err := json.Unmarshal([]byte(os.Args[2]), &request); err != nil {
logger.Fatal(err) logger.Fatal("unmarshaling request json failed", err)
} }
if err := handler.ReceivePack(os.Args[1], &request); err != nil { if err := handler.ReceivePack(os.Args[1], &request); err != nil {
logger.Fatal(err) logger.Fatal("receive-pack failed", err)
} }
} }
...@@ -16,15 +16,15 @@ func init() { ...@@ -16,15 +16,15 @@ func init() {
func main() { func main() {
if err := handler.Prepare(); err != nil { if err := handler.Prepare(); err != nil {
logger.Fatal(err) logger.Fatal("preparation failed", err)
} }
var request pb.SSHUploadPackRequest var request pb.SSHUploadPackRequest
if err := json.Unmarshal([]byte(os.Args[2]), &request); err != nil { if err := json.Unmarshal([]byte(os.Args[2]), &request); err != nil {
logger.Fatal(err) logger.Fatal("unmarshaling request json failed", err)
} }
if err := handler.UploadPack(os.Args[1], &request); err != nil { if err := handler.UploadPack(os.Args[1], &request); err != nil {
logger.Fatal(err) logger.Fatal("upload-pack failed", err)
} }
} }
...@@ -31,24 +31,26 @@ func Configure(cfg *config.Config) error { ...@@ -31,24 +31,26 @@ func Configure(cfg *config.Config) error {
return err return err
} }
func logPrint(msg ...interface{}) { func logPrint(msg string, err error) {
mutex.Lock() mutex.Lock()
defer mutex.Unlock() defer mutex.Unlock()
if logWriter == nil { if logWriter == nil {
bootstrapLogPrint(msg...) bootstrapLogPrint(msg, err)
return return
} }
// Emulate the existing log format of gitlab-shell // Emulate the existing log format of gitlab-shell
t := time.Now().Format("2006-01-02T15:04:05.999999") t := time.Now().Format("2006-01-02T15:04:05.999999")
prefix := fmt.Sprintf("E, [%s #%d] ERROR -- : %s: ", t, pid, ProgName) prefix := fmt.Sprintf("E, [%s #%d] ERROR -- : %s:", t, pid, ProgName)
fmt.Fprintln(logWriter, append([]interface{}{prefix}, msg...)...) fmt.Fprintf(logWriter, "%s %s: %v\n", prefix, msg, err)
} }
func Fatal(msg ...interface{}) { func Fatal(msg string, err error) {
logPrint(msg...) logPrint(msg, err)
fmt.Fprintf(os.Stderr, "%s: fatal error\n", ProgName) // We don't show the error to the end user because it can leak
// information that is private to the GitLab server.
fmt.Fprintf(os.Stderr, "%s: fatal: %s\n", ProgName, msg)
os.Exit(1) os.Exit(1)
} }
...@@ -57,7 +59,7 @@ func Fatal(msg ...interface{}) { ...@@ -57,7 +59,7 @@ func Fatal(msg ...interface{}) {
// function attemps to log to syslog. // function attemps to log to syslog.
// //
// We assume the logging mutex is already locked. // We assume the logging mutex is already locked.
func bootstrapLogPrint(msg ...interface{}) { func bootstrapLogPrint(msg string, err error) {
if bootstrapLogger == nil { if bootstrapLogger == nil {
var err error var err error
bootstrapLogger, err = syslog.NewLogger(syslog.LOG_ERR|syslog.LOG_USER, 0) bootstrapLogger, err = syslog.NewLogger(syslog.LOG_ERR|syslog.LOG_USER, 0)
...@@ -67,6 +69,5 @@ func bootstrapLogPrint(msg ...interface{}) { ...@@ -67,6 +69,5 @@ func bootstrapLogPrint(msg ...interface{}) {
} }
} }
args := append([]interface{}{ProgName + ":"}, msg...) bootstrapLogger.Print(ProgName+":", msg+":", err)
bootstrapLogger.Print(args)
} }
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment