feat: Add revisionCreator command (#2321)

add revisions.create event
This commit is contained in:
Tom Moor
2021-07-15 15:26:43 -04:00
committed by GitHub
parent 30cf244610
commit 8884da8a4b
5 changed files with 95 additions and 15 deletions

View File

@ -0,0 +1,43 @@
// @flow
import { Document, User, Event, Revision } from "../models";
import { sequelize } from "../sequelize";
export default async function revisionCreator({
document,
user,
ip,
}: {
document: Document,
user: User,
ip?: string,
}) {
let transaction;
try {
transaction = await sequelize.transaction();
const revision = await Revision.createFromDocument(document, {
transaction,
});
await Event.create(
{
name: "revisions.create",
documentId: document.id,
modelId: revision.id,
teamId: document.teamId,
actorId: user.id,
ip: ip || user.lastActiveIp,
},
{ transaction }
);
await transaction.commit();
return revision;
} catch (err) {
if (transaction) {
await transaction.rollback();
}
throw err;
}
}

View File

@ -0,0 +1,27 @@
// @flow
import { Event } from "../models";
import { buildDocument, buildUser } from "../test/factories";
import { flushdb } from "../test/support";
import revisionCreator from "./revisionCreator";
beforeEach(() => flushdb());
describe("revisionCreator", () => {
const ip = "127.0.0.1";
it("should create revision model from document", async () => {
const user = await buildUser();
const document = await buildDocument({
userId: user.id,
teamId: user.teamId,
});
const revision = await revisionCreator({ document, user, ip });
const event = await Event.findOne();
expect(revision.documentId).toEqual(document.id);
expect(revision.userId).toEqual(user.id);
expect(event.name).toEqual("revisions.create");
expect(event.modelId).toEqual(revision.id);
});
});

View File

@ -67,6 +67,7 @@ Event.ACTIVITY_EVENTS = [
"documents.delete",
"documents.permanent_delete",
"documents.restore",
"revisions.create",
"users.create",
];
@ -96,6 +97,7 @@ Event.AUDIT_EVENTS = [
"groups.create",
"groups.update",
"groups.delete",
"revisions.create",
"shares.create",
"shares.update",
"shares.revoke",

View File

@ -49,19 +49,22 @@ Revision.findLatest = function (documentId) {
});
};
Revision.createFromDocument = function (document) {
return Revision.create({
title: document.title,
text: document.text,
userId: document.lastModifiedById,
editorVersion: document.editorVersion,
version: document.version,
documentId: document.id,
Revision.createFromDocument = function (document, options) {
return Revision.create(
{
title: document.title,
text: document.text,
userId: document.lastModifiedById,
editorVersion: document.editorVersion,
version: document.version,
documentId: document.id,
// revision time is set to the last time document was touched as this
// handler can be debounced in the case of an update
createdAt: document.updatedAt,
});
// revision time is set to the last time document was touched as this
// handler can be debounced in the case of an update
createdAt: document.updatedAt,
},
options
);
};
Revision.prototype.migrateVersion = function () {

View File

@ -1,6 +1,8 @@
// @flow
import invariant from "invariant";
import revisionCreator from "../commands/revisionCreator";
import type { DocumentEvent, RevisionEvent } from "../events";
import { Revision, Document } from "../models";
import { Revision, Document, User } from "../models";
export default class Revisions {
async on(event: DocumentEvent | RevisionEvent) {
@ -8,7 +10,7 @@ export default class Revisions {
case "documents.publish":
case "documents.update.debounced": {
const document = await Document.findByPk(event.documentId);
if (!document) return;
invariant(document, "Document should exist");
const previous = await Revision.findLatest(document.id);
@ -22,7 +24,10 @@ export default class Revisions {
return;
}
await Revision.createFromDocument(document);
const user = await User.findByPk(event.actorId);
invariant(user, "User should exist");
await revisionCreator({ user, document });
break;
}