mirror of
https://github.com/octoleo/syncthing.git
synced 2025-01-10 02:07:14 +00:00
Expose ignores from model
This commit is contained in:
parent
39cf269d6b
commit
8e624cedb1
@ -5,10 +5,12 @@
|
|||||||
package model
|
package model
|
||||||
|
|
||||||
import (
|
import (
|
||||||
|
"bufio"
|
||||||
"crypto/tls"
|
"crypto/tls"
|
||||||
"errors"
|
"errors"
|
||||||
"fmt"
|
"fmt"
|
||||||
"io"
|
"io"
|
||||||
|
"io/ioutil"
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
@ -22,6 +24,7 @@ import (
|
|||||||
"github.com/syncthing/syncthing/files"
|
"github.com/syncthing/syncthing/files"
|
||||||
"github.com/syncthing/syncthing/ignore"
|
"github.com/syncthing/syncthing/ignore"
|
||||||
"github.com/syncthing/syncthing/lamport"
|
"github.com/syncthing/syncthing/lamport"
|
||||||
|
"github.com/syncthing/syncthing/osutil"
|
||||||
"github.com/syncthing/syncthing/protocol"
|
"github.com/syncthing/syncthing/protocol"
|
||||||
"github.com/syncthing/syncthing/scanner"
|
"github.com/syncthing/syncthing/scanner"
|
||||||
"github.com/syncthing/syncthing/stats"
|
"github.com/syncthing/syncthing/stats"
|
||||||
@ -579,6 +582,78 @@ func (m *Model) ConnectedTo(nodeID protocol.NodeID) bool {
|
|||||||
return ok
|
return ok
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (m *Model) GetIgnores(repo string) ([]string, error) {
|
||||||
|
var lines []string
|
||||||
|
|
||||||
|
cfg, ok := m.repoCfgs[repo]
|
||||||
|
if !ok {
|
||||||
|
return lines, fmt.Errorf("Repo %s does not exist", repo)
|
||||||
|
}
|
||||||
|
|
||||||
|
m.rmut.Lock()
|
||||||
|
defer m.rmut.Unlock()
|
||||||
|
|
||||||
|
fd, err := os.Open(filepath.Join(cfg.Directory, ".stignore"))
|
||||||
|
if err != nil {
|
||||||
|
if os.IsNotExist(err) {
|
||||||
|
return lines, nil
|
||||||
|
}
|
||||||
|
l.Warnln("Loading .stignore:", err)
|
||||||
|
return lines, err
|
||||||
|
}
|
||||||
|
defer fd.Close()
|
||||||
|
|
||||||
|
scanner := bufio.NewScanner(fd)
|
||||||
|
for scanner.Scan() {
|
||||||
|
lines = append(lines, strings.TrimSpace(scanner.Text()))
|
||||||
|
}
|
||||||
|
|
||||||
|
return lines, nil
|
||||||
|
}
|
||||||
|
|
||||||
|
func (m *Model) SetIgnores(repo string, content []string) error {
|
||||||
|
cfg, ok := m.repoCfgs[repo]
|
||||||
|
if !ok {
|
||||||
|
return fmt.Errorf("Repo %s does not exist", repo)
|
||||||
|
}
|
||||||
|
|
||||||
|
fd, err := ioutil.TempFile("", "stignore-"+repo)
|
||||||
|
if err != nil {
|
||||||
|
l.Warnln("Saving .stignore:", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
writer := bufio.NewWriter(fd)
|
||||||
|
for _, line := range content {
|
||||||
|
fmt.Fprintln(writer, line)
|
||||||
|
}
|
||||||
|
|
||||||
|
err = writer.Flush()
|
||||||
|
if err != nil {
|
||||||
|
l.Warnln("Saving .stignore:", err)
|
||||||
|
fd.Close()
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
err = fd.Close()
|
||||||
|
if err != nil {
|
||||||
|
l.Warnln("Saving .stignore:", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
file := filepath.Join(cfg.Directory, ".stignore")
|
||||||
|
m.rmut.Lock()
|
||||||
|
os.Remove(file)
|
||||||
|
err = osutil.Rename(fd.Name(), file)
|
||||||
|
m.rmut.Unlock()
|
||||||
|
if err != nil {
|
||||||
|
l.Warnln("Saving .stignore:", err)
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
|
return m.ScanRepo(repo)
|
||||||
|
}
|
||||||
|
|
||||||
// AddConnection adds a new peer connection to the model. An initial index will
|
// AddConnection adds a new peer connection to the model. An initial index will
|
||||||
// be sent to the connected peer, thereafter index updates whenever the local
|
// be sent to the connected peer, thereafter index updates whenever the local
|
||||||
// repository changes.
|
// repository changes.
|
||||||
|
Loading…
Reference in New Issue
Block a user