Unverified Commit d80a7d05 authored by Eric_Lee's avatar Eric_Lee Committed by GitHub

Sftp优化 (#37)

* [update]sftp优化

* 调整sftp结构

* 优化sftp code
parent 0c876a8e
...@@ -5,7 +5,7 @@ go 1.12 ...@@ -5,7 +5,7 @@ go 1.12
require ( require (
github.com/Azure/azure-pipeline-go v0.1.9 // indirect github.com/Azure/azure-pipeline-go v0.1.9 // indirect
github.com/Azure/azure-storage-blob-go v0.6.0 github.com/Azure/azure-storage-blob-go v0.6.0
github.com/LeeEirc/elfinder v0.0.0-20190604073433-f4f8357e9220 github.com/LeeEirc/elfinder v0.0.0-20190718024942-8893ec7a969f
github.com/aliyun/aliyun-oss-go-sdk v1.9.8 github.com/aliyun/aliyun-oss-go-sdk v1.9.8
github.com/aws/aws-sdk-go v1.19.46 github.com/aws/aws-sdk-go v1.19.46
github.com/baiyubin/aliyun-sts-go-sdk v0.0.0-20180326062324-cfa1a18b161f // indirect github.com/baiyubin/aliyun-sts-go-sdk v0.0.0-20180326062324-cfa1a18b161f // indirect
......
...@@ -15,6 +15,10 @@ github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ ...@@ -15,6 +15,10 @@ github.com/BurntSushi/toml v0.3.1 h1:WXkYYl6Yr3qBf1K79EBnL4mak0OimBfB0XUf9Vl28OQ
github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU= github.com/BurntSushi/toml v0.3.1/go.mod h1:xHWCNGjB5oqiDr8zfno3MHue2Ht5sIBksp03qcyfWMU=
github.com/LeeEirc/elfinder v0.0.0-20190604073433-f4f8357e9220 h1:U865EO8YNrjZIGNp7O8QEYLZFDJ8zcooD73BiAqgDg4= github.com/LeeEirc/elfinder v0.0.0-20190604073433-f4f8357e9220 h1:U865EO8YNrjZIGNp7O8QEYLZFDJ8zcooD73BiAqgDg4=
github.com/LeeEirc/elfinder v0.0.0-20190604073433-f4f8357e9220/go.mod h1:ApL/XFs34Gvqinex9Z1sZdsp3Jeu26nNuEsf1wQFx8s= github.com/LeeEirc/elfinder v0.0.0-20190604073433-f4f8357e9220/go.mod h1:ApL/XFs34Gvqinex9Z1sZdsp3Jeu26nNuEsf1wQFx8s=
github.com/LeeEirc/elfinder v0.0.0-20190718023636-5679c8bdb7bf h1:dZipr1cwienSKNTXsveMmyd7VFY3v/eMHNl/vueN10s=
github.com/LeeEirc/elfinder v0.0.0-20190718023636-5679c8bdb7bf/go.mod h1:ApL/XFs34Gvqinex9Z1sZdsp3Jeu26nNuEsf1wQFx8s=
github.com/LeeEirc/elfinder v0.0.0-20190718024942-8893ec7a969f h1:xhKgvkrt+lR8IRL+YzmeebV0dlrOiFj1i4UfwSEPVSc=
github.com/LeeEirc/elfinder v0.0.0-20190718024942-8893ec7a969f/go.mod h1:ApL/XFs34Gvqinex9Z1sZdsp3Jeu26nNuEsf1wQFx8s=
github.com/LeeEirc/go-socket.io v1.4.2-0.20190610105739-e344e8b5a55a h1:l5fhBUD24xuw9S4yCUd6hD7OFjYXiJiALT1aqQ4LLfA= github.com/LeeEirc/go-socket.io v1.4.2-0.20190610105739-e344e8b5a55a h1:l5fhBUD24xuw9S4yCUd6hD7OFjYXiJiALT1aqQ4LLfA=
github.com/LeeEirc/go-socket.io v1.4.2-0.20190610105739-e344e8b5a55a/go.mod h1:yjlQxKcAZXZjpGwQVW/y1sgyL1ou+DdCpkswURDCRrU= github.com/LeeEirc/go-socket.io v1.4.2-0.20190610105739-e344e8b5a55a/go.mod h1:yjlQxKcAZXZjpGwQVW/y1sgyL1ou+DdCpkswURDCRrU=
github.com/aliyun/aliyun-oss-go-sdk v1.9.8 h1:BOflvK0Zs/zGmoabyFIzTg5c3kguktWTXEwewwbuba0= github.com/aliyun/aliyun-oss-go-sdk v1.9.8 h1:BOflvK0Zs/zGmoabyFIzTg5c3kguktWTXEwewwbuba0=
...@@ -66,8 +70,6 @@ github.com/gorilla/websocket v1.4.0 h1:WDFjx/TMzVgy9VdMMQi2K2Emtwi2QcUQsztZ/zLaH ...@@ -66,8 +70,6 @@ github.com/gorilla/websocket v1.4.0 h1:WDFjx/TMzVgy9VdMMQi2K2Emtwi2QcUQsztZ/zLaH
github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ= github.com/gorilla/websocket v1.4.0/go.mod h1:E7qHFY5m1UJ88s3WnNqhKjPHQ0heANvMoAMk2YaljkQ=
github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA= github.com/gregjones/httpcache v0.0.0-20180305231024-9cad4c3443a7/go.mod h1:FecbI9+v66THATjSRHfNgh1IVFe/9kFxbXtjV0ctIMA=
github.com/grpc-ecosystem/grpc-gateway v1.5.0/go.mod h1:RSKVYQBd5MCa4OVpNdGskqpgL2+G+NZTnrVHpWWfpdw= github.com/grpc-ecosystem/grpc-gateway v1.5.0/go.mod h1:RSKVYQBd5MCa4OVpNdGskqpgL2+G+NZTnrVHpWWfpdw=
github.com/ibuler/crypto v0.0.0-20190509101200-a7099eef26a7 h1:1wAr7VKNYJw3mhTTU1Ztu5lyJKHzHmjlA9n+LV09z8E=
github.com/ibuler/crypto v0.0.0-20190509101200-a7099eef26a7/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
github.com/ibuler/crypto v0.0.0-20190715092645-911d13b3bf6e h1:QnLvABxtQH9BFja0P/wEjeTPABqvvwIz+to52VNn170= github.com/ibuler/crypto v0.0.0-20190715092645-911d13b3bf6e h1:QnLvABxtQH9BFja0P/wEjeTPABqvvwIz+to52VNn170=
github.com/ibuler/crypto v0.0.0-20190715092645-911d13b3bf6e/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI= github.com/ibuler/crypto v0.0.0-20190715092645-911d13b3bf6e/go.mod h1:yigFU9vqHzYiE8UmvKecakEJjdnWj3jj499lnFckfCI=
github.com/ibuler/go-engine.io v1.4.2-0.20190529094538-7786d3a289b9 h1:8vjRBcvQ50mYr5y9jQWbYXOew3nn3+eF2YNpaAcFrAU= github.com/ibuler/go-engine.io v1.4.2-0.20190529094538-7786d3a289b9 h1:8vjRBcvQ50mYr5y9jQWbYXOew3nn3+eF2YNpaAcFrAU=
......
...@@ -323,7 +323,7 @@ func (h *interactiveHandler) refreshAssetsAndNodesData() { ...@@ -323,7 +323,7 @@ func (h *interactiveHandler) refreshAssetsAndNodesData() {
} }
func (h *interactiveHandler) loadUserAssets(cachePolicy string) { func (h *interactiveHandler) loadUserAssets(cachePolicy string) {
assets := service.GetUserAssets(h.user.ID, cachePolicy) assets := service.GetUserAssets(h.user.ID, cachePolicy, "")
userAssetsCached.SetValue(h.user.ID, assets) userAssetsCached.SetValue(h.user.ID, assets)
h.mu.Lock() h.mu.Lock()
h.assets = assets h.assets = assets
......
This diff is collapsed.
...@@ -74,6 +74,8 @@ func sftpFinder(wr http.ResponseWriter, req *http.Request) { ...@@ -74,6 +74,8 @@ func sftpFinder(wr http.ResponseWriter, req *http.Request) {
} }
func sftpHostConnectorView(wr http.ResponseWriter, req *http.Request) { func sftpHostConnectorView(wr http.ResponseWriter, req *http.Request) {
vars := mux.Vars(req)
hostID := vars["host"]
user := req.Context().Value(cctx.ContextKeyUser).(*model.User) user := req.Context().Value(cctx.ContextKeyUser).(*model.User)
remoteIP := req.Context().Value(cctx.ContextKeyRemoteAddr).(string) remoteIP := req.Context().Value(cctx.ContextKeyRemoteAddr).(string)
switch req.Method { switch req.Method {
...@@ -92,7 +94,12 @@ func sftpHostConnectorView(wr http.ResponseWriter, req *http.Request) { ...@@ -92,7 +94,12 @@ func sftpHostConnectorView(wr http.ResponseWriter, req *http.Request) {
sid := req.Form.Get("sid") sid := req.Form.Get("sid")
userV, ok := GetUserVolume(sid) userV, ok := GetUserVolume(sid)
if !ok { if !ok {
userV = NewUserVolume(user, remoteIP) switch strings.TrimSpace(hostID) {
case "_":
userV = NewUserVolume(user, remoteIP,"")
default:
userV = NewUserVolume(user, remoteIP, hostID)
}
addUserVolume(sid, userV) addUserVolume(sid, userV)
} }
logger.Debugf("sid: %s", sid) logger.Debugf("sid: %s", sid)
......
This diff is collapsed.
...@@ -2,12 +2,19 @@ package httpd ...@@ -2,12 +2,19 @@ package httpd
import ( import (
"sync" "sync"
"github.com/LeeEirc/elfinder"
) )
var userVolumes = make(map[string]*UserVolume) type VolumeCloser interface {
elfinder.Volume
Close()
}
var userVolumes = make(map[string]VolumeCloser)
var volumeLock = new(sync.RWMutex) var volumeLock = new(sync.RWMutex)
func addUserVolume(sid string, v *UserVolume) { func addUserVolume(sid string, v VolumeCloser) {
volumeLock.Lock() volumeLock.Lock()
defer volumeLock.Unlock() defer volumeLock.Unlock()
userVolumes[sid] = v userVolumes[sid] = v
...@@ -27,7 +34,7 @@ func removeUserVolume(sid string) { ...@@ -27,7 +34,7 @@ func removeUserVolume(sid string) {
} }
func GetUserVolume(sid string) (*UserVolume, bool) { func GetUserVolume(sid string) (VolumeCloser, bool) {
volumeLock.RLock() volumeLock.RLock()
defer volumeLock.RUnlock() defer volumeLock.RUnlock()
v, ok := userVolumes[sid] v, ok := userVolumes[sid]
......
...@@ -70,7 +70,7 @@ func uploadRemainReplay(rootPath string) { ...@@ -70,7 +70,7 @@ func uploadRemainReplay(rootPath string) {
} }
_ = os.Remove(path) _ = os.Remove(path)
} }
relayRecord := &proxy.ReplyRecorder{} relayRecord := &proxy.ReplyRecorder{SessionID:sid}
relayRecord.AbsGzFilePath = absGzPath relayRecord.AbsGzFilePath = absGzPath
relayRecord.Target, _ = filepath.Rel(path, rootPath) relayRecord.Target, _ = filepath.Rel(path, rootPath)
relayRecord.UploadGzipFile(3) relayRecord.UploadGzipFile(3)
......
...@@ -220,6 +220,7 @@ func SortAssetNodesByKey(assetNodes []Node) { ...@@ -220,6 +220,7 @@ func SortAssetNodesByKey(assetNodes []Node) {
const LoginModeManual = "manual" const LoginModeManual = "manual"
const ( const (
AllAction = "all"
ConnectAction = "connect" ConnectAction = "connect"
UploadAction = "upload_file" UploadAction = "upload_file"
DownloadAction = "download_file" DownloadAction = "download_file"
......
package model package model
const (
OperateRemoveDir = "Rmdir"
OperateDownaload = "Download"
OperateUpload = "Upload"
OperateRename = "Rename"
OperateMkdir = "Mkdir"
OperateDelete = "Delete"
OperateSymlink = "Symlink"
)
...@@ -22,7 +22,7 @@ func NewCommandRecorder(sid string) (recorder *CommandRecorder) { ...@@ -22,7 +22,7 @@ func NewCommandRecorder(sid string) (recorder *CommandRecorder) {
} }
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
} }
...@@ -93,7 +93,7 @@ func (c *CommandRecorder) record() { ...@@ -93,7 +93,7 @@ func (c *CommandRecorder) record() {
} }
type ReplyRecorder struct { type ReplyRecorder struct {
sessionID string SessionID string
absFilePath string absFilePath string
AbsGzFilePath string AbsGzFilePath string
...@@ -119,7 +119,7 @@ func (r *ReplyRecorder) Record(b []byte) { ...@@ -119,7 +119,7 @@ func (r *ReplyRecorder) Record(b []byte) {
} }
func (r *ReplyRecorder) prepare() { func (r *ReplyRecorder) prepare() {
sessionID := r.sessionID sessionID := r.SessionID
rootPath := config.GetConf().RootPath rootPath := config.GetConf().RootPath
today := time.Now().UTC().Format("2006-01-02") today := time.Now().UTC().Format("2006-01-02")
gzFileName := sessionID + ".replay.gz" gzFileName := sessionID + ".replay.gz"
...@@ -179,7 +179,7 @@ func (r *ReplyRecorder) UploadGzipFile(maxRetry int) { ...@@ -179,7 +179,7 @@ func (r *ReplyRecorder) UploadGzipFile(maxRetry int) {
err := r.storage.Upload(r.AbsGzFilePath, r.Target) err := r.storage.Upload(r.AbsGzFilePath, r.Target)
if err == nil { if err == nil {
_ = os.Remove(r.AbsGzFilePath) _ = os.Remove(r.AbsGzFilePath)
service.FinishReply(r.sessionID) service.FinishReply(r.SessionID)
break break
} }
// 如果还是失败,使用备用storage再传一次 // 如果还是失败,使用备用storage再传一次
......
...@@ -7,11 +7,14 @@ import ( ...@@ -7,11 +7,14 @@ import (
"github.com/jumpserver/koko/pkg/model" "github.com/jumpserver/koko/pkg/model"
) )
func GetUserAssets(userID, cachePolicy string) (assets model.AssetList) { func GetUserAssets(userID, cachePolicy, assetId string) (assets model.AssetList) {
if cachePolicy == "" { if cachePolicy == "" {
cachePolicy = "1" cachePolicy = "1"
} }
payload := map[string]string{"cache_policy": cachePolicy} payload := map[string]string{"cache_policy": cachePolicy}
if assetId != "" {
payload["id"] = assetId
}
Url := fmt.Sprintf(UserAssetsURL, userID) Url := fmt.Sprintf(UserAssetsURL, userID)
err := authClient.Get(Url, &assets, payload) err := authClient.Get(Url, &assets, payload)
if err != nil { if err != nil {
......
This diff is collapsed.
package srvconn package srvconn
import ( import (
"golang.org/x/crypto/ssh"
"io/ioutil" "io/ioutil"
"golang.org/x/crypto/ssh"
) )
func GetPubKeyFromFile(keypath string) (ssh.Signer, error) { func GetPubKeyFromFile(keypath string) (ssh.Signer, error) {
......
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