mirror of
https://github.com/gristlabs/grist-core.git
synced 2024-10-27 20:44:07 +00:00
(core) make filtering of metadata consistent in presence of default access rules
Summary: This brings the treatment of metadata updates being broadcast to a user into line with how it is treated when they first open the document. Specifically, this fixes a bug where, for a document with a default access rule denying access to everything, a user would not receive any metadata updates. Test Plan: added test; existing tests pass Reviewers: jarek, dsagal Reviewed By: jarek, dsagal Differential Revision: https://phab.getgrist.com/D3711
This commit is contained in:
parent
1a6d427339
commit
6061b67fd9
@ -2149,11 +2149,17 @@ export class GranularAccess implements GranularAccessForBundle {
|
|||||||
private async _filterOutgoingDocAction(cursor: ActionCursor): Promise<DocAction[]> {
|
private async _filterOutgoingDocAction(cursor: ActionCursor): Promise<DocAction[]> {
|
||||||
const {action} = cursor;
|
const {action} = cursor;
|
||||||
const tableId = getTableId(action);
|
const tableId = getTableId(action);
|
||||||
|
|
||||||
|
let results: DocAction[] = [];
|
||||||
|
if (tableId.startsWith('_grist')) {
|
||||||
|
// Granular access rules don't apply to metadata directly, instead there
|
||||||
|
// is a process of censorship (see later in this method).
|
||||||
|
results = [action];
|
||||||
|
} else {
|
||||||
const permInfo = await this._getStepAccess(cursor);
|
const permInfo = await this._getStepAccess(cursor);
|
||||||
const tableAccess = permInfo.getTableAccess(tableId);
|
const tableAccess = permInfo.getTableAccess(tableId);
|
||||||
const access = this.getReadPermission(tableAccess);
|
const access = this.getReadPermission(tableAccess);
|
||||||
const readAccessCheck = this._readAccessCheck(cursor.docSession);
|
const readAccessCheck = this._readAccessCheck(cursor.docSession);
|
||||||
const results: DocAction[] = [];
|
|
||||||
if (access === 'deny') {
|
if (access === 'deny') {
|
||||||
// filter out this data.
|
// filter out this data.
|
||||||
} else if (access === 'allow') {
|
} else if (access === 'allow') {
|
||||||
@ -2168,6 +2174,7 @@ export class GranularAccess implements GranularAccessForBundle {
|
|||||||
if (prunedAct) { results.push(prunedAct); }
|
if (prunedAct) { results.push(prunedAct); }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
const secondPass: DocAction[] = [];
|
const secondPass: DocAction[] = [];
|
||||||
for (const act of results) {
|
for (const act of results) {
|
||||||
if (STRUCTURAL_TABLES.has(getTableId(act)) && isDataAction(act)) {
|
if (STRUCTURAL_TABLES.has(getTableId(act)) && isDataAction(act)) {
|
||||||
|
Loading…
Reference in New Issue
Block a user