| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881 | .\" Man page generated from reStructuredText...TH "SYNCTHING-EVENT-API" "7" "Jul 24, 2018" "v0.14" "Syncthing".SH NAMEsyncthing-event-api \- Event API..nr rst2man-indent-level 0..de1 rstReportMargin\\$1 \\n[an-margin]level \\n[rst2man-indent-level]level margin: \\n[rst2man-indent\\n[rst2man-indent-level]]-\\n[rst2man-indent0]\\n[rst2man-indent1]\\n[rst2man-indent2]...de1 INDENT.\" .rstReportMargin pre:. RS \\$1. nr rst2man-indent\\n[rst2man-indent-level] \\n[an-margin]. nr rst2man-indent-level +1.\" .rstReportMargin post:...de UNINDENT. RE.\" indent \\n[an-margin].\" old: \\n[rst2man-indent\\n[rst2man-indent-level]].nr rst2man-indent-level -1.\" new: \\n[rst2man-indent\\n[rst2man-indent-level]].in \\n[rst2man-indent\\n[rst2man-indent-level]]u...SH DESCRIPTION.spSyncthing provides a simple long polling interface for exposing events from thecore utility towards a GUI. To receive events, see events\-get\&..SH EVENT STRUCTURE.spEach event is represented by an object similar to the following:.INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 2,    "globalID": 3,    "type": "DeviceConnected",    "time": "2014\-07\-13T21:04:33.687836696+02:00",    "data": {        "addr": "172.16.32.25:22000",        "id": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG"    }}.ft P.fi.UNINDENT.UNINDENT.spThe top level keys \fBid\fP, \fBglobalID\fP, \fBtime\fP, \fBtype\fP and \fBdata\fP are always present,though \fBdata\fP may be \fBnull\fP\&..INDENT 0.0.TP.B idA unique ID for this event on the events API. It always increases by 1: the firstevent generated has id \fB1\fP, the next has id \fB2\fP etc. If this increases bymore than 1, then one or more events have been skipped by the events API..TP.B globalIDA global ID for this event, across the events API, the audit log, and any othersources. It may increase by more than 1, but it will always be greaterthan or equal to the id..TP.B timeThe time the event was generated..TP.B typeIndicates the type of (i.e. reason for) the event and is one of the eventtypes below..TP.B dataAn object containing optional extra information; the exact structure isdetermined by the event type..UNINDENT.SH EVENT TYPES.SS ConfigSaved.spEmitted after the config has been saved by the user or by Syncthingitself..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 50,    "globalID": 50,    "type": "ConfigSaved",    "time": "2014\-12\-13T00:09:13.5166486Z",    "data": {        "Version": 7,        "Options": {"..."},        "GUI": {"..."},        "Devices": [{"..."}],        "Folders": [{"..."}]    }}.ft P.fi.UNINDENT.UNINDENT.SS DeviceConnected.spGenerated each time a connection to a device has been established..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 2,    "globalID": 2,    "type": "DeviceConnected",    "time": "2014\-07\-13T21:04:33.687836696+02:00",    "data": {        "addr": "172.16.32.25:22000",        "id": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG",        "deviceName": "Laptop",        "clientName": "syncthing",        "clientVersion": "v0.13.4",        "type": "TCP (Client)"    }}.ft P.fi.UNINDENT.UNINDENT.SS DeviceDisconnected.spGenerated each time a connection to a device has been terminated..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 48,    "globalID": 48,    "type": "DeviceDisconnected",    "time": "2014\-07\-13T21:18:52.859929215+02:00",    "data": {        "error": "unexpected EOF",        "id": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG"    }}.ft P.fi.UNINDENT.UNINDENT.sp\fBNOTE:\fP.INDENT 0.0.INDENT 3.5The error key contains the cause for disconnection, which might notnecessarily be an error as such. Specifically, “EOF” and “unexpectedEOF” both signify TCP connection termination, either due to the otherdevice restarting or going offline or due to a network change..UNINDENT.UNINDENT.SS DeviceDiscovered.spEmitted when a new device is discovered using local discovery..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 13,    "globalID": 13,    "type": "DeviceDiscovered",    "time": "2014\-07\-17T13:28:05.043465207+02:00",    "data": {        "addrs": [            "172.16.32.25:22000"        ],        "device": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG"    }}.ft P.fi.UNINDENT.UNINDENT.SS DevicePaused.spEmitted when a device was paused..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 13,    "globalID": 13,    "type": "DevicePaused",    "time": "2014\-07\-17T13:28:05.043465207+02:00",    "data": {        "device": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG"    }}.ft P.fi.UNINDENT.UNINDENT.SS DeviceRejected.spEmitted when there is a connection from a device we are not configuredto talk to..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 24,    "globalID": 24,    "type": "DeviceRejected",    "time": "2014\-08\-19T10:43:00.562821045+02:00",    "data": {        "address": "127.0.0.1:51807",        "name": "My dusty computer",        "device": "EJHMPAQ\-OGCVORE\-ISB4IS3\-SYYVJXF\-TKJGLTU\-66DIQPF\-GJ5D2GX\-GQ3OWQK"    }}.ft P.fi.UNINDENT.UNINDENT.SS DeviceResumed.spGenerated each time a device was resumed..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 2,    "globalID": 2,    "type": "DeviceResumed",    "time": "2014\-07\-13T21:04:33.687836696+02:00",    "data": {        "device": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG"    }}.ft P.fi.UNINDENT.UNINDENT.SS DownloadProgress.spEmitted during file downloads for each folder for each file. By defaultonly a single file in a folder is handled at the same time, but customconfiguration can cause multiple files to be shown..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 221,    "globalID": 221,    "type": "DownloadProgress",    "time": "2014\-12\-13T00:26:12.9876937Z",    "data": {        "folder1": {            "file1": {                "Total": 800,                "Pulling": 2,                "CopiedFromOrigin": 0,                "Reused": 633,                "CopiedFromElsewhere": 0,                "Pulled": 38,                "BytesTotal": 104792064,                "BytesDone": 87883776            },            "dir\e\efile2": {                "Total": 80,                "Pulling": 2,                "CopiedFromOrigin": 0,                "Reused": 0,                "CopiedFromElsewhere": 0,                "Pulled": 32,                "BytesTotal": 10420224,                "BytesDone": 4128768            }        },        "folder2": {            "file3": {                "Total": 800,                "Pulling": 2,                "CopiedFromOrigin": 0,                "Reused": 633,                "CopiedFromElsewhere": 0,                "Pulled": 38,                "BytesTotal": 104792064,                "BytesDone": 87883776            },            "dir\e\efile4": {                "Total": 80,                "Pulling": 2,                "CopiedFromOrigin": 0,                "Reused": 0,                "CopiedFromElsewhere": 0,                "Pulled": 32,                "BytesTotal": 10420224,                "BytesDone": 4128768            }        }    }}.ft P.fi.UNINDENT.UNINDENT.INDENT 0.0.IP \(bu 2\fBTotal\fP \- total number of blocks in the file.IP \(bu 2\fBPulling\fP \- number of blocks currently being downloaded.IP \(bu 2\fBCopiedFromOrigin\fP \- number of blocks copied from the file we areabout to replace.IP \(bu 2\fBReused\fP \- number of blocks reused from a previous temporary file.IP \(bu 2\fBCopiedFromElsewhere\fP \- number of blocks copied from other files orpotentially other folders.IP \(bu 2\fBPulled\fP \- number of blocks actually downloaded so far.IP \(bu 2\fBBytesTotal\fP \- approximate total file size.IP \(bu 2\fBBytesDone\fP \- approximate number of bytes already handled (alreadyreused, copied or pulled).UNINDENT.spWhere block size is 128KB..spFiles/folders appearing in the event data imply that the download hasbeen started for that file/folder, where disappearing implies that thedownloads have been finished or failed for that file/folder. There isalways a last event emitted with no data, which implies all downloadshave finished/failed..SS FolderCompletion.spThe \fBFolderCompletion\fP event is emitted when the local or remotecontents for a folder changes. It contains the completion percentage fora given remote device and is emitted once per currently connected remotedevice..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 84,    "globalID": 84,    "type": "FolderCompletion",    "time": "2015\-04\-17T14:14:27.043576583+09:00",    "data": {        "completion": 100,        "device": "I6KAH76\-66SLLLB\-5PFXSOA\-UFJCDZC\-YAOMLEK\-CP2GB32\-BV5RQST\-3PSROAU",        "folder": "default"    }}.ft P.fi.UNINDENT.UNINDENT.SS FolderErrors.spThe \fBFolderErrors\fP event is emitted when a folder cannot be successfullysynchronized. The event contains the ID of the affected folder and a list oferrors for files or directories therein. This list of errors is obsolete oncethe folder changes state to \fBsyncing\fP \- if errors remain after the nextsynchronization attempt, a new \fBFolderErrors\fP event is emitted..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 132,    "type": "FolderErrors",    "time": "2015\-06\-26T13:39:24.697401384+02:00",    "data": {        "errors": [            {                "error": "open /Users/jb/src/github.com/syncthing/syncthing/test/s2/h2j/.syncthing.aslkjd.tmp: permission denied",                "path": "h2j/aslkjd"            }        ],        "folder": "default"    }}.ft P.fi.UNINDENT.UNINDENT.spNew in version 0.11.12..sp\fBSEE ALSO:\fP.INDENT 0.0.INDENT 3.5The statechanged event..UNINDENT.UNINDENT.SS FolderRejected.spEmitted when a device sends index information for a folder we do nothave, or have but do not share with the device in question..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 27,    "globalID": 27,    "type": "FolderRejected",    "time": "2014\-08\-19T10:41:06.761751399+02:00",    "data": {        "device": "EJHMPAQ\-OGCVORE\-ISB4IS3\-SYYVJXF\-TKJGLTU\-66DIQPF\-GJ5D2GX\-GQ3OWQK",        "folder": "GXWxf\-3zgnU",        "folderLabel": "My Pictures"    }}.ft P.fi.UNINDENT.UNINDENT.SS Folder Scan Progress.spEmitted in regular intervals (folder setting ProgressIntervalS, 2s by default)during scans giving the amount of bytes already scanned and to be scanned intotal , as well as the current scanning rates in bytes per second..INDENT 0.0.INDENT 3.5.sp.nf.ft C{   "data" : {      "total" : 1,      "rate" : 0,      "current" : 0,      "folder" : "bd7q3\-zskm5"   },   "globalID" : 29,   "type" : "FolderScanProgress",   "time" : "2017\-03\-06T15:00:58.072004209+01:00",   "id" : 29}.ft P.fi.UNINDENT.UNINDENT.SS FolderSummary.spThe FolderSummary event is emitted when folder contents have changedlocally. This can be used to calculate the current local completionstate..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 16,    "globalID": 16,    "type": "FolderSummary",    "time": "2015\-04\-17T14:12:20.460121585+09:00",    "data": {        "folder": "default",        "summary": {            "globalBytes": 0,            "globalDeleted": 0,            "globalFiles": 0,            "ignorePatterns": false,            "inSyncBytes": 0,            "inSyncFiles": 0,            "invalid": "",            "localBytes": 0,            "localDeleted": 0,            "localFiles": 0,            "needBytes": 0,            "needFiles": 0,            "state": "idle",            "stateChanged": "2015\-04\-17T14:12:12.455224687+09:00",            "version": 0        }    }}.ft P.fi.UNINDENT.UNINDENT.SS ItemFinished.spGenerated when Syncthing ends synchronizing a file to a newer version. Asuccessful operation:.INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 93,    "globalID": 93,    "type": "ItemFinished",    "time": "2014\-07\-13T21:22:03.414609034+02:00",    "data": {        "item": "test.txt",        "folder": "default",        "error": null,        "type": "file",        "action": "update"    }}.ft P.fi.UNINDENT.UNINDENT.spAn unsuccessful operation:.INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 44,    "globalID": 44,    "type": "ItemFinished",    "time": "2015\-05\-27T11:21:05.711133004+02:00",    "data": {        "action": "update",        "error": "open /Users/jb/src/github.com/syncthing/syncthing/test/s2/foo/.syncthing.hej.tmp: permission denied",        "folder": "default",        "item": "foo/hej",        "type": "file"    }}.ft P.fi.UNINDENT.UNINDENT.spThe \fBaction\fP field is either \fBupdate\fP (contents changed), \fBmetadata\fP (file metadata changed but not contents), or \fBdelete\fP\&..spNew in version 0.11.10: The \fBmetadata\fP action..SS ItemStarted.spGenerated when Syncthing begins synchronizing a file to a newer version..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 93,    "globalID": 93,    "type": "ItemStarted",    "time": "2014\-07\-13T21:22:03.414609034+02:00",    "data": {        "item": "test.txt",        "folder": "default",        "type": "file",        "action": "update"    }}.ft P.fi.UNINDENT.UNINDENT.spThe \fBaction\fP field is either \fBupdate\fP (contents changed), \fBmetadata\fP (file metadata changed but not contents), or \fBdelete\fP\&..spNew in version 0.11.10: The \fBmetadata\fP action..SS Listen Addresses Changed.spThis event is emitted when a listen address changes..INDENT 0.0.INDENT 3.5.sp.nf.ft C{   "type" : "ListenAddressesChanged",   "id" : 70,   "time" : "2017\-03\-06T15:01:24.88340663+01:00",   "globalID" : 70,   "data" : {      "address" : {         "Fragment" : "",         "RawQuery" : "",         "Scheme" : "dynamic+https",         "Path" : "/endpoint",         "RawPath" : "",         "User" : null,         "ForceQuery" : false,         "Host" : "relays.syncthing.net",         "Opaque" : ""      },      "wan" : [         {            "ForceQuery" : false,            "User" : null,            "Host" : "31.15.66.212:443",            "Opaque" : "",            "Path" : "/",            "RawPath" : "",            "RawQuery" : "id=F4HSJVO\-CP2C3IL\-YLQYLSU\-XTYODAG\-PPU4LGV\-PH3MU4N\-G6K56DV\-IPN47A&pingInterval=1m0s&networkTimeout=2m0s&sessionLimitBps=0&globalLimitBps=0&statusAddr=:22070&providedBy=",            "Scheme" : "relay",            "Fragment" : ""         }      ],      "lan" : [         {            "RawQuery" : "id=F4HSJVO\-CP2C3IL\-YLQYLSU\-XTYODAG\-PPU4LGV\-PH3MU4N\-G6K56DV\-IPN47A&pingInterval=1m0s&networkTimeout=2m0s&sessionLimitBps=0&globalLimitBps=0&statusAddr=:22070&providedBy=",            "Scheme" : "relay",            "Fragment" : "",            "RawPath" : "",            "Path" : "/",            "Host" : "31.15.66.212:443",            "Opaque" : "",            "ForceQuery" : false,            "User" : null         }      ]   }}.ft P.fi.UNINDENT.UNINDENT.SS LocalChangeDetected.spGenerated upon scan whenever the local disk has discovered an updated file from theprevious scan.  This does \fInot\fP include events that are discovered and copied fromother devices (remote\-change\-detected), only files that were changed on thelocal filesystem..INDENT 0.0.INDENT 3.5.sp.nf.ft C{  "id": 7,  "globalID": 59,  "time": "2016\-09\-26T22:07:10.7189141\-04:00",  "type": "LocalChangeDetected",  "data": {    "action": "deleted",    "folderID": "vitwy\-zjxqt",    "label": "TestSync",    "path": "C:\e\eUsers\e\eNate\e\eSync\e\etestfolder\e\etest file.rtf",    "type": "file"  }}.ft P.fi.UNINDENT.UNINDENT.SS LocalIndexUpdated.spGenerated when the local index information has changed, due tosynchronizing one or more items from the cluster or discovering localchanges during a scan..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 59,    "globalID": 59,    "type": "LocalIndexUpdated",    "time": "2014\-07\-17T13:27:28.051369434+02:00",    "data": {        "folder": "default",        "items": 1000,    }}.ft P.fi.UNINDENT.UNINDENT.SS Login Attempt.spWhen authentication is enabled for the GUI, this event is emitted on everylogin attempt. If either the username or password are incorrect, \fBsuccess\fPis false and in any case the given username is returned..INDENT 0.0.INDENT 3.5.sp.nf.ft C{   "id" : 187,   "time" : "2017\-03\-07T00:19:24.420386143+01:00",   "data" : {      "username" : "somename",      "success" : false   },   "type" : "LoginAttempt",   "globalID" : 195}.ft P.fi.UNINDENT.UNINDENT.SS RemoteChangeDetected.spGenerated upon scan whenever a file is locally updated due to a remote change.Files that are updated locally produce a local\-change\-detected event..INDENT 0.0.INDENT 3.5.sp.nf.ft C{   "time" : "2017\-03\-06T23:58:21.844739891+01:00",   "globalID" : 123,   "data" : {      "type" : "file",      "action" : "deleted",      "path" : "/media/ntfs_data/Dokumente/testfile",      "label" : "Dokumente",      "folderID" : "Dokumente",      "modifiedBy" : "BPDFDTU"   },   "type" : "RemoteChangeDetected",   "id" : 2}.ft P.fi.UNINDENT.UNINDENT.SS Remote Download Progress.spThis event is emitted when a download\-progress message isreceived. It returns a map \fBdata\fP of filenames with a count ofdownloaded blocks. The files in questions are currently beingdownloaded on the remote \fBdevice\fP and belong to \fBfolder\fP\&..INDENT 0.0.INDENT 3.5.sp.nf.ft C{   "time" : "2017\-03\-07T00:11:37.65838955+01:00",   "globalID" : 170,   "data" : {      "state" : {         "tahr64\-6.0.5.iso" : 1784      },      "device" : "F4HSJVO\-CP2C3IL\-YLQYLSU\-XTYODAG\-PPU4LGV\-PH3MU4N\-G6K56DV\-IPN47A",      "folder" : "Dokumente"   },   "type" : "RemoteDownloadProgress",   "id" : 163}.ft P.fi.UNINDENT.UNINDENT.SS RemoteIndexUpdated.spGenerated each time new index information is received from a device..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 44,    "globalID": 44,    "type": "RemoteIndexUpdated",    "time": "2014\-07\-13T21:04:35.394184435+02:00",    "data": {        "device": "NFGKEKE\-7Z6RTH7\-I3PRZXS\-DEJF3UJ\-FRWJBFO\-VBBTDND\-4SGNGVZ\-QUQHJAG",        "folder": "lightroom",        "items": 1000    }}.ft P.fi.UNINDENT.UNINDENT.SS Starting.spEmitted exactly once, when Syncthing starts, before parsingconfiguration etc..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 1,    "globalID": 1,    "type": "Starting",    "time": "2014\-07\-17T13:13:32.044470055+02:00",    "data": {        "home": "/home/jb/.config/syncthing"    }}.ft P.fi.UNINDENT.UNINDENT.SS StartupComplete.spEmitted exactly once, when initialization is complete and Syncthing isready to start exchanging data with other devices..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 1,    "globalID": 1,    "type": "StartupComplete",    "time": "2014\-07\-13T21:03:18.383239179+02:00",    "data": null}.ft P.fi.UNINDENT.UNINDENT.SS StateChanged.spEmitted when a folder changes state. Possible states are \fBidle\fP,\fBscanning\fP, \fBsyncing\fP and \fBerror\fP\&. The field \fBduration\fP isthe number of seconds the folder spent in state \fBfrom\fP\&. In the examplebelow, the folder \fBdefault\fP was in state \fBscanning\fP for 0.198seconds and is now in state \fBidle\fP\&..INDENT 0.0.INDENT 3.5.sp.nf.ft C{    "id": 8,    "globalID": 8,    "type": "StateChanged",    "time": "2014\-07\-17T13:14:28.697493016+02:00",    "data": {        "folder": "default",        "from": "scanning",        "duration": 0.19782869900000002,        "to": "idle"    }}.ft P.fi.UNINDENT.UNINDENT.SH AUTHORThe Syncthing Authors.SH COPYRIGHT2014-2018, The Syncthing Authors.\" Generated by docutils manpage writer..
 |