2019-09-16 06:52:58 +00:00
|
|
|
package cmd
|
|
|
|
|
|
|
|
import (
|
|
|
|
"fmt"
|
2020-06-20 12:30:46 +00:00
|
|
|
"os"
|
2020-03-02 21:56:14 +00:00
|
|
|
"path/filepath"
|
2019-09-16 06:52:58 +00:00
|
|
|
|
2020-05-06 17:36:34 +00:00
|
|
|
"github.com/spf13/cobra"
|
|
|
|
|
2021-06-26 05:31:41 +00:00
|
|
|
"github.com/drakkan/sftpgo/v2/service"
|
2021-07-11 13:26:51 +00:00
|
|
|
"github.com/drakkan/sftpgo/v2/util"
|
2019-09-16 06:52:58 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
|
|
|
startCmd = &cobra.Command{
|
|
|
|
Use: "start",
|
2021-10-03 06:14:57 +00:00
|
|
|
Short: "Start the SFTPGo Windows Service",
|
2019-09-16 06:52:58 +00:00
|
|
|
Run: func(cmd *cobra.Command, args []string) {
|
2021-07-11 13:26:51 +00:00
|
|
|
configDir = util.CleanDirInput(configDir)
|
|
|
|
if !filepath.IsAbs(logFilePath) && util.IsFileInputValid(logFilePath) {
|
2020-03-02 23:34:06 +00:00
|
|
|
logFilePath = filepath.Join(configDir, logFilePath)
|
|
|
|
}
|
2019-09-16 06:52:58 +00:00
|
|
|
s := service.Service{
|
2020-03-02 23:34:06 +00:00
|
|
|
ConfigDir: configDir,
|
2019-09-16 06:52:58 +00:00
|
|
|
ConfigFile: configFile,
|
|
|
|
LogFilePath: logFilePath,
|
|
|
|
LogMaxSize: logMaxSize,
|
|
|
|
LogMaxBackups: logMaxBackups,
|
|
|
|
LogMaxAge: logMaxAge,
|
|
|
|
LogCompress: logCompress,
|
2022-07-13 08:40:24 +00:00
|
|
|
LogLevel: logLevel,
|
2021-11-06 15:27:01 +00:00
|
|
|
LogUTCTime: logUTCTime,
|
2019-09-16 06:52:58 +00:00
|
|
|
Shutdown: make(chan bool),
|
|
|
|
}
|
|
|
|
winService := service.WindowsService{
|
|
|
|
Service: s,
|
|
|
|
}
|
|
|
|
err := winService.RunService()
|
|
|
|
if err != nil {
|
|
|
|
fmt.Printf("Error starting service: %v\r\n", err)
|
2020-06-20 12:30:46 +00:00
|
|
|
os.Exit(1)
|
2019-09-16 06:52:58 +00:00
|
|
|
} else {
|
|
|
|
fmt.Printf("Service started!\r\n")
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}
|
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
serviceCmd.AddCommand(startCmd)
|
|
|
|
addServeFlags(startCmd)
|
|
|
|
}
|