Some fixes for admin videos list

This commit is contained in:
Chocobozzz 2021-11-02 11:00:40 +01:00
parent fd5fa94bbc
commit 7e7d8e4853
No known key found for this signature in database
GPG Key ID: 583A612D890159BE
12 changed files with 54 additions and 54 deletions

View File

@ -69,7 +69,7 @@
<span *ngIf="video.nsfw" class="badge badge-red" i18n>NSFW</span>
<span *ngIf="isUnpublished(video.state.id)" class="badge badge-yellow" i18n>Not published yet</span>
<span *ngIf="isUnpublished(video.state.id)" class="badge badge-yellow" i18n>{{ video.state.label }}</span>
<span *ngIf="isAccountBlocked(video)" class="badge badge-red" i18n>Account muted</span>
<span *ngIf="isServerBlocked(video)" class="badge badge-red" i18n>Server muted</span>
@ -80,8 +80,9 @@
<td>
<span *ngIf="isHLS(video)" class="badge badge-blue">HLS</span>
<span *ngIf="isWebTorrent(video)" class="badge badge-blue">WebTorrent</span>
<span *ngIf="video.isLive" class="badge badge-blue">Live</span>
<span *ngIf="!video.remote">{{ getFilesSize(video) | bytes: 1 }}</span>
<span *ngIf="!video.isLive && video.isLocal">{{ getFilesSize(video) | bytes: 1 }}</span>
</td>
<td>

View File

@ -16,7 +16,7 @@ export class VideoListComponent extends RestTable implements OnInit {
videos: Video[] = []
totalRecords = 0
sort: SortMeta = { field: 'publishedAt', order: 1 }
sort: SortMeta = { field: 'publishedAt', order: -1 }
pagination: RestPagination = { count: this.rowsPerPage, start: 0 }
bulkVideoActions: DropdownAction<Video[]>[][] = []
@ -99,7 +99,7 @@ export class VideoListComponent extends RestTable implements OnInit {
}
isUnpublished (state: VideoState) {
return state !== VideoState.PUBLISHED
return state !== VideoState.LIVE_ENDED && state !== VideoState.PUBLISHED
}
isAccountBlocked (video: Video) {

View File

@ -48,7 +48,7 @@ export type CommonVideoParams = {
@Injectable()
export class VideoService {
static BASE_VIDEO_URL = environment.apiUrl + '/api/v1/videos/'
static BASE_VIDEO_URL = environment.apiUrl + '/api/v1/videos'
static BASE_FEEDS_URL = environment.apiUrl + '/feeds/videos.'
static BASE_SUBSCRIPTION_FEEDS_URL = environment.apiUrl + '/feeds/subscriptions.'
@ -60,18 +60,18 @@ export class VideoService {
) {}
getVideoViewUrl (uuid: string) {
return VideoService.BASE_VIDEO_URL + uuid + '/views'
return VideoService.BASE_VIDEO_URL + '/' + uuid + '/views'
}
getUserWatchingVideoUrl (uuid: string) {
return VideoService.BASE_VIDEO_URL + uuid + '/watching'
return VideoService.BASE_VIDEO_URL + '/' + uuid + '/watching'
}
getVideo (options: { videoId: string }): Observable<VideoDetails> {
return this.serverService.getServerLocale()
.pipe(
switchMap(translations => {
return this.authHttp.get<VideoDetailsServerModel>(VideoService.BASE_VIDEO_URL + options.videoId)
return this.authHttp.get<VideoDetailsServerModel>(VideoService.BASE_VIDEO_URL + '/' + options.videoId)
.pipe(map(videoHash => ({ videoHash, translations })))
}),
map(({ videoHash, translations }) => new VideoDetails(videoHash, translations)),
@ -111,7 +111,7 @@ export class VideoService {
const data = objectToFormData(body)
return this.authHttp.put(VideoService.BASE_VIDEO_URL + video.id, data)
return this.authHttp.put(VideoService.BASE_VIDEO_URL + '/' + video.id, data)
.pipe(
map(this.restExtractor.extractDataBool),
catchError(err => this.restExtractor.handleError(err))
@ -119,7 +119,7 @@ export class VideoService {
}
uploadVideo (video: FormData) {
const req = new HttpRequest('POST', VideoService.BASE_VIDEO_URL + 'upload', video, { reportProgress: true })
const req = new HttpRequest('POST', VideoService.BASE_VIDEO_URL + '/' + 'upload', video, { reportProgress: true })
return this.authHttp
.request<{ video: { id: number, uuid: string } }>(req)
@ -321,7 +321,7 @@ export class VideoService {
return from(ids)
.pipe(
concatMap(id => this.authHttp.delete(VideoService.BASE_VIDEO_URL + id)),
concatMap(id => this.authHttp.delete(VideoService.BASE_VIDEO_URL + '/' + id)),
toArray(),
catchError(err => this.restExtractor.handleError(err))
)
@ -413,7 +413,7 @@ export class VideoService {
}
private setVideoRate (id: number, rateType: UserVideoRateType) {
const url = VideoService.BASE_VIDEO_URL + id + '/rate'
const url = VideoService.BASE_VIDEO_URL + '/' + id + '/rate'
const body: UserVideoRateUpdate = {
rating: rateType
}

View File

@ -6,7 +6,7 @@ import { QueryTypes, Sequelize, Transaction } from 'sequelize'
*
*/
export class AbstractVideosQueryBuilder {
export class AbstractRunQuery {
protected sequelize: Sequelize
protected query: string

View File

@ -1,8 +1,8 @@
import { createSafeIn } from '@server/models/utils'
import { MUserAccountId } from '@server/types/models'
import validator from 'validator'
import { AbstractVideosQueryBuilder } from './abstract-videos-query-builder'
import { VideoTables } from './video-tables'
import { AbstractRunQuery } from './abstract-run-query'
import { VideoTableAttributes } from './video-table-attributes'
/**
*
@ -10,18 +10,18 @@ import { VideoTables } from './video-tables'
*
*/
export class AbstractVideosModelQueryBuilder extends AbstractVideosQueryBuilder {
export class AbstractVideoQueryBuilder extends AbstractRunQuery {
protected attributes: { [key: string]: string } = {}
protected joins = ''
protected where: string
protected tables: VideoTables
protected tables: VideoTableAttributes
constructor (protected readonly mode: 'list' | 'get') {
super()
this.tables = new VideoTables(this.mode)
this.tables = new VideoTableAttributes(this.mode)
}
protected buildSelect () {

View File

@ -1,6 +1,6 @@
import { Sequelize } from 'sequelize'
import { BuildVideoGetQueryOptions } from '../video-model-get-query-builder'
import { AbstractVideosModelQueryBuilder } from './abstract-videos-model-query-builder'
import { AbstractVideoQueryBuilder } from './abstract-video-query-builder'
/**
*
@ -8,7 +8,7 @@ import { AbstractVideosModelQueryBuilder } from './abstract-videos-model-query-b
*
*/
export class VideoFileQueryBuilder extends AbstractVideosModelQueryBuilder {
export class VideoFileQueryBuilder extends AbstractVideoQueryBuilder {
protected attributes: { [key: string]: string }
constructor (protected readonly sequelize: Sequelize) {

View File

@ -18,7 +18,7 @@ import { VideoChannelModel } from '../../video-channel'
import { VideoFileModel } from '../../video-file'
import { VideoLiveModel } from '../../video-live'
import { VideoStreamingPlaylistModel } from '../../video-streaming-playlist'
import { VideoTables } from './video-tables'
import { VideoTableAttributes } from './video-table-attributes'
type SQLRow = { [id: string]: string | number }
@ -51,7 +51,7 @@ export class VideoModelBuilder {
constructor (
readonly mode: 'get' | 'list',
readonly tables: VideoTables
readonly tables: VideoTableAttributes
) {
}

View File

@ -4,7 +4,7 @@
* Class to build video attributes/join names we want to fetch from the database
*
*/
export class VideoTables {
export class VideoTableAttributes {
constructor (readonly mode: 'get' | 'list') {
@ -93,10 +93,11 @@ export class VideoTables {
}
getStreamingPlaylistAttributes () {
let playlistKeys = [ 'id', 'playlistUrl', 'playlistFilename', 'type' ]
if (this.mode === 'get') {
playlistKeys = playlistKeys.concat([
return [
'id',
'playlistUrl',
'playlistFilename',
'type',
'p2pMediaLoaderInfohashes',
'p2pMediaLoaderPeerVersion',
'segmentsSha256Filename',
@ -105,10 +106,7 @@ export class VideoTables {
'createdAt',
'updatedAt',
'storage'
])
}
return playlistKeys
]
}
getUserHistoryAttributes () {

View File

@ -1,8 +1,8 @@
import { Sequelize, Transaction } from 'sequelize'
import { AbstractVideosModelQueryBuilder } from './shared/abstract-videos-model-query-builder'
import { AbstractVideoQueryBuilder } from './shared/abstract-video-query-builder'
import { VideoFileQueryBuilder } from './shared/video-file-query-builder'
import { VideoModelBuilder } from './shared/video-model-builder'
import { VideoTables } from './shared/video-tables'
import { VideoTableAttributes } from './shared/video-table-attributes'
/**
*
@ -46,7 +46,7 @@ export class VideoModelGetQueryBuilder {
this.webtorrentFilesQueryBuilder = new VideoFileQueryBuilder(sequelize)
this.streamingPlaylistFilesQueryBuilder = new VideoFileQueryBuilder(sequelize)
this.videoModelBuilder = new VideoModelBuilder('get', new VideoTables('get'))
this.videoModelBuilder = new VideoModelBuilder('get', new VideoTableAttributes('get'))
}
async queryVideo (options: BuildVideoGetQueryOptions) {
@ -69,15 +69,16 @@ export class VideoModelGetQueryBuilder {
})
if (videos.length > 1) {
throw new Error('Video results is more than ')
throw new Error('Video results is more than 1')
}
if (videos.length === 0) return null
return videos[0]
}
}
export class VideosModelGetQuerySubBuilder extends AbstractVideosModelQueryBuilder {
export class VideosModelGetQuerySubBuilder extends AbstractVideoQueryBuilder {
protected attributes: { [key: string]: string }
protected webtorrentFilesQuery: string

View File

@ -5,7 +5,7 @@ import { WEBSERVER } from '@server/initializers/constants'
import { buildDirectionAndField, createSafeIn } from '@server/models/utils'
import { MUserAccountId, MUserId } from '@server/types/models'
import { VideoInclude, VideoPrivacy, VideoState } from '@shared/models'
import { AbstractVideosQueryBuilder } from './shared/abstract-videos-query-builder'
import { AbstractRunQuery } from './shared/abstract-run-query'
/**
*
@ -72,7 +72,7 @@ export type BuildVideosListQueryOptions = {
having?: string
}
export class VideosIdListQueryBuilder extends AbstractVideosQueryBuilder {
export class VideosIdListQueryBuilder extends AbstractRunQuery {
protected replacements: any = {}
private attributes: string[]
@ -105,7 +105,7 @@ export class VideosIdListQueryBuilder extends AbstractVideosQueryBuilder {
return this.runQuery().then(rows => rows.length !== 0 ? rows[0].total : 0)
}
getIdsListQueryAndSort (options: BuildVideosListQueryOptions) {
getQuery (options: BuildVideosListQueryOptions) {
this.buildIdsListQuery(options)
return { query: this.query, sort: this.sort, replacements: this.replacements }

View File

@ -1,6 +1,6 @@
import { VideoInclude } from '@shared/models'
import { Sequelize } from 'sequelize'
import { AbstractVideosModelQueryBuilder } from './shared/abstract-videos-model-query-builder'
import { AbstractVideoQueryBuilder } from './shared/abstract-video-query-builder'
import { VideoModelBuilder } from './shared/video-model-builder'
import { BuildVideosListQueryOptions, VideosIdListQueryBuilder } from './videos-id-list-query-builder'
@ -10,7 +10,7 @@ import { BuildVideosListQueryOptions, VideosIdListQueryBuilder } from './videos-
*
*/
export class VideosModelListQueryBuilder extends AbstractVideosModelQueryBuilder {
export class VideosModelListQueryBuilder extends AbstractVideoQueryBuilder {
protected attributes: { [key: string]: string }
private innerQuery: string
@ -26,7 +26,7 @@ export class VideosModelListQueryBuilder extends AbstractVideosModelQueryBuilder
queryVideos (options: BuildVideosListQueryOptions) {
this.buildInnerQuery(options)
this.buildListQueryFromIdsQuery(options)
this.buildMainQuery(options)
return this.runQuery()
.then(rows => this.videoModelBuilder.buildVideosFromRows({ rows, include: options.include }))
@ -34,14 +34,14 @@ export class VideosModelListQueryBuilder extends AbstractVideosModelQueryBuilder
private buildInnerQuery (options: BuildVideosListQueryOptions) {
const idsQueryBuilder = new VideosIdListQueryBuilder(this.sequelize)
const { query, sort, replacements } = idsQueryBuilder.getIdsListQueryAndSort(options)
const { query, sort, replacements } = idsQueryBuilder.getQuery(options)
this.replacements = replacements
this.innerQuery = query
this.innerSort = sort
}
private buildListQueryFromIdsQuery (options: BuildVideosListQueryOptions) {
private buildMainQuery (options: BuildVideosListQueryOptions) {
this.attributes = {
'"video".*': ''
}

View File

@ -4805,7 +4805,7 @@ components:
required: false
schema:
type: boolean
description: 'Display only local or remote videos'
description: '**PeerTube >= 4.0** Display only local or remote videos'
include:
name: include
in: query
@ -4819,7 +4819,7 @@ components:
- 4
- 8
description: >
Include additional videos in results (can be combined using bitwise or operator)
**PeerTube >= 4.0** Include additional videos in results (can be combined using bitwise or operator)
- `0` NONE