| 
									
										
										
										
											2015-07-07 02:54:22 +02:00
										 |  |  | // Copyright 2015 The go-ethereum Authors | 
					
						
							| 
									
										
										
										
											2015-07-22 18:48:40 +02:00
										 |  |  | // This file is part of the go-ethereum library. | 
					
						
							| 
									
										
										
										
											2015-07-07 02:54:22 +02:00
										 |  |  | // | 
					
						
							| 
									
										
										
										
											2015-07-23 18:35:11 +02:00
										 |  |  | // The go-ethereum library is free software: you can redistribute it and/or modify | 
					
						
							| 
									
										
										
										
											2015-07-07 02:54:22 +02:00
										 |  |  | // it under the terms of the GNU Lesser General Public License as published by | 
					
						
							|  |  |  | // the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | // (at your option) any later version. | 
					
						
							|  |  |  | // | 
					
						
							| 
									
										
										
										
											2015-07-22 18:48:40 +02:00
										 |  |  | // The go-ethereum library is distributed in the hope that it will be useful, | 
					
						
							| 
									
										
										
										
											2015-07-07 02:54:22 +02:00
										 |  |  | // but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							| 
									
										
										
										
											2015-07-22 18:48:40 +02:00
										 |  |  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
					
						
							| 
									
										
										
										
											2015-07-07 02:54:22 +02:00
										 |  |  | // GNU Lesser General Public License for more details. | 
					
						
							|  |  |  | // | 
					
						
							|  |  |  | // You should have received a copy of the GNU Lesser General Public License | 
					
						
							| 
									
										
										
										
											2015-07-22 18:48:40 +02:00
										 |  |  | // along with the go-ethereum library. If not, see <http://www.gnu.org/licenses/>. | 
					
						
							| 
									
										
										
										
											2015-07-07 02:54:22 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | package logger | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import ( | 
					
						
							|  |  |  | 	"fmt" | 
					
						
							|  |  |  | 	"io" | 
					
						
							|  |  |  | 	"log" | 
					
						
							|  |  |  | 	"os" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-16 11:27:38 +01:00
										 |  |  | 	"github.com/ethereum/go-ethereum/common" | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | ) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func openLogFile(datadir string, filename string) *os.File { | 
					
						
							| 
									
										
										
										
											2015-03-16 11:27:38 +01:00
										 |  |  | 	path := common.AbsolutePath(datadir, filename) | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	file, err := os.OpenFile(path, os.O_RDWR|os.O_CREATE|os.O_APPEND, 0666) | 
					
						
							|  |  |  | 	if err != nil { | 
					
						
							|  |  |  | 		panic(fmt.Sprintf("error opening log file '%s': %v", filename, err)) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return file | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-21 09:20:47 +00:00
										 |  |  | func New(datadir string, logFile string, logLevel int) LogSystem { | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	var writer io.Writer | 
					
						
							|  |  |  | 	if logFile == "" { | 
					
						
							|  |  |  | 		writer = os.Stdout | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		writer = openLogFile(datadir, logFile) | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-21 10:17:07 -06:00
										 |  |  | 	var sys LogSystem | 
					
						
							| 
									
										
										
										
											2015-03-21 09:20:47 +00:00
										 |  |  | 	sys = NewStdLogSystem(writer, log.LstdFlags, LogLevel(logLevel)) | 
					
						
							|  |  |  | 	AddLogSystem(sys) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return sys | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | func NewJSONsystem(datadir string, logFile string) LogSystem { | 
					
						
							|  |  |  | 	var writer io.Writer | 
					
						
							|  |  |  | 	if logFile == "-" { | 
					
						
							|  |  |  | 		writer = os.Stdout | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		writer = openLogFile(datadir, logFile) | 
					
						
							| 
									
										
										
										
											2015-01-21 10:17:07 -06:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2015-03-21 09:20:47 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	var sys LogSystem | 
					
						
							|  |  |  | 	sys = NewJsonLogSystem(writer) | 
					
						
							| 
									
										
										
										
											2015-01-04 14:20:16 +01:00
										 |  |  | 	AddLogSystem(sys) | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return sys | 
					
						
							|  |  |  | } |