Initial commit
This commit is contained in:
48
application/log/ditch.go
Normal file
48
application/log/ditch.go
Normal file
@@ -0,0 +1,48 @@
|
||||
// Sshwifty - A Web SSH client
|
||||
//
|
||||
// Copyright (C) 2019 Rui NI <nirui@gmx.com>
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as
|
||||
// published by the Free Software Foundation, either version 3 of the
|
||||
// License, or (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
package log
|
||||
|
||||
// Ditch ditch all logs
|
||||
type Ditch struct{}
|
||||
|
||||
// NewDitch creates a new Ditch
|
||||
func NewDitch() Ditch {
|
||||
return Ditch{}
|
||||
}
|
||||
|
||||
// Context build a new Sub context
|
||||
func (w Ditch) Context(name string, params ...interface{}) Logger {
|
||||
return w
|
||||
}
|
||||
|
||||
// Write writes default error
|
||||
func (w Ditch) Write(b []byte) (int, error) {
|
||||
return len(b), nil
|
||||
}
|
||||
|
||||
// Info write an info message
|
||||
func (w Ditch) Info(msg string, params ...interface{}) {}
|
||||
|
||||
// Debug write an debug message
|
||||
func (w Ditch) Debug(msg string, params ...interface{}) {}
|
||||
|
||||
// Warning write an warning message
|
||||
func (w Ditch) Warning(msg string, params ...interface{}) {}
|
||||
|
||||
// Error write an error message
|
||||
func (w Ditch) Error(msg string, params ...interface{}) {}
|
||||
28
application/log/log.go
Normal file
28
application/log/log.go
Normal file
@@ -0,0 +1,28 @@
|
||||
// Sshwifty - A Web SSH client
|
||||
//
|
||||
// Copyright (C) 2019 Rui NI <nirui@gmx.com>
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as
|
||||
// published by the Free Software Foundation, either version 3 of the
|
||||
// License, or (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
package log
|
||||
|
||||
// Logger represents a logger
|
||||
type Logger interface {
|
||||
Context(name string, params ...interface{}) Logger
|
||||
Write(b []byte) (int, error)
|
||||
Info(msg string, params ...interface{})
|
||||
Debug(msg string, params ...interface{})
|
||||
Warning(msg string, params ...interface{})
|
||||
Error(msg string, params ...interface{})
|
||||
}
|
||||
80
application/log/writer.go
Normal file
80
application/log/writer.go
Normal file
@@ -0,0 +1,80 @@
|
||||
// Sshwifty - A Web SSH client
|
||||
//
|
||||
// Copyright (C) 2019 Rui NI <nirui@gmx.com>
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as
|
||||
// published by the Free Software Foundation, either version 3 of the
|
||||
// License, or (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
package log
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"io"
|
||||
"time"
|
||||
)
|
||||
|
||||
// Writer will write logs to the underlaying writer
|
||||
type Writer struct {
|
||||
c string
|
||||
w io.Writer
|
||||
}
|
||||
|
||||
// NewWriter creates a new Writer
|
||||
func NewWriter(context string, w io.Writer) Writer {
|
||||
return Writer{
|
||||
c: context,
|
||||
w: w,
|
||||
}
|
||||
}
|
||||
|
||||
// Context build a new Sub context
|
||||
func (w Writer) Context(name string, params ...interface{}) Logger {
|
||||
return NewWriter(w.c+" > "+fmt.Sprintf(name, params...), w.w)
|
||||
}
|
||||
|
||||
// Write writes default error
|
||||
func (w Writer) Write(b []byte) (int, error) {
|
||||
_, wErr := w.write("DEF", string(b))
|
||||
|
||||
if wErr != nil {
|
||||
return 0, wErr
|
||||
}
|
||||
|
||||
return len(b), nil
|
||||
}
|
||||
|
||||
func (w Writer) write(
|
||||
prefix string, msg string, params ...interface{}) (int, error) {
|
||||
return fmt.Fprintf(w.w, "["+prefix+"] "+
|
||||
time.Now().Format(time.RFC1123)+" "+w.c+": "+msg+"\r\n", params...)
|
||||
}
|
||||
|
||||
// Info write an info message
|
||||
func (w Writer) Info(msg string, params ...interface{}) {
|
||||
w.write("INF", msg, params...)
|
||||
}
|
||||
|
||||
// Debug write an debug message
|
||||
func (w Writer) Debug(msg string, params ...interface{}) {
|
||||
w.write("DBG", msg, params...)
|
||||
}
|
||||
|
||||
// Warning write an warning message
|
||||
func (w Writer) Warning(msg string, params ...interface{}) {
|
||||
w.write("WRN", msg, params...)
|
||||
}
|
||||
|
||||
// Error write an error message
|
||||
func (w Writer) Error(msg string, params ...interface{}) {
|
||||
w.write("ERR", msg, params...)
|
||||
}
|
||||
54
application/log/writer_nodebug.go
Normal file
54
application/log/writer_nodebug.go
Normal file
@@ -0,0 +1,54 @@
|
||||
// Sshwifty - A Web SSH client
|
||||
//
|
||||
// Copyright (C) 2019 Rui NI <nirui@gmx.com>
|
||||
//
|
||||
// This program is free software: you can redistribute it and/or modify
|
||||
// it under the terms of the GNU Affero General Public License as
|
||||
// published by the Free Software Foundation, either version 3 of the
|
||||
// License, or (at your option) any later version.
|
||||
//
|
||||
// This program is distributed in the hope that it will be useful,
|
||||
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
// GNU Affero General Public License for more details.
|
||||
//
|
||||
// You should have received a copy of the GNU Affero General Public License
|
||||
// along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||
|
||||
package log
|
||||
|
||||
import (
|
||||
"fmt"
|
||||
"io"
|
||||
)
|
||||
|
||||
// NonDebugWriter will write logs to the underlaying writer
|
||||
type NonDebugWriter struct {
|
||||
Writer
|
||||
}
|
||||
|
||||
// NewNonDebugWriter creates a new Writer with debug output disabled
|
||||
func NewNonDebugWriter(context string, w io.Writer) NonDebugWriter {
|
||||
return NonDebugWriter{
|
||||
Writer: NewWriter(context, w),
|
||||
}
|
||||
}
|
||||
|
||||
// NewDebugOrNonDebugWriter creates debug or nondebug log depends on
|
||||
// given `useDebug`
|
||||
func NewDebugOrNonDebugWriter(
|
||||
useDebug bool, context string, w io.Writer) Logger {
|
||||
if useDebug {
|
||||
return NewWriter(context, w)
|
||||
}
|
||||
|
||||
return NewNonDebugWriter(context, w)
|
||||
}
|
||||
|
||||
// Context build a new Sub context
|
||||
func (w NonDebugWriter) Context(name string, params ...interface{}) Logger {
|
||||
return NewNonDebugWriter(w.c+" > "+fmt.Sprintf(name, params...), w.w)
|
||||
}
|
||||
|
||||
// Debug ditchs debug operation
|
||||
func (w NonDebugWriter) Debug(msg string, params ...interface{}) {}
|
||||
Reference in New Issue
Block a user