Updated and moved update requests to /scripts
This commit is contained in:
@@ -11,7 +11,7 @@
|
|||||||
"test": "cross-env SEASONED_CONFIG=conf/test.json NODE_PATH=. mocha --require @babel/register --recursive test/unit test/system",
|
"test": "cross-env SEASONED_CONFIG=conf/test.json NODE_PATH=. mocha --require @babel/register --recursive test/unit test/system",
|
||||||
"coverage": "cross-env SEASONED_CONFIG=conf/test.json NODE_PATH=. nyc mocha --require @babel/register --recursive test && nyc report --reporter=text-lcov | coveralls",
|
"coverage": "cross-env SEASONED_CONFIG=conf/test.json NODE_PATH=. nyc mocha --require @babel/register --recursive test && nyc report --reporter=text-lcov | coveralls",
|
||||||
"lint": "./node_modules/.bin/eslint src/",
|
"lint": "./node_modules/.bin/eslint src/",
|
||||||
"update": "cross-env SEASONED_CONFIG=conf/development.json NODE_PATH=. node src/plex/updateRequestsInPlex.js",
|
"update": "cross-env SEASONED_CONFIG=conf/development.json NODE_PATH=. node scripts/updateRequestsInPlex.js",
|
||||||
"docs": "yarn apiDocs; yarn classDocs",
|
"docs": "yarn apiDocs; yarn classDocs",
|
||||||
"apiDocs": "",
|
"apiDocs": "",
|
||||||
"classDocs": "./script/generate-class-docs.sh"
|
"classDocs": "./script/generate-class-docs.sh"
|
||||||
|
|||||||
44
seasoned_api/scripts/updateRequestsInPlex.js
Normal file
44
seasoned_api/scripts/updateRequestsInPlex.js
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
const Plex = require("src/plex/plex");
|
||||||
|
const configuration = require("src/config/configuration").getInstance();
|
||||||
|
const plex = new Plex(configuration.get("plex", "ip"));
|
||||||
|
const establishedDatabase = require("src/database/database");
|
||||||
|
|
||||||
|
const queries = {
|
||||||
|
getRequestsNotYetInPlex: `SELECT * FROM requests WHERE status = 'requested' OR status = 'downloading'`,
|
||||||
|
saveNewStatus: `UPDATE requests SET status = ? WHERE id IS ? and type IS ?`
|
||||||
|
};
|
||||||
|
|
||||||
|
const getByStatus = () =>
|
||||||
|
establishedDatabase.all(queries.getRequestsNotYetInPlex);
|
||||||
|
|
||||||
|
const checkIfRequestExistInPlex = async request => {
|
||||||
|
request.existsInPlex = await plex.existsInPlex(request);
|
||||||
|
return request;
|
||||||
|
};
|
||||||
|
|
||||||
|
const commitNewStatus = (status, id, type, title) => {
|
||||||
|
console.log(type, title, "updated to:", status);
|
||||||
|
return establishedDatabase.run(queries.saveNewStatus, [status, id, type]);
|
||||||
|
};
|
||||||
|
|
||||||
|
const getNewRequestMatchesInPlex = async () => {
|
||||||
|
const requests = await getByStatus();
|
||||||
|
|
||||||
|
return Promise.all(requests.map(checkIfRequestExistInPlex))
|
||||||
|
.catch(error =>
|
||||||
|
console.log("error from checking plex for existance:", error)
|
||||||
|
)
|
||||||
|
.then(matchedRequests =>
|
||||||
|
matchedRequests.filter(request => request.existsInPlex)
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const updateMatchInDb = (match, status) => {
|
||||||
|
return commitNewStatus(status, match.id, match.type, match.title);
|
||||||
|
};
|
||||||
|
|
||||||
|
getNewRequestMatchesInPlex()
|
||||||
|
.then(newMatches =>
|
||||||
|
Promise.all(newMatches.map(match => updateMatchInDb(match, "downloaded")))
|
||||||
|
)
|
||||||
|
.then(() => process.exit(0));
|
||||||
@@ -1,47 +0,0 @@
|
|||||||
const Plex = require("src/plex/plex");
|
|
||||||
const configuration = require("src/config/configuration").getInstance();
|
|
||||||
const plex = new Plex(configuration.get("plex", "ip"));
|
|
||||||
const establishedDatabase = require("src/database/database");
|
|
||||||
|
|
||||||
class UpdateRequestsInPlex {
|
|
||||||
constructor() {
|
|
||||||
this.database = establishedDatabase;
|
|
||||||
this.queries = {
|
|
||||||
getMovies: `SELECT * FROM requests WHERE status = 'requested' OR status = 'downloading'`,
|
|
||||||
// getMovies: "select * from requests where status is 'reset'",
|
|
||||||
saveNewStatus: `UPDATE requests SET status = ? WHERE id IS ? and type IS ?`
|
|
||||||
};
|
|
||||||
}
|
|
||||||
getByStatus() {
|
|
||||||
return this.database.all(this.queries.getMovies);
|
|
||||||
}
|
|
||||||
scrub() {
|
|
||||||
return this.getByStatus().then(requests =>
|
|
||||||
Promise.all(requests.map(movie => plex.existsInPlex(movie)))
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
commitNewStatus(status, id, type, title) {
|
|
||||||
console.log(type, title, "updated to:", status);
|
|
||||||
this.database.run(this.queries.saveNewStatus, [status, id, type]);
|
|
||||||
}
|
|
||||||
|
|
||||||
updateStatus(status) {
|
|
||||||
this.getByStatus()
|
|
||||||
.then(requests =>
|
|
||||||
Promise.all(requests.map(request => plex.existsInPlex(request)))
|
|
||||||
)
|
|
||||||
.then(matchedRequests =>
|
|
||||||
matchedRequests.filter(request => request.existsInPlex)
|
|
||||||
)
|
|
||||||
.then(newMatches =>
|
|
||||||
newMatches.map(match =>
|
|
||||||
this.commitNewStatus(status, match.id, match.type, match.title)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
var requestsUpdater = new UpdateRequestsInPlex();
|
|
||||||
requestsUpdater.updateStatus("downloaded");
|
|
||||||
|
|
||||||
module.exports = UpdateRequestsInPlex;
|
|
||||||
Reference in New Issue
Block a user