Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Adds transfers between stores to external attachments #1358

Open
wants to merge 42 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
42 commits
Select commit Hold shift + click to select a range
8342a4c
Adds "delete" operator to attachment stores
Spoffy Dec 17, 2024
a0cc24c
Enables updating of file info
Spoffy Dec 18, 2024
b62bab8
Incremental refactoring towards transfers
Spoffy Dec 30, 2024
76db9e5
Adds functioning transfers of individual files
Spoffy Dec 30, 2024
8b23319
Adds test for attachment file corruption on transfer
Spoffy Dec 30, 2024
71f1314
Adds additional check to file transfer
Spoffy Dec 31, 2024
a9d36d3
Adds attachment transfer queue and job
Spoffy Dec 31, 2024
382847d
Adds test for all files being transferred
Spoffy Dec 31, 2024
011e5d1
Adds test for recent transfers taking priority
Spoffy Dec 31, 2024
c53c016
Adds test for recent transfer requests taking precedence
Spoffy Jan 2, 2025
7e34d8f
Updates an existing all files transfer if possible
Spoffy Jan 3, 2025
2addc2f
Adds location summary function and misc behaviour tweaks
Spoffy Jan 4, 2025
6de387c
Cleans up transfer logic and adds doc endpoint ID.
Spoffy Jan 4, 2025
7c0ee63
Fixes test compilation problem
Spoffy Jan 6, 2025
a44944a
Removes TODO from _performPendingTransfers
Spoffy Jan 6, 2025
d10ba26
Makes transfer code more understandable
Spoffy Jan 7, 2025
cbaf592
Fixes an inconsistent import
Spoffy Jan 7, 2025
1ffeb45
Fixes a linter issue
Spoffy Jan 8, 2025
ca0ee2d
Improves several checks
Spoffy Jan 14, 2025
d721c79
Splits findOrAttach file into 2 functions
Spoffy Jan 14, 2025
7153b44
Fixes issue with transfer job not type safety
Spoffy Jan 14, 2025
e1c9a8d
Renames "findOrAttachFile" to "attachFileIfNew"
Spoffy Jan 14, 2025
586d5a4
Switches "UNIQUE" constraint check to a "SELECT"
Spoffy Jan 14, 2025
220e6f9
Splits getFileInfo into two functions
Spoffy Jan 14, 2025
83d984e
Splits AttachmentFileManager._addFile into two functions
Spoffy Jan 14, 2025
fdc3fa4
Rephrases a comment
Spoffy Jan 14, 2025
2dc01d0
Fixes a failing AttachmentFileManager test
Spoffy Jan 14, 2025
34ac344
Revert "Switches "UNIQUE" constraint check to a "SELECT""
Spoffy Jan 15, 2025
337c128
Adds a comment explaining why UNIQUE constraint is caught.
Spoffy Jan 15, 2025
4bba04e
Fixes bad record insert
Spoffy Jan 18, 2025
5008b27
Serializes attachment prep
Spoffy Jan 18, 2025
c553390
Moves interfaces to bottom of AttachmentFileManager
Spoffy Jan 18, 2025
981edbb
Simplifies AttachmentFileManager transferJob logic
Spoffy Jan 19, 2025
761d351
Simplifies waiting for transfers to finish
Spoffy Jan 19, 2025
4b733b3
Fixes transferStatus being uncallable, adds locationSummary
Spoffy Jan 20, 2025
5fde08f
Minor cleaning in AttachmentFileManager
Spoffy Jan 20, 2025
30d606e
Merge branch 'main' into spoffy/external-attachments-transfers
Spoffy Jan 20, 2025
64f9259
Adds test for transferStatus to DocApi
Spoffy Jan 21, 2025
c2bc833
Extracts DocAttachmentsLocationSummary to UserAPI
Spoffy Jan 22, 2025
02a1cdb
Removes IAttachmentFileManager interface
Spoffy Jan 22, 2025
37e0244
Adds attachment transfer start to doc keepopen
Spoffy Jan 22, 2025
459d56e
Adds vacuum at the end of transfers
Spoffy Jan 22, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 6 additions & 0 deletions app/common/UserAPI.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,7 @@ import {
import {addCurrentOrgToPath, getGristConfig} from 'app/common/urlUtils';
import { AxiosProgressEvent } from 'axios';
import omitBy from 'lodash/omitBy';
import {StringUnion} from 'app/common/StringUnion';


export type {FullUser, UserProfile};
Expand Down Expand Up @@ -454,6 +455,11 @@ interface SqlResult extends TableRecordValuesWithoutIds {
statement: string;
}

export const DocAttachmentsLocation = StringUnion(
"NO FILES", "INTERNAL", "MIXED", "EXTERNAL"
);
export type DocAttachmentsLocation = typeof DocAttachmentsLocation.type;

/**
* Collect endpoints related to the content of a single document that we've been thinking
* of as the (restful) "Doc API". A few endpoints that could be here are not, for historical
Expand Down
29 changes: 27 additions & 2 deletions app/server/lib/ActiveDoc.ts
Original file line number Diff line number Diff line change
Expand Up @@ -869,8 +869,12 @@ export class ActiveDoc extends EventEmitter {
}
}
);
const userActions: UserAction[] = await Promise.all(
upload.files.map(file => this._prepAttachment(docSession, file)));
const userActions: UserAction[] = [];
// Process uploads sequentially to reduce risk of race conditions.
// Minimal performance impact due to the main async operation being serialized SQL queries.
for (const file of upload.files) {
userActions.push(await this._prepAttachment(docSession, file));
}
const result = await this._applyUserActionsWithExtendedOptions(docSession, userActions, {
attachment: true,
});
Expand Down Expand Up @@ -943,6 +947,27 @@ export class ActiveDoc extends EventEmitter {
return data;
}

@ActiveDoc.keepDocOpen
public async startTransferringAllAttachmentsToDefaultStore() {
Spoffy marked this conversation as resolved.
Show resolved Hide resolved
const attachmentStoreId = (await this._getDocumentSettings()).attachmentStoreId;
// If no attachment store is set on the doc, it should transfer everything to internal storage
await this._attachmentFileManager.startTransferringAllFilesToOtherStore(attachmentStoreId);
}

/**
* Returns a summary of pending attachment transfers between attachment stores.
*/
public attachmentTransferStatus() {
return this._attachmentFileManager.transferStatus();
}

/**
* Returns a summary of where attachments on this doc are stored.
*/
public async attachmentLocationSummary() {
return await this._attachmentFileManager.locationSummary();
}

/**
* Fetches the meta tables to return to the client when first opening a document.
*/
Expand Down
Loading
Loading