Initial commit

This commit is contained in:
NI
2019-08-07 15:56:51 +08:00
commit 02f14eb14f
206 changed files with 38863 additions and 0 deletions

48
application/log/ditch.go Normal file
View 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
View 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
View 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...)
}

View 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{}) {}