mirror of
https://github.com/hcengineering/platform.git
synced 2024-12-19 08:51:37 +03:00
UBERF-8897 Use proper state when update collab doc activity (#7475)
Signed-off-by: Alexander Onnikov <Alexander.Onnikov@xored.com>
This commit is contained in:
parent
413da21b50
commit
377fb908ba
@ -16,7 +16,7 @@
|
||||
import activity, { DocUpdateMessage } from '@hcengineering/activity'
|
||||
import { loadCollabJson, loadCollabYdoc, saveCollabJson, saveCollabYdoc } from '@hcengineering/collaboration'
|
||||
import { decodeDocumentId } from '@hcengineering/collaborator-client'
|
||||
import core, { AttachedData, MeasureContext, TxOperations } from '@hcengineering/core'
|
||||
import core, { AttachedData, MeasureContext, Ref, Space, TxOperations } from '@hcengineering/core'
|
||||
import { StorageAdapter } from '@hcengineering/server-core'
|
||||
import { markupToYDocNoSchema, areEqualMarkups } from '@hcengineering/text'
|
||||
import { Doc as YDoc } from 'yjs'
|
||||
@ -173,6 +173,8 @@ export class PlatformStorageAdapter implements CollabStorageAdapter {
|
||||
await ctx.with('update', {}, () => client.diffUpdate(current, { [objectAttr]: blobId }))
|
||||
|
||||
await ctx.with('activity', {}, () => {
|
||||
const space = hierarchy.isDerived(current._class, core.class.Space) ? (current._id as Ref<Space>) : current.space
|
||||
|
||||
const data: AttachedData<DocUpdateMessage> = {
|
||||
objectId,
|
||||
objectClass,
|
||||
@ -189,7 +191,7 @@ export class PlatformStorageAdapter implements CollabStorageAdapter {
|
||||
}
|
||||
return client.addCollection(
|
||||
activity.class.DocUpdateMessage,
|
||||
current.space,
|
||||
space,
|
||||
current._id,
|
||||
current._class,
|
||||
'docUpdateMessages',
|
||||
|
95
workers/collaborator/src/metrics.ts
Normal file
95
workers/collaborator/src/metrics.ts
Normal file
@ -0,0 +1,95 @@
|
||||
//
|
||||
// Copyright © 2024 Hardcore Engineering Inc.
|
||||
//
|
||||
// Licensed under the Eclipse Public License, Version 2.0 (the 'License');
|
||||
// you may not use this file except in compliance with the License. You may
|
||||
// obtain a copy of the License at https://www.eclipse.org/legal/epl-2.0
|
||||
//
|
||||
// Unless required by applicable law or agreed to in writing, software
|
||||
// distributed under the License is distributed on an 'AS IS' BASIS,
|
||||
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||
//
|
||||
// See the License for the specific language governing permissions and
|
||||
// limitations under the License.
|
||||
//
|
||||
|
||||
import { type Env } from './env'
|
||||
|
||||
export async function withMetrics<T> (name: string, fn: (ctx: MetricsContext) => Promise<T>): Promise<T> {
|
||||
const ctx = new MetricsContext()
|
||||
|
||||
const start = performance.now()
|
||||
|
||||
try {
|
||||
return await fn(ctx)
|
||||
} finally {
|
||||
const total = performance.now() - start
|
||||
const ops = ctx.metrics
|
||||
const message = `${name} total=${total} ` + ctx.toString()
|
||||
console.log({ message, total, ops })
|
||||
}
|
||||
}
|
||||
|
||||
export interface MetricsData {
|
||||
op: string
|
||||
time: number
|
||||
}
|
||||
|
||||
export class MetricsContext {
|
||||
metrics: Array<MetricsData> = []
|
||||
|
||||
debug (...data: any[]): void {
|
||||
console.debug(...data)
|
||||
}
|
||||
|
||||
log (...data: any[]): void {
|
||||
console.log(...data)
|
||||
}
|
||||
|
||||
error (...data: any[]): void {
|
||||
console.error(...data)
|
||||
}
|
||||
|
||||
async with<T>(op: string, fn: () => Promise<T>): Promise<T> {
|
||||
const start = performance.now()
|
||||
try {
|
||||
return await fn()
|
||||
} finally {
|
||||
const time = performance.now() - start
|
||||
this.metrics.push({ op, time })
|
||||
}
|
||||
}
|
||||
|
||||
withSync<T>(op: string, fn: () => T): T {
|
||||
const start = performance.now()
|
||||
try {
|
||||
return fn()
|
||||
} finally {
|
||||
const time = performance.now() - start
|
||||
this.metrics.push({ op, time })
|
||||
}
|
||||
}
|
||||
|
||||
toString (): string {
|
||||
return this.metrics.map((p) => `${p.op}=${p.time}`).join(' ')
|
||||
}
|
||||
}
|
||||
|
||||
export class LoggedDatalake {
|
||||
constructor (
|
||||
private readonly datalake: Env['DATALAKE'],
|
||||
private readonly ctx: MetricsContext
|
||||
) {}
|
||||
|
||||
async getBlob (workspace: string, name: string): Promise<ArrayBuffer> {
|
||||
return await this.ctx.with('datalake.getBlob', () => {
|
||||
return this.datalake.getBlob(workspace, name)
|
||||
})
|
||||
}
|
||||
|
||||
async putBlob (workspace: string, name: string, data: ArrayBuffer | Blob | string, type: string): Promise<void> {
|
||||
await this.ctx.with('datalake.putBlob', () => {
|
||||
return this.datalake.putBlob(workspace, name, data, type)
|
||||
})
|
||||
}
|
||||
}
|
Loading…
Reference in New Issue
Block a user