Correctly handle video import errors

pull/904/merge
Chocobozzz 2018-08-03 09:27:30 +02:00
parent ed31c05985
commit d7f83948a1
7 changed files with 38 additions and 7 deletions

View File

@ -1,9 +1,10 @@
<p-table <p-table
[value]="videoImports" [lazy]="true" [paginator]="true" [totalRecords]="totalRecords" [rows]="rowsPerPage" [value]="videoImports" [lazy]="true" [paginator]="true" [totalRecords]="totalRecords" [rows]="rowsPerPage"
[sortField]="sort.field" [sortOrder]="sort.order" (onLazyLoad)="loadLazy($event)" [sortField]="sort.field" [sortOrder]="sort.order" (onLazyLoad)="loadLazy($event)" dataKey="id"
> >
<ng-template pTemplate="header"> <ng-template pTemplate="header">
<tr> <tr>
<th style="width: 40px;"></th>
<th i18n>URL</th> <th i18n>URL</th>
<th i18n>Video</th> <th i18n>Video</th>
<th i18n style="width: 150px">State</th> <th i18n style="width: 150px">State</th>
@ -12,8 +13,14 @@
</tr> </tr>
</ng-template> </ng-template>
<ng-template pTemplate="body" let-videoImport> <ng-template pTemplate="body" let-expanded="expanded" let-videoImport>
<tr> <tr>
<td>
<span *ngIf="videoImport.error" class="expander" [pRowToggler]="videoImport">
<i [ngClass]="expanded ? 'glyphicon glyphicon-menu-down' : 'glyphicon glyphicon-menu-right'"></i>
</span>
</td>
<td> <td>
<a [href]="videoImport.targetUrl" target="_blank" rel="noopener noreferrer">{{ videoImport.targetUrl }}</a> <a [href]="videoImport.targetUrl" target="_blank" rel="noopener noreferrer">{{ videoImport.targetUrl }}</a>
</td> </td>
@ -34,4 +41,12 @@
</td> </td>
</tr> </tr>
</ng-template> </ng-template>
<ng-template pTemplate="rowexpansion" let-videoImport>
<tr class="video-import-error" *ngIf="videoImport.error">
<td colspan="6">
<pre>{{ videoImport.error }}</pre>
</td>
</tr>
</ng-template>
</p-table> </p-table>

View File

@ -1,2 +1,10 @@
@import '_variables'; @import '_variables';
@import '_mixins'; @import '_mixins';
pre {
font-size: 11px;
}
.video-import-error {
color: red;
}

View File

@ -6,7 +6,7 @@
<label i18n for="targetUrl">URL</label> <label i18n for="targetUrl">URL</label>
<my-help <my-help
helpType="custom" i18n-customHtml helpType="custom" i18n-customHtml
customHtml="You can import any URL <a href='https://rg3.github.io/youtube-dl/supportedsites.html'>supported by youtube-dl</a> or URL that points to a raw MP4 file. Failure to secure these rights could cause legal trouble to yourself and your instance." customHtml="You can import any URL <a href='https://rg3.github.io/youtube-dl/supportedsites.html' target='_blank' rel='noopener noreferrer'>supported by youtube-dl</a> or URL that points to a raw MP4 file. Failure to secure these rights could cause legal trouble to yourself and your instance."
></my-help> ></my-help>
<input type="text" id="targetUrl" [(ngModel)]="targetUrl" /> <input type="text" id="targetUrl" [(ngModel)]="targetUrl" />

View File

@ -35,7 +35,7 @@ async function processVideoImport (job: Bull.Job) {
// Get information about this video // Get information about this video
const { videoFileResolution } = await getVideoFileResolution(tempVideoPath) const { videoFileResolution } = await getVideoFileResolution(tempVideoPath)
const fps = await getVideoFileFPS(tempVideoPath + 's') const fps = await getVideoFileFPS(tempVideoPath)
const stats = await statPromise(tempVideoPath) const stats = await statPromise(tempVideoPath)
const duration = await getDurationFromVideoFile(tempVideoPath) const duration = await getDurationFromVideoFile(tempVideoPath)
@ -115,6 +115,7 @@ async function processVideoImport (job: Bull.Job) {
logger.error('Cannot cleanup files after a video import error.', { err: errUnlink }) logger.error('Cannot cleanup files after a video import error.', { err: errUnlink })
} }
videoImport.error = err.message
videoImport.state = VideoImportState.FAILED videoImport.state = VideoImportState.FAILED
await videoImport.save() await videoImport.save()

View File

@ -79,7 +79,10 @@ class JobQueue {
const handler = handlers[handlerName] const handler = handlers[handlerName]
queue.process(JOB_CONCURRENCY[handlerName], handler) queue.process(JOB_CONCURRENCY[handlerName], handler)
.catch(err => logger.error('Cannot execute job queue %s.', handlerName, { err }))
queue.on('failed', (job, err) => {
logger.error('Cannot execute job %d in queue %s.', job.id, handlerName, { payload: job.data, err })
})
queue.on('error', err => { queue.on('error', err => {
logger.error('Error in job queue %s.', handlerName, { err }) logger.error('Error in job queue %s.', handlerName, { err })

View File

@ -26,7 +26,7 @@ import { TagModel } from './tag'
include: [ include: [
{ {
model: () => VideoModel, model: () => VideoModel,
required: true, required: false,
include: [ include: [
{ {
model: () => VideoChannelModel, model: () => VideoChannelModel,
@ -112,7 +112,7 @@ export class VideoImportModel extends Model<VideoImportModel> {
include: [ include: [
{ {
model: VideoModel, model: VideoModel,
required: true, required: false,
include: [ include: [
{ {
model: VideoChannelModel, model: VideoChannelModel,
@ -157,11 +157,13 @@ export class VideoImportModel extends Model<VideoImportModel> {
: undefined : undefined
return { return {
id: this.id,
targetUrl: this.targetUrl, targetUrl: this.targetUrl,
state: { state: {
id: this.state, id: this.state,
label: VideoImportModel.getStateLabel(this.state) label: VideoImportModel.getStateLabel(this.state)
}, },
error: this.error,
updatedAt: this.updatedAt.toISOString(), updatedAt: this.updatedAt.toISOString(),
createdAt: this.createdAt.toISOString(), createdAt: this.createdAt.toISOString(),
video video

View File

@ -3,10 +3,12 @@ import { VideoConstant } from './video-constant.model'
import { VideoImportState } from '../../index' import { VideoImportState } from '../../index'
export interface VideoImport { export interface VideoImport {
id: number
targetUrl: string targetUrl: string
createdAt: string createdAt: string
updatedAt: string updatedAt: string
state: VideoConstant<VideoImportState> state: VideoConstant<VideoImportState>
error?: string
video?: Video & { tags: string[] } video?: Video & { tags: string[] }
} }