Compare commits

...

No commits in common. "release" and "gh-pages" have entirely different histories.

31 changed files with 960 additions and 983 deletions

3
.gitignore vendored
View File

@ -1,3 +0,0 @@
config.js
nodes_modules
nodes_modules/*

135
README.md
View File

@ -1,135 +0,0 @@
Plex Web Downloader
===============
The original translated into english and using pwd url base for nginx reverse proxy use
This project allows you to create a list of your plex video files and to share them through a web interface.
**************************************************************************************************************************************
I would recomend setting up a crontab that backups the plex database every night then have this use the new file that has been created that way this doesn't lock the plex database
***************************************************************************************************************************************
MANUAL INSTALLATION
--------------------
If you prefer to compile the latest version of the project yourself, or if your operating system is not supported:
** On Windows **
  prerequisites, install git (https://git-scm.com/download/win)
  prerequisites, install nodejs 0.12.x (https://nodejs.org/dist/v0.12.7/)
  open the 'cmb' command prompt, and then move to a directory where you want to install
    git clone https://github.com/12nick12/pwd.git
    cd plex-web-downloader
    npm install
  modify the file config.js, to put the path of the database plex (attention must double the anti-slash and protect the spaces)
  For example: C: \\ Users \\ yourUsername \\ AppData \\ Local \\ Plex \ Media \ Server \\ Plug-in \ Support \\ Databases \\ com.plexapp.plugins.library.db
    npm start
  then open in your browser the address http: // localhost: 3000
** Under MacOS **
  prerequisites, nodejs
    brew install node
  then
    git clone https://github.com/12nick12/pwd.git
    cd plex-web-downloader
    npm install
  modify the file config.js, to put the path of the database plex
  example: / Users / yourUsername / Library / Application Support / Plex Media Server / Plug-in Support / Databases / com.plexapp.plugins.library.db
    npm start
  then open in your browser the address http: // localhost: 3000
** Under Ubuntu **
  prerequisites nodejs, or
    apt-get install nodejs
    ln -s / usr / bin / nodejs / usr / local / bin / node
  then move to your directory to install and:
    git clone https://github.com/12nick12/pwd.git
    cd plex-web-downloader
    npm install
  modify the file config.js, to put the path of the database plex
  Example: / home / yourUsername / plex-config / Plex Media Server / Plug-in Support / Databases / com.plexapp.plugins.library.db
    npm start
  then open in your browser the address http: // localhost: 3000
DEVELOPMENT
--------------------
** the project was originally created with **
    node install express -g
    node install express-generator -g
    express project_name
    cd project_name
    npm install
** to install plex (from a dockerfile) **
    mkdir ~ / plex-config
    sudo chown 797: 797 -R ~ / plex-config
    sudo docker -d --restart = always -v ~ / plex-config: / config -v ~ / Movies: / media / plex -p 32400: 32400 wernight / plex-media-server
    sudo chmod 777 ~ / plex-config / Plex \ Media \ Server / Plug-in / Support / Databases / *
    sudo chmod 777 ~ / Movies
    sudo ln -s ~ / Movies / media / plex
then configure your channels on: http: // localhost: 32400 / web / index.html
COMPILATION
--------------------
    npm install enclose -g
      enclose -o bin / mac_bin --loglevel info -c enclose_config.js -v 0.12.7 ./bin/www
TODO List
--------------------
* Manage thumbnail images
* Manage multi-source downloads by offering a link aria2 (see aria2.sourceforge.net)
* Integrated web ui: http://ziahamza.github.io/webui-aria2/
* Set up an upload limit that can be activated on demand

89
app.js
View File

@ -1,89 +0,0 @@
var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser');
var config = require('./config');
var app = express();
// view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'jade');
//password protection
if( typeof config.auth_user !== 'undefined' && typeof config.auth_password !== 'undefined' ){
console.log("SAFE MODE: votre serveur est protégé par mot de passe.");
var basicAuth = require('basic-auth');
app.use(function(req, res, next) {
var user = basicAuth(req);
if (!user || user.name !== config.auth_user || user.pass !== config.auth_password) {
res.set('WWW-Authenticate', 'Basic realm=Authorization Required');
return res.sendStatus(401);
}
else{
next();
}
});
}
else{
console.log("UNSAFE MODE: configurez un auth_user et auth_password dans le fichier config.js");
}
//send config to everyone
app.use(function(req, res, next) {
res.locals.config = config;
next();
});
app.use(favicon(path.join(__dirname, 'public', 'iconarchive_plex.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public')));
app.use('/pwd/', require('./routes/index'));
app.use('/pwd/users', require('./routes/users'));
app.use('/pwd/file', require('./routes/file'));
app.use('/pwd/channel', require('./routes/channel'));
app.use('/pwd/movie', require('./routes/movie'));
app.use('/pwd/show_list', require('./routes/show_list'));
app.use('/pwd/show', require('./routes/show'));
app.use('/pwd/divers', require('./routes/divers'));
// catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
});
// error handlers
// development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
}
// production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
});
module.exports = app;

114
bin/www
View File

@ -1,114 +0,0 @@
#!/usr/bin/env node
//One begins with the clustering
var cluster = require('cluster');
// Code to run if we're in the master process
if (cluster.isMaster) {
// Count the machine's CPUs
var cpuCount = require('os').cpus().length;
// Create a worker for each CPU
for (var i = 0; i < cpuCount; i += 1) {
console.log('Création du fork ' + i);
cluster.fork();
}
// Listen for dying workers
cluster.on('exit', function (worker) {
// Replace the dead worker, we're not sentimental
console.log('Worker ' + worker.id + ' died :(');
cluster.fork();
console.log('Remplacement du worker ');
});
// Code to run if we're in a worker process
} else {
/**
* Module dependencies.
*/
var app = require('../app');
var debug = require('debug')('plex_webdown:server');
var http = require('http');
/**
* Get port from environment and store in Express.
*/
var port = normalizePort(process.env.PORT || '3000');
app.set('port', port);
/**
* Create HTTP server.
*/
var server = http.createServer(app);
/**
* Listen on provided port, on all network interfaces.
*/
server.listen(port);
server.on('error', onError);
server.on('listening', onListening);
}
/**
* Normalize a port into a number, string, or false.
*/
function normalizePort(val) {
var port = parseInt(val, 10);
if (isNaN(port)) {
// named pipe
return val;
}
if (port >= 0) {
// port number
return port;
}
return false;
}
/**
* Event listener for HTTP server "error" event.
*/
function onError(error) {
if (error.syscall !== 'listen') {
throw error;
}
var bind = typeof port === 'string'
? 'Pipe ' + port
: 'Port ' + port;
// handle specific listen errors with friendly messages
switch (error.code) {
case 'EACCES':
console.error(bind + ' requires elevated privileges');
process.exit(1);
break;
case 'EADDRINUSE':
console.error(bind + ' is already in use');
process.exit(1);
break;
default:
throw error;
}
}
/**
* Event listener for HTTP server "listening" event.
*/
function onListening() {
var addr = server.address();
var bind = typeof addr === 'string'
? 'pipe ' + addr
: 'port ' + addr.port;
debug('Listening on ' + bind);
}

View File

@ -1,30 +0,0 @@
/*
Chercher votre fichier de base de données plex, grace à ces indications:
Windows Vista, Server 2008, Server 2008 R2, WHS 2011, Windows 7, Windows 8:
C:\\Users\\yourusername\\AppData\\Local\\Plex Media Server\\Plug-in\ Support\\Databases\\com.plexapp.plugins.library.db
Mac OS X:
~/Library/Application Support/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db
Windows XP, Server 2003, ou Home Server:
C:\Documents and Settings\yourusername\Local Settings\Application Data\Plex Media Server\Plug-in Support\Databases\com.plexapp.plugins.library.db
Docker
/home/username/plex-config/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db
*/
module.exports = {
database: "/home/antoine/plex-config/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db",
theme: "//cdnjs.cloudflare.com/ajax/libs/bootswatch/3.3.5/darkly/bootstrap.css",
presentation: "<h1>Bienvenue sur mon serveur</h1><p>Merci de respecter mon upload...</p>",
//auth_user: "monUser",
//auth_password: "monPassword",
init_db: function(){
var sqlite3 = require('sqlite3').verbose();
var db = new sqlite3.Database(this.database);
return db;
}
};

174
index.html Normal file
View File

@ -0,0 +1,174 @@
<!DOCTYPE html>
<html lang="en-us">
<head>
<meta charset="UTF-8">
<title>Plex-web-downloader by TwanoO67</title>
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" type="text/css" href="stylesheets/normalize.css" media="screen">
<link href='https://fonts.googleapis.com/css?family=Open+Sans:400,700' rel='stylesheet' type='text/css'>
<link rel="stylesheet" type="text/css" href="stylesheets/stylesheet.css" media="screen">
<link rel="stylesheet" type="text/css" href="stylesheets/github-light.css" media="screen">
</head>
<body>
<section class="page-header">
<h1 class="project-name">Plex-web-downloader</h1>
<h2 class="project-tagline"></h2>
<a href="https://github.com/TwanoO67/plex-web-downloader" class="btn">View on GitHub</a>
<a href="https://github.com/TwanoO67/plex-web-downloader/zipball/master" class="btn">Download .zip</a>
<a href="https://github.com/TwanoO67/plex-web-downloader/tarball/master" class="btn">Download .tar.gz</a>
</section>
<section class="main-content">
<h1>
<a id="plex-web-downloader" class="anchor" href="#plex-web-downloader" aria-hidden="true"><span class="octicon octicon-link"></span></a>Plex Web Downloader</h1>
<p>Ce projet permet de créer une liste de vos fichiers vidéo plex et de les partager aux travers d'une interface web.</p>
<h2>
<a id="installation" class="anchor" href="#installation" aria-hidden="true"><span class="octicon octicon-link"></span></a>INSTALLATION</h2>
<p><strong>Sur Windows</strong></p>
<p>pré requis, installer git ( <a href="https://git-scm.com/download/win">https://git-scm.com/download/win</a> )</p>
<p>pré requis, installer nodejs 0.12.x ( <a href="https://nodejs.org/dist/v0.12.7/">https://nodejs.org/dist/v0.12.7/</a> )</p>
<p>ouvrir l'invite de commande 'cmb', puis se deplacer dans un repertoire où vous voulez installer</p>
<pre><code>git clone https://github.com/TwanoO67/plex-web-downloader.git
cd plex-web-downloader
npm install
</code></pre>
<p>modifier le fichier config.js, pour y mettre le chemin de la base de données plex (attention il faut doubler les anti-slash et proteger les espaces )</p>
<p>exemple: C:\Users\yourUsername\AppData\Local\Plex\ Media\ Server\Plug-in\ Support\Databases\com.plexapp.plugins.library.db</p>
<pre><code>npm start
</code></pre>
<p>puis ouvrir dans votre navigateur l'adresse http://localhost:3000</p>
<p><strong>Sous MacOS</strong></p>
<p>pré requis, nodejs</p>
<p>sinon installer homebrew</p>
<pre><code>ruby -e "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)"
</code></pre>
<p>et :</p>
<pre><code>brew install node
git clone https://github.com/TwanoO67/plex-web-downloader.git
cd plex-web-downloader
npm install
</code></pre>
<p>modifier le fichier config.js, pour y mettre le chemin de la base de données plex</p>
<p>exemple: /Users/yourUsername/Library/Application Support/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db</p>
<pre><code>npm start
</code></pre>
<p>puis ouvrir dans votre navigateur l'adresse http://localhost:3000</p>
<p><strong>Sous Ubuntu</strong></p>
<p>pré requis nodejs, ou</p>
<pre><code>apt-get install nodejs
ln -s /usr/bin/nodejs /usr/local/bin/node
</code></pre>
<p>puis, se déplacer dans votre repertoire pour l'install et :</p>
<pre><code>git clone https://github.com/TwanoO67/plex-web-downloader.git
cd plex-web-downloader
npm install
</code></pre>
<p>modifier le fichier config.js, pour y mettre le chemin de la base de données plex</p>
<p>exemple: /home/yourUsername/plex-config/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db</p>
<pre><code>npm start
</code></pre>
<p>puis ouvrir dans votre navigateur l'adresse http://localhost:3000</p>
<h2>
<a id="developpement" class="anchor" href="#developpement" aria-hidden="true"><span class="octicon octicon-link"></span></a>DEVELOPPEMENT</h2>
<p><strong>le projet a été créée initialement avec</strong></p>
<pre><code>node install express -g
node install express-generator -g
express nom_du_projet
cd nom_du_projet
npm install
</code></pre>
<p><strong>pour installer plex (depuis un dockerfile)</strong></p>
<pre><code>mkdir ~/plex-config
sudo chown 797:797 -R ~/plex-config
sudo docker run -d --restart=always -v ~/plex-config:/config -v ~/Movies:/media/plex -p 32400:32400 wernight/plex-media-server
sudo chmod 777 ~/plex-config/Plex\ Media\ Server/Plug-in\ Support/Databases/*
sudo chmod 777 ~/Movies
sudo ln -s ~/Movies /media/plex
</code></pre>
<p>puis configurer vos chaines sur: http://localhost:32400/web/index.html</p>
<h2>
<a id="compilation" class="anchor" href="#compilation" aria-hidden="true"><span class="octicon octicon-link"></span></a>COMPILATION</h2>
<pre><code>npm install enclose -g
enclose -o bin/mac_bin --loglevel info -c enclose_config.js -v 0.12.7 ./bin/www
</code></pre>
<h2>
<a id="todo-liste" class="anchor" href="#todo-liste" aria-hidden="true"><span class="octicon octicon-link"></span></a>TODO Liste</h2>
<ul>
<li>Ajouter une présentation sur l'index, configurable dans config.js</li>
<li>Gérer les images des vignettes</li>
<li>Faire une page spéciales pour les séries</li>
<li>Gérer les téléchargements multi-source en proposant un lien aria2 (voir aria2.sourceforge.net)</li>
<li>Intégré web ui: <a href="http://ziahamza.github.io/webui-aria2/">http://ziahamza.github.io/webui-aria2/</a>
</li>
<li>Mettre en place une limite d'upload activable à la demande</li>
</ul>
<footer class="site-footer">
<span class="site-footer-owner"><a href="https://github.com/TwanoO67/plex-web-downloader">Plex-web-downloader</a> is maintained by <a href="https://github.com/TwanoO67">TwanoO67</a>.</span>
<span class="site-footer-credits">This page was generated by <a href="https://pages.github.com">GitHub Pages</a> using the <a href="https://github.com/jasonlong/cayman-theme">Cayman theme</a> by <a href="https://twitter.com/jasonlong">Jason Long</a>.</span>
</footer>
</section>
</body>
</html>

View File

@ -1,20 +0,0 @@
{
"name": "plex_webdown",
"version": "0.0.1",
"private": true,
"scripts": {
"start": "node ./bin/www"
},
"dependencies": {
"basic-auth": "^1.0.3",
"body-parser": "~1.13.2",
"cluster": "~0.7.7",
"cookie-parser": "~1.3.5",
"debug": "~2.2.0",
"express": "~4.13.1",
"jade": "~1.11.0",
"morgan": "~1.6.1",
"serve-favicon": "~2.3.0",
"sqlite3": "~3"
}
}

1
params.json Normal file
View File

@ -0,0 +1 @@
{"name":"Plex-web-downloader","tagline":"","body":"Plex Web Downloader\r\n===============\r\n\r\nCe projet permet de créer une liste de vos fichiers vidéo plex et de les partager aux travers d'une interface web.\r\n\r\n\r\nINSTALLATION\r\n--------------------\r\n\r\n**Sur Windows**\r\n\r\n pré requis, installer git ( https://git-scm.com/download/win )\r\n\r\n pré requis, installer nodejs 0.12.x ( https://nodejs.org/dist/v0.12.7/ )\r\n\r\n ouvrir l'invite de commande 'cmb', puis se deplacer dans un repertoire où vous voulez installer\r\n\r\n git clone https://github.com/TwanoO67/plex-web-downloader.git\r\n\r\n cd plex-web-downloader\r\n\r\n npm install\r\n\r\n modifier le fichier config.js, pour y mettre le chemin de la base de données plex (attention il faut doubler les anti-slash et proteger les espaces )\r\n\r\n exemple: C:\\\\Users\\\\yourUsername\\\\AppData\\\\Local\\\\Plex\\ Media\\ Server\\\\Plug-in\\ Support\\\\Databases\\\\com.plexapp.plugins.library.db\r\n\r\n npm start\r\n\r\n puis ouvrir dans votre navigateur l'adresse http://localhost:3000\r\n\r\n\r\n**Sous MacOS**\r\n\r\n pré requis, nodejs\r\n\r\n sinon installer homebrew\r\n\r\n ruby -e \"$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/master/install)\"\r\n\r\n et :\r\n\r\n brew install node\r\n\r\n git clone https://github.com/TwanoO67/plex-web-downloader.git\r\n\r\n cd plex-web-downloader\r\n\r\n npm install\r\n\r\n modifier le fichier config.js, pour y mettre le chemin de la base de données plex\r\n\r\n exemple: /Users/yourUsername/Library/Application Support/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db\r\n\r\n npm start\r\n\r\n puis ouvrir dans votre navigateur l'adresse http://localhost:3000\r\n\r\n\r\n**Sous Ubuntu**\r\n\r\n pré requis nodejs, ou\r\n\r\n apt-get install nodejs\r\n\r\n ln -s /usr/bin/nodejs /usr/local/bin/node\r\n\r\n puis, se déplacer dans votre repertoire pour l'install et :\r\n\r\n git clone https://github.com/TwanoO67/plex-web-downloader.git\r\n\r\n cd plex-web-downloader\r\n\r\n npm install\r\n\r\n modifier le fichier config.js, pour y mettre le chemin de la base de données plex\r\n\r\n exemple: /home/yourUsername/plex-config/Plex Media Server/Plug-in Support/Databases/com.plexapp.plugins.library.db\r\n\r\n npm start\r\n\r\n puis ouvrir dans votre navigateur l'adresse http://localhost:3000\r\n\r\n\r\n\r\nDEVELOPPEMENT\r\n--------------------\r\n\r\n**le projet a été créée initialement avec**\r\n\r\n node install express -g\r\n\r\n node install express-generator -g\r\n\r\n express nom_du_projet\r\n\r\n cd nom_du_projet\r\n\r\n npm install\r\n\r\n**pour installer plex (depuis un dockerfile)**\r\n\r\n mkdir ~/plex-config\r\n\r\n sudo chown 797:797 -R ~/plex-config\r\n\r\n sudo docker run -d --restart=always -v ~/plex-config:/config -v ~/Movies:/media/plex -p 32400:32400 wernight/plex-media-server\r\n\r\n sudo chmod 777 ~/plex-config/Plex\\ Media\\ Server/Plug-in\\ Support/Databases/*\r\n\r\n sudo chmod 777 ~/Movies\r\n\r\n sudo ln -s ~/Movies /media/plex\r\n\r\npuis configurer vos chaines sur: http://localhost:32400/web/index.html\r\n\r\n\r\nCOMPILATION\r\n--------------------\r\n\r\n npm install enclose -g\r\n\r\n enclose -o bin/mac_bin --loglevel info -c enclose_config.js -v 0.12.7 ./bin/www\r\n\r\n\r\nTODO Liste\r\n--------------------\r\n* Ajouter une présentation sur l'index, configurable dans config.js\r\n* Gérer les images des vignettes\r\n* Faire une page spéciales pour les séries\r\n* Gérer les téléchargements multi-source en proposant un lien aria2 (voir aria2.sourceforge.net)\r\n* Intégré web ui: http://ziahamza.github.io/webui-aria2/\r\n* Mettre en place une limite d'upload activable à la demande\r\n","google":"","note":"Don't delete this file! It's used internally to help with page regeneration."}

Binary file not shown.

Before

Width:  |  Height:  |  Size: 158 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 193 KiB

View File

@ -1,8 +0,0 @@
body {
padding: 50px;
font: 14px "Lucida Grande", Helvetica, Arial, sans-serif;
}
a {
color: #00B7FF;
}

View File

@ -1,60 +0,0 @@
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/:id', function(req, res, next) {
var config = res.locals.config;
var db = config.init_db();
var data = [];
var channel_info = [];
function addZero(v) {
return v.toString().replace(/^(\d)$/,'0$1');
};
function formatDuree(time) {
if(typeof time !== 'undefined' && time != "" && time > 0){
var d = new Date(time); // js fonctionne en milisecondes
return addZero(d.getHours()-1) + "h "+ addZero(d.getMinutes()) + "m "+ addZero(d.getSeconds()) + "s ";
}
else {
return "";
}
}
//we do all the basic operations following
db.serialize(function() {
//db.run("CREATE TABLE if not exists user_info (info TEXT)");
//var stmt = db.prepare("INSERT INTO user_info VALUES (?)");
//for (var i = 0; i < 10; i++) {
// stmt.run("Ipsum " + i);
//}
//stmt.finalize();
db.get("SELECT id, name, section_type as type"
+ " FROM library_sections WHERE id = ? ORDER BY name ASC",req.params.id, function(err, row) {
channel_info = row;
});
db.each("SELECT i.id as id, i.title as title, i.duration as second, i.year as year"
+ " FROM metadata_items i, media_items t "
+ " WHERE i.id = t.metadata_item_id AND i.title != '' AND t.library_section_id = ? "
+ " GROUP BY i.id",req.params.id, function(err, row) {
row.duree = formatDuree(row.second);
data.push(row);
},
//after all the operations of the database
function() {
res.render('channel', { title: 'List of videos',videos: data, channel: channel_info });
});
});
db.close();
});
module.exports = router;

View File

@ -1,69 +0,0 @@
var express = require('express');
var router = express.Router();
function secondsToString(seconds) {
seconds = Math.round(seconds);
var years = Math.floor(seconds / 31536000);
var max =2;
var current = 0;
var str = "";
if (years && current<max) {
str+= years + 'y ';
current++;
}
var days = Math.floor((seconds %= 31536000) / 86400);
if (days && current<max) {
str+= days + 'd ';
current++;
}
var hours = Math.floor((seconds %= 86400) / 3600);
if (hours && current<max) {
str+= hours + 'h ';
current++;
}
var minutes = Math.floor((seconds %= 3600) / 60);
if (minutes && current<max) {
str+= minutes + 'm ';
current++;
}
var seconds = seconds % 60;
if (seconds && current<max) {
str+= seconds + 's ';
current++;
}
return str;
}
/* GET home page. */
router.get('/', function(req, res, next) {
var config = res.locals.config;//require('../config');
var db = config.init_db();
/*var data = [];
//we do all the basic operations following
db.serialize(function() {
//db.run("CREATE TABLE if not exists user_info (info TEXT)");
//var stmt = db.prepare("INSERT INTO user_info VALUES (?)");
//for (var i = 0; i < 10; i++) {
// stmt.run("Ipsum " + i);
//}
//stmt.finalize();
db.each("SELECT id, name, section_type as type"
+ " FROM library_sections ORDER BY name ASC", function(err, row) {
data.push(row);
},
//aprés toute les opération de la base
function() {*/
res.render('divers', { title: 'Divers',/*channels: data,*/ presentation: config.presentation, uptime: secondsToString(process.uptime()) });
/*});
});
db.close();*/
});
module.exports = router;

View File

@ -1,46 +0,0 @@
var express = require('express');
var router = express.Router();
/* GET users listing. */
router.get('/:id/:filename', function (req, res, next) {
var config = res.locals.config;
var db = config.init_db();
//db.run("CREATE TABLE if not exists user_info (info TEXT)");
//var stmt = db.prepare("INSERT INTO user_info VALUES (?)");
//for (var i = 0; i < 10; i++) {
// stmt.run("Ipsum " + i);
//}
//stmt.finalize();
db.get("SELECT file FROM media_parts WHERE id = ?",req.params.id, function(err, row) {
var options = {
//root: /*__dirname +*/ '/public/',
dotfiles: 'deny',
headers: {
'x-timestamp': Date.now(),
'x-sent': true
}
};
var fileName = row.file;
res.sendFile(fileName , options, function (err) {
if (err) {
console.log(err);
res.status(err.status).end();
}
else {
console.log('Sent:', fileName);
}
});
});
db.close();
})
module.exports = router;

View File

@ -1,35 +0,0 @@
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/', function(req, res, next) {
var config = res.locals.config;//require('../config');
var db = config.init_db();
var data = [];
//we do all the basic operations following
db.serialize(function() {
//db.run("CREATE TABLE if not exists user_info (info TEXT)");
//var stmt = db.prepare("INSERT INTO user_info VALUES (?)");
//for (var i = 0; i < 10; i++) {
// stmt.run("Ipsum " + i);
//}
//stmt.finalize();
db.each("SELECT id, name, section_type as type"
+ " FROM library_sections ORDER BY name ASC", function(err, row) {
data.push(row);
},
//after all the operations of the database
function() {
res.render('index', { title: 'List of videos',channels: data, presentation: config.presentation });
});
});
db.close();
});
module.exports = router;

View File

@ -1,55 +0,0 @@
var express = require('express');
var router = express.Router();
function humanFileSize(bytes, si) {
var thresh = si ? 1000 : 1024;
if(Math.abs(bytes) < thresh) {
return bytes + ' B';
}
var units = si
? ['kB','MB','GB','TB','PB','EB','ZB','YB']
: ['KiB','MiB','GiB','TiB','PiB','EiB','ZiB','YiB'];
var u = -1;
do {
bytes /= thresh;
++u;
} while(Math.abs(bytes) >= thresh && u < units.length - 1);
return bytes.toFixed(1)+' '+units[u];
}
/* GET home page. */
router.get('/:id', function(req, res, next) {
var config = res.locals.config;
var db = config.init_db();
var data;
db.get("SELECT id,title,original_title,studio,rating,summary,duration,tags_genre,tags_star,year FROM metadata_items WHERE id = ?",req.params.id, function(err, row) {
row.tags_genre = row.tags_genre.split('|');
row.tags_star = row.tags_star.split('|');
row.rating = Math.round(row.rating,2);
row.file = [];
db.each("SELECT id,file,size,hash,duration FROM media_parts where media_item_id IN (SELECT id FROM media_items WHERE metadata_item_id = ? )",req.params.id, function(error, ligne) {
var tab = ligne.file.split('/');
var tab2 = tab[tab.length -1].split('\\');
var filename = tab2[tab2.length -1];
ligne.filename = filename;
ligne.size = humanFileSize(ligne.size,true);
row.file.push(ligne);
},function(){
res.render('movie', { title: 'Video Detail',movie: row });
});
});
db.close();
});
module.exports = router;

View File

@ -1,73 +0,0 @@
var express = require('express');
var router = express.Router();
function formatDuree(time) {
if(typeof time !== 'undefined' && time != "" && time > 0){
var d = new Date(time); // js fonctionne en milisecondes
return addZero(d.getHours()-1) + "h "+ addZero(d.getMinutes()) + "m "+ addZero(d.getSeconds()) + "s ";
}
else {
return "";
}
}
function addZero(v) {
return v.toString().replace(/^(\d)$/,'0$1');
};
/* GET home page. */
router.get('/:id/:incoming_chan', function(req, res, next) {
var config = res.locals.config;
var db = config.init_db();
var data = [];
//we do all the basic operations following
db.serialize(function() {
db.each("SELECT episode.id as id, episode.title as titre, episode.[index] as episode, episode.duration as second, season.[index] as saison, show.title as serie "+
"FROM metadata_items episode,metadata_items season,metadata_items show "+
"WHERE episode.parent_id=season.id AND season.parent_id = show.id AND show.id = ? ",req.params.id, function(err, row) {
/*//découpage des hints
var params = {};
var tab = row.hints.split('&');
tab.forEach(function(val,index,table){
var tab2 = val.split('=');
params[tab2[0]] = decodeURIComponent(tab2[1]);
});
row.info_meta = params;
*/
if(typeof row.episode !== '' && row.saison !== '' ){
row.season_episode = "S"+addZero(row.saison)+"E"+addZero(row.episode );
}
row.duree = formatDuree(row.second);
data.push(row);
},
function() {
//a la fin du foreach
});
db.close(function(){
//after all the operations of the database
var titre = "Série inexistante";
if(data.length > 0){
titre = 'Episode de '+data[0].serie;
}
res.render('show',{
title: titre,
videos: data,
channel_id: req.params.incoming_chan,
show_id: req.params.id
});
});
});
});
module.exports = router;

View File

@ -1,31 +0,0 @@
var express = require('express');
var router = express.Router();
/* GET home page. */
router.get('/:id', function(req, res, next) {
var config = res.locals.config;
var db = config.init_db();
var shows = [];
//we do all the basic operations following
db.serialize(function() {
db.each("SELECT id, title, year"
+ " FROM metadata_items "
+ " WHERE parent_id IS NULL AND library_section_id = ? "
,req.params.id, function(err, row) {
shows.push(row);
},
//after all the operations of the database
function(){
console.log(shows);
res.render('show_list', { title: 'List of series',shows: shows, channel_id: req.params.id });
});
});
db.close();
});
module.exports = router;

View File

@ -1,10 +0,0 @@
var express = require('express');
var router = express.Router();
/* GET users listing. */
router.get('/', function(req, res, next) {
var config = res.locals.config;
res.send('respond with a resource');
});
module.exports = router;

View File

@ -0,0 +1,116 @@
/*
Copyright 2014 GitHub Inc.
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
.pl-c /* comment */ {
color: #969896;
}
.pl-c1 /* constant, markup.raw, meta.diff.header, meta.module-reference, meta.property-name, support, support.constant, support.variable, variable.other.constant */,
.pl-s .pl-v /* string variable */ {
color: #0086b3;
}
.pl-e /* entity */,
.pl-en /* entity.name */ {
color: #795da3;
}
.pl-s .pl-s1 /* string source */,
.pl-smi /* storage.modifier.import, storage.modifier.package, storage.type.java, variable.other, variable.parameter.function */ {
color: #333;
}
.pl-ent /* entity.name.tag */ {
color: #63a35c;
}
.pl-k /* keyword, storage, storage.type */ {
color: #a71d5d;
}
.pl-pds /* punctuation.definition.string, string.regexp.character-class */,
.pl-s /* string */,
.pl-s .pl-pse .pl-s1 /* string punctuation.section.embedded source */,
.pl-sr /* string.regexp */,
.pl-sr .pl-cce /* string.regexp constant.character.escape */,
.pl-sr .pl-sra /* string.regexp string.regexp.arbitrary-repitition */,
.pl-sr .pl-sre /* string.regexp source.ruby.embedded */ {
color: #183691;
}
.pl-v /* variable */ {
color: #ed6a43;
}
.pl-id /* invalid.deprecated */ {
color: #b52a1d;
}
.pl-ii /* invalid.illegal */ {
background-color: #b52a1d;
color: #f8f8f8;
}
.pl-sr .pl-cce /* string.regexp constant.character.escape */ {
color: #63a35c;
font-weight: bold;
}
.pl-ml /* markup.list */ {
color: #693a17;
}
.pl-mh /* markup.heading */,
.pl-mh .pl-en /* markup.heading entity.name */,
.pl-ms /* meta.separator */ {
color: #1d3e81;
font-weight: bold;
}
.pl-mq /* markup.quote */ {
color: #008080;
}
.pl-mi /* markup.italic */ {
color: #333;
font-style: italic;
}
.pl-mb /* markup.bold */ {
color: #333;
font-weight: bold;
}
.pl-md /* markup.deleted, meta.diff.header.from-file */ {
background-color: #ffecec;
color: #bd2c00;
}
.pl-mi1 /* markup.inserted, meta.diff.header.to-file */ {
background-color: #eaffea;
color: #55a532;
}
.pl-mdr /* meta.diff.range */ {
color: #795da3;
font-weight: bold;
}
.pl-mo /* meta.output */ {
color: #1d3e81;
}

424
stylesheets/normalize.css vendored Normal file
View File

@ -0,0 +1,424 @@
/*! normalize.css v3.0.2 | MIT License | git.io/normalize */
/**
* 1. Set default font family to sans-serif.
* 2. Prevent iOS text size adjust after orientation change, without disabling
* user zoom.
*/
html {
font-family: sans-serif; /* 1 */
-ms-text-size-adjust: 100%; /* 2 */
-webkit-text-size-adjust: 100%; /* 2 */
}
/**
* Remove default margin.
*/
body {
margin: 0;
}
/* HTML5 display definitions
========================================================================== */
/**
* Correct `block` display not defined for any HTML5 element in IE 8/9.
* Correct `block` display not defined for `details` or `summary` in IE 10/11
* and Firefox.
* Correct `block` display not defined for `main` in IE 11.
*/
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
menu,
nav,
section,
summary {
display: block;
}
/**
* 1. Correct `inline-block` display not defined in IE 8/9.
* 2. Normalize vertical alignment of `progress` in Chrome, Firefox, and Opera.
*/
audio,
canvas,
progress,
video {
display: inline-block; /* 1 */
vertical-align: baseline; /* 2 */
}
/**
* Prevent modern browsers from displaying `audio` without controls.
* Remove excess height in iOS 5 devices.
*/
audio:not([controls]) {
display: none;
height: 0;
}
/**
* Address `[hidden]` styling not present in IE 8/9/10.
* Hide the `template` element in IE 8/9/11, Safari, and Firefox < 22.
*/
[hidden],
template {
display: none;
}
/* Links
========================================================================== */
/**
* Remove the gray background color from active links in IE 10.
*/
a {
background-color: transparent;
}
/**
* Improve readability when focused and also mouse hovered in all browsers.
*/
a:active,
a:hover {
outline: 0;
}
/* Text-level semantics
========================================================================== */
/**
* Address styling not present in IE 8/9/10/11, Safari, and Chrome.
*/
abbr[title] {
border-bottom: 1px dotted;
}
/**
* Address style set to `bolder` in Firefox 4+, Safari, and Chrome.
*/
b,
strong {
font-weight: bold;
}
/**
* Address styling not present in Safari and Chrome.
*/
dfn {
font-style: italic;
}
/**
* Address variable `h1` font-size and margin within `section` and `article`
* contexts in Firefox 4+, Safari, and Chrome.
*/
h1 {
font-size: 2em;
margin: 0.67em 0;
}
/**
* Address styling not present in IE 8/9.
*/
mark {
background: #ff0;
color: #000;
}
/**
* Address inconsistent and variable font size in all browsers.
*/
small {
font-size: 80%;
}
/**
* Prevent `sub` and `sup` affecting `line-height` in all browsers.
*/
sub,
sup {
font-size: 75%;
line-height: 0;
position: relative;
vertical-align: baseline;
}
sup {
top: -0.5em;
}
sub {
bottom: -0.25em;
}
/* Embedded content
========================================================================== */
/**
* Remove border when inside `a` element in IE 8/9/10.
*/
img {
border: 0;
}
/**
* Correct overflow not hidden in IE 9/10/11.
*/
svg:not(:root) {
overflow: hidden;
}
/* Grouping content
========================================================================== */
/**
* Address margin not present in IE 8/9 and Safari.
*/
figure {
margin: 1em 40px;
}
/**
* Address differences between Firefox and other browsers.
*/
hr {
box-sizing: content-box;
height: 0;
}
/**
* Contain overflow in all browsers.
*/
pre {
overflow: auto;
}
/**
* Address odd `em`-unit font size rendering in all browsers.
*/
code,
kbd,
pre,
samp {
font-family: monospace, monospace;
font-size: 1em;
}
/* Forms
========================================================================== */
/**
* Known limitation: by default, Chrome and Safari on OS X allow very limited
* styling of `select`, unless a `border` property is set.
*/
/**
* 1. Correct color not being inherited.
* Known issue: affects color of disabled elements.
* 2. Correct font properties not being inherited.
* 3. Address margins set differently in Firefox 4+, Safari, and Chrome.
*/
button,
input,
optgroup,
select,
textarea {
color: inherit; /* 1 */
font: inherit; /* 2 */
margin: 0; /* 3 */
}
/**
* Address `overflow` set to `hidden` in IE 8/9/10/11.
*/
button {
overflow: visible;
}
/**
* Address inconsistent `text-transform` inheritance for `button` and `select`.
* All other form control elements do not inherit `text-transform` values.
* Correct `button` style inheritance in Firefox, IE 8/9/10/11, and Opera.
* Correct `select` style inheritance in Firefox.
*/
button,
select {
text-transform: none;
}
/**
* 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
* and `video` controls.
* 2. Correct inability to style clickable `input` types in iOS.
* 3. Improve usability and consistency of cursor style between image-type
* `input` and others.
*/
button,
html input[type="button"], /* 1 */
input[type="reset"],
input[type="submit"] {
-webkit-appearance: button; /* 2 */
cursor: pointer; /* 3 */
}
/**
* Re-set default cursor for disabled elements.
*/
button[disabled],
html input[disabled] {
cursor: default;
}
/**
* Remove inner padding and border in Firefox 4+.
*/
button::-moz-focus-inner,
input::-moz-focus-inner {
border: 0;
padding: 0;
}
/**
* Address Firefox 4+ setting `line-height` on `input` using `!important` in
* the UA stylesheet.
*/
input {
line-height: normal;
}
/**
* It's recommended that you don't attempt to style these elements.
* Firefox's implementation doesn't respect box-sizing, padding, or width.
*
* 1. Address box sizing set to `content-box` in IE 8/9/10.
* 2. Remove excess padding in IE 8/9/10.
*/
input[type="checkbox"],
input[type="radio"] {
box-sizing: border-box; /* 1 */
padding: 0; /* 2 */
}
/**
* Fix the cursor style for Chrome's increment/decrement buttons. For certain
* `font-size` values of the `input`, it causes the cursor style of the
* decrement button to change from `default` to `text`.
*/
input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
height: auto;
}
/**
* 1. Address `appearance` set to `searchfield` in Safari and Chrome.
* 2. Address `box-sizing` set to `border-box` in Safari and Chrome
* (include `-moz` to future-proof).
*/
input[type="search"] {
-webkit-appearance: textfield; /* 1 */ /* 2 */
box-sizing: content-box;
}
/**
* Remove inner padding and search cancel button in Safari and Chrome on OS X.
* Safari (but not Chrome) clips the cancel button when the search input has
* padding (and `textfield` appearance).
*/
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
-webkit-appearance: none;
}
/**
* Define consistent border, margin, and padding.
*/
fieldset {
border: 1px solid #c0c0c0;
margin: 0 2px;
padding: 0.35em 0.625em 0.75em;
}
/**
* 1. Correct `color` not being inherited in IE 8/9/10/11.
* 2. Remove padding so people aren't caught out if they zero out fieldsets.
*/
legend {
border: 0; /* 1 */
padding: 0; /* 2 */
}
/**
* Remove default vertical scrollbar in IE 8/9/10/11.
*/
textarea {
overflow: auto;
}
/**
* Don't inherit the `font-weight` (applied by a rule above).
* NOTE: the default cannot safely be changed in Chrome and Safari on OS X.
*/
optgroup {
font-weight: bold;
}
/* Tables
========================================================================== */
/**
* Remove most spacing between table cells.
*/
table {
border-collapse: collapse;
border-spacing: 0;
}
td,
th {
padding: 0;
}

245
stylesheets/stylesheet.css Normal file
View File

@ -0,0 +1,245 @@
* {
box-sizing: border-box; }
body {
padding: 0;
margin: 0;
font-family: "Open Sans", "Helvetica Neue", Helvetica, Arial, sans-serif;
font-size: 16px;
line-height: 1.5;
color: #606c71; }
a {
color: #1e6bb8;
text-decoration: none; }
a:hover {
text-decoration: underline; }
.btn {
display: inline-block;
margin-bottom: 1rem;
color: rgba(255, 255, 255, 0.7);
background-color: rgba(255, 255, 255, 0.08);
border-color: rgba(255, 255, 255, 0.2);
border-style: solid;
border-width: 1px;
border-radius: 0.3rem;
transition: color 0.2s, background-color 0.2s, border-color 0.2s; }
.btn + .btn {
margin-left: 1rem; }
.btn:hover {
color: rgba(255, 255, 255, 0.8);
text-decoration: none;
background-color: rgba(255, 255, 255, 0.2);
border-color: rgba(255, 255, 255, 0.3); }
@media screen and (min-width: 64em) {
.btn {
padding: 0.75rem 1rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.btn {
padding: 0.6rem 0.9rem;
font-size: 0.9rem; } }
@media screen and (max-width: 42em) {
.btn {
display: block;
width: 100%;
padding: 0.75rem;
font-size: 0.9rem; }
.btn + .btn {
margin-top: 1rem;
margin-left: 0; } }
.page-header {
color: #fff;
text-align: center;
background-color: #159957;
background-image: linear-gradient(120deg, #155799, #159957); }
@media screen and (min-width: 64em) {
.page-header {
padding: 5rem 6rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.page-header {
padding: 3rem 4rem; } }
@media screen and (max-width: 42em) {
.page-header {
padding: 2rem 1rem; } }
.project-name {
margin-top: 0;
margin-bottom: 0.1rem; }
@media screen and (min-width: 64em) {
.project-name {
font-size: 3.25rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.project-name {
font-size: 2.25rem; } }
@media screen and (max-width: 42em) {
.project-name {
font-size: 1.75rem; } }
.project-tagline {
margin-bottom: 2rem;
font-weight: normal;
opacity: 0.7; }
@media screen and (min-width: 64em) {
.project-tagline {
font-size: 1.25rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.project-tagline {
font-size: 1.15rem; } }
@media screen and (max-width: 42em) {
.project-tagline {
font-size: 1rem; } }
.main-content :first-child {
margin-top: 0; }
.main-content img {
max-width: 100%; }
.main-content h1, .main-content h2, .main-content h3, .main-content h4, .main-content h5, .main-content h6 {
margin-top: 2rem;
margin-bottom: 1rem;
font-weight: normal;
color: #159957; }
.main-content p {
margin-bottom: 1em; }
.main-content code {
padding: 2px 4px;
font-family: Consolas, "Liberation Mono", Menlo, Courier, monospace;
font-size: 0.9rem;
color: #383e41;
background-color: #f3f6fa;
border-radius: 0.3rem; }
.main-content pre {
padding: 0.8rem;
margin-top: 0;
margin-bottom: 1rem;
font: 1rem Consolas, "Liberation Mono", Menlo, Courier, monospace;
color: #567482;
word-wrap: normal;
background-color: #f3f6fa;
border: solid 1px #dce6f0;
border-radius: 0.3rem; }
.main-content pre > code {
padding: 0;
margin: 0;
font-size: 0.9rem;
color: #567482;
word-break: normal;
white-space: pre;
background: transparent;
border: 0; }
.main-content .highlight {
margin-bottom: 1rem; }
.main-content .highlight pre {
margin-bottom: 0;
word-break: normal; }
.main-content .highlight pre, .main-content pre {
padding: 0.8rem;
overflow: auto;
font-size: 0.9rem;
line-height: 1.45;
border-radius: 0.3rem; }
.main-content pre code, .main-content pre tt {
display: inline;
max-width: initial;
padding: 0;
margin: 0;
overflow: initial;
line-height: inherit;
word-wrap: normal;
background-color: transparent;
border: 0; }
.main-content pre code:before, .main-content pre code:after, .main-content pre tt:before, .main-content pre tt:after {
content: normal; }
.main-content ul, .main-content ol {
margin-top: 0; }
.main-content blockquote {
padding: 0 1rem;
margin-left: 0;
color: #819198;
border-left: 0.3rem solid #dce6f0; }
.main-content blockquote > :first-child {
margin-top: 0; }
.main-content blockquote > :last-child {
margin-bottom: 0; }
.main-content table {
display: block;
width: 100%;
overflow: auto;
word-break: normal;
word-break: keep-all; }
.main-content table th {
font-weight: bold; }
.main-content table th, .main-content table td {
padding: 0.5rem 1rem;
border: 1px solid #e9ebec; }
.main-content dl {
padding: 0; }
.main-content dl dt {
padding: 0;
margin-top: 1rem;
font-size: 1rem;
font-weight: bold; }
.main-content dl dd {
padding: 0;
margin-bottom: 1rem; }
.main-content hr {
height: 2px;
padding: 0;
margin: 1rem 0;
background-color: #eff0f1;
border: 0; }
@media screen and (min-width: 64em) {
.main-content {
max-width: 64rem;
padding: 2rem 6rem;
margin: 0 auto;
font-size: 1.1rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.main-content {
padding: 2rem 4rem;
font-size: 1.1rem; } }
@media screen and (max-width: 42em) {
.main-content {
padding: 2rem 1rem;
font-size: 1rem; } }
.site-footer {
padding-top: 2rem;
margin-top: 2rem;
border-top: solid 1px #eff0f1; }
.site-footer-owner {
display: block;
font-weight: bold; }
.site-footer-credits {
color: #819198; }
@media screen and (min-width: 64em) {
.site-footer {
font-size: 1rem; } }
@media screen and (min-width: 42em) and (max-width: 64em) {
.site-footer {
font-size: 1rem; } }
@media screen and (max-width: 42em) {
.site-footer {
font-size: 0.9rem; } }

View File

@ -1,15 +0,0 @@
# /etc/systemd/system/pwd.service
# change user to someone whos not root
[Unit]
Description=pwd
After=network-online.target
[Service]
User=root
Type=simple
ExecStart=/usr/bin/npm start /opt/plex-web-downloader/
Restart=on-abort
[Install]
WantedBy=default.target

View File

@ -1,26 +0,0 @@
extends layout
block content
h1= channel.name
table(id="example", class="table table-striped table-bordered", cellspacing="0", width="100%")
thead
tr
th Name
th duration
th Year
tbody
each video, i in videos
tr
td
a(href="/pwd/movie/#{video.id}") #{video.title}&nbsp;
td= video.duration
td= video.year
script.
$(document).ready(function() {
$('#example').DataTable({
"language": {
"url": "//cdn.datatables.net/plug-ins/1.10.8/i18n/English.json"
}
});
});

View File

@ -1,21 +0,0 @@
extends layout
block content
h1= title
| Ce serveur http est open-source
br
br
| Venez participer au developpement ici:
br
br
a(href="https://github.com/TwanoO67/plex-web-downloader") GitHub
br
br
| Le serveur tourne depuis #{uptime}
br
br

View File

@ -1,6 +0,0 @@
extends layout
block content
h1= message
h2= error.status
pre #{error.stack}

View File

@ -1,16 +0,0 @@
extends layout
block content
if(presentation != '')
!{presentation}
h1= title
ul
each channel, i in channels
li
if(channel.type == 2)
a(href="/pwd/show_list/#{channel.id}")= channel.name
else
a(href="/pwd/channel/#{channel.id}")= channel.name

View File

@ -1,32 +0,0 @@
doctype html
html
head
title= title
meta(charset='UTF8')
link(rel='stylesheet', href='#{config.theme}')
link(rel='stylesheet', href='//cdn.datatables.net/1.10.9/css/dataTables.bootstrap.min.css')
script(type='text/javascript', src='//code.jquery.com/jquery-1.11.3.min.js')
script(type='text/javascript', src='//cdn.datatables.net/1.10.9/js/jquery.dataTables.min.js')
script(type='text/javascript', src='//cdn.datatables.net/1.10.9/js/dataTables.bootstrap.min.js')
body
nav.navbar.navbar-default.navbar-static-top.transparent(role="navigation")
div.container
div.navbar-header
button.navbar-toggle(type="button",data-toggle="collapse",data-target="#collapse-menu")
span.sr-only Toggle navigation
i.fa.fa-bars
a.navbar-brand(href="/pwd/")
b Plex&nbsp;
| Web Downloader
div#collapse-menu.collapse.navbar-collapse
ul.nav.navbar-nav.navbar-right
li.active
a(href="/pwd/") Home
li
a(href="/pwd/divers") Divers
div.wrapper
div.container
block content

View File

@ -1,35 +0,0 @@
extends layout
block content
h1= movie.title
a(href="#",onclick="window.history.back();") back to the list
br
br
label Note
p= movie.rating
label Download
br
each file, i in movie.file
a(href="/pwd/file/#{file.id}/#{file.filename}") #{file.size} #{file.filename}
br
br
label Résumé
p= movie.summary
br
br
label Genre
each tag, i in movie.tags_genre
if(tag!='')
span= tag
| &nbsp;
br
br
label Acteurs
each tag, i in movie.tags_star
if(tag!='')
span= tag
| &nbsp;
br

View File

@ -1,30 +0,0 @@
extends layout
block content
h1= title
a(href="/pwd/show_list/#{channel_id}") Back to the list of series
br
br
table(id="example", class="table table-striped table-bordered", cellspacing="0", width="100%")
thead
tr
th Name
th Season & Episode
th duration
tbody
each video, i in videos
tr
td
a(href="/pwd/movie/#{video.id}") #{video.titre}&nbsp;
td= video.season_episode
td= video.duration
script.
$(document).ready(function() {
$('#example').DataTable({
"language": {
"url": "//cdn.datatables.net/plug-ins/1.10.8/i18n/English.json"
}
});
});

View File

@ -1,24 +0,0 @@
extends layout
block content
h1= title
table(id="example", class="table table-striped table-bordered", cellspacing="0", width="100%")
thead
tr
th Series
th Year
tbody
each show, i in shows
tr
td
a(href="/pwd/show/#{show.id}/#{channel_id}")= show.title
td= show.year
script.
$(document).ready(function() {
$('#example').DataTable({
"language": {
"url": "//cdn.datatables.net/plug-ins/1.10.8/i18n/English.json"
}
});
});