Started work on archived media collection.
This commit is contained in:
parent
8d7d08d5c0
commit
855343dfc3
3 changed files with 194 additions and 1 deletions
80
src/schemas/channel/media/archivedMediaSchema.js
Normal file
80
src/schemas/channel/media/archivedMediaSchema.js
Normal file
|
|
@ -0,0 +1,80 @@
|
|||
/*Canopy - The next generation of stoner streaming software
|
||||
Copyright (C) 2024-2025 Rainbownapkin and the TTN Community
|
||||
|
||||
This program is free software: you can redistribute it and/or modify
|
||||
it under the terms of the GNU Affero General Public License as
|
||||
published by the Free Software Foundation, either version 3 of the
|
||||
License, or (at your option) any later version.
|
||||
|
||||
This program is distributed in the hope that it will be useful,
|
||||
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
GNU Affero General Public License for more details.
|
||||
|
||||
You should have received a copy of the GNU Affero General Public License
|
||||
along with this program. If not, see <https://www.gnu.org/licenses/>.*/
|
||||
|
||||
//NPM Imports
|
||||
const {mongoose} = require('mongoose');
|
||||
|
||||
//Local Imports
|
||||
const mediaSchema = require('./mediaSchema');
|
||||
const archivedMedia = require('../../../app/channel/media/archivedMedia');
|
||||
|
||||
/**
|
||||
* DB Schema for documents representing a queued media object
|
||||
*/
|
||||
const archivedProperties = new mongoose.Schema({
|
||||
channel: {
|
||||
type: mongoose.SchemaTypes.String,
|
||||
required: true,
|
||||
},
|
||||
startTime: {
|
||||
type: mongoose.SchemaTypes.Number,
|
||||
required: true,
|
||||
},
|
||||
startTimeStamp: {
|
||||
type: mongoose.SchemaTypes.Number,
|
||||
required: false,
|
||||
},
|
||||
earlyEnd: {
|
||||
type: mongoose.SchemaTypes.Number,
|
||||
required: false,
|
||||
},
|
||||
uuid: {
|
||||
type: mongoose.SchemaTypes.UUID,
|
||||
required: true,
|
||||
},
|
||||
},
|
||||
{
|
||||
discriminatorKey: 'status'
|
||||
});
|
||||
|
||||
//Methods
|
||||
/**
|
||||
* Rehydrate to a full phat archived media object
|
||||
* @returns {archivedMedia} A full phat archived media object, re-hydrated from the DB
|
||||
*/
|
||||
archivedProperties.methods.rehydrate = function(){
|
||||
return new archivedMedia(
|
||||
this.title,
|
||||
this.fileName,
|
||||
this.url,
|
||||
this.id,
|
||||
this.type,
|
||||
this.duration,
|
||||
//We don't save raw links that are stored seperate from the standard URL as they tend to expire.
|
||||
undefined,
|
||||
this.startTime,
|
||||
this.startTimeStamp,
|
||||
this.earlyEnd,
|
||||
this.uuid.toString(),
|
||||
this.channel
|
||||
);
|
||||
}
|
||||
|
||||
//Create 'archivedMediaSchema' as descriminator of mediaSchema
|
||||
var archivedMediaSchema = mediaSchema.discriminator('archived', archivedProperties);
|
||||
|
||||
//Export mongoose model based on archivedSchema
|
||||
module.exports = mongoose.model("archivedMedia", archivedMediaSchema);
|
||||
Loading…
Add table
Add a link
Reference in a new issue