| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | // Copyright 2014 The Gogs Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // Copyright 2019 The Gitea Authors. All rights reserved. | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | // Use of this source code is governed by a MIT-style | 
					
						
							|  |  |  | // license that can be found in the LICENSE file. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | package log | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							| 
									
										
										
										
											2021-03-01 21:08:10 +00:00
										 |  |  | 	"fmt" | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | 	"io" | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | 	"os" | 
					
						
							| 
									
										
										
										
											2021-03-01 21:08:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-07-25 00:03:58 +08:00
										 |  |  | 	"code.gitea.io/gitea/modules/json" | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // CanColorStdout reports if we can color the Stdout | 
					
						
							|  |  |  | // Although we could do terminal sniffing and the like - in reality | 
					
						
							|  |  |  | // most tools on *nix are happy to display ansi colors. | 
					
						
							|  |  |  | // We will terminal sniff on Windows in console_windows.go | 
					
						
							|  |  |  | var CanColorStdout = true | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // CanColorStderr reports if we can color the Stderr | 
					
						
							|  |  |  | var CanColorStderr = true | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | type nopWriteCloser struct { | 
					
						
							|  |  |  | 	w io.WriteCloser | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | func (n *nopWriteCloser) Write(p []byte) (int, error) { | 
					
						
							|  |  |  | 	return n.w.Write(p) | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | func (n *nopWriteCloser) Close() error { | 
					
						
							|  |  |  | 	return nil | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // ConsoleLogger implements LoggerProvider and writes messages to terminal. | 
					
						
							|  |  |  | type ConsoleLogger struct { | 
					
						
							| 
									
										
										
										
											2019-04-07 01:25:14 +01:00
										 |  |  | 	WriterLogger | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | 	Stderr bool `json:"stderr"` | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // NewConsoleLogger create ConsoleLogger returning as LoggerProvider. | 
					
						
							|  |  |  | func NewConsoleLogger() LoggerProvider { | 
					
						
							|  |  |  | 	log := &ConsoleLogger{} | 
					
						
							| 
									
										
										
										
											2019-04-07 01:25:14 +01:00
										 |  |  | 	log.NewWriterLogger(&nopWriteCloser{ | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | 		w: os.Stdout, | 
					
						
							|  |  |  | 	}) | 
					
						
							|  |  |  | 	return log | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // Init inits connection writer with json config. | 
					
						
							|  |  |  | // json config only need key "level". | 
					
						
							|  |  |  | func (log *ConsoleLogger) Init(config string) error { | 
					
						
							|  |  |  | 	err := json.Unmarshal([]byte(config), log) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							| 
									
										
										
										
											2021-03-01 21:08:10 +00:00
										 |  |  | 		return fmt.Errorf("Unable to parse JSON: %v", err) | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | 	if log.Stderr { | 
					
						
							| 
									
										
										
										
											2019-04-07 01:25:14 +01:00
										 |  |  | 		log.NewWriterLogger(&nopWriteCloser{ | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | 			w: os.Stderr, | 
					
						
							|  |  |  | 		}) | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2019-04-07 01:25:14 +01:00
										 |  |  | 		log.NewWriterLogger(log.out) | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-02-25 10:20:50 +01:00
										 |  |  | // Content returns the content accumulated in the content provider | 
					
						
							|  |  |  | func (log *ConsoleLogger) Content() (string, error) { | 
					
						
							|  |  |  | 	return "", fmt.Errorf("not supported") | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-11-26 19:53:29 +08:00
										 |  |  | // Flush when log should be flushed | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | func (log *ConsoleLogger) Flush() { | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-06 01:07:07 +01:00
										 |  |  | // ReleaseReopen causes the console logger to reconnect to os.Stdout | 
					
						
							|  |  |  | func (log *ConsoleLogger) ReleaseReopen() error { | 
					
						
							|  |  |  | 	if log.Stderr { | 
					
						
							|  |  |  | 		log.NewWriterLogger(&nopWriteCloser{ | 
					
						
							|  |  |  | 			w: os.Stderr, | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		log.NewWriterLogger(&nopWriteCloser{ | 
					
						
							|  |  |  | 			w: os.Stdout, | 
					
						
							|  |  |  | 		}) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return nil | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | // GetName returns the default name for this implementation | 
					
						
							|  |  |  | func (log *ConsoleLogger) GetName() string { | 
					
						
							|  |  |  | 	return "console" | 
					
						
							| 
									
										
										
										
											2014-07-26 18:37:18 -04:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | func init() { | 
					
						
							| 
									
										
										
										
											2019-04-02 08:48:31 +01:00
										 |  |  | 	Register("console", NewConsoleLogger) | 
					
						
							| 
									
										
										
										
											2014-07-26 00:24:27 -04:00
										 |  |  | } |