blob: b76b3f31b3a39fa87d2cc6838908550d8481e15a (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
|
package folder
// FolderType definition
type FolderType int
const (
TypePathMap = 1
TypeCloudSync = 2
TypeCifsSmb = 3
)
// Folder Status definition
const (
StatusErrorConfig = "ErrorConfig"
StatusDisable = "Disable"
StatusEnable = "Enable"
)
// IFOLDER Folder interface
type IFOLDER interface {
Add(cfg FolderConfig) (*FolderConfig, error) // Add a new folder
GetConfig() FolderConfig // Get folder public configuration
GetFullPath(dir string) string // Get folder full path
Remove() error // Remove a folder
Sync() error // Force folder files synchronization
IsInSync() (bool, error) // Check if folder files are in-sync
}
// FolderConfig is the config for one folder
type FolderConfig struct {
ID string `json:"id"`
Label string `json:"label"`
ClientPath string `json:"path"`
Type FolderType `json:"type"`
Status string `json:"status"`
DefaultSdk string `json:"defaultSdk"`
// Not exported fields from REST API point of view
RootPath string `json:"-"`
// FIXME: better to define an equivalent to union data and then implement
// UnmarshalJSON/MarshalJSON to decode/encode according to Type value
// Data interface{} `json:"data"`
// Specific data depending on which Type is used
DataPathMap PathMapConfig `json:"dataPathMap,omitempty"`
DataCloudSync CloudSyncConfig `json:"dataCloudSync,omitempty"`
}
// PathMapConfig Path mapping specific data
type PathMapConfig struct {
ServerPath string `json:"serverPath"`
}
// CloudSyncConfig CloudSync (AKA Syncthing) specific data
type CloudSyncConfig struct {
SyncThingID string `json:"syncThingID"`
BuilderSThgID string `json:"builderSThgID"`
}
|