2018-10-31 02:42:54 +01:00
|
|
|
/*
|
2022-09-30 00:42:19 +02:00
|
|
|
Package commands provides the CLI commands of PhotoPrism.
|
2022-04-12 19:14:21 +02:00
|
|
|
|
2022-04-13 22:17:59 +02:00
|
|
|
Copyright (c) 2018 - 2022 PhotoPrism UG. All rights reserved.
|
2022-04-12 19:14:21 +02:00
|
|
|
|
2022-08-10 16:09:21 +02:00
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under Version 3 of the GNU Affero General Public License (the "AGPL"):
|
|
|
|
<https://docs.photoprism.app/license/agpl>
|
2022-04-12 19:14:21 +02:00
|
|
|
|
2022-08-10 16:09:21 +02:00
|
|
|
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.
|
2022-04-12 19:14:21 +02:00
|
|
|
|
2022-08-10 16:09:21 +02:00
|
|
|
The AGPL is supplemented by our Trademark and Brand Guidelines,
|
|
|
|
which describe how our Brand Assets may be used:
|
|
|
|
<https://photoprism.app/trademark>
|
2022-04-12 19:14:21 +02:00
|
|
|
|
2022-04-13 22:17:59 +02:00
|
|
|
Feel free to send an email to hello@photoprism.app if you have questions,
|
2022-04-12 19:14:21 +02:00
|
|
|
want to support our work, or just want to say hello.
|
|
|
|
|
|
|
|
Additional information can be found in our Developer Guide:
|
|
|
|
<https://docs.photoprism.app/developer-guide/>
|
2018-10-31 02:42:54 +01:00
|
|
|
*/
|
|
|
|
package commands
|
2019-06-30 05:38:39 +02:00
|
|
|
|
2019-07-03 19:56:47 +02:00
|
|
|
import (
|
2022-09-28 09:01:17 +02:00
|
|
|
"context"
|
2019-07-03 19:56:47 +02:00
|
|
|
"os"
|
|
|
|
"syscall"
|
|
|
|
|
2022-04-12 19:14:21 +02:00
|
|
|
"github.com/sevlyar/go-daemon"
|
|
|
|
"github.com/urfave/cli"
|
|
|
|
|
2022-09-28 09:01:17 +02:00
|
|
|
"github.com/photoprism/photoprism/internal/config"
|
2019-12-02 00:30:58 +01:00
|
|
|
"github.com/photoprism/photoprism/internal/event"
|
2022-09-30 00:42:19 +02:00
|
|
|
"github.com/photoprism/photoprism/internal/service"
|
2020-01-12 14:00:56 +01:00
|
|
|
"github.com/photoprism/photoprism/pkg/fs"
|
2019-07-03 19:56:47 +02:00
|
|
|
)
|
2019-06-30 05:38:39 +02:00
|
|
|
|
2019-12-02 00:30:58 +01:00
|
|
|
var log = event.Log
|
2019-07-03 19:56:47 +02:00
|
|
|
|
2022-04-12 19:14:21 +02:00
|
|
|
// PhotoPrism contains the photoprism CLI (sub-)commands.
|
|
|
|
var PhotoPrism = []cli.Command{
|
|
|
|
StartCommand,
|
|
|
|
StopCommand,
|
|
|
|
StatusCommand,
|
|
|
|
IndexCommand,
|
|
|
|
ImportCommand,
|
|
|
|
CopyCommand,
|
|
|
|
FacesCommand,
|
|
|
|
PlacesCommand,
|
|
|
|
PurgeCommand,
|
|
|
|
CleanUpCommand,
|
|
|
|
OptimizeCommand,
|
|
|
|
MomentsCommand,
|
|
|
|
ConvertCommand,
|
|
|
|
ThumbsCommand,
|
2022-09-28 09:01:17 +02:00
|
|
|
MigrateCommand,
|
2022-04-12 19:14:21 +02:00
|
|
|
MigrationsCommand,
|
|
|
|
BackupCommand,
|
|
|
|
RestoreCommand,
|
|
|
|
ResetCommand,
|
|
|
|
PasswdCommand,
|
|
|
|
UsersCommand,
|
|
|
|
ShowCommand,
|
|
|
|
VersionCommand,
|
2022-04-14 10:49:56 +02:00
|
|
|
ShowConfigCommand,
|
2022-04-12 19:14:21 +02:00
|
|
|
}
|
|
|
|
|
2020-10-01 12:15:43 +02:00
|
|
|
// childAlreadyRunning tests if a .pid file at filePath is a running process.
|
2020-02-18 23:42:51 +01:00
|
|
|
// it returns the pid value and the running status (true or false).
|
2019-07-03 19:56:47 +02:00
|
|
|
func childAlreadyRunning(filePath string) (pid int, running bool) {
|
2020-01-12 14:00:56 +01:00
|
|
|
if !fs.FileExists(filePath) {
|
2019-07-03 19:56:47 +02:00
|
|
|
return pid, false
|
|
|
|
}
|
|
|
|
|
|
|
|
pid, err := daemon.ReadPidFile(filePath)
|
2022-09-28 09:01:17 +02:00
|
|
|
|
|
|
|
// Failed?
|
2019-07-03 19:56:47 +02:00
|
|
|
if err != nil {
|
|
|
|
return pid, false
|
|
|
|
}
|
|
|
|
|
2022-09-28 09:01:17 +02:00
|
|
|
process, err := os.FindProcess(pid)
|
|
|
|
|
|
|
|
// Failed?
|
2019-07-03 19:56:47 +02:00
|
|
|
if err != nil {
|
|
|
|
return pid, false
|
|
|
|
}
|
|
|
|
|
|
|
|
return pid, process.Signal(syscall.Signal(0)) == nil
|
|
|
|
}
|
2022-09-28 09:01:17 +02:00
|
|
|
|
|
|
|
// CallWithDependencies calls a command action with initialized dependencies.
|
|
|
|
func CallWithDependencies(ctx *cli.Context, action func(conf *config.Config) error) (err error) {
|
|
|
|
conf := config.NewConfig(ctx)
|
|
|
|
service.SetConfig(conf)
|
|
|
|
|
|
|
|
_, cancel := context.WithCancel(context.Background())
|
|
|
|
defer cancel()
|
|
|
|
|
|
|
|
if err := conf.Init(); err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
conf.RegisterDb()
|
|
|
|
defer conf.Shutdown()
|
|
|
|
|
|
|
|
// Run command.
|
|
|
|
err = action(conf)
|
|
|
|
|
|
|
|
return err
|
|
|
|
}
|