feat(snjs): add revisions api v2 (#2154)
* feat(snjs): add revisions api v2 * fix(snjs): reference listing and getting revisions in specs * fix(snjs): revisions specs * fix(web): usage of revision metadata * fix(snjs): add specs for decryption revision * fix(snjs): issue with building mocked specs * fix(snjs): adjust revision creation delay
This commit is contained in:
@@ -0,0 +1,5 @@
|
||||
export enum RevisionApiOperations {
|
||||
List,
|
||||
Delete,
|
||||
Get,
|
||||
}
|
||||
@@ -0,0 +1,79 @@
|
||||
import { ErrorMessage } from '../../Error/ErrorMessage'
|
||||
import { ApiCallError } from '../../Error/ApiCallError'
|
||||
|
||||
import { RevisionApiServiceInterface } from './RevisionApiServiceInterface'
|
||||
import { RevisionApiOperations } from './RevisionApiOperations'
|
||||
import { RevisionServerInterface } from '../../Server'
|
||||
import { DeleteRevisionResponse } from '../../Response/Revision/DeleteRevisionResponse'
|
||||
import { GetRevisionResponse } from '../../Response/Revision/GetRevisionResponse'
|
||||
import { ListRevisionsResponse } from '../../Response/Revision/ListRevisionsResponse'
|
||||
|
||||
export class RevisionApiService implements RevisionApiServiceInterface {
|
||||
private operationsInProgress: Map<RevisionApiOperations, boolean>
|
||||
|
||||
constructor(private revisionServer: RevisionServerInterface) {
|
||||
this.operationsInProgress = new Map()
|
||||
}
|
||||
|
||||
async listRevisions(itemUuid: string): Promise<ListRevisionsResponse> {
|
||||
if (this.operationsInProgress.get(RevisionApiOperations.List)) {
|
||||
throw new ApiCallError(ErrorMessage.GenericInProgress)
|
||||
}
|
||||
|
||||
this.operationsInProgress.set(RevisionApiOperations.List, true)
|
||||
|
||||
try {
|
||||
const response = await this.revisionServer.listRevisions({
|
||||
itemUuid,
|
||||
})
|
||||
|
||||
return response
|
||||
} catch (error) {
|
||||
throw new ApiCallError(ErrorMessage.GenericFail)
|
||||
} finally {
|
||||
this.operationsInProgress.set(RevisionApiOperations.List, false)
|
||||
}
|
||||
}
|
||||
|
||||
async getRevision(itemUuid: string, revisionUuid: string): Promise<GetRevisionResponse> {
|
||||
if (this.operationsInProgress.get(RevisionApiOperations.Get)) {
|
||||
throw new ApiCallError(ErrorMessage.GenericInProgress)
|
||||
}
|
||||
|
||||
this.operationsInProgress.set(RevisionApiOperations.Get, true)
|
||||
|
||||
try {
|
||||
const response = await this.revisionServer.getRevision({
|
||||
itemUuid,
|
||||
revisionUuid,
|
||||
})
|
||||
|
||||
return response
|
||||
} catch (error) {
|
||||
throw new ApiCallError(ErrorMessage.GenericFail)
|
||||
} finally {
|
||||
this.operationsInProgress.set(RevisionApiOperations.Get, false)
|
||||
}
|
||||
}
|
||||
|
||||
async deleteRevision(itemUuid: string, revisionUuid: string): Promise<DeleteRevisionResponse> {
|
||||
if (this.operationsInProgress.get(RevisionApiOperations.Delete)) {
|
||||
throw new ApiCallError(ErrorMessage.GenericInProgress)
|
||||
}
|
||||
|
||||
this.operationsInProgress.set(RevisionApiOperations.Delete, true)
|
||||
|
||||
try {
|
||||
const response = await this.revisionServer.deleteRevision({
|
||||
itemUuid,
|
||||
revisionUuid,
|
||||
})
|
||||
|
||||
return response
|
||||
} catch (error) {
|
||||
throw new ApiCallError(ErrorMessage.GenericFail)
|
||||
} finally {
|
||||
this.operationsInProgress.set(RevisionApiOperations.Delete, false)
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,9 @@
|
||||
import { DeleteRevisionResponse } from '../../Response/Revision/DeleteRevisionResponse'
|
||||
import { GetRevisionResponse } from '../../Response/Revision/GetRevisionResponse'
|
||||
import { ListRevisionsResponse } from '../../Response/Revision/ListRevisionsResponse'
|
||||
|
||||
export interface RevisionApiServiceInterface {
|
||||
listRevisions(itemUuid: string): Promise<ListRevisionsResponse>
|
||||
getRevision(itemUuid: string, revisionUuid: string): Promise<GetRevisionResponse>
|
||||
deleteRevision(itemUuid: string, revisionUuid: string): Promise<DeleteRevisionResponse>
|
||||
}
|
||||
@@ -4,6 +4,9 @@ export * from './Auth/AuthApiServiceInterface'
|
||||
export * from './Authenticator/AuthenticatorApiOperations'
|
||||
export * from './Authenticator/AuthenticatorApiService'
|
||||
export * from './Authenticator/AuthenticatorApiServiceInterface'
|
||||
export * from './Revision/RevisionApiOperations'
|
||||
export * from './Revision/RevisionApiService'
|
||||
export * from './Revision/RevisionApiServiceInterface'
|
||||
export * from './Subscription/SubscriptionApiOperations'
|
||||
export * from './Subscription/SubscriptionApiService'
|
||||
export * from './Subscription/SubscriptionApiServiceInterface'
|
||||
|
||||
Reference in New Issue
Block a user