Commit a048486b authored by Eric's avatar Eric

[update] adjust code, release memory

parent 676c8ec8
...@@ -28,7 +28,7 @@ type Client struct { ...@@ -28,7 +28,7 @@ type Client struct {
BaseHost string BaseHost string
basicAuth []string basicAuth []string
cookie map[string]string cookie map[string]string
http *http.Client http http.Client
UrlParsers []UrlParser UrlParsers []UrlParser
} }
...@@ -36,11 +36,12 @@ type UrlParser interface { ...@@ -36,11 +36,12 @@ type UrlParser interface {
parse(url string, params ...map[string]string) string parse(url string, params ...map[string]string) string
} }
func NewClient(timeout time.Duration, baseHost string) *Client { func NewClient(timeout time.Duration, baseHost string) Client {
headers := make(map[string]string, 0) headers := make(map[string]string, 0)
client := new(http.Client) client := http.Client{
client.Timeout = timeout * time.Second Timeout: timeout * time.Second,
return &Client{ }
return Client{
BaseHost: baseHost, BaseHost: baseHost,
Timeout: timeout * time.Second, Timeout: timeout * time.Second,
Headers: headers, Headers: headers,
......
...@@ -148,14 +148,14 @@ func (t *WrapperTable) convertDataToSlice() [][]string { ...@@ -148,14 +148,14 @@ func (t *WrapperTable) convertDataToSlice() [][]string {
switch t.TruncPolicy { switch t.TruncPolicy {
case TruncSuffix: case TruncSuffix:
row[m] = fmt.Sprintf("%s...", row[m] = fmt.Sprintf("%s...",
GetValidString(j[n],columSize-3, true)) GetValidString(j[n], columSize-3, true))
case TruncPrefix: case TruncPrefix:
row[m] = fmt.Sprintf("...%s", row[m] = fmt.Sprintf("...%s",
GetValidString(j[n],len(j[n])-columSize-3, false)) GetValidString(j[n], len(j[n])-columSize-3, false))
case TruncMiddle: case TruncMiddle:
midValue := (columSize - 3) / 2 midValue := (columSize - 3) / 2
row[m] = fmt.Sprintf("%s...%s",GetValidString(j[n],midValue, true), row[m] = fmt.Sprintf("%s...%s", GetValidString(j[n], midValue, true),
GetValidString(j[n],len(j[n])-midValue, false)) GetValidString(j[n], len(j[n])-midValue, false))
} }
} }
...@@ -168,8 +168,8 @@ func (t *WrapperTable) convertDataToSlice() [][]string { ...@@ -168,8 +168,8 @@ func (t *WrapperTable) convertDataToSlice() [][]string {
func (t *WrapperTable) Display() string { func (t *WrapperTable) Display() string {
t.CalculateColumnsSize() t.CalculateColumnsSize()
tableString := &strings.Builder{} tableString := strings.Builder{}
table := tablewriter.NewWriter(tableString) table := tablewriter.NewWriter(&tableString)
table.SetBorder(false) table.SetBorder(false)
table.SetHeader(t.Labels) table.SetHeader(t.Labels)
colors := make([]tablewriter.Colors, len(t.Fields)) colors := make([]tablewriter.Colors, len(t.Fields))
...@@ -193,23 +193,23 @@ func (t *WrapperTable) Display() string { ...@@ -193,23 +193,23 @@ func (t *WrapperTable) Display() string {
return tableString.String() return tableString.String()
} }
func GetValidString(s string, position int, positive bool) string{ func GetValidString(s string, position int, positive bool) string {
step := 1 step := 1
if positive { if positive {
step = -1 step = -1
} }
for position >=0 && position <= len(s) { for position >= 0 && position <= len(s) {
switch positive { switch positive {
case true: case true:
if utf8.ValidString(s[:position]){ if utf8.ValidString(s[:position]) {
return s[:position] return s[:position]
} }
case false: case false:
if utf8.ValidString(s[position:]){ if utf8.ValidString(s[position:]) {
return s[position:] return s[position:]
} }
} }
position += step position += step
} }
return "" return ""
} }
\ No newline at end of file
...@@ -28,10 +28,12 @@ func GzipCompressFile(srcPath, dstPath string) error { ...@@ -28,10 +28,12 @@ func GzipCompressFile(srcPath, dstPath string) error {
if err != nil { if err != nil {
return err return err
} }
defer sf.Close()
df, err := os.Create(dstPath) df, err := os.Create(dstPath)
if err != nil { if err != nil {
return err return err
} }
defer df.Close()
writer := gzip.NewWriter(df) writer := gzip.NewWriter(df)
writer.Name = dstPath writer.Name = dstPath
writer.ModTime = time.Now().UTC() writer.ModTime = time.Now().UTC()
...@@ -60,6 +62,6 @@ func Abs(x int) int { ...@@ -60,6 +62,6 @@ func Abs(x int) int {
return x return x
} }
func CurrentUTCTime()string{ func CurrentUTCTime() string {
return time.Now().UTC().Format("2006-01-02 15:04:05 +0000") return time.Now().UTC().Format("2006-01-02 15:04:05 +0000")
} }
\ No newline at end of file
...@@ -13,8 +13,8 @@ import ( ...@@ -13,8 +13,8 @@ import (
"github.com/jumpserver/koko/pkg/utils" "github.com/jumpserver/koko/pkg/utils"
) )
func NewAssetPagination(term *utils.Terminal, assets []model.Asset) *AssetPagination { func NewAssetPagination(term *utils.Terminal, assets []model.Asset) AssetPagination {
assetPage := &AssetPagination{term: term, assets: assets} assetPage := AssetPagination{term: term, assets: assets}
assetPage.Initial() assetPage.Initial()
return assetPage return assetPage
} }
...@@ -181,8 +181,8 @@ func (p *AssetPagination) displayTipsInfo() { ...@@ -181,8 +181,8 @@ func (p *AssetPagination) displayTipsInfo() {
} }
func NewUserPagination(term *utils.Terminal, uid, search string, policy bool) *UserAssetPagination { func NewUserPagination(term *utils.Terminal, uid, search string, policy bool) UserAssetPagination {
return &UserAssetPagination{ return UserAssetPagination{
UserID: uid, UserID: uid,
offset: 0, offset: 0,
limit: 0, limit: 0,
...@@ -269,7 +269,7 @@ func (p *UserAssetPagination) Start() []model.Asset { ...@@ -269,7 +269,7 @@ func (p *UserAssetPagination) Start() []model.Asset {
func (p *UserAssetPagination) displayPageAssets() { func (p *UserAssetPagination) displayPageAssets() {
if len(p.Data.Data) == 0 { if len(p.Data.Data) == 0 {
_, _ = p.term.Write([]byte(getI18nFromMap("NoAssets")+"\n\r")) _, _ = p.term.Write([]byte(getI18nFromMap("NoAssets") + "\n\r"))
return return
} }
......
...@@ -43,6 +43,7 @@ func (w *WrapperSession) readLoop() { ...@@ -43,6 +43,7 @@ func (w *WrapperSession) readLoop() {
} }
w.mux.RLock() w.mux.RLock()
_ = w.inWriter.Close() _ = w.inWriter.Close()
_ = w.outReader.Close()
w.mux.RUnlock() w.mux.RUnlock()
close(w.closed) close(w.closed)
logger.Infof("Request %s: Read loop break", w.Uuid) logger.Infof("Request %s: Read loop break", w.Uuid)
......
...@@ -31,8 +31,8 @@ const ( ...@@ -31,8 +31,8 @@ const (
CommandOutputParserName = "Command Output parser" CommandOutputParserName = "Command Output parser"
) )
func newParser(sid string) *Parser { func newParser(sid string) Parser {
parser := &Parser{id: sid} parser := Parser{id: sid}
parser.initial() parser.initial()
return parser return parser
} }
...@@ -55,8 +55,8 @@ type Parser struct { ...@@ -55,8 +55,8 @@ type Parser struct {
command string command string
output string output string
cmdInputParser *CmdParser cmdInputParser CmdParser
cmdOutputParser *CmdParser cmdOutputParser CmdParser
cmdFilterRules []model.SystemUserFilterRule cmdFilterRules []model.SystemUserFilterRule
closed chan struct{} closed chan struct{}
......
...@@ -12,8 +12,8 @@ import ( ...@@ -12,8 +12,8 @@ import (
var ps1Pattern = regexp.MustCompile(`^\[?.*@.*\]?[\\$#]\s|mysql>\s`) var ps1Pattern = regexp.MustCompile(`^\[?.*@.*\]?[\\$#]\s|mysql>\s`)
func NewCmdParser(sid, name string) *CmdParser { func NewCmdParser(sid, name string) CmdParser {
parser := &CmdParser{id: sid, name:name} parser := CmdParser{id: sid, name:name}
parser.initial() parser.initial()
return parser return parser
} }
......
...@@ -21,8 +21,8 @@ func NewCommandRecorder(sid string) (recorder *CommandRecorder) { ...@@ -21,8 +21,8 @@ func NewCommandRecorder(sid string) (recorder *CommandRecorder) {
return recorder return recorder
} }
func NewReplyRecord(sid string) (recorder *ReplyRecorder) { func NewReplyRecord(sid string) (recorder ReplyRecorder) {
recorder = &ReplyRecorder{SessionID: sid} recorder = ReplyRecorder{SessionID: sid}
recorder.initial() recorder.initial()
return recorder return recorder
} }
......
...@@ -117,8 +117,8 @@ func (s *SwitchSession) SetFilterRules(cmdRules []model.SystemUserFilterRule) { ...@@ -117,8 +117,8 @@ func (s *SwitchSession) SetFilterRules(cmdRules []model.SystemUserFilterRule) {
// Bridge 桥接两个链接 // Bridge 桥接两个链接
func (s *SwitchSession) Bridge(userConn UserConnection, srvConn srvconn.ServerConnection) (err error) { func (s *SwitchSession) Bridge(userConn UserConnection, srvConn srvconn.ServerConnection) (err error) {
var ( var (
parser *Parser parser Parser
replayRecorder *ReplyRecorder replayRecorder ReplyRecorder
userInChan chan []byte userInChan chan []byte
srvInChan chan []byte srvInChan chan []byte
......
...@@ -35,10 +35,9 @@ func Initial(ctx context.Context) { ...@@ -35,10 +35,9 @@ func Initial(ctx context.Context) {
go KeepSyncConfigWithServer(ctx) go KeepSyncConfigWithServer(ctx)
} }
func newClient() *common.Client { func newClient() common.Client {
cf := config.GetConf() cf := config.GetConf()
cli := common.NewClient(30, "") cli := common.NewClient(30, cf.CoreHost)
cli.BaseHost = cf.CoreHost
return cli return cli
} }
......
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