123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227 |
- import config from "config";
- import async from "async";
- import axios from "axios";
- import { isAdminRequired } from "./hooks";
- import moduleManager from "../../index";
- const UtilsModule = moduleManager.modules.utils;
- const WSModule = moduleManager.modules.ws;
- const YouTubeModule = moduleManager.modules.youtube;
- export default {
- /**
- * Fetches a list of songs from Youtube's API
- *
- * @param {object} session - user session
- * @param {string} query - the query we'll pass to youtubes api
- * @param {Function} cb - callback
- * @returns {{status: string, data: object}} - returns an object
- */
- searchYoutube(session, query, cb) {
- return YouTubeModule.runJob("SEARCH", { query }, this)
- .then(data => {
- this.log("SUCCESS", "APIS_SEARCH_YOUTUBE", `Searching YouTube successful with query "${query}".`);
- return cb({ status: "success", data });
- })
- .catch(async err => {
- err = await UtilsModule.runJob("GET_ERROR", { error: err }, this);
- this.log("ERROR", "APIS_SEARCH_YOUTUBE", `Searching youtube failed with query "${query}". "${err}"`);
- return cb({ status: "error", message: err });
- });
- },
- /**
- * Fetches a specific page of search results from Youtube's API
- *
- * @param {object} session - user session
- * @param {string} query - the query we'll pass to youtubes api
- * @param {string} pageToken - identifies a specific page in the result set that should be retrieved
- * @param {Function} cb - callback
- * @returns {{status: string, data: object}} - returns an object
- */
- searchYoutubeForPage(session, query, pageToken, cb) {
- return YouTubeModule.runJob("SEARCH", { query, pageToken }, this)
- .then(data => {
- this.log(
- "SUCCESS",
- "APIS_SEARCH_YOUTUBE_FOR_PAGE",
- `Searching YouTube successful with query "${query}".`
- );
- return cb({ status: "success", data });
- })
- .catch(async err => {
- err = await UtilsModule.runJob("GET_ERROR", { error: err }, this);
- this.log(
- "ERROR",
- "APIS_SEARCH_YOUTUBE_FOR_PAGE",
- `Searching youtube failed with query "${query}". "${err}"`
- );
- return cb({ status: "error", message: err });
- });
- },
- /**
- * Gets Discogs data
- *
- * @param session
- * @param query - the query
- * @param {Function} cb
- */
- searchDiscogs: isAdminRequired(function searchDiscogs(session, query, page, cb) {
- async.waterfall(
- [
- next => {
- const options = {
- params: { q: query, per_page: 20, page },
- headers: {
- "User-Agent": "Request",
- Authorization: `Discogs key=${config.get("apis.discogs.client")}, secret=${config.get(
- "apis.discogs.secret"
- )}`
- }
- };
- axios
- .get("https://api.discogs.com/database/search", options)
- .then(res => next(null, res.data))
- .catch(err => next(err));
- }
- ],
- async (err, body) => {
- if (err) {
- err = await UtilsModule.runJob("GET_ERROR", { error: err }, this);
- this.log(
- "ERROR",
- "APIS_SEARCH_DISCOGS",
- `Searching discogs failed with query "${query}". "${err}"`
- );
- return cb({ status: "error", message: err });
- }
- this.log(
- "SUCCESS",
- "APIS_SEARCH_DISCOGS",
- `User "${session.userId}" searched Discogs succesfully for query "${query}".`
- );
- return cb({
- status: "success",
- data: {
- results: body.results,
- pages: body.pagination.pages
- }
- });
- }
- );
- }),
- /**
- * Joins a room
- *
- * @param {object} session - user session
- * @param {string} room - the room to join
- * @param {Function} cb - callback
- */
- joinRoom(session, room, cb) {
- if (
- room === "home" ||
- room === "news" ||
- room.startsWith("profile.") ||
- room.startsWith("manage-station.") ||
- room.startsWith("edit-song.") ||
- room.startsWith("view-report.")
- ) {
- WSModule.runJob("SOCKET_JOIN_ROOM", {
- socketId: session.socketId,
- room
- })
- .then(() => {})
- .catch(err => {
- this.log("ERROR", `Joining room failed: ${err.message}`);
- });
- }
- cb({ status: "success", message: "Successfully joined room." });
- },
- /**
- * Leaves a room
- *
- * @param {object} session - user session
- * @param {string} room - the room to leave
- * @param {Function} cb - callback
- */
- leaveRoom(session, room, cb) {
- if (
- room === "home" ||
- room.startsWith("profile.") ||
- room.startsWith("manage-station.") ||
- room.startsWith("edit-song.") ||
- room.startsWith("view-report.")
- ) {
- WSModule.runJob("SOCKET_LEAVE_ROOM", {
- socketId: session.socketId,
- room
- })
- .then(() => {})
- .catch(err => {
- this.log("ERROR", `Leaving room failed: ${err.message}`);
- });
- }
- cb({ status: "success", message: "Successfully left room." });
- },
- /**
- * Joins an admin room
- *
- * @param {object} session - user session
- * @param {string} page - the admin room to join
- * @param {Function} cb - callback
- */
- joinAdminRoom: isAdminRequired((session, page, cb) => {
- if (
- page === "unverifiedSongs" ||
- page === "songs" ||
- page === "hiddenSongs" ||
- page === "stations" ||
- page === "reports" ||
- page === "news" ||
- page === "playlists" ||
- page === "users" ||
- page === "statistics" ||
- page === "punishments"
- ) {
- WSModule.runJob("SOCKET_LEAVE_ROOMS", { socketId: session.socketId }).then(() => {
- WSModule.runJob("SOCKET_JOIN_ROOM", {
- socketId: session.socketId,
- room: `admin.${page}`
- });
- });
- }
- cb({ status: "success", message: "Successfully joined admin room." });
- }),
- /**
- * Leaves all rooms
- *
- * @param {object} session - user session
- * @param {Function} cb - callback
- */
- leaveRooms(session, cb) {
- WSModule.runJob("SOCKET_LEAVE_ROOMS", { socketId: session.socketId });
- cb({ status: "success", message: "Successfully left all rooms." });
- },
- /**
- * Returns current date
- *
- * @param {object} session - user session
- * @param {Function} cb - callback
- */
- ping(session, cb) {
- cb({ status: "success", message: "Successfully pinged.", data: { date: Date.now() } });
- }
- };
|