2015-03-19 11:31:21 +01:00
|
|
|
// Copyright (C) 2015 The Syncthing Authors.
|
|
|
|
//
|
|
|
|
// This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
// License, v. 2.0. If a copy of the MPL was not distributed with this file,
|
|
|
|
// You can obtain one at http://mozilla.org/MPL/2.0/.
|
|
|
|
|
|
|
|
package versioner
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
|
|
|
"os"
|
|
|
|
"os/exec"
|
|
|
|
"path/filepath"
|
|
|
|
"strings"
|
2015-04-14 19:31:25 +09:00
|
|
|
|
2015-08-06 11:29:25 +02:00
|
|
|
"github.com/syncthing/syncthing/lib/osutil"
|
2015-03-19 11:31:21 +01:00
|
|
|
)
|
|
|
|
|
|
|
|
func init() {
|
|
|
|
// Register the constructor for this type of versioner with the name "external"
|
|
|
|
Factories["external"] = NewExternal
|
|
|
|
}
|
|
|
|
|
|
|
|
type External struct {
|
|
|
|
command string
|
|
|
|
folderPath string
|
|
|
|
}
|
|
|
|
|
|
|
|
func NewExternal(folderID, folderPath string, params map[string]string) Versioner {
|
|
|
|
command := params["command"]
|
|
|
|
|
|
|
|
s := External{
|
|
|
|
command: command,
|
|
|
|
folderPath: folderPath,
|
|
|
|
}
|
|
|
|
|
2015-10-03 17:25:21 +02:00
|
|
|
l.Debugf("instantiated %#v", s)
|
2015-03-19 11:31:21 +01:00
|
|
|
return s
|
|
|
|
}
|
|
|
|
|
2015-04-28 22:32:10 +02:00
|
|
|
// Archive moves the named file away to a version archive. If this function
|
|
|
|
// returns nil, the named file does not exist any more (has been archived).
|
2015-03-19 11:31:21 +01:00
|
|
|
func (v External) Archive(filePath string) error {
|
2015-04-14 19:31:25 +09:00
|
|
|
_, err := osutil.Lstat(filePath)
|
2015-03-19 11:31:21 +01:00
|
|
|
if os.IsNotExist(err) {
|
2015-10-03 17:25:21 +02:00
|
|
|
l.Debugln("not archiving nonexistent file", filePath)
|
2015-03-19 11:31:21 +01:00
|
|
|
return nil
|
|
|
|
} else if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
2015-10-03 17:25:21 +02:00
|
|
|
l.Debugln("archiving", filePath)
|
2015-03-19 11:31:21 +01:00
|
|
|
|
|
|
|
inFolderPath, err := filepath.Rel(v.folderPath, filePath)
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
if v.command == "" {
|
|
|
|
return errors.New("Versioner: command is empty, please enter a valid command")
|
|
|
|
}
|
|
|
|
|
|
|
|
cmd := exec.Command(v.command, v.folderPath, inFolderPath)
|
|
|
|
env := os.Environ()
|
|
|
|
// filter STGUIAUTH and STGUIAPIKEY from environment variables
|
|
|
|
filteredEnv := []string{}
|
|
|
|
for _, x := range env {
|
|
|
|
if !strings.HasPrefix(x, "STGUIAUTH=") && !strings.HasPrefix(x, "STGUIAPIKEY=") {
|
|
|
|
filteredEnv = append(filteredEnv, x)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
cmd.Env = filteredEnv
|
|
|
|
err = cmd.Run()
|
|
|
|
if err != nil {
|
|
|
|
return err
|
|
|
|
}
|
|
|
|
|
|
|
|
// return error if the file was not removed
|
2015-04-14 19:31:25 +09:00
|
|
|
if _, err = osutil.Lstat(filePath); os.IsNotExist(err) {
|
2015-03-19 11:31:21 +01:00
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return errors.New("Versioner: file was not removed by external script")
|
|
|
|
}
|