UBERF-4729: Fix front service (#4260)

Signed-off-by: Andrey Sobolev <haiodo@gmail.com>
This commit is contained in:
Andrey Sobolev 2023-12-25 19:11:08 +07:00 committed by GitHub
parent 8d7d11a2e0
commit b522334f0e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
9 changed files with 76 additions and 20 deletions

View File

@ -1022,6 +1022,9 @@ dependencies:
mongodb: mongodb:
specifier: ^4.11.0 specifier: ^4.11.0
version: 4.17.1 version: 4.17.1
morgan:
specifier: ^1.10.0
version: 1.10.0
msgpackr: msgpackr:
specifier: ^1.8.5 specifier: ^1.8.5
version: 1.9.9 version: 1.9.9
@ -7259,6 +7262,12 @@ packages:
'@types/node': 16.11.68 '@types/node': 16.11.68
dev: false dev: false
/@types/morgan@1.9.9:
resolution: {integrity: sha512-iRYSDKVaC6FkGSpEVVIvrRGw0DfJMiQzIn3qr2G5B3C//AWkulhXgaBd7tS9/J79GWSYMTHGs7PfI5b3Y8m+RQ==}
dependencies:
'@types/node': 16.11.68
dev: false
/@types/node-fetch@2.6.6: /@types/node-fetch@2.6.6:
resolution: {integrity: sha512-95X8guJYhfqiuVVhRFxVQcf4hW/2bCuoPwDasMf/531STFoNoWTT7YDnWdXHEZKqAGUigmpG31r2FE70LwnzJw==} resolution: {integrity: sha512-95X8guJYhfqiuVVhRFxVQcf4hW/2bCuoPwDasMf/531STFoNoWTT7YDnWdXHEZKqAGUigmpG31r2FE70LwnzJw==}
dependencies: dependencies:
@ -13356,6 +13365,17 @@ packages:
resolution: {integrity: sha512-YRIr1exCIfBDLZle8WHOfSo7Xg3M+phcZfq9Fx1L6Abo+atGp7cge5pM7PjyBn4s1oZI/BRD4EMrzQBbPpVb5Q==} resolution: {integrity: sha512-YRIr1exCIfBDLZle8WHOfSo7Xg3M+phcZfq9Fx1L6Abo+atGp7cge5pM7PjyBn4s1oZI/BRD4EMrzQBbPpVb5Q==}
dev: false dev: false
/morgan@1.10.0:
resolution: {integrity: sha512-AbegBVI4sh6El+1gNwvD5YIck7nSA36weD7xvIxG4in80j/UoK8AEGaWnnz8v1GxonMCltmlNs5ZKbGvl9b1XQ==}
engines: {node: '>= 0.8.0'}
dependencies:
basic-auth: 2.0.1
debug: 2.6.9
depd: 2.0.0
on-finished: 2.3.0
on-headers: 1.0.2
dev: false
/mri@1.2.0: /mri@1.2.0:
resolution: {integrity: sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==} resolution: {integrity: sha512-tzzskb3bG8LvYGFF/mDTpq3jpI6Q9wc3LEmBaghu+DdCssd1FakN7Bc0hVNmEyGq1bq3RgfkCb3cmQLpNPOroA==}
engines: {node: '>=4'} engines: {node: '>=4'}
@ -18613,7 +18633,7 @@ packages:
dev: false dev: false
file:projects/front.tgz(esbuild@0.16.17)(svelte@4.2.5): file:projects/front.tgz(esbuild@0.16.17)(svelte@4.2.5):
resolution: {integrity: sha512-xBechy2SGLSNUUN/rM60kyFJOJA8edlX2f/gqHk272BIfcsGXtUlPl8yPXv/H9zciOKSAUSy/6fMDZVNATVuqA==, tarball: file:projects/front.tgz} resolution: {integrity: sha512-G4bpLQ5WO+t2ZP5hbCRzS4Zpzi1bwLhpC0hdhLTNkwFw6GUj38chkzMtzroD/cExV30MrjtntL5yQJ2n3yvv2A==, tarball: file:projects/front.tgz}
id: file:projects/front.tgz id: file:projects/front.tgz
name: '@rush-temp/front' name: '@rush-temp/front'
version: 0.0.0 version: 0.0.0
@ -18624,6 +18644,7 @@ packages:
'@types/express': 4.17.18 '@types/express': 4.17.18
'@types/express-fileupload': 1.4.2 '@types/express-fileupload': 1.4.2
'@types/jest': 29.5.5 '@types/jest': 29.5.5
'@types/morgan': 1.9.9
'@types/node': 16.11.68 '@types/node': 16.11.68
'@types/sharp': 0.32.0 '@types/sharp': 0.32.0
'@types/uuid': 8.3.4 '@types/uuid': 8.3.4
@ -18641,6 +18662,7 @@ packages:
express: 4.18.2 express: 4.18.2
express-fileupload: 1.4.1 express-fileupload: 1.4.1
jest: 29.7.0(@types/node@16.11.68)(ts-node@10.9.1) jest: 29.7.0(@types/node@16.11.68)(ts-node@10.9.1)
morgan: 1.10.0
prettier: 3.1.0 prettier: 3.1.0
prettier-plugin-svelte: 3.1.0(prettier@3.1.0)(svelte@4.2.5) prettier-plugin-svelte: 3.1.0(prettier@3.1.0)(svelte@4.2.5)
sharp: 0.32.6 sharp: 0.32.6
@ -23558,7 +23580,7 @@ packages:
dev: false dev: false
file:projects/telegram-resources.tgz(@types/node@16.11.68)(esbuild@0.16.17)(postcss-load-config@4.0.1)(postcss@8.4.31)(ts-node@10.9.1): file:projects/telegram-resources.tgz(@types/node@16.11.68)(esbuild@0.16.17)(postcss-load-config@4.0.1)(postcss@8.4.31)(ts-node@10.9.1):
resolution: {integrity: sha512-qrqvq8PmtA09Sn9AOCaId5Zupe804Fw4t6pRfrDPlmYm39aemhZ+QHAyUIvg2kr/yo0jNRwXg4g3DBpUbUTRhA==, tarball: file:projects/telegram-resources.tgz} resolution: {integrity: sha512-xz5vevvHFXT/WIU4CCz9TPJUwGOgAUtiEgcJFYsWwzFUUL5Mz2ImUG0GkV9wQeAfkjaz0KiKD6YWe78Ir9WD5w==, tarball: file:projects/telegram-resources.tgz}
id: file:projects/telegram-resources.tgz id: file:projects/telegram-resources.tgz
name: '@rush-temp/telegram-resources' name: '@rush-temp/telegram-resources'
version: 0.0.0 version: 0.0.0

View File

@ -798,6 +798,10 @@ export async function restore (
}) })
}) })
const unzip = createGunzip() const unzip = createGunzip()
readStream.on('end', () => {
readStream.destroy()
})
readStream.pipe(unzip) readStream.pipe(unzip)
unzip.pipe(ex) unzip.pipe(ex)

View File

@ -118,6 +118,7 @@ export class ContentRetrievalStage implements FullTextPipelineStage {
{}, {},
async () => await this.contentAdapter.content(ref, contentType, readable) async () => await this.contentAdapter.content(ref, contentType, readable)
) )
readable?.destroy()
textContent = textContent textContent = textContent
.split(/ +|\t+|\f+/) .split(/ +|\t+|\f+/)

View File

@ -36,7 +36,8 @@
"jest": "^29.7.0", "jest": "^29.7.0",
"ts-jest": "^29.1.1", "ts-jest": "^29.1.1",
"@types/jest": "^29.5.5", "@types/jest": "^29.5.5",
"prettier-plugin-svelte": "^3.1.0" "prettier-plugin-svelte": "^3.1.0",
"@types/morgan": "~1.9.9"
}, },
"dependencies": { "dependencies": {
"@hcengineering/core": "^0.6.28", "@hcengineering/core": "^0.6.28",
@ -52,6 +53,7 @@
"body-parser": "~1.19.1", "body-parser": "~1.19.1",
"compression": "~1.7.4", "compression": "~1.7.4",
"sharp": "~0.32.0", "sharp": "~0.32.0",
"@hcengineering/minio": "^0.6.0" "@hcengineering/minio": "^0.6.0",
"morgan": "^1.10.0"
} }
} }

View File

@ -26,6 +26,7 @@ import https from 'https'
import { join, resolve } from 'path' import { join, resolve } from 'path'
import sharp from 'sharp' import sharp from 'sharp'
import { v4 as uuid } from 'uuid' import { v4 as uuid } from 'uuid'
import morgan from 'morgan'
async function minioUpload (minio: MinioService, workspace: WorkspaceId, file: UploadedFile): Promise<string> { async function minioUpload (minio: MinioService, workspace: WorkspaceId, file: UploadedFile): Promise<string> {
const id = uuid() const id = uuid()
@ -85,7 +86,14 @@ async function getFileRange (
'Content-Range': `bytes ${start}-${end}/${size}`, 'Content-Range': `bytes ${start}-${end}/${size}`,
'Accept-Ranges': 'bytes', 'Accept-Ranges': 'bytes',
'Content-Length': end - start + 1, 'Content-Length': end - start + 1,
'Content-Type': stat.metaData['content-type'] 'Content-Type': stat.metaData['content-type'],
Etag: stat.etag,
'Last-Modified': stat.lastModified.toISOString()
})
dataStream.on('end', () => {
dataStream.destroy()
res.end()
}) })
dataStream.pipe(res) dataStream.pipe(res)
@ -100,19 +108,18 @@ async function getFile (client: MinioService, workspace: WorkspaceId, uuid: stri
try { try {
const dataStream = await client.get(workspace, uuid) const dataStream = await client.get(workspace, uuid)
res.status(200) res.writeHead(200, {
res.set('Cache-Control', 'max-age=7d') 'Content-Type': stat.metaData['content-type'],
Etag: stat.etag,
const contentType = stat.metaData['content-type'] 'Last-Modified': stat.lastModified.toISOString()
if (contentType !== undefined) { })
res.setHeader('Content-Type', contentType)
}
dataStream.on('data', function (chunk) { dataStream.on('data', function (chunk) {
res.write(chunk) res.write(chunk)
}) })
dataStream.on('end', function () { dataStream.on('end', function () {
res.end() res.end()
dataStream.destroy()
}) })
dataStream.on('error', function (err) { dataStream.on('error', function (err) {
console.log(err) console.log(err)
@ -169,6 +176,8 @@ export function start (
app.use(bp.json()) app.use(bp.json())
app.use(bp.urlencoded({ extended: true })) app.use(bp.urlencoded({ extended: true }))
app.use(morgan('combined'))
// eslint-disable-next-line @typescript-eslint/no-misused-promises // eslint-disable-next-line @typescript-eslint/no-misused-promises
app.get('/config.json', async (req, res) => { app.get('/config.json', async (req, res) => {
res.status(200) res.status(200)
@ -215,11 +224,14 @@ export function start (
const fileSize = stat.size const fileSize = stat.size
res.writeHead(200, {
'accept-ranges': 'bytes',
'content-length': fileSize,
Etag: stat.etag,
'Last-Modified': stat.lastModified.toISOString()
})
res.status(200) res.status(200)
res.setHeader('accept-ranges', 'bytes')
res.setHeader('content-length', fileSize)
res.end() res.end()
} catch (error) { } catch (error) {
console.log(error) console.log(error)
@ -229,7 +241,6 @@ export function start (
const filesHandler = async (req: any, res: Response): Promise<void> => { const filesHandler = async (req: any, res: Response): Promise<void> => {
try { try {
console.log(req.headers)
const cookies = ((req?.headers?.cookie as string) ?? '').split(';').map((it) => it.trim().split('=')) const cookies = ((req?.headers?.cookie as string) ?? '').split(';').map((it) => it.trim().split('='))
const token = cookies.find((it) => it[0] === 'presentation-metadata-Token')?.[1] const token = cookies.find((it) => it[0] === 'presentation-metadata-Token')?.[1]
@ -262,8 +273,12 @@ export function start (
} else { } else {
await getFile(config.minio, payload.workspace, uuid, res) await getFile(config.minio, payload.workspace, uuid, res)
} }
} catch (error) { } catch (error: any) {
console.log(error) if (error?.code === 'NoSuchKey' || error?.code === 'NotFound') {
console.log('No such key', req.query.file)
} else {
console.log(error)
}
res.status(500).send() res.status(500).send()
} }
} }
@ -565,7 +580,9 @@ async function getResizeID (
const d = await config.minio.stat(payload.workspace, sizeId) const d = await config.minio.stat(payload.workspace, sizeId)
hasSmall = d !== undefined && d.size > 0 hasSmall = d !== undefined && d.size > 0
} catch (err: any) { } catch (err: any) {
console.error(err) if (err.code !== 'NotFound') {
console.error(err)
}
} }
if (hasSmall) { if (hasSmall) {
// We have cached small document, let's proceed with it. // We have cached small document, let's proceed with it.

View File

@ -67,6 +67,7 @@ export class MinioService {
} }
}) })
list.on('end', () => { list.on('end', () => {
list.destroy()
resolve(null) resolve(null)
}) })
}) })
@ -111,6 +112,7 @@ export class MinioService {
}) })
data.on('end', () => { data.on('end', () => {
data.destroy()
resolve(null) resolve(null)
}) })
}) })

View File

@ -20,6 +20,10 @@
"name": "#platform.notification.logging", "name": "#platform.notification.logging",
"value": "false" "value": "false"
}, },
{
"name": "#platform.notification.timeout",
"value": "0"
},
{ {
"name": "#platform.lazy.loading", "name": "#platform.lazy.loading",
"value": "false" "value": "false"

View File

@ -20,6 +20,10 @@
"name": "#platform.notification.timeout", "name": "#platform.notification.timeout",
"value": "0" "value": "0"
}, },
{
"name": "#platform.notification.timeout",
"value": "0"
},
{ {
"name": "#platform.testing.enabled", "name": "#platform.testing.enabled",
"value": "true" "value": "true"

View File

@ -74,7 +74,7 @@ export class IssuesPage extends CommonTrackerPage {
) )
} }
async createNewIssue (data: NewIssue, closeNotification: boolean = true): Promise<void> { async createNewIssue (data: NewIssue, closeNotification: boolean = false): Promise<void> {
await this.buttonCreateNewIssue.click() await this.buttonCreateNewIssue.click()
await this.fillNewIssueForm(data) await this.fillNewIssueForm(data)
await this.buttonCreateIssue.click() await this.buttonCreateIssue.click()