2023-03-12 20:51:45 +01:00
|
|
|
const { DataTypes, Model } = require('sequelize')
|
|
|
|
|
|
|
|
module.exports = (sequelize) => {
|
|
|
|
class Podcast extends Model { }
|
|
|
|
|
|
|
|
Podcast.init({
|
|
|
|
id: {
|
|
|
|
type: DataTypes.UUID,
|
|
|
|
defaultValue: DataTypes.UUIDV4,
|
|
|
|
primaryKey: true
|
|
|
|
},
|
|
|
|
// Metadata
|
|
|
|
title: DataTypes.STRING,
|
|
|
|
author: DataTypes.STRING,
|
|
|
|
releaseDate: DataTypes.STRING,
|
2023-03-18 22:56:57 +01:00
|
|
|
feedURL: DataTypes.STRING,
|
|
|
|
imageURL: DataTypes.STRING,
|
2023-03-12 20:51:45 +01:00
|
|
|
description: DataTypes.TEXT,
|
2023-03-18 22:56:57 +01:00
|
|
|
itunesPageURL: DataTypes.STRING,
|
2023-03-12 20:51:45 +01:00
|
|
|
itunesId: DataTypes.STRING,
|
|
|
|
itunesArtistId: DataTypes.STRING,
|
|
|
|
language: DataTypes.STRING,
|
2023-03-18 22:56:57 +01:00
|
|
|
podcastType: DataTypes.STRING,
|
2023-03-12 20:51:45 +01:00
|
|
|
explicit: DataTypes.BOOLEAN,
|
|
|
|
|
|
|
|
autoDownloadEpisodes: DataTypes.BOOLEAN,
|
|
|
|
autoDownloadSchedule: DataTypes.STRING,
|
|
|
|
lastEpisodeCheck: DataTypes.DATE,
|
|
|
|
maxEpisodesToKeep: DataTypes.INTEGER,
|
|
|
|
maxNewEpisodesToDownload: DataTypes.INTEGER,
|
|
|
|
lastCoverSearchQuery: DataTypes.STRING,
|
|
|
|
lastCoverSearch: DataTypes.DATE
|
|
|
|
}, {
|
|
|
|
sequelize,
|
|
|
|
modelName: 'Podcast'
|
|
|
|
})
|
|
|
|
|
|
|
|
const { LibraryItem, FileMetadata } = sequelize.models
|
|
|
|
LibraryItem.hasOne(Podcast)
|
|
|
|
Podcast.belongsTo(LibraryItem)
|
|
|
|
|
2023-03-18 22:56:57 +01:00
|
|
|
FileMetadata.hasOne(Podcast, { foreignKey: 'ImageFileId' })
|
|
|
|
Podcast.belongsTo(FileMetadata, { as: 'ImageFile', foreignKey: 'ImageFileId' }) // Ref: https://sequelize.org/docs/v6/core-concepts/assocs/#defining-an-alias
|
2023-03-12 20:51:45 +01:00
|
|
|
|
|
|
|
return Podcast
|
|
|
|
}
|