X-Git-Url: https://git.immae.eu/?a=blobdiff_plain;f=server%2Fmodels%2Fvideo%2Ftag.ts;h=653b9694b8a6adef8a3c68cfb8b1822e6c2667c3;hb=ba2684ceddf9b76312635b9cddc6bf6975ce436a;hp=c1eebe27f2950f27779ea225c9afd7ee77dabe59;hpb=5ec3cbdf22fc88ebe57f370fc0bc0e3df7453458;p=github%2FChocobozzz%2FPeerTube.git diff --git a/server/models/video/tag.ts b/server/models/video/tag.ts index c1eebe27f..653b9694b 100644 --- a/server/models/video/tag.ts +++ b/server/models/video/tag.ts @@ -1,7 +1,7 @@ import { col, fn, QueryTypes, Transaction } from 'sequelize' import { AllowNull, BelongsToMany, Column, CreatedAt, Is, Model, Table, UpdatedAt } from 'sequelize-typescript' import { MTag } from '@server/types/models' -import { AttributesOnly } from '@shared/core-utils' +import { AttributesOnly } from '@shared/typescript-utils' import { VideoPrivacy, VideoState } from '../../../shared/models/videos' import { isVideoTagValid } from '../../helpers/custom-validators/videos' import { throwIfNotValid } from '../utils' @@ -18,7 +18,7 @@ import { VideoTagModel } from './video-tag' }, { name: 'tag_lower_name', - fields: [ fn('lower', col('name')) ] as any // FIXME: typings + fields: [ fn('lower', col('name')) ] } ] }) @@ -45,8 +45,9 @@ export class TagModel extends Model>> { static findOrCreateTags (tags: string[], transaction: Transaction): Promise { if (tags === null) return Promise.resolve([]) - const tasks: Promise[] = [] - tags.forEach(tag => { + const uniqueTags = new Set(tags) + + const tasks = Array.from(uniqueTags).map(tag => { const query = { where: { name: tag @@ -57,9 +58,8 @@ export class TagModel extends Model>> { transaction } - const promise = TagModel.findOrCreate(query) + return TagModel.findOrCreate(query) .then(([ tagInstance ]) => tagInstance) - tasks.push(promise) }) return Promise.all(tasks)