mirror of https://github.com/laurent22/joplin.git
Server: Clean up share logic
parent
e1cd8d9b85
commit
107f2e128e
|
@ -199,6 +199,20 @@ export default class ShareModel extends BaseModel<Share> {
|
||||||
const handleCreated = async (change: Change, item: Item, share: Share) => {
|
const handleCreated = async (change: Change, item: Item, share: Share) => {
|
||||||
if (!item.jop_share_id) return;
|
if (!item.jop_share_id) return;
|
||||||
|
|
||||||
|
// When a folder is unshared, the share object is deleted, then all
|
||||||
|
// items that were shared get their 'share_id' property set to an
|
||||||
|
// empty string. This is all done client side.
|
||||||
|
//
|
||||||
|
// However it means that if a share object is deleted but the items
|
||||||
|
// are not synced, we'll find items that are associated with a share
|
||||||
|
// that no longer exists. This is fine, but we need to handle it
|
||||||
|
// properly below, otherwise the share update process will fail.
|
||||||
|
|
||||||
|
if (!share) {
|
||||||
|
logger.warn(`Found an item (${item.id}) associated with a share that no longer exists (${item.jop_share_id}) - skipping it`);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
const shareUserIds = await this.allShareUserIds(share);
|
const shareUserIds = await this.allShareUserIds(share);
|
||||||
for (const shareUserId of shareUserIds) {
|
for (const shareUserId of shareUserIds) {
|
||||||
if (shareUserId === change.user_id) continue;
|
if (shareUserId === change.user_id) continue;
|
||||||
|
@ -301,25 +315,10 @@ export default class ShareModel extends BaseModel<Share> {
|
||||||
// Item associated with the change may have been
|
// Item associated with the change may have been
|
||||||
// deleted, so take this into account.
|
// deleted, so take this into account.
|
||||||
if (item) {
|
if (item) {
|
||||||
// When a folder is unshared, the share object is
|
|
||||||
// deleted, then all items that were shared get their
|
|
||||||
// 'share_id' property set to an empty string. This is
|
|
||||||
// all done client side.
|
|
||||||
//
|
|
||||||
// However it means that if a share object is deleted
|
|
||||||
// but the items are not synced, we'll find items that
|
|
||||||
// are associated with a share that no longer exists.
|
|
||||||
// This is fine, but we need to handle it properly
|
|
||||||
// below, otherwise the share update process will fail.
|
|
||||||
|
|
||||||
const itemShare = shares.find(s => s.id === item.jop_share_id);
|
const itemShare = shares.find(s => s.id === item.jop_share_id);
|
||||||
|
|
||||||
if (change.type === ChangeType.Create) {
|
if (change.type === ChangeType.Create) {
|
||||||
if (!itemShare) {
|
await handleCreated(change, item, itemShare);
|
||||||
logger.warn(`Found an item (${item.id}) associated with a share that no longer exists (${item.jop_share_id}) - skipping it`);
|
|
||||||
} else {
|
|
||||||
await handleCreated(change, item, itemShare);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (change.type === ChangeType.Update) {
|
if (change.type === ChangeType.Update) {
|
||||||
|
|
Loading…
Reference in New Issue