mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-19 21:11:32 +01:00
checkpoint, ensuredefaultsession
This commit is contained in:
parent
b85be3457c
commit
60199713e8
@ -496,20 +496,17 @@ func main() {
|
|||||||
fmt.Printf("[error] %v\n", err)
|
fmt.Printf("[error] %v\n", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
numSessions, err := sstore.NumSessions(context.Background())
|
|
||||||
if err != nil {
|
|
||||||
fmt.Printf("[error] getting num sessions: %v\n", err)
|
|
||||||
return
|
|
||||||
}
|
|
||||||
err = sstore.EnsureLocalRemote(context.Background())
|
err = sstore.EnsureLocalRemote(context.Background())
|
||||||
if err != nil {
|
if err != nil {
|
||||||
fmt.Printf("[error] ensuring local remote: %v\n", err)
|
fmt.Printf("[error] ensuring local remote: %v\n", err)
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
fmt.Printf("[db] sessions count=%d\n", numSessions)
|
defaultSession, err := sstore.EnsureDefaultSession(context.Background())
|
||||||
if numSessions == 0 {
|
if err != nil {
|
||||||
sstore.CreateInitialSession(context.Background())
|
fmt.Printf("[error] ensuring default session: %v\n", err)
|
||||||
|
return
|
||||||
}
|
}
|
||||||
|
fmt.Printf("session: %#v\n", defaultSession)
|
||||||
return
|
return
|
||||||
|
|
||||||
runnerProc, err := remote.LaunchMShell()
|
runnerProc, err := remote.LaunchMShell()
|
||||||
|
@ -94,17 +94,23 @@ func GetSessionById(ctx context.Context, id string) (*SessionType, error) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
func GetSessionByName(ctx context.Context, name string) (*SessionType, error) {
|
func GetSessionByName(ctx context.Context, name string) (*SessionType, error) {
|
||||||
db, err := GetDB()
|
var rtnSession *SessionType
|
||||||
query := `SELECT * FROM session WHERE name = ?`
|
err := WithTx(ctx, func(tx *TxWrap) error {
|
||||||
var session SessionType
|
var session SessionType
|
||||||
err = db.GetContext(ctx, &session, query, name)
|
query := `SELECT * FROM session WHERE name = ?`
|
||||||
if err == sql.ErrNoRows {
|
found := tx.GetWrap(&session, query, name)
|
||||||
return nil, nil
|
if !found {
|
||||||
}
|
return nil
|
||||||
|
}
|
||||||
|
rtnSession = &session
|
||||||
|
query = `SELECT sessionid, windowid, name, curremote, version FROM window WHERE sessionid = ?`
|
||||||
|
tx.SelectWrap(&session.Windows, query, session.SessionId)
|
||||||
|
return nil
|
||||||
|
})
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
return &session, nil
|
return rtnSession, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
// also creates window, and sessionremote
|
// also creates window, and sessionremote
|
||||||
|
@ -51,20 +51,19 @@ func GetDB() (*sqlx.DB, error) {
|
|||||||
|
|
||||||
type SessionType struct {
|
type SessionType struct {
|
||||||
SessionId string `json:"sessionid"`
|
SessionId string `json:"sessionid"`
|
||||||
Remote string `json:"remote"`
|
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
Windows []*WindowType `json:"windows"`
|
Windows []*WindowType `json:"windows"`
|
||||||
Cmds []*CmdType `json:"cmds"`
|
Cmds []*CmdType `json:"cmds"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type WindowType struct {
|
type WindowType struct {
|
||||||
SessionId string `json:"sessionid"`
|
SessionId string `json:"sessionid"`
|
||||||
WindowId string `json:"windowid"`
|
WindowId string `json:"windowid"`
|
||||||
Name string `json:"name"`
|
Name string `json:"name"`
|
||||||
CurRemote string `json:"curremote"`
|
CurRemote string `json:"curremote"`
|
||||||
Remotes []*SessionRemote `json:"remotes"`
|
Remotes []*RemoteType `json:"remotes"`
|
||||||
Lines []*LineType `json:"lines"`
|
Lines []*LineType `json:"lines"`
|
||||||
Version int `json:"version"`
|
Version int `json:"version"`
|
||||||
}
|
}
|
||||||
|
|
||||||
type SessionRemote struct {
|
type SessionRemote struct {
|
||||||
@ -178,19 +177,19 @@ func EnsureLocalRemote(ctx context.Context) error {
|
|||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func EnsureDefaultSession(ctx context.Context) error {
|
func EnsureDefaultSession(ctx context.Context) (*SessionType, error) {
|
||||||
session, err := GetSessionByName(ctx, DefaultSessionName)
|
session, err := GetSessionByName(ctx, DefaultSessionName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return nil, err
|
||||||
}
|
}
|
||||||
if session != nil {
|
if session != nil {
|
||||||
return nil
|
return session, nil
|
||||||
}
|
}
|
||||||
err = InsertSessionWithName(ctx, DefaultSessionName)
|
err = InsertSessionWithName(ctx, DefaultSessionName)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return err
|
return nil, err
|
||||||
}
|
}
|
||||||
return nil
|
return GetSessionByName(ctx, DefaultSessionName)
|
||||||
}
|
}
|
||||||
|
|
||||||
func CreateInitialSession(ctx context.Context) error {
|
func CreateInitialSession(ctx context.Context) error {
|
||||||
|
@ -65,24 +65,28 @@ func (tx *TxWrap) ExecWrap(query string, args ...interface{}) sql.Result {
|
|||||||
return result
|
return result
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *TxWrap) GetWrap(dest interface{}, query string, args ...interface{}) error {
|
func (tx *TxWrap) GetWrap(dest interface{}, query string, args ...interface{}) bool {
|
||||||
if tx.Err != nil {
|
if tx.Err != nil {
|
||||||
return nil
|
return false
|
||||||
}
|
}
|
||||||
err := tx.Txx.Get(dest, query, args...)
|
err := tx.Txx.Get(dest, query, args...)
|
||||||
if err != nil && err != sql.ErrNoRows {
|
if err != nil && err == sql.ErrNoRows {
|
||||||
tx.Err = err
|
return false
|
||||||
}
|
}
|
||||||
return err
|
if err != nil {
|
||||||
|
tx.Err = err
|
||||||
|
return false
|
||||||
|
}
|
||||||
|
return true
|
||||||
}
|
}
|
||||||
|
|
||||||
func (tx *TxWrap) SelectWrap(dest interface{}, query string, args ...interface{}) error {
|
func (tx *TxWrap) SelectWrap(dest interface{}, query string, args ...interface{}) {
|
||||||
if tx.Err != nil {
|
if tx.Err != nil {
|
||||||
return nil
|
return
|
||||||
}
|
}
|
||||||
err := tx.Txx.Select(dest, query, args...)
|
err := tx.Txx.Select(dest, query, args...)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
tx.Err = err
|
tx.Err = err
|
||||||
}
|
}
|
||||||
return err
|
return
|
||||||
}
|
}
|
||||||
|
12
scripthaus.md
Normal file
12
scripthaus.md
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
# SH2 Server Commands
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# @scripthaus command dump-schema
|
||||||
|
sqlite3 /Users/mike/scripthaus/sh2.db .schema > db/schema.sql
|
||||||
|
```
|
||||||
|
|
||||||
|
```bash
|
||||||
|
# @scripthaus command opendb
|
||||||
|
sqlite3 /Users/mike/scripthaus/sh2.db
|
||||||
|
```
|
||||||
|
|
Loading…
Reference in New Issue
Block a user