blob: 32088696d08c0e24e55a7dd4b5ddaa3f5b452af6 (
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
|
package folder
// FolderType definition
type FolderType string
const (
TypePathMap = "PathMap"
TypeCloudSync = "CloudSync"
TypeCifsSmb = "CIFS"
)
// Folder Status definition
const (
StatusErrorConfig = "ErrorConfig"
StatusDisable = "Disable"
StatusEnable = "Enable"
StatusPause = "Pause"
StatusSyncing = "Syncing"
)
type EventCBData map[string]interface{}
type EventCB func(cfg *FolderConfig, data *EventCBData)
// IFOLDER Folder interface
type IFOLDER interface {
NewUID(suffix string) string // Get a new folder UUID
Add(cfg FolderConfig) (*FolderConfig, error) // Add a new folder
GetConfig() FolderConfig // Get folder public configuration
GetFullPath(dir string) string // Get folder full path
ConvPathCli2Svr(s string) string // Convert path from Client to Server
ConvPathSvr2Cli(s string) string // Convert path from Server to Client
Remove() error // Remove a folder
Update(cfg FolderConfig) (*FolderConfig, error) // Update a new folder
RegisterEventChange(cb *EventCB, data *EventCBData) error // Request events registration (sent through WS)
UnRegisterEventChange() error // Un-register events
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"`
IsInSync bool `json:"isInSync"`
DefaultSdk string `json:"defaultSdk"`
ClientData string `json:"clientData"` // free form field that can used by client
// 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"`
}
// FolderConfigUpdatableFields List fields that can be updated using Update function
var FolderConfigUpdatableFields = []string{
"Label", "DefaultSdk", "ClientData",
}
// PathMapConfig Path mapping specific data
type PathMapConfig struct {
ServerPath string `json:"serverPath"`
// Don't keep temporary file name (IOW we don't want to save it and reuse it)
CheckFile string `json:"checkFile" xml:"-"`
CheckContent string `json:"checkContent" xml:"-"`
}
// CloudSyncConfig CloudSync (AKA Syncthing) specific data
type CloudSyncConfig struct {
SyncThingID string `json:"syncThingID"`
}
|