Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
jio_mebibou
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
Analytics
Analytics
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Commits
Issue Boards
Open sidebar
Alexandra Rogova
jio_mebibou
Commits
13d437bc
Commit
13d437bc
authored
Jul 06, 2017
by
Romain Courteaud
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
ReplicateStorage: do not sync document attachment twice.
parent
c28b6cf6
Changes
1
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
21 additions
and
5 deletions
+21
-5
src/jio.storage/replicatestorage.js
src/jio.storage/replicatestorage.js
+21
-5
No files found.
src/jio.storage/replicatestorage.js
View file @
13d437bc
...
@@ -640,6 +640,7 @@
...
@@ -640,6 +640,7 @@
function
propagateModification
(
context
,
source
,
destination
,
doc
,
hash
,
id
,
function
propagateModification
(
context
,
source
,
destination
,
doc
,
hash
,
id
,
skip_document_dict
,
skip_document_dict
,
skip_deleted_document_dict
,
options
)
{
options
)
{
var
result
=
new
RSVP
.
Queue
(),
var
result
=
new
RSVP
.
Queue
(),
post_id
,
post_id
,
...
@@ -720,6 +721,7 @@
...
@@ -720,6 +721,7 @@
// Drop signature if the destination document was empty
// Drop signature if the destination document was empty
// but a signature exists
// but a signature exists
if
(
options
.
create_new_document
===
true
)
{
if
(
options
.
create_new_document
===
true
)
{
delete
skip_deleted_document_dict
[
id
];
return
context
.
_signature_sub_storage
.
remove
(
id
);
return
context
.
_signature_sub_storage
.
remove
(
id
);
}
}
})
})
...
@@ -746,7 +748,8 @@
...
@@ -746,7 +748,8 @@
});
});
}
}
function
propagateDeletion
(
context
,
destination
,
id
,
skip_document_dict
)
{
function
propagateDeletion
(
context
,
destination
,
id
,
skip_document_dict
,
skip_deleted_document_dict
)
{
// Do not delete a document if it has an attachment
// Do not delete a document if it has an attachment
// ie, replication should prevent losing user data
// ie, replication should prevent losing user data
// Synchronize attachments before, to ensure
// Synchronize attachments before, to ensure
...
@@ -771,10 +774,13 @@
...
@@ -771,10 +774,13 @@
})
})
.
push
(
function
()
{
.
push
(
function
()
{
skip_document_dict
[
id
]
=
null
;
skip_document_dict
[
id
]
=
null
;
// No need to sync attachment twice on this document
skip_deleted_document_dict
[
id
]
=
null
;
});
});
}
}
function
checkAndPropagate
(
context
,
skip_document_dict
,
function
checkAndPropagate
(
context
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
status_hash
,
local_hash
,
doc
,
status_hash
,
local_hash
,
doc
,
source
,
destination
,
id
,
source
,
destination
,
id
,
...
@@ -831,10 +837,12 @@
...
@@ -831,10 +837,12 @@
if
(
local_hash
===
null
)
{
if
(
local_hash
===
null
)
{
// Deleted locally
// Deleted locally
return
propagateDeletion
(
context
,
destination
,
id
,
return
propagateDeletion
(
context
,
destination
,
id
,
skip_document_dict
);
skip_document_dict
,
skip_deleted_document_dict
);
}
}
return
propagateModification
(
context
,
source
,
destination
,
doc
,
return
propagateModification
(
context
,
source
,
destination
,
doc
,
local_hash
,
id
,
skip_document_dict
,
local_hash
,
id
,
skip_document_dict
,
skip_deleted_document_dict
,
{
use_post
:
((
options
.
use_post
)
&&
{
use_post
:
((
options
.
use_post
)
&&
(
remote_hash
===
null
)),
(
remote_hash
===
null
)),
create_new_document
:
create_new_document
:
...
@@ -852,7 +860,8 @@
...
@@ -852,7 +860,8 @@
// Automatically resolve conflict or force revert
// Automatically resolve conflict or force revert
if
(
remote_hash
===
null
)
{
if
(
remote_hash
===
null
)
{
// Deleted remotely
// Deleted remotely
return
propagateDeletion
(
context
,
source
,
id
,
skip_document_dict
);
return
propagateDeletion
(
context
,
source
,
id
,
skip_document_dict
,
skip_deleted_document_dict
);
}
}
return
propagateModification
(
return
propagateModification
(
context
,
context
,
...
@@ -862,6 +871,7 @@
...
@@ -862,6 +871,7 @@
remote_hash
,
remote_hash
,
id
,
id
,
skip_document_dict
,
skip_document_dict
,
skip_deleted_document_dict
,
{
use_post
:
((
options
.
use_revert_post
)
&&
{
use_post
:
((
options
.
use_revert_post
)
&&
(
local_hash
===
null
)),
(
local_hash
===
null
)),
create_new_document
:
((
local_hash
===
null
)
&&
create_new_document
:
((
local_hash
===
null
)
&&
...
@@ -874,6 +884,7 @@
...
@@ -874,6 +884,7 @@
// Copy remote modification remotely
// Copy remote modification remotely
return
propagateModification
(
context
,
source
,
destination
,
doc
,
return
propagateModification
(
context
,
source
,
destination
,
doc
,
local_hash
,
id
,
skip_document_dict
,
local_hash
,
id
,
skip_document_dict
,
skip_deleted_document_dict
,
{
use_post
:
options
.
use_post
,
{
use_post
:
options
.
use_post
,
create_new_document
:
create_new_document
:
(
status_hash
!==
null
)});
(
status_hash
!==
null
)});
...
@@ -888,6 +899,7 @@
...
@@ -888,6 +899,7 @@
}
}
function
checkLocalDeletion
(
queue
,
context
,
skip_document_dict
,
function
checkLocalDeletion
(
queue
,
context
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
destination
,
id
,
source
,
destination
,
id
,
source
,
conflict_force
,
conflict_revert
,
conflict_force
,
conflict_revert
,
...
@@ -900,6 +912,7 @@
...
@@ -900,6 +912,7 @@
.
push
(
function
(
result
)
{
.
push
(
function
(
result
)
{
status_hash
=
result
.
hash
;
status_hash
=
result
.
hash
;
return
checkAndPropagate
(
context
,
skip_document_dict
,
return
checkAndPropagate
(
context
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
status_hash
,
null
,
null
,
status_hash
,
null
,
null
,
source
,
destination
,
id
,
source
,
destination
,
id
,
...
@@ -910,6 +923,7 @@
...
@@ -910,6 +923,7 @@
}
}
function
checkSignatureDifference
(
queue
,
context
,
skip_document_dict
,
function
checkSignatureDifference
(
queue
,
context
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
source
,
destination
,
id
,
source
,
destination
,
id
,
conflict_force
,
conflict_revert
,
conflict_force
,
conflict_revert
,
...
@@ -932,6 +946,7 @@
...
@@ -932,6 +946,7 @@
if
(
local_hash
!==
status_hash
)
{
if
(
local_hash
!==
status_hash
)
{
return
checkAndPropagate
(
context
,
skip_document_dict
,
return
checkAndPropagate
(
context
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
status_hash
,
local_hash
,
doc
,
status_hash
,
local_hash
,
doc
,
source
,
destination
,
id
,
source
,
destination
,
id
,
...
@@ -1018,6 +1033,7 @@
...
@@ -1018,6 +1033,7 @@
if
(
is_modification
===
true
||
is_creation
===
true
)
{
if
(
is_modification
===
true
||
is_creation
===
true
)
{
argument_list
.
push
([
undefined
,
context
,
skip_document_dict
,
argument_list
.
push
([
undefined
,
context
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
source
,
destination
,
source
,
destination
,
key
,
key
,
...
@@ -1045,6 +1061,7 @@
...
@@ -1045,6 +1061,7 @@
argument_list_deletion
.
push
([
undefined
,
argument_list_deletion
.
push
([
undefined
,
context
,
context
,
skip_document_dict
,
skip_document_dict
,
skip_deleted_document_dict
,
cache
,
destination_key
,
cache
,
destination_key
,
destination
,
key
,
destination
,
key
,
source
,
source
,
...
@@ -1216,8 +1233,7 @@
...
@@ -1216,8 +1233,7 @@
id
=
result
.
data
.
rows
[
i
].
id
;
id
=
result
.
data
.
rows
[
i
].
id
;
// Do not synchronize attachment if one version of the document
// Do not synchronize attachment if one version of the document
// is deleted but not pushed to the other storage
// is deleted but not pushed to the other storage
if
(
!
skip_deleted_document_dict
.
hasOwnProperty
(
id
)
||
if
(
!
skip_deleted_document_dict
.
hasOwnProperty
(
id
))
{
skip_document_dict
.
hasOwnProperty
(
id
))
{
local_argument_list
.
push
(
local_argument_list
.
push
(
[
undefined
,
context
,
id
]
[
undefined
,
context
,
id
]
);
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment