{% include anchor.html edit="true" title="Sync a database" hash="sync" %} {% highlight js %} var sync = PouchDB.sync(src, target, [options]) {% endhighlight %} Sync data from `src` to `target` and `target` to `src`. This is a convenience method for bidirectional data replication. In other words, this code: {% highlight js %} PouchDB.replicate('mydb', 'http://localhost:5984/mydb'); PouchDB.replicate('http://localhost:5984/mydb', 'mydb'); {% endhighlight %} is equivalent to this code: {% highlight js %} PouchDB.sync('mydb', 'http://localhost:5984/mydb'); {% endhighlight %} ### Options * `options.push` + `options.pull`: Allows you to specify separate [replication options](api.html#replication) for the individual replications. Replication options such as `filter` passed to sync directly will be passed to both replications. Please refer to [replicate()](api.html#replication) for documentation on those options. #### Example Usage: {% highlight js %} var sync = PouchDB.sync('mydb', 'http://localhost:5984/mydb', { live: true, retry: true }).on('change', function (info) { // handle change }).on('paused', function (err) { // replication paused (e.g. replication up to date, user went offline) }).on('active', function () { // replicate resumed (e.g. new changes replicating, user went back online) }).on('denied', function (err) { // a document failed to replicate (e.g. due to permissions) }).on('complete', function (info) { // handle complete }).on('error', function (err) { // handle error }); sync.cancel(); // whenever you want to cancel {% endhighlight %} There is also a shorthand for syncing given existing PouchDB objects. This behaves the same as `PouchDB.sync()`: {% highlight js %} db.sync(remoteDB, [options]); {% endhighlight %} #### Example Response: Change events in `sync` have an extra property `direction` which refers to the direction the change was going. Its value will either be `push` or `pull`. {% highlight js %} { direction: 'push', change: { ok: true, start_time: '2015-10-21T15:26:51.151Z', docs_read: 1, docs_written: 1, doc_write_failures: 0, errors: [], last_seq: 1, docs: [ [Object] ] } } {% endhighlight %} For any further details, please refer to [replicate()](api.html#replication).