mirror of https://github.com/Chocobozzz/PeerTube
Correctly handle video import errors
parent
ed31c05985
commit
d7f83948a1
|
@ -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>
|
||||||
|
|
|
@ -1,2 +1,10 @@
|
||||||
@import '_variables';
|
@import '_variables';
|
||||||
@import '_mixins';
|
@import '_mixins';
|
||||||
|
|
||||||
|
pre {
|
||||||
|
font-size: 11px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.video-import-error {
|
||||||
|
color: red;
|
||||||
|
}
|
|
@ -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" />
|
||||||
|
|
|
@ -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()
|
||||||
|
|
||||||
|
|
|
@ -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 })
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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[] }
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue