diff --git a/src/Api/dist/app.js b/src/Api/dist/app.js new file mode 100644 index 0000000..629f23c --- /dev/null +++ b/src/Api/dist/app.js @@ -0,0 +1,60 @@ +"use strict"; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const express_1 = __importDefault(require("express")); +// import compression from 'compression'; +const cors_1 = __importDefault(require("cors")); +// import ErrorMiddleware from './middleware/error.middleware'; +const body_parser_1 = __importDefault(require("body-parser")); +const mongoose_1 = __importDefault(require("mongoose")); +class App { + constructor(controllers, port) { + this.express = (0, express_1.default)(); + this.port = port; + this.dataBase = null; + this.initialiseDatabase(); + this.initialiseMiddleware(); + this.initialiseControllers(controllers); + // this.initialiseErrorHandling(); + } + initialiseMiddleware() { + // this.express.use(helmet()); + this.express.use((0, cors_1.default)()); + // this.express.use(morgan('dev')); + this.express.use(express_1.default.json()); + this.express.use(express_1.default.urlencoded({ extended: false })); + // this.express.use(compression()); + // mine + this.express.use(body_parser_1.default.json()); + this.express.use(body_parser_1.default.urlencoded({ + extended: true + })); + } + initialiseControllers(controllers) { + controllers.forEach((controller) => { + this.express.use('/api', controller.router); + this.express.get('/toto', (req, res) => { + res.send('Hello World!'); + }); + }); + } + // private initialiseErrorHandling(): void { + // this.express.use(ErrorMiddleware); + // } + listen() { + const server = this.express.listen(this.port, () => { + console.log(`⚡️[server] : App listening on the port ${this.port}`); + }); + } + initialiseDatabase() { + const { MONGO_USER, MONGO_PASSWORD, MONGO_PATH } = process.env; + const uri = "mongodb+srv://fladDevDb:ZslYlNRWIOUU7i6o@fladcluster.b29tytu.mongodb.net/?retryWrites=true&w=majority"; + mongoose_1.default.connect(uri) + .then(() => console.log("Connect to MongoDB database successfully")) + .catch(err => console.log("Error connecting : " + err)); + } +} +exports.default = App; +//# sourceMappingURL=app.js.map \ No newline at end of file diff --git a/src/Api/dist/app.js.map b/src/Api/dist/app.js.map new file mode 100644 index 0000000..3b2404e --- /dev/null +++ b/src/Api/dist/app.js.map @@ -0,0 +1 @@ +{"version":3,"file":"app.js","sourceRoot":"","sources":["../src/app.ts"],"names":[],"mappings":";;;;;AAAA,sDAA+C;AAC/C,yCAAyC;AACzC,gDAAwB;AAIxB,+DAA+D;AAC/D,8DAAqC;AACrC,wDAAgC;AAOhC,MAAM,GAAG;IAOL,YAAY,WAAyB,EAAE,IAAY;QAC/C,IAAI,CAAC,OAAO,GAAG,IAAA,iBAAO,GAAE,CAAC;QACzB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAC5B,IAAI,CAAC,qBAAqB,CAAC,WAAW,CAAC,CAAC;QAExC,kCAAkC;IACtC,CAAC;IAEO,oBAAoB;QACxB,8BAA8B;QAC9B,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAA,cAAI,GAAE,CAAC,CAAC;QACzB,mCAAmC;QACnC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QACjC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,iBAAO,CAAC,UAAU,CAAC,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAC1D,mCAAmC;QACnC,OAAO;QACP,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAU,CAAC,IAAI,EAAE,CAAC,CAAC;QACpC,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAU,CAAC,UAAU,CAAC;YACnC,QAAQ,EAAE,IAAI;SACf,CAAC,CAAC,CAAC;IAEV,CAAC;IAEO,qBAAqB,CAAC,WAAyB;QACnD,WAAW,CAAC,OAAO,CAAC,CAAC,UAAsB,EAAE,EAAE;YAC3C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,CAAC;YAC5C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,OAAO,EAAE,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;gBACnC,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;YAC3B,CAAC,CAAC,CAAA;QACR,CAAC,CAAC,CAAC;IACP,CAAC;IAED,4CAA4C;IAC5C,yCAAyC;IACzC,IAAI;IAEG,MAAM;QACT,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,EAAE;YAC/C,OAAO,CAAC,GAAG,CAAC,0CAA0C,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACvE,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,kBAAkB;QACtB,MAAM,EAAE,UAAU,EAAE,cAAc,EAAE,UAAU,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC;QAC/D,MAAM,GAAG,GAAG,uGAAuG,CAAA;QACnH,kBAAQ,CAAC,OAAO,CAAC,GAAG,CAAC;aACpB,IAAI,CAAC,GAAG,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,0CAA0C,CAAC,CAAC;aACnE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,qBAAqB,GAAE,GAAG,CAAE,CAAC,CAAC;IAC5D,CAAC;CAEJ;AAED,kBAAe,GAAG,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/controller/Icontroller.js b/src/Api/dist/controller/Icontroller.js new file mode 100644 index 0000000..b804bba --- /dev/null +++ b/src/Api/dist/controller/Icontroller.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=Icontroller.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/Icontroller.js.map b/src/Api/dist/controller/Icontroller.js.map new file mode 100644 index 0000000..b57d665 --- /dev/null +++ b/src/Api/dist/controller/Icontroller.js.map @@ -0,0 +1 @@ +{"version":3,"file":"Icontroller.js","sourceRoot":"","sources":["../../src/controller/Icontroller.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/controller/TestCtrl.js b/src/Api/dist/controller/TestCtrl.js new file mode 100644 index 0000000..b239e96 --- /dev/null +++ b/src/Api/dist/controller/TestCtrl.js @@ -0,0 +1,34 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const express_1 = require("express"); +class PingController { + constructor() { + this.path = '/ping'; + this.router = (0, express_1.Router)(); + this.initialiseRoutes(); + } + initialiseRoutes() { + this.router.get("/ping", (_req, res) => __awaiter(this, void 0, void 0, function* () { + const response = yield this.getMessage(); + return res.send(response); + })); + } + getMessage() { + return __awaiter(this, void 0, void 0, function* () { + return { + message: "pong", + }; + }); + } +} +exports.default = PingController; +//# sourceMappingURL=TestCtrl.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/TestCtrl.js.map b/src/Api/dist/controller/TestCtrl.js.map new file mode 100644 index 0000000..782b7d8 --- /dev/null +++ b/src/Api/dist/controller/TestCtrl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"TestCtrl.js","sourceRoot":"","sources":["../../src/controller/TestCtrl.ts"],"names":[],"mappings":";;;;;;;;;;;AAAA,qCAAiC;AAOjC,MAAqB,cAAc;IAI/B;QAHO,SAAI,GAAG,OAAO,CAAC;QACf,WAAM,GAAG,IAAA,gBAAM,GAAE,CAAC;QAGrB,IAAI,CAAC,gBAAgB,EAAE,CAAC;IAC5B,CAAC;IAEO,gBAAgB;QACpB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,OAAO,EAAE,CAAO,IAAI,EAAE,GAAG,EAAE,EAAE;YACzC,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;YACzC,OAAO,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC,CAAA,CAAC,CAAC;IACT,CAAC;IACK,UAAU;;YACZ,OAAO;gBACP,OAAO,EAAE,MAAM;aACd,CAAC;QACN,CAAC;KAAA;CACJ;AAnBD,iCAmBC"} \ No newline at end of file diff --git a/src/Api/dist/controller/chat-controller/chatCtrl.js b/src/Api/dist/controller/chat-controller/chatCtrl.js new file mode 100644 index 0000000..317becf --- /dev/null +++ b/src/Api/dist/controller/chat-controller/chatCtrl.js @@ -0,0 +1,85 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const express_1 = require("express"); +const httpExeption_1 = __importDefault(require("../../middleware/exeption/httpExeption")); +const UserService_1 = __importDefault(require("../../service/UserService")); +const UserValidation_1 = __importDefault(require("../../database/schema/User/UserValidation")); +const ValidatorMiddleware_1 = __importDefault(require("../../middleware/validation/ValidatorMiddleware")); +const authMiddleware_1 = __importDefault(require("../../middleware/authMiddleware")); +const LocationService_1 = __importDefault(require("../../service/LocationService")); +class UserController { + constructor() { + this.path = '/users'; + this.router = (0, express_1.Router)(); + this.userService = new UserService_1.default(); + this.locationService = new LocationService_1.default(); + this.register = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + try { + // the FladId should be created by the Userservice + const { name, email, password, idFlad, idSpotify } = req.body; + console.log(name, email, password, idFlad, idSpotify); + const token = yield this.userService.register(name, email, password, idFlad, idSpotify); + res.status(201).json({ token }); + } + catch (error) { + next(new httpExeption_1.default(400, error.message)); + } + }); + this.login = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + try { + const { email, password } = req.body; + const token = yield this.userService.login(email, password); + res.status(200).json({ token }); + } + catch (error) { + next(new httpExeption_1.default(400, error.message)); + } + }); + this.getUser = (req, res, next) => { + if (!req.user) { + return next(new httpExeption_1.default(404, 'No logged in user')); + } + res.status(200).send({ data: req.user }); + }; + this.getUserNext = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + try { + const longitude = Number(req.params.longitude); + const latitude = Number(req.params.latitude); + //verify::val_int(){ + console.log('woooooooooooooo' + req); + if (isNaN(longitude) || isNaN(latitude)) { + console.log('Impossible de convertir la chaîne en nombre'); + } + //} + const userId = req.user.idFlad; + const musicId = req.params.currentMusic; + const data = yield this.locationService.getNearUser(userId, musicId, latitude, longitude); + console.log(data); + res.status(201).send(data); + } + catch (error) { + next(new httpExeption_1.default(400, 'Cannot create get netUser')); + } + }); + this.initialiseRoutes(); + } + initialiseRoutes() { + this.router.post(`${this.path}/register`, (0, ValidatorMiddleware_1.default)(UserValidation_1.default.register), this.register); + this.router.post(`${this.path}/login`, (0, ValidatorMiddleware_1.default)(UserValidation_1.default.login), this.login); + this.router.get(`${this.path}`, authMiddleware_1.default, this.getUser); + } +} +exports.default = ChatController; +//# sourceMappingURL=chatCtrl.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/chat-controller/chatCtrl.js.map b/src/Api/dist/controller/chat-controller/chatCtrl.js.map new file mode 100644 index 0000000..0d9e995 --- /dev/null +++ b/src/Api/dist/controller/chat-controller/chatCtrl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"chatCtrl.js","sourceRoot":"","sources":["../../../src/controller/chat-controller/chatCtrl.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/src/Api/dist/controller/spot-controller/spotCtrl.js b/src/Api/dist/controller/spot-controller/spotCtrl.js new file mode 100644 index 0000000..646d480 --- /dev/null +++ b/src/Api/dist/controller/spot-controller/spotCtrl.js @@ -0,0 +1,208 @@ +// import Controller from '../Icontroller'; +// import { Router, Request, Response, NextFunction, RequestHandler } from 'express'; +// import HttpException from '../../middleware/exeption/httpExeption'; +// import axios from 'axios'; +// import AES from 'crypto-js' +// import querystring from 'querystring'; +// import qs from 'qs'; +// class SpotifyController implements Controller { +// public path = '/spot'; +// public router = Router(); +// constructor() { +// console.log("useeeee"); +// this.initialiseRoutes(); +// } +// initialiseRoutes() { +// // this.router.post(`${this.path}`,this.createTask); +// this.router.get(`${this.path}/likes/{user}/{id-spot}`,this.like); +// this.router.get(`${this.path}/callback`,this.getAccessToken); +// this.router.post(`${this.path}/refresh`,this.getRefreshToken); +// this.router.get(`${this.path}/spot`, this.getSpot); +// } +// // need to put in ENvironement file +// // private readonly CLIENT_CALLBACK_URL = "http://localhost:8080/callback"; +// private readonly API_URL = "https://accounts.spotify.com/api/token"; +// private readonly CLIENT_ID = "1f1e34e4b6ba48b388469dba80202b10"; +// private readonly CLIENT_SECRET = "779371c6d4994a68b8dd6e84b0873c82"; +// // private readonly CLIENT_CALLBACK_URL = "https://auth.expo.io/@thed47/FLAD//callback"; +// private readonly CALLBACK_2 = 'https://flad-api-production.up.railway.app/api/spotify/callback'; +// private readonly SCOPES ='user-read-private user-read-email user-read-playback-state user-read-currently-playing user-read-recently-played playlist-modify-public ugc-image-upload user-modify-playback-state'; +// private readonly ENCRYPTION_SECRET = new CryptString(16); +// private login = async ( +// req: Request, +// res: Response, +// next: NextFunction +// ): Promise => { +// console.log("useeeee== login"); +// try { +// // const params = req.body; +// // if (!params.refresh_token) { +// // return res.json({ +// // "error": "Parameter missing" +// // }); +// // } +// // this.spotifyRequest({ +// // grant_type: "authorization_code", +// // redirect_uri: this.CLIENT_CALLBACK_2, +// // // code: params.code +// // }) +// console.log("aloorrr si c'est niquuuuuuuuuuuueeee" +this.CALLBACK_2+ "gennnnnnnnnrree vraiiiiiiiment "); +// res.redirect('https://accounts.spotify.com/authorize?' + +// qs.stringify({ +// response_type: 'code', +// client_id: this.CLIENT_ID, +// scope: this.SCOPES, +// redirect_uri: this.CALLBACK_2, +// // state: this.ENCRYPTION_SECRET.stringCrypt +// })); +// // '?response_type=code' + +// // '&client_id=' + +// // "1f1e34e4b6ba48b388469dba80202b10" + +// // (this.SCOPES ? '&scope=' + encodeURIComponent(this.SCOPES) : '') + +// // '&redirect_uri=' + +// // encodeURIComponent(this.CALLBACK_2) +// // ); +// // .then(session => { +// // let result = { +// // "access_token": session.access_token, +// // "expires_in": session.expires_in, +// // "refresh_token": this.encrypt(session.refresh_token) +// // }; +// // return res.send(result); +// // }) +// // .catch(response => { +// // return res.json(response); +// // }); +// } catch (error) { +// next(new HttpException(400, 'Cannot create spot')); +// } +// }; +// private getRefreshToken = async ( +// req: Request, +// res: Response, +// next: NextFunction +// ): Promise => { +// console.log('UUse2'); +// try { +// const params = req.query.refresh_token; +// if (!req.query.refresh_token) { +// return res.json({ +// "error": "Parameter refresh_token missing" +// }); +// } +// var authOptions = { +// method: 'POST', +// url: 'https://accounts.spotify.com/api/token', +// data: qs.stringify({ +// grant_type: 'refresh_token', +// refresh_token: params +// }), +// headers: { +// 'Authorization': 'Basic ' + ( Buffer.from(this.CLIENT_ID + ':' + this.CLIENT_SECRET).toString('base64')), +// 'Content-Type' : 'application/x-www-form-urlencoded' +// }, +// json: true +// }; +// // request.post(authOptions, function(error, response, body) { +// // if (!error && response.statusCode === 200) { +// // var access_token = body.access_token; +// // res.send({ +// // 'access_token': access_token +// // }); +// // } +// // }); +// axios(authOptions) +// .then(session => { +// if(session.status === 200){ +// res.send({ +// "access_token": session.data.access_token, +// "expires_in": session.data.expires_in +// }); +// }}); +// console.log("goood"); +// } catch (error) { +// console.log("errur"); +// next(new HttpException(400, 'Cannot create post')); +// } +// } +// public getSpot = async ( +// req: Request, +// res: Response, +// next: NextFunction +// ): Promise => { +// const spots = [ +// { +// name: "blue", +// sourceUrl: "https://cdns-images.dzcdn.net/images/artist/399e7e760d8fedf3cc2891e9c0c41658/200x200-000000-80-0-0.jpg", +// index: 3 +// }, +// { +// name: "strange history", +// sourceUrl: "https://images.genius.com/339dfe2a7c0adf9a5d08febf29a845f4.1000x1000x1.jpg", +// index: 7 +// }, +// { +// name: "oboy album", +// sourceUrl: "https://i.pinimg.com/originals/ad/cc/d5/adccd58a0d0ff516a6114703cd05810e.jpg", +// index: 1 +// } +// ]; +// try { +// res.send(spots); +// } catch (error) { +// console.log('heuuuuuuuuuuuuuuuuuuuuubizzzaaarrreeee'); +// console.log(error); +// next(new HttpException(400, 'On peut pas avoir darray mec')); +// } } +// private getAccessToken = async ( +// req: Request, +// res: Response, +// next: NextFunction +// ): Promise => { +// console.log("useeeee== accesToken"); +// var code = req.query.code; +// var state = req.query.state || null; +// // var storedState = req.cookies ? req.cookies[stateKey] : null; +// var authOptions = { +// method: 'POST', +// url: 'https://accounts.spotify.com/api/token', +// data: qs.stringify({ +// code: code, +// redirect_uri: this.CALLBACK_2, +// grant_type: 'authorization_code' +// }), +// headers: { +// 'Authorization': 'Basic ' + ( Buffer.from(this.CLIENT_ID + ':' + this.CLIENT_SECRET).toString('base64')), +// 'Content-Type' : 'application/x-www-form-urlencoded' +// }, +// json: true +// }; +// try { +// var resp = await axios(authOptions); +// if (resp.status === 200) { +// console.log('oon esttt laaa'); +// var access_token = resp.data.access_token; +// var expiration =resp.data.expires_in; +// var refresh = resp.data.refresh_token +// console.log(access_token); +// // res.send({ +// // "access_token": access_token, +// // "expires_in": expiration, +// // "refresh" : refresh +// // }); +// res.redirect('/#'+ +// qs.stringify({ +// "access_token": access_token, +// "expires_in": expiration, +// "refreshuyjfguk" : refresh +// })); +// } +// } catch (error) { +// console.log('heuuuuuuuuuuuuuuuuuuuuubizzzaaarrreeee'); +// console.log(error); +// next(new HttpException(400, 'On peut pas te connecter mec'+ error.message)); +// } +// }; +// } +// export default SpotifyController; +//# sourceMappingURL=spotCtrl.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/spot-controller/spotCtrl.js.map b/src/Api/dist/controller/spot-controller/spotCtrl.js.map new file mode 100644 index 0000000..cb83353 --- /dev/null +++ b/src/Api/dist/controller/spot-controller/spotCtrl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"spotCtrl.js","sourceRoot":"","sources":["../../../src/controller/spot-controller/spotCtrl.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/src/Api/dist/controller/spotify-controller/crypt.js b/src/Api/dist/controller/spotify-controller/crypt.js new file mode 100644 index 0000000..2fdf1dc --- /dev/null +++ b/src/Api/dist/controller/spotify-controller/crypt.js @@ -0,0 +1,17 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +class CryptString { + constructor(length) { + this.stringCrypt = this.generateRandomString(length); + } + generateRandomString(length) { + var text = ''; + var possible = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789'; + for (var i = 0; i < length; i++) { + text += possible.charAt(Math.floor(Math.random() * possible.length)); + } + return text; + } +} +exports.default = CryptString; +//# sourceMappingURL=crypt.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/spotify-controller/crypt.js.map b/src/Api/dist/controller/spotify-controller/crypt.js.map new file mode 100644 index 0000000..76c08d1 --- /dev/null +++ b/src/Api/dist/controller/spotify-controller/crypt.js.map @@ -0,0 +1 @@ +{"version":3,"file":"crypt.js","sourceRoot":"","sources":["../../../src/controller/spotify-controller/crypt.ts"],"names":[],"mappings":";;AAAA,MAAqB,WAAW;IAI5B,YAAY,MAAe;QACvB,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,oBAAoB,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC;IACD,oBAAoB,CAAE,MAAe;QACjC,IAAI,IAAI,GAAG,EAAE,CAAC;QACd,IAAI,QAAQ,GAAG,gEAAgE,CAAC;QAEhF,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,MAAM,EAAE,CAAC,EAAE,EAAE;YAC/B,IAAI,IAAI,QAAQ,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM,EAAE,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC;SACtE;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;CACJ;AAhBD,8BAgBC"} \ No newline at end of file diff --git a/src/Api/dist/controller/spotify-controller/request/authReqBody.js b/src/Api/dist/controller/spotify-controller/request/authReqBody.js new file mode 100644 index 0000000..e9ba136 --- /dev/null +++ b/src/Api/dist/controller/spotify-controller/request/authReqBody.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=authReqBody.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/spotify-controller/request/authReqBody.js.map b/src/Api/dist/controller/spotify-controller/request/authReqBody.js.map new file mode 100644 index 0000000..7e5a006 --- /dev/null +++ b/src/Api/dist/controller/spotify-controller/request/authReqBody.js.map @@ -0,0 +1 @@ +{"version":3,"file":"authReqBody.js","sourceRoot":"","sources":["../../../../src/controller/spotify-controller/request/authReqBody.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/controller/spotify-controller/spotifyCtrl.js b/src/Api/dist/controller/spotify-controller/spotifyCtrl.js new file mode 100644 index 0000000..86823d3 --- /dev/null +++ b/src/Api/dist/controller/spotify-controller/spotifyCtrl.js @@ -0,0 +1,210 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const express_1 = require("express"); +const httpExeption_1 = __importDefault(require("../../middleware/exeption/httpExeption")); +const axios_1 = __importDefault(require("axios")); +const crypt_1 = __importDefault(require("./crypt")); +const qs_1 = __importDefault(require("qs")); +class SpotifyController { + constructor() { + this.path = '/spotify'; + this.router = (0, express_1.Router)(); + // need to put in ENvironement file + // private readonly CLIENT_CALLBACK_URL = "http://localhost:8080/callback"; + this.API_URL = "https://accounts.spotify.com/api/token"; + this.CLIENT_ID = "1f1e34e4b6ba48b388469dba80202b10"; + this.CLIENT_SECRET = "779371c6d4994a68b8dd6e84b0873c82"; + // private readonly CLIENT_CALLBACK_URL = "https://auth.expo.io/@thed47/FLAD//callback"; + this.CALLBACK_2 = 'https://flad-api-production.up.railway.app/api/spotify/callback'; + this.SCOPES = 'user-read-private user-read-email user-read-playback-state user-read-currently-playing user-read-recently-played playlist-modify-public ugc-image-upload user-modify-playback-state'; + this.ENCRYPTION_SECRET = new crypt_1.default(16); + this.login = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + console.log("useeeee== login"); + try { + // const params = req.body; + // if (!params.refresh_token) { + // return res.json({ + // "error": "Parameter missing" + // }); + // } + // this.spotifyRequest({ + // grant_type: "authorization_code", + // redirect_uri: this.CLIENT_CALLBACK_2, + // // code: params.code + // }) + console.log("aloorrr si c'est niquuuuuuuuuuuueeee" + this.CALLBACK_2 + "gennnnnnnnnrree vraiiiiiiiment "); + res.redirect('https://accounts.spotify.com/authorize?' + + qs_1.default.stringify({ + response_type: 'code', + client_id: this.CLIENT_ID, + scope: this.SCOPES, + redirect_uri: this.CALLBACK_2, + // state: this.ENCRYPTION_SECRET.stringCrypt + })); + // '?response_type=code' + + // '&client_id=' + + // "1f1e34e4b6ba48b388469dba80202b10" + + // (this.SCOPES ? '&scope=' + encodeURIComponent(this.SCOPES) : '') + + // '&redirect_uri=' + + // encodeURIComponent(this.CALLBACK_2) + // ); + // .then(session => { + // let result = { + // "access_token": session.access_token, + // "expires_in": session.expires_in, + // "refresh_token": this.encrypt(session.refresh_token) + // }; + // return res.send(result); + // }) + // .catch(response => { + // return res.json(response); + // }); + } + catch (error) { + next(new httpExeption_1.default(400, 'Cannot create spot')); + } + }); + this.getRefreshToken = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + console.log('UUse2'); + try { + const params = req.query.refresh_token; + if (!req.query.refresh_token) { + return res.json({ + "error": "Parameter refresh_token missing" + }); + } + var authOptions = { + method: 'POST', + url: 'https://accounts.spotify.com/api/token', + data: qs_1.default.stringify({ + grant_type: 'refresh_token', + refresh_token: params + }), + headers: { + 'Authorization': 'Basic ' + (Buffer.from(this.CLIENT_ID + ':' + this.CLIENT_SECRET).toString('base64')), + 'Content-Type': 'application/x-www-form-urlencoded' + }, + json: true + }; + // request.post(authOptions, function(error, response, body) { + // if (!error && response.statusCode === 200) { + // var access_token = body.access_token; + // res.send({ + // 'access_token': access_token + // }); + // } + // }); + (0, axios_1.default)(authOptions) + .then(session => { + if (session.status === 200) { + res.send({ + "access_token": session.data.access_token, + "expires_in": session.data.expires_in + }); + } + }); + console.log("goood"); + } + catch (error) { + console.log("errur"); + next(new httpExeption_1.default(400, 'Cannot create post')); + } + }); + this.getSpot = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + const spots = [ + { + name: "blue", + sourceUrl: "https://cdns-images.dzcdn.net/images/artist/399e7e760d8fedf3cc2891e9c0c41658/200x200-000000-80-0-0.jpg", + index: 3 + }, + { + name: "strange history", + sourceUrl: "https://images.genius.com/339dfe2a7c0adf9a5d08febf29a845f4.1000x1000x1.jpg", + index: 7 + }, + { + name: "oboy album", + sourceUrl: "https://i.pinimg.com/originals/ad/cc/d5/adccd58a0d0ff516a6114703cd05810e.jpg", + index: 1 + } + ]; + try { + res.send(spots); + } + catch (error) { + console.log('heuuuuuuuuuuuuuuuuuuuuubizzzaaarrreeee'); + console.log(error); + next(new httpExeption_1.default(400, 'On peut pas avoir darray mec')); + } + }); + this.getAccessToken = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + console.log("useeeee== accesToken"); + var code = req.query.code; + var state = req.query.state || null; + // var storedState = req.cookies ? req.cookies[stateKey] : null; + var authOptions = { + method: 'POST', + url: 'https://accounts.spotify.com/api/token', + data: qs_1.default.stringify({ + code: code, + redirect_uri: this.CALLBACK_2, + grant_type: 'authorization_code' + }), + headers: { + 'Authorization': 'Basic ' + (Buffer.from(this.CLIENT_ID + ':' + this.CLIENT_SECRET).toString('base64')), + 'Content-Type': 'application/x-www-form-urlencoded' + }, + json: true + }; + try { + var resp = yield (0, axios_1.default)(authOptions); + if (resp.status === 200) { + console.log('oon esttt laaa'); + var access_token = resp.data.access_token; + var expiration = resp.data.expires_in; + var refresh = resp.data.refresh_token; + console.log(access_token); + // res.send({ + // "access_token": access_token, + // "expires_in": expiration, + // "refresh" : refresh + // }); + res.redirect('/#' + + qs_1.default.stringify({ + "access_token": access_token, + "expires_in": expiration, + "refreshuyjfguk": refresh + })); + } + } + catch (error) { + console.log('heuuuuuuuuuuuuuuuuuuuuubizzzaaarrreeee'); + console.log(error); + next(new httpExeption_1.default(400, 'On peut pas te connecter mec' + error.message)); + } + }); + console.log("useeeee"); + this.initialiseRoutes(); + } + initialiseRoutes() { + // this.router.post(`${this.path}`,this.createTask); + this.router.get(`${this.path}/exchange`, this.login); + this.router.get(`${this.path}/callback`, this.getAccessToken); + this.router.post(`${this.path}/refresh`, this.getRefreshToken); + this.router.get(`${this.path}/spot`, this.getSpot); + } +} +exports.default = SpotifyController; +//# sourceMappingURL=spotifyCtrl.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/spotify-controller/spotifyCtrl.js.map b/src/Api/dist/controller/spotify-controller/spotifyCtrl.js.map new file mode 100644 index 0000000..77ca8d4 --- /dev/null +++ b/src/Api/dist/controller/spotify-controller/spotifyCtrl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"spotifyCtrl.js","sourceRoot":"","sources":["../../../src/controller/spotify-controller/spotifyCtrl.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/src/Api/dist/controller/user-controller/userCtrl.js b/src/Api/dist/controller/user-controller/userCtrl.js new file mode 100644 index 0000000..9156ab0 --- /dev/null +++ b/src/Api/dist/controller/user-controller/userCtrl.js @@ -0,0 +1,188 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const express_1 = require("express"); +const httpExeption_1 = __importDefault(require("../../middleware/exeption/httpExeption")); +const UserService_1 = __importDefault(require("../../service/UserService")); +const UserValidation_1 = __importDefault(require("../../database/schema/User/UserValidation")); +const ValidatorMiddleware_1 = __importDefault(require("../../middleware/validation/ValidatorMiddleware")); +const authMiddleware_1 = __importDefault(require("../../middleware/authMiddleware")); +const LocationService_1 = __importDefault(require("../../service/LocationService")); +class UserController { + constructor() { + this.path = '/users'; + this.router = (0, express_1.Router)(); + this.userService = new UserService_1.default(); + this.locationService = new LocationService_1.default(); + // private createUser = async ( + // req: Request, + // res: Response, + // next: NextFunction + // ): Promise => { + // try { + // console.log(req.body); + // const reqBody:CreateTaskReqBody = Object.assign({}, req.body); + // checkIfIsValidCreateTaskReqBody(reqBody); + // await this.userService.createUserById(reqBody.fin + // ); + // res.status(200).send({ status: "Success", msg: "Success add" }); + // } catch (error) { + // next(new HttpException(400, 'Cannot create post')); + // } + // }; + // private readonly getUserById: RequestHandler = async ( + // req: Request, + // res: Response, + // next: NextFunction + // ): Promise => { + // try { + // const id = req.params.taskId; + // const userId = req.params.userId; + // const data = await this.userService.getUserById(id, userId); + // res.status(201).send(data); + // } + // catch(error){ + // next(new HttpException(400, 'Cannot create post')); + // } + // } + // private readonly getAllUsers: RequestHandler = async ( + // req: Request, + // res: Response, + // next: NextFunction + // ): Promise => { + // try { + // const userId = req.params.userId; + // const tasks = await this.userService.getUsers(userId); + // const responseList = tasks.map(task => new TaskResumedRes(task)); + // res.status(201).send(responseList); + // } + // catch(error){ + // next(new HttpException(400, 'Cannot get user task')); + // } + // } + // private deleteUser = async ( + // req: Request, + // res: Response, + // next: NextFunction + // ): Promise => { + // try { + // const id = req.params.taskId; + // const userId = req.params.userId; + // await this.userService.DeleteUser(id, userId); + // return res.status(200).send({ status: "Success", msg: "Data Removed" }); + // } catch (error) { + // next(new HttpException(400, 'Cannot create post')); + // } + // }; + // private updateUser = async ( + // req: Request, + // res: Response, + // next: NextFunction + // ): Promise => { + // try { + // const taskId = req.params.taskId; + // const userId = req.params.userId; + // const reqBody:CreateTaskReqBody = Object.assign({}, req.body); + // const updatedTask = await this.userService.UpdateTask( + // // req.auth!.uid, + // taskId, + // userId, + // // firebase.auth().currentUser.getIdToken() + // reqBody.nom, + // reqBody.description, + // reqBody.logo, + // reqBody.duration, + // reqBody.done, + // // reqBody.tags, + // reqBody.repepat, + // reqBody.deb, + // reqBody.fin + // ); + // // res.send('Success add'); + // // res.status(201).json({ task }); + // res.status(204).send(`Update a new contact: ${updatedTask}`); + // } catch (error) { + // console.log(error); + // next(new HttpException(403, 'Cannot create post')); + // } + // }; + this.register = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + try { + // the FladId should be created by the Userservice + const { name, email, password, idFlad, idSpotify } = req.body; + console.log(name, email, password, idFlad, idSpotify); + const token = yield this.userService.register(name, email, password, idFlad, idSpotify); + res.status(201).json({ token }); + } + catch (error) { + next(new httpExeption_1.default(400, error.message)); + } + }); + this.login = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + try { + const { email, password } = req.body; + const token = yield this.userService.login(email, password); + res.status(200).json({ token }); + } + catch (error) { + next(new httpExeption_1.default(400, error.message)); + } + }); + this.getUser = (req, res, next) => { + if (!req.user) { + return next(new httpExeption_1.default(404, 'No logged in user')); + } + res.status(200).send({ data: req.user }); + }; + this.getUserNext = (req, res, next) => __awaiter(this, void 0, void 0, function* () { + try { + const longitude = Number(req.params.longitude); + const latitude = Number(req.params.latitude); + //verify::val_int(){ + console.log('woooooooooooooo' + req); + if (isNaN(longitude) || isNaN(latitude)) { + console.log('Impossible de convertir la chaîne en nombre'); + } + //} + const userId = req.user.idFlad; + const musicId = req.params.currentMusic; + const data = yield this.locationService.getNearUser(userId, musicId, latitude, longitude); + console.log(data); + res.status(201).send(data); + } + catch (error) { + next(new httpExeption_1.default(400, 'Cannot create get netUser')); + } + }); + this.initialiseRoutes(); + } + initialiseRoutes() { + this.router.post(`${this.path}/register`, (0, ValidatorMiddleware_1.default)(UserValidation_1.default.register), this.register); + this.router.post(`${this.path}/login`, (0, ValidatorMiddleware_1.default)(UserValidation_1.default.login), this.login); + this.router.get(`${this.path}`, authMiddleware_1.default, this.getUser); + this.router.get(`${this.path}/nextTo`, authMiddleware_1.default, this.getUserNext); + // //create + // this.router.post(`${this.path}`,this.createUser); + // // // get One + // this.router.get (`${this.path}/:userId`, this.getUserById); + // // // get All + // this.router.get (`${this.path}`, this.getAllUsers); + // //update One + // this.router.put (`${this.path}/:userId`, this.updateUser); + // //Delete One + // this.router.delete (`${this.path}/:userId`, this.deleteUser); + } +} +exports.default = UserController; +//# sourceMappingURL=userCtrl.js.map \ No newline at end of file diff --git a/src/Api/dist/controller/user-controller/userCtrl.js.map b/src/Api/dist/controller/user-controller/userCtrl.js.map new file mode 100644 index 0000000..45eff3c --- /dev/null +++ b/src/Api/dist/controller/user-controller/userCtrl.js.map @@ -0,0 +1 @@ +{"version":3,"file":"userCtrl.js","sourceRoot":"","sources":["../../../src/controller/user-controller/userCtrl.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/src/Api/dist/database/MongoDataBase.js b/src/Api/dist/database/MongoDataBase.js new file mode 100644 index 0000000..ea520c6 --- /dev/null +++ b/src/Api/dist/database/MongoDataBase.js @@ -0,0 +1,2 @@ +// export default db = new MongoClient(uri); +//# sourceMappingURL=MongoDataBase.js.map \ No newline at end of file diff --git a/src/Api/dist/database/MongoDataBase.js.map b/src/Api/dist/database/MongoDataBase.js.map new file mode 100644 index 0000000..2d7c3f5 --- /dev/null +++ b/src/Api/dist/database/MongoDataBase.js.map @@ -0,0 +1 @@ +{"version":3,"file":"MongoDataBase.js","sourceRoot":"","sources":["../../src/database/MongoDataBase.ts"],"names":[],"mappings":"AACA,4CAA4C"} \ No newline at end of file diff --git a/src/Api/dist/database/StrategyDatabase.js b/src/Api/dist/database/StrategyDatabase.js new file mode 100644 index 0000000..c376e83 --- /dev/null +++ b/src/Api/dist/database/StrategyDatabase.js @@ -0,0 +1 @@ +//# sourceMappingURL=StrategyDatabase.js.map \ No newline at end of file diff --git a/src/Api/dist/database/StrategyDatabase.js.map b/src/Api/dist/database/StrategyDatabase.js.map new file mode 100644 index 0000000..c04ad53 --- /dev/null +++ b/src/Api/dist/database/StrategyDatabase.js.map @@ -0,0 +1 @@ +{"version":3,"file":"StrategyDatabase.js","sourceRoot":"","sources":["../../src/database/StrategyDatabase.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/database/schema/LocationSchema.js b/src/Api/dist/database/schema/LocationSchema.js new file mode 100644 index 0000000..40dfc76 --- /dev/null +++ b/src/Api/dist/database/schema/LocationSchema.js @@ -0,0 +1,26 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const mongoose_1 = require("mongoose"); +const locationSchema = new mongoose_1.Schema({ + idFlad: { + type: String, + required: true, + unique: true, + }, + musicId: { + type: String, + required: true, + }, + latitude: { + type: Number, + required: true, + }, + longitude: { + type: Number, + required: true, + }, +}, { timestamps: true }); +// fladDevDb +// ZslYlNRWIOUU7i6o +exports.default = (0, mongoose_1.model)('Location', locationSchema); +//# sourceMappingURL=LocationSchema.js.map \ No newline at end of file diff --git a/src/Api/dist/database/schema/LocationSchema.js.map b/src/Api/dist/database/schema/LocationSchema.js.map new file mode 100644 index 0000000..38457b6 --- /dev/null +++ b/src/Api/dist/database/schema/LocationSchema.js.map @@ -0,0 +1 @@ +{"version":3,"file":"LocationSchema.js","sourceRoot":"","sources":["../../../src/database/schema/LocationSchema.ts"],"names":[],"mappings":";;AAAA,uCAAkD;AAGlD,MAAM,cAAc,GAAG,IAAI,iBAAM,CAC7B;IAEI,MAAM,EAAE;QACJ,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,IAAI;KACf;IACD,OAAO,EAAE;QACL,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;KACjB;IACD,QAAQ,EAAE;QACN,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;KACjB;IACD,SAAS,EAAE;QACP,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;KACjB;CAGJ,EACD,EAAE,UAAU,EAAE,IAAI,EAAE,CACvB,CAAC;AAEF,YAAY;AACZ,mBAAmB;AACnB,kBAAe,IAAA,gBAAK,EAAY,UAAU,EAAE,cAAc,CAAC,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/database/schema/NotificationSchema.js b/src/Api/dist/database/schema/NotificationSchema.js new file mode 100644 index 0000000..bb42953 --- /dev/null +++ b/src/Api/dist/database/schema/NotificationSchema.js @@ -0,0 +1,9 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +const mongoose_1 = require("mongoose"); +const notificationSchema = new mongoose_1.Schema({ + type: { type: String, required: true }, + content: { type: String, required: true } +}); +exports.default = { Notification: (0, mongoose_1.model)("nofitication", notificationSchema) }; +//# sourceMappingURL=NotificationSchema.js.map \ No newline at end of file diff --git a/src/Api/dist/database/schema/NotificationSchema.js.map b/src/Api/dist/database/schema/NotificationSchema.js.map new file mode 100644 index 0000000..ed407fc --- /dev/null +++ b/src/Api/dist/database/schema/NotificationSchema.js.map @@ -0,0 +1 @@ +{"version":3,"file":"NotificationSchema.js","sourceRoot":"","sources":["../../../src/database/schema/NotificationSchema.ts"],"names":[],"mappings":";;AAAA,uCAAyC;AAEzC,MAAM,kBAAkB,GAAG,IAAI,iBAAM,CAAC;IAClC,IAAI,EAAE,EAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAC;IACpC,OAAO,EAAE,EAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAC;CAC1C,CAAC,CAAC;AAEH,kBAAe,EAAC,YAAY,EAAE,IAAA,gBAAK,EAAC,cAAc,EAAE,kBAAkB,CAAC,EAAC,CAAA"} \ No newline at end of file diff --git a/src/Api/dist/database/schema/Token/IToken.js b/src/Api/dist/database/schema/Token/IToken.js new file mode 100644 index 0000000..af0fc56 --- /dev/null +++ b/src/Api/dist/database/schema/Token/IToken.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=IToken.js.map \ No newline at end of file diff --git a/src/Api/dist/database/schema/Token/IToken.js.map b/src/Api/dist/database/schema/Token/IToken.js.map new file mode 100644 index 0000000..c2c2353 --- /dev/null +++ b/src/Api/dist/database/schema/Token/IToken.js.map @@ -0,0 +1 @@ +{"version":3,"file":"IToken.js","sourceRoot":"","sources":["../../../../src/database/schema/Token/IToken.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/database/schema/User/UserInterface.js b/src/Api/dist/database/schema/User/UserInterface.js new file mode 100644 index 0000000..01d113f --- /dev/null +++ b/src/Api/dist/database/schema/User/UserInterface.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=UserInterface.js.map \ No newline at end of file diff --git a/src/Api/dist/database/schema/User/UserInterface.js.map b/src/Api/dist/database/schema/User/UserInterface.js.map new file mode 100644 index 0000000..5d59c31 --- /dev/null +++ b/src/Api/dist/database/schema/User/UserInterface.js.map @@ -0,0 +1 @@ +{"version":3,"file":"UserInterface.js","sourceRoot":"","sources":["../../../../src/database/schema/User/UserInterface.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/database/schema/User/UserSchema.js b/src/Api/dist/database/schema/User/UserSchema.js new file mode 100644 index 0000000..5af36a4 --- /dev/null +++ b/src/Api/dist/database/schema/User/UserSchema.js @@ -0,0 +1,82 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const mongoose_1 = require("mongoose"); +const bcrypt_1 = __importDefault(require("bcrypt")); +// const userSchema: Schema = new Schema({ +// pseudo: {type: String, index: { unique: true }}, +// email: {type: String}, +// idDafl: {type: String, index: { unique: true }}, +// idSpotify: {type: String}, +// password: {type: String}, +// prenom: {type: String, default: ""}, +// description: {type: String, default: ""}, +// nom: {type: String, default: ""}, +// ville: {type: String, default: ""}, +// profilPic: {type: String}, +// noteList: [], +// notifications: [], +// friends: {type: [String] }, +// favoris: [], +// conversations: {type: [String] } +// }); +const userSchema = new mongoose_1.Schema({ + idFlad: { + type: String, + required: true, + unique: true, + }, + idSpotify: { + type: String, + required: true, + unique: true, + }, + name: { + type: String, + required: true, + }, + email: { + type: String, + required: true, + // this mean that we identify user by email + unique: true, + // delete the whitespace + trim: true, + }, + password: { + type: String, + }, +}, { timestamps: true }); +// this means that we hash the user password before saving it to the database +userSchema.pre('save', function (next) { + return __awaiter(this, void 0, void 0, function* () { + if (!this.isModified('password')) { + //just had that to be sure that the api still going + return next(); + } + const hash = yield bcrypt_1.default.hash(this.password, 8); + this.password = hash; + next(); + }); +}); +userSchema.methods.isValidPassword = function (password) { + return __awaiter(this, void 0, void 0, function* () { + return yield bcrypt_1.default.compare(password, this.password); + }); +}; +// fladDevDb +// ZslYlNRWIOUU7i6o +exports.default = (0, mongoose_1.model)('User', userSchema); +// export const User: Model = model('User', userSchema); +//# sourceMappingURL=UserSchema.js.map \ No newline at end of file diff --git a/src/Api/dist/database/schema/User/UserSchema.js.map b/src/Api/dist/database/schema/User/UserSchema.js.map new file mode 100644 index 0000000..80388e0 --- /dev/null +++ b/src/Api/dist/database/schema/User/UserSchema.js.map @@ -0,0 +1 @@ +{"version":3,"file":"UserSchema.js","sourceRoot":"","sources":["../../../../src/database/schema/User/UserSchema.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAEA,uCAAyC;AACzC,oDAA4B;AAC5B,iDAAiD;AACjD,uDAAuD;AACvD,6BAA6B;AAC7B,uDAAuD;AACvD,iCAAiC;AACjC,gCAAgC;AAChC,2CAA2C;AAC3C,gDAAgD;AAChD,wCAAwC;AACxC,0CAA0C;AAC1C,iCAAiC;AACjC,oBAAoB;AACpB,yBAAyB;AACzB,kCAAkC;AAClC,mBAAmB;AACnB,uCAAuC;AACvC,MAAM;AAEN,MAAM,UAAU,GAAG,IAAI,iBAAM,CACzB;IAEI,MAAM,EAAE;QACJ,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,IAAI;KACf;IACD,SAAS,EAAE;QACP,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;QACd,MAAM,EAAE,IAAI;KACf;IACD,IAAI,EAAE;QACF,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;KACjB;IACD,KAAK,EAAE;QACH,IAAI,EAAE,MAAM;QACZ,QAAQ,EAAE,IAAI;QACd,2CAA2C;QAC3C,MAAM,EAAE,IAAI;QACZ,wBAAwB;QACxB,IAAI,EAAE,IAAI;KACb;IACD,QAAQ,EAAE;QACN,IAAI,EAAE,MAAM;KACf;CAEJ,EACD,EAAE,UAAU,EAAE,IAAI,EAAE,CACvB,CAAC;AAEF,6EAA6E;AAC7E,UAAU,CAAC,GAAG,CAAQ,MAAM,EAAE,UAAgB,IAAI;;QAC9C,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,UAAU,CAAC,EAAE;YAC9B,mDAAmD;YACnD,OAAO,IAAI,EAAE,CAAC;SACjB;QAED,MAAM,IAAI,GAAG,MAAM,gBAAM,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;QAEjD,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QAErB,IAAI,EAAE,CAAC;IACX,CAAC;CAAA,CAAC,CAAC;AAEH,UAAU,CAAC,OAAO,CAAC,eAAe,GAAG,UACjC,QAAgB;;QAEhB,OAAO,MAAM,gBAAM,CAAC,OAAO,CAAC,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IACzD,CAAC;CAAA,CAAC;AAEF,YAAY;AACZ,mBAAmB;AACnB,kBAAe,IAAA,gBAAK,EAAQ,MAAM,EAAE,UAAU,CAAC,CAAC;AAChD,+DAA+D"} \ No newline at end of file diff --git a/src/Api/dist/database/schema/User/UserValidation.js b/src/Api/dist/database/schema/User/UserValidation.js new file mode 100644 index 0000000..cd0111a --- /dev/null +++ b/src/Api/dist/database/schema/User/UserValidation.js @@ -0,0 +1,20 @@ +"use strict"; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const joi_1 = __importDefault(require("joi")); +const register = joi_1.default.object({ + name: joi_1.default.string().max(30).required(), + email: joi_1.default.string().email().required(), + password: joi_1.default.string().min(6).required(), + // can add an field like confimPassword and cheked that the password is equal to the confirmPassword + idSpotify: joi_1.default.string(), + idFlad: joi_1.default.string(), +}); +const login = joi_1.default.object({ + email: joi_1.default.string().email().required(), + password: joi_1.default.string().required(), +}); +exports.default = { register, login }; +//# sourceMappingURL=UserValidation.js.map \ No newline at end of file diff --git a/src/Api/dist/database/schema/User/UserValidation.js.map b/src/Api/dist/database/schema/User/UserValidation.js.map new file mode 100644 index 0000000..34d24e7 --- /dev/null +++ b/src/Api/dist/database/schema/User/UserValidation.js.map @@ -0,0 +1 @@ +{"version":3,"file":"UserValidation.js","sourceRoot":"","sources":["../../../../src/database/schema/User/UserValidation.ts"],"names":[],"mappings":";;;;;AAAA,8CAAsB;AAEtB,MAAM,QAAQ,GAAG,aAAG,CAAC,MAAM,CAAC;IACxB,IAAI,EAAE,aAAG,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,QAAQ,EAAE;IAErC,KAAK,EAAE,aAAG,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE;IAEtC,QAAQ,EAAE,aAAG,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,EAAE;IACxC,oGAAoG;IACpG,SAAS,EAAE,aAAG,CAAC,MAAM,EAAE;IACvB,MAAM,EAAG,aAAG,CAAC,MAAM,EAAE;CACxB,CAAC,CAAC;AAEH,MAAM,KAAK,GAAG,aAAG,CAAC,MAAM,CAAC;IACrB,KAAK,EAAE,aAAG,CAAC,MAAM,EAAE,CAAC,KAAK,EAAE,CAAC,QAAQ,EAAE;IACtC,QAAQ,EAAE,aAAG,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACpC,CAAC,CAAC;AAEH,kBAAe,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/index.js b/src/Api/dist/index.js new file mode 100644 index 0000000..632b661 --- /dev/null +++ b/src/Api/dist/index.js @@ -0,0 +1,14 @@ +"use strict"; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const app_1 = __importDefault(require("./app")); +const spotifyCtrl_1 = __importDefault(require("./controller/spotify-controller/spotifyCtrl")); +const TestCtrl_1 = __importDefault(require("./controller/TestCtrl")); +const userCtrl_1 = __importDefault(require("./controller/user-controller/userCtrl")); +const dotenv_1 = __importDefault(require("dotenv")); +dotenv_1.default.config(); +const app = new app_1.default([new TestCtrl_1.default(), new spotifyCtrl_1.default(), new userCtrl_1.default()], Number(process.env.PORT)); +app.listen(); +//# sourceMappingURL=index.js.map \ No newline at end of file diff --git a/src/Api/dist/index.js.map b/src/Api/dist/index.js.map new file mode 100644 index 0000000..3d14e47 --- /dev/null +++ b/src/Api/dist/index.js.map @@ -0,0 +1 @@ +{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":";;;;;AAAA,gDAAwB;AACxB,8FAA4E;AAC5E,qEAAmD;AACnD,qFAAmE;AACnE,oDAA2B;AAC3B,gBAAM,CAAC,MAAM,EAAE,CAAC;AAChB,MAAM,GAAG,GAAG,IAAI,aAAG,CACf,CAAC,IAAI,kBAAc,EAAE,EAAE,IAAI,qBAAiB,EAAE,EAAE,IAAI,kBAAc,EAAE,CAAC,EACrE,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAE3B,CAAC;AAEF,GAAG,CAAC,MAAM,EAAE,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/middleware/authMiddleware.js b/src/Api/dist/middleware/authMiddleware.js new file mode 100644 index 0000000..24ac50e --- /dev/null +++ b/src/Api/dist/middleware/authMiddleware.js @@ -0,0 +1,46 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const jsonwebtoken_1 = __importDefault(require("jsonwebtoken")); +const UserSchema_1 = __importDefault(require("../database/schema/User/UserSchema")); +const token_1 = __importDefault(require("../model/token")); +const httpExeption_1 = __importDefault(require("./exeption/httpExeption")); +function authenticatedMiddleware(req, res, next) { + return __awaiter(this, void 0, void 0, function* () { + const bearer = req.headers.authorization; + if (!bearer || !bearer.startsWith('Bearer ')) { + return next(new httpExeption_1.default(401, 'Unauthorised')); + } + const accessToken = bearer.split('Bearer ')[1].trim(); + try { + const payload = yield token_1.default.verifyToken(accessToken); + if (payload instanceof jsonwebtoken_1.default.JsonWebTokenError) { + return next(new httpExeption_1.default(401, 'Unauthorised')); + } + const user = yield UserSchema_1.default.findById(payload.id) + .select('-password') + .exec(); + if (!user) { + return next(new httpExeption_1.default(401, 'Unauthorised')); + } + req.user = user; + return next(); + } + catch (error) { + return next(new httpExeption_1.default(401, 'Unauthorised')); + } + }); +} +exports.default = authenticatedMiddleware; +//# sourceMappingURL=authMiddleware.js.map \ No newline at end of file diff --git a/src/Api/dist/middleware/authMiddleware.js.map b/src/Api/dist/middleware/authMiddleware.js.map new file mode 100644 index 0000000..77d6a84 --- /dev/null +++ b/src/Api/dist/middleware/authMiddleware.js.map @@ -0,0 +1 @@ +{"version":3,"file":"authMiddleware.js","sourceRoot":"","sources":["../../src/middleware/authMiddleware.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,gEAA+B;AAE/B,oFAA4D;AAC5D,2DAAmC;AACnC,2EAAoD;AAEpD,SAAe,uBAAuB,CAClC,GAAY,EACZ,GAAa,EACb,IAAkB;;QAElB,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,CAAC,aAAa,CAAC;QAEzC,IAAI,CAAC,MAAM,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,EAAE;YAC1C,OAAO,IAAI,CAAC,IAAI,sBAAa,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC,CAAC;SACvD;QAED,MAAM,WAAW,GAAG,MAAM,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC;QACtD,IAAI;YACA,MAAM,OAAO,GAAmC,MAAM,eAAK,CAAC,WAAW,CACnE,WAAW,CACd,CAAC;YAEF,IAAI,OAAO,YAAY,sBAAG,CAAC,iBAAiB,EAAE;gBAC1C,OAAO,IAAI,CAAC,IAAI,sBAAa,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC,CAAC;aACvD;YAED,MAAM,IAAI,GAAG,MAAM,oBAAU,CAAC,QAAQ,CAAC,OAAO,CAAC,EAAE,CAAC;iBAC7C,MAAM,CAAC,WAAW,CAAC;iBACnB,IAAI,EAAE,CAAC;YAEZ,IAAI,CAAC,IAAI,EAAE;gBACP,OAAO,IAAI,CAAC,IAAI,sBAAa,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC,CAAC;aACvD;YAED,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC;YAEhB,OAAO,IAAI,EAAE,CAAC;SACjB;QAAC,OAAO,KAAK,EAAE;YACZ,OAAO,IAAI,CAAC,IAAI,sBAAa,CAAC,GAAG,EAAE,cAAc,CAAC,CAAC,CAAC;SACvD;IACL,CAAC;CAAA;AAED,kBAAe,uBAAuB,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/middleware/exeption/httpExeption.js b/src/Api/dist/middleware/exeption/httpExeption.js new file mode 100644 index 0000000..bfed40e --- /dev/null +++ b/src/Api/dist/middleware/exeption/httpExeption.js @@ -0,0 +1,12 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +class HttpException extends Error { + constructor(status, message) { + super(message); + this.status = status; + this.message = message; + } +} +// en fontion de l'exeption firebas,etc une bonne exeption +exports.default = HttpException; +//# sourceMappingURL=httpExeption.js.map \ No newline at end of file diff --git a/src/Api/dist/middleware/exeption/httpExeption.js.map b/src/Api/dist/middleware/exeption/httpExeption.js.map new file mode 100644 index 0000000..47983ff --- /dev/null +++ b/src/Api/dist/middleware/exeption/httpExeption.js.map @@ -0,0 +1 @@ +{"version":3,"file":"httpExeption.js","sourceRoot":"","sources":["../../../src/middleware/exeption/httpExeption.ts"],"names":[],"mappings":";;AAAA,MAAM,aAAc,SAAQ,KAAK;IAI7B,YAAY,MAAc,EAAE,OAAe;QACvC,KAAK,CAAC,OAAO,CAAC,CAAC;QACf,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC;QACrB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IAC3B,CAAC;CACJ;AACD,0DAA0D;AAE1D,kBAAe,aAAa,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/middleware/validation/ValidatorMiddleware.js b/src/Api/dist/middleware/validation/ValidatorMiddleware.js new file mode 100644 index 0000000..98ad7de --- /dev/null +++ b/src/Api/dist/middleware/validation/ValidatorMiddleware.js @@ -0,0 +1,34 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +Object.defineProperty(exports, "__esModule", { value: true }); +function validationMiddleware(schema) { + return (req, res, next) => __awaiter(this, void 0, void 0, function* () { + const validationOptions = { + abortEarly: false, + allowUnknown: true, + stripUnknown: true, + }; + try { + const value = yield schema.validateAsync(req.body, validationOptions); + req.body = value; + next(); + } + catch (e) { + const errors = []; + e.details.forEach((error) => { + errors.push(error.message); + }); + res.status(400).send({ errors: errors }); + } + }); +} +exports.default = validationMiddleware; +//# sourceMappingURL=ValidatorMiddleware.js.map \ No newline at end of file diff --git a/src/Api/dist/middleware/validation/ValidatorMiddleware.js.map b/src/Api/dist/middleware/validation/ValidatorMiddleware.js.map new file mode 100644 index 0000000..80fc94e --- /dev/null +++ b/src/Api/dist/middleware/validation/ValidatorMiddleware.js.map @@ -0,0 +1 @@ +{"version":3,"file":"ValidatorMiddleware.js","sourceRoot":"","sources":["../../../src/middleware/validation/ValidatorMiddleware.ts"],"names":[],"mappings":";;;;;;;;;;;AAGA,SAAS,oBAAoB,CAAC,MAAkB;IAC5C,OAAO,CACH,GAAY,EACZ,GAAa,EACb,IAAkB,EACL,EAAE;QACf,MAAM,iBAAiB,GAAG;YACtB,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,IAAI;YAClB,YAAY,EAAE,IAAI;SACrB,CAAC;QAEF,IAAI;YACA,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,aAAa,CACpC,GAAG,CAAC,IAAI,EACR,iBAAiB,CACpB,CAAC;YACF,GAAG,CAAC,IAAI,GAAG,KAAK,CAAC;YACjB,IAAI,EAAE,CAAC;SACV;QAAC,OAAO,CAAM,EAAE;YACb,MAAM,MAAM,GAAa,EAAE,CAAC;YAC5B,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,KAA8B,EAAE,EAAE;gBACjD,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;YAC/B,CAAC,CAAC,CAAC;YACH,GAAG,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;SAC5C;IACL,CAAC,CAAA,CAAC;AACN,CAAC;AAED,kBAAe,oBAAoB,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/middleware/winston.js b/src/Api/dist/middleware/winston.js new file mode 100644 index 0000000..79ab948 --- /dev/null +++ b/src/Api/dist/middleware/winston.js @@ -0,0 +1,9 @@ +// export const loggerOptions: expressWinston.LoggerOptions = { +// transports: [new winston.transports.Console()], +// format: winston.format.combine( +// winston.format.json(), +// winston.format.prettyPrint(), +// winston.format.colorize({ all: true }) +// ), +// }; +//# sourceMappingURL=winston.js.map \ No newline at end of file diff --git a/src/Api/dist/middleware/winston.js.map b/src/Api/dist/middleware/winston.js.map new file mode 100644 index 0000000..7a79c49 --- /dev/null +++ b/src/Api/dist/middleware/winston.js.map @@ -0,0 +1 @@ +{"version":3,"file":"winston.js","sourceRoot":"","sources":["../../src/middleware/winston.ts"],"names":[],"mappings":"AAAA,+DAA+D;AAC/D,sDAAsD;AACtD,sCAAsC;AACtC,iCAAiC;AACjC,wCAAwC;AACxC,iDAAiD;AACjD,SAAS;AACT,KAAK"} \ No newline at end of file diff --git a/src/Api/dist/model/IUser.js b/src/Api/dist/model/IUser.js new file mode 100644 index 0000000..6d13f68 --- /dev/null +++ b/src/Api/dist/model/IUser.js @@ -0,0 +1,3 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +//# sourceMappingURL=IUser.js.map \ No newline at end of file diff --git a/src/Api/dist/model/IUser.js.map b/src/Api/dist/model/IUser.js.map new file mode 100644 index 0000000..1281d2b --- /dev/null +++ b/src/Api/dist/model/IUser.js.map @@ -0,0 +1 @@ +{"version":3,"file":"IUser.js","sourceRoot":"","sources":["../../src/model/IUser.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/model/Message.js b/src/Api/dist/model/Message.js new file mode 100644 index 0000000..7f46289 --- /dev/null +++ b/src/Api/dist/model/Message.js @@ -0,0 +1 @@ +//# sourceMappingURL=Message.js.map \ No newline at end of file diff --git a/src/Api/dist/model/Message.js.map b/src/Api/dist/model/Message.js.map new file mode 100644 index 0000000..3fbefdf --- /dev/null +++ b/src/Api/dist/model/Message.js.map @@ -0,0 +1 @@ +{"version":3,"file":"Message.js","sourceRoot":"","sources":["../../src/model/Message.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/model/factory/MessageFactory.js b/src/Api/dist/model/factory/MessageFactory.js new file mode 100644 index 0000000..d726ad3 --- /dev/null +++ b/src/Api/dist/model/factory/MessageFactory.js @@ -0,0 +1 @@ +//# sourceMappingURL=MessageFactory.js.map \ No newline at end of file diff --git a/src/Api/dist/model/factory/MessageFactory.js.map b/src/Api/dist/model/factory/MessageFactory.js.map new file mode 100644 index 0000000..026e1fa --- /dev/null +++ b/src/Api/dist/model/factory/MessageFactory.js.map @@ -0,0 +1 @@ +{"version":3,"file":"MessageFactory.js","sourceRoot":"","sources":["../../../src/model/factory/MessageFactory.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/model/locationModel.js b/src/Api/dist/model/locationModel.js new file mode 100644 index 0000000..679d00b --- /dev/null +++ b/src/Api/dist/model/locationModel.js @@ -0,0 +1,27 @@ +"use strict"; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.Place = exports.UserLocation = exports.PlacePosition = void 0; +class PlacePosition { + constructor(timestamp, latitude, longitude) { + this.timestamp = timestamp; + this.coords = { latitude, longitude }; + } +} +exports.PlacePosition = PlacePosition; +class UserLocation { + constructor(uuid, musicId, latitude, longitude) { + this.uuid = uuid; + this.musicId = musicId; + this.latitude = latitude; + this.longitude = longitude; + } +} +exports.UserLocation = UserLocation; +class Place { + constructor(address, position) { + this.position = position; + this.address = address; + } +} +exports.Place = Place; +//# sourceMappingURL=locationModel.js.map \ No newline at end of file diff --git a/src/Api/dist/model/locationModel.js.map b/src/Api/dist/model/locationModel.js.map new file mode 100644 index 0000000..835a347 --- /dev/null +++ b/src/Api/dist/model/locationModel.js.map @@ -0,0 +1 @@ +{"version":3,"file":"locationModel.js","sourceRoot":"","sources":["../../src/model/locationModel.ts"],"names":[],"mappings":";;;AAmBA,MAAa,aAAa;IAMtB,YAAY,SAAiB,EAAC,QAAiB,EAAE,SAAiB;QAC9D,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,MAAM,GAAG,EAAC,QAAQ,EAAE,SAAS,EAAC,CAAC;IACxC,CAAC;CACJ;AAVD,sCAUC;AACD,MAAa,YAAY;IAKrB,YAAY,IAAY,EAAE,OAAgB,EAAC,QAAgB,EAAE,SAAiB;QAC1E,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC;QACjB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;QACvB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;IAC/B,CAAC;CACJ;AAXD,oCAWC;AAED,MAAa,KAAK;IAGlB,YAAY,OAAgB,EAAC,QAAkB;QAC3C,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;QACzB,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC;IAC3B,CAAC;CACA;AAPD,sBAOC"} \ No newline at end of file diff --git a/src/Api/dist/model/token.js b/src/Api/dist/model/token.js new file mode 100644 index 0000000..f63afa4 --- /dev/null +++ b/src/Api/dist/model/token.js @@ -0,0 +1,34 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +exports.verifyToken = exports.createToken = void 0; +const jsonwebtoken_1 = __importDefault(require("jsonwebtoken")); +const createToken = (user) => { + return jsonwebtoken_1.default.sign({ id: user._id }, "foo", { + expiresIn: '100d', + }); +}; +exports.createToken = createToken; +const verifyToken = (token) => __awaiter(void 0, void 0, void 0, function* () { + return new Promise((resolve, reject) => { + jsonwebtoken_1.default.verify(token, "foo", (err, payload) => { + if (err) + return reject(err); + resolve(payload); + }); + }); +}); +exports.verifyToken = verifyToken; +exports.default = { createToken: exports.createToken, verifyToken: exports.verifyToken }; +//# sourceMappingURL=token.js.map \ No newline at end of file diff --git a/src/Api/dist/model/token.js.map b/src/Api/dist/model/token.js.map new file mode 100644 index 0000000..87b1e0c --- /dev/null +++ b/src/Api/dist/model/token.js.map @@ -0,0 +1 @@ +{"version":3,"file":"token.js","sourceRoot":"","sources":["../../src/model/token.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AAAA,gEAA+B;AAIxB,MAAM,WAAW,GAAG,CAAC,IAAW,EAAU,EAAE;IAC/C,OAAO,sBAAG,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,KAAmB,EAAE;QACnD,SAAS,EAAE,MAAM;KACpB,CAAC,CAAC;AACP,CAAC,CAAC;AAJW,QAAA,WAAW,eAItB;AAEK,MAAM,WAAW,GAAG,CACvB,KAAa,EACqB,EAAE;IACpC,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACnC,sBAAG,CAAC,MAAM,CACN,KAAK,EACL,KAAmB,EACnB,CAAC,GAAG,EAAE,OAAO,EAAE,EAAE;YACb,IAAI,GAAG;gBAAE,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC;YAE5B,OAAO,CAAC,OAAiB,CAAC,CAAC;QAC/B,CAAC,CACJ,CAAC;IACN,CAAC,CAAC,CAAC;AACP,CAAC,CAAA,CAAC;AAdW,QAAA,WAAW,eActB;AAEF,kBAAe,EAAE,WAAW,EAAX,mBAAW,EAAE,WAAW,EAAX,mBAAW,EAAE,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/service/ChatService.js b/src/Api/dist/service/ChatService.js new file mode 100644 index 0000000..ed4c9b3 --- /dev/null +++ b/src/Api/dist/service/ChatService.js @@ -0,0 +1 @@ +//# sourceMappingURL=ChatService.js.map \ No newline at end of file diff --git a/src/Api/dist/service/ChatService.js.map b/src/Api/dist/service/ChatService.js.map new file mode 100644 index 0000000..a7ae9de --- /dev/null +++ b/src/Api/dist/service/ChatService.js.map @@ -0,0 +1 @@ +{"version":3,"file":"ChatService.js","sourceRoot":"","sources":["../../src/service/ChatService.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/service/LocationService.js b/src/Api/dist/service/LocationService.js new file mode 100644 index 0000000..a1eaed7 --- /dev/null +++ b/src/Api/dist/service/LocationService.js @@ -0,0 +1,116 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +// import db from '../database'; +const locationModel_1 = require("../model/locationModel"); +const LocationSchema_1 = __importDefault(require("../database/schema/LocationSchema")); +class LocationService { + constructor() { + this.locationCollection = LocationSchema_1.default; + this.toRad = (value) => (value * Math.PI) / 180; + this.toDeg = (value) => (value * 180) / Math.PI; + // getCenter(coords) + } + // private API_KEY : string = "AIzaSyBFCEAtmhZ8jvw84UTQvX3Aqpr66GVqB_A"; + getNearUser(idFlad, musicId, latitude, longitude) { + return __awaiter(this, void 0, void 0, function* () { + yield this.locationCollection.findOneAndUpdate({ idFlad }, { idFlad, musicId, latitude, longitude }, { upsert: true }); + const snapshot = yield this.locationCollection.find({ idFlad: { $ne: idFlad } }); + if (snapshot.length === 0) { + console.log('No matching documents.'); + return; + } + let dbUsersList = []; + snapshot.forEach(doc => { + dbUsersList.push(new locationModel_1.UserLocation(doc.idFlad, doc.musicId, doc.latitude, doc.longitude)); + console.log(doc.idFlad, '=>', doc); + }); + // missing the curent music + let listUser = []; + const listUser2 = {}; + dbUsersList.forEach(user => { + console.log(user); + const dist = this.distanceBetween(latitude, longitude, user.latitude, user.longitude); + console.log(user.uuid, dist); + if (dist <= 100) { + listUser.push(user.uuid); + listUser2[user.uuid] = user.musicId; + } + }); + return { listUser, listUser2 }; + // $listUser[] = {userID,idMusic}; + }); + } + getCenter(points) { + if (Array.isArray(points) === false || points.length === 0) { + return false; + } + const numberOfPoints = points.length; + const sum = points.reduce((acc, point) => { + const pointLat = this.toRad(point.coords.latitude); + const pointLon = this.toRad(point.coords.longitude); + return { + X: acc.X + Math.cos(pointLat) * Math.cos(pointLon), + Y: acc.Y + Math.cos(pointLat) * Math.sin(pointLon), + Z: acc.Z + Math.sin(pointLat), + }; + }, { X: 0, Y: 0, Z: 0 }); + const X = sum.X / numberOfPoints; + const Y = sum.Y / numberOfPoints; + const Z = sum.Z / numberOfPoints; + return { + longitude: this.toDeg(Math.atan2(Y, X)), + latitude: this.toDeg(Math.atan2(Z, Math.sqrt(X * X + Y * Y))), + }; + } + ; + // sa c'est un utils du coup mettre dans une calss utils + // resulta en km + distanceBetween(lat1, lon1, lat2, lon2) { + if ((lat1 == lat2) && (lon1 == lon2)) { + return 0; + } + else { + var radlat1 = Math.PI * lat1 / 180; + var radlat2 = Math.PI * lat2 / 180; + var theta = lon1 - lon2; + var radtheta = Math.PI * theta / 180; + var dist = Math.sin(radlat1) * Math.sin(radlat2) + Math.cos(radlat1) * Math.cos(radlat2) * Math.cos(radtheta); + if (dist > 1) { + dist = 1; + } + dist = Math.acos(dist); + dist = dist * 180 / Math.PI; + dist = dist * 60 * 1.1515; + dist = dist * 1.609344; + return dist; + } + } + distanceBetweenPosition(first, second) { + return this.distanceBetween(first.coords.latitude, first.coords.longitude, second.coords.latitude, second.coords.longitude); + } + // give a array of position sorted by distance and return the first + findNearest(main, list) { + this.orderByDistance(main, list)[0]; + } + //distanceFn: DistanceFn = getDistance est param sa serrait cool de lui passer un fonction + orderByDistance(mainPos, coords) { + return coords + .slice() + .sort((a, b) => this.distanceBetweenPosition(mainPos, a) - this.distanceBetweenPosition(mainPos, b)); + } + ; +} +exports.default = LocationService; +//# sourceMappingURL=LocationService.js.map \ No newline at end of file diff --git a/src/Api/dist/service/LocationService.js.map b/src/Api/dist/service/LocationService.js.map new file mode 100644 index 0000000..1f6b0d5 --- /dev/null +++ b/src/Api/dist/service/LocationService.js.map @@ -0,0 +1 @@ +{"version":3,"file":"LocationService.js","sourceRoot":"","sources":["../../src/service/LocationService.ts"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/src/Api/dist/service/Notifier.js b/src/Api/dist/service/Notifier.js new file mode 100644 index 0000000..e4f507a --- /dev/null +++ b/src/Api/dist/service/Notifier.js @@ -0,0 +1 @@ +//# sourceMappingURL=Notifier.js.map \ No newline at end of file diff --git a/src/Api/dist/service/Notifier.js.map b/src/Api/dist/service/Notifier.js.map new file mode 100644 index 0000000..0a22445 --- /dev/null +++ b/src/Api/dist/service/Notifier.js.map @@ -0,0 +1 @@ +{"version":3,"file":"Notifier.js","sourceRoot":"","sources":["../../src/service/Notifier.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/dist/service/UserService.js b/src/Api/dist/service/UserService.js new file mode 100644 index 0000000..8e0e51e --- /dev/null +++ b/src/Api/dist/service/UserService.js @@ -0,0 +1,69 @@ +"use strict"; +var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) { + function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); } + return new (P || (P = Promise))(function (resolve, reject) { + function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } } + function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } } + function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); } + step((generator = generator.apply(thisArg, _arguments || [])).next()); + }); +}; +var __importDefault = (this && this.__importDefault) || function (mod) { + return (mod && mod.__esModule) ? mod : { "default": mod }; +}; +Object.defineProperty(exports, "__esModule", { value: true }); +const UserSchema_1 = __importDefault(require("../database/schema/User/UserSchema")); +const token_1 = __importDefault(require("../model/token")); +class UserService { + constructor() { + this.user = UserSchema_1.default; + } + /** + * Register a new user + */ + register(name, email, password, idFlad, idSpotify) { + return __awaiter(this, void 0, void 0, function* () { + try { + const user = yield this.user.create({ + name, + email, + password, + idFlad, + idSpotify + }); + const accessToken = token_1.default.createToken(user); + return accessToken; + } + catch (error) { + throw new Error(error.message); + } + }); + } + /** + * Attempt to login a user + */ + login(email, password) { + return __awaiter(this, void 0, void 0, function* () { + try { + // should maybe creat a method base on id and other information for better security + // need to view with Emre + const user = yield this.user.findOne({ email }); + // const user = await this.user.findById(idFlad); + if (!user) { + throw new Error('Unable to find user with that email address'); + } + if (yield user.isValidPassword(password)) { + return token_1.default.createToken(user); + } + else { + throw new Error('Wrong credentials given'); + } + } + catch (error) { + throw new Error('Unable to create user'); + } + }); + } +} +exports.default = UserService; +//# sourceMappingURL=UserService.js.map \ No newline at end of file diff --git a/src/Api/dist/service/UserService.js.map b/src/Api/dist/service/UserService.js.map new file mode 100644 index 0000000..cb002da --- /dev/null +++ b/src/Api/dist/service/UserService.js.map @@ -0,0 +1 @@ +{"version":3,"file":"UserService.js","sourceRoot":"","sources":["../../src/service/UserService.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,oFAA4D;AAC5D,2DAAmC;AAGnC,MAAM,WAAW;IAAjB;QACY,SAAI,GAAG,oBAAU,CAAC;IAuD9B,CAAC;IArDG;;OAEG;IACU,QAAQ,CACjB,IAAY,EACZ,KAAa,EACb,QAAgB,EAChB,MAAe,EACf,SAAkB;;YAElB,IAAI;gBACA,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;oBAChC,IAAI;oBACJ,KAAK;oBACL,QAAQ;oBACR,MAAM;oBACN,SAAS;iBACZ,CAAC,CAAC;gBAEH,MAAM,WAAW,GAAG,eAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBAE5C,OAAO,WAAW,CAAC;aACtB;YAAC,OAAO,KAAW,EAAE;gBAClB,MAAM,IAAI,KAAK,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;aAClC;QACL,CAAC;KAAA;IAED;;OAEG;IACU,KAAK,CACd,KAAa,EACb,QAAgB;;YAEhB,IAAI;gBACA,mFAAmF;gBACnF,yBAAyB;gBACzB,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;gBAChD,iDAAiD;gBAEjD,IAAI,CAAC,IAAI,EAAE;oBACP,MAAM,IAAI,KAAK,CAAC,6CAA6C,CAAC,CAAC;iBAClE;gBAED,IAAI,MAAM,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,EAAE;oBACtC,OAAO,eAAK,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;iBAClC;qBAAM;oBACH,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;iBAC9C;aACJ;YAAC,OAAO,KAAK,EAAE;gBACZ,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;aAC5C;QACL,CAAC;KAAA;CACJ;AAED,kBAAe,WAAW,CAAC"} \ No newline at end of file diff --git a/src/Api/dist/service/interfaces/IChatService.js b/src/Api/dist/service/interfaces/IChatService.js new file mode 100644 index 0000000..3f36422 --- /dev/null +++ b/src/Api/dist/service/interfaces/IChatService.js @@ -0,0 +1 @@ +//# sourceMappingURL=IChatService.js.map \ No newline at end of file diff --git a/src/Api/dist/service/interfaces/IChatService.js.map b/src/Api/dist/service/interfaces/IChatService.js.map new file mode 100644 index 0000000..de8a972 --- /dev/null +++ b/src/Api/dist/service/interfaces/IChatService.js.map @@ -0,0 +1 @@ +{"version":3,"file":"IChatService.js","sourceRoot":"","sources":["../../../src/service/interfaces/IChatService.ts"],"names":[],"mappings":""} \ No newline at end of file diff --git a/src/Api/package.json b/src/Api/package.json index f566d89..4e4f64e 100644 --- a/src/Api/package.json +++ b/src/Api/package.json @@ -5,6 +5,7 @@ "main": "dist/index.js", "scripts": { "build": "tsc", + "dave": "nodemon ./src/index.ts", "dev": "tsc -w & nodemon .", "start": "tsc & node .", "test": "echo \"Error: no test specified\" && exit 1" @@ -44,6 +45,7 @@ "mongodb": "^5.0.0", "mongoose": "^6.9.0", "morgan": "^1.10.0", + "mqtt": "^4.3.7", "request": "^2.88.2", "rimraf": "^4.1.2", "swagger-ui-express": "^4.6.0", diff --git a/src/Api/src/controller/chat-controller/chatCtrl.ts b/src/Api/src/controller/chat-controller/chatCtrl.ts new file mode 100644 index 0000000..87f7d07 --- /dev/null +++ b/src/Api/src/controller/chat-controller/chatCtrl.ts @@ -0,0 +1,96 @@ +import { Router, Request, Response, NextFunction, RequestHandler } from 'express'; +import Controller from '../Icontroller'; +import HttpException from '../../middleware/exeption/httpExeption'; +// import LocationService from '../../service/LocationService'; +import IUser from '../../database/schema/User/UserInterface'; +import UserService from '../../service/UserService'; +import validator from '../../database/schema/User/UserValidation' +import validationMiddleware from '../../middleware/validation/ValidatorMiddleware'; +import authenticator from '../../middleware/authMiddleware' +import LocationService from '../../service/LocationService'; +class ChatController implements Controller { + public path = '/chat'; + public router = Router(); + private chatService = new ChatService(); + + constructor() { + this.initialiseRoutes(); + } + + private initialiseRoutes(): void { + this.router.post( + `${this.path}/register`, + validationMiddleware(validator.register), + this.register + ); + this.router.post( + `${this.path}/login`, + validationMiddleware(validator.login), + this.login + ); + this.router.get(`${this.path}`, authenticator, this.getUser); + + } + + + + private register = async ( + req: Request, + res: Response, + next: NextFunction + ): Promise => { + try { + // the FladId should be created by the Userservice + const { name, email, password , idFlad, idSpotify } = req.body; + console.log(name, email, password, idFlad, idSpotify); + + const token = await this.userService.register( + name, + email, + password, + idFlad, + idSpotify + ); + + res.status(201).json({ token }); + } catch (error : any) { + next(new HttpException(400, error.message)); + } + }; + + private login = async ( + req: Request, + res: Response, + next: NextFunction + ): Promise => { + try { + const { email, password } = req.body; + + const token = await this.userService.login(email, password); + + res.status(200).json({ token }); + } catch (error : any) { + next(new HttpException(400, error.message)); + } + }; + + private getUser = ( + req: Request, + res: Response, + next: NextFunction + ): Response | void => { + if (!req.user) { + return next(new HttpException(404, 'No logged in user')); + } + + res.status(200).send({ data: req.user }); + }; + + + + +} + +export default ChatController; + + diff --git a/src/Api/src/controller/user-controller/userCtrl.ts b/src/Api/src/controller/user-controller/userCtrl.ts index 2ecfa85..c490bec 100644 --- a/src/Api/src/controller/user-controller/userCtrl.ts +++ b/src/Api/src/controller/user-controller/userCtrl.ts @@ -212,17 +212,22 @@ class UserController implements Controller { next: NextFunction ): Promise => { try { - const longitude = Number(req.params.longitude); - const latitude = Number(req.params.latitude); + const longitude = Number(req.query.longitude); + const latitude = Number(req.query.latitude); //verify::val_int(){ console.log('woooooooooooooo' + req); if (isNaN(longitude) || isNaN(latitude)) { + console.log('============' + longitude) + console.log('============' + latitude) console.log('Impossible de convertir la chaîne en nombre'); } //} const userId = req.user.idFlad; - const musicId = req.params.currentMusic; - const data = await this.locationService.getNearUser(userId,musicId,latitude,longitude,); + const musicId = String(req.query.currentMusic); + console.log('============' + longitude) + console.log('============' + latitude) + console.log('daaaaaaaaaaaaaaaaaaaaaa' + musicId); + const data = await this.locationService.getNearUser(userId,musicId,latitude,longitude); console.log(data); res.status(201).send(data); diff --git a/src/Api/src/model/Message.ts b/src/Api/src/model/Message.ts new file mode 100644 index 0000000..e69de29 diff --git a/src/Api/src/model/factory/MessageFactory.ts b/src/Api/src/model/factory/MessageFactory.ts new file mode 100644 index 0000000..e69de29 diff --git a/src/Api/src/service/ChatService.ts b/src/Api/src/service/ChatService.ts new file mode 100644 index 0000000..87855ea --- /dev/null +++ b/src/Api/src/service/ChatService.ts @@ -0,0 +1,63 @@ +import UserSchema from "../database/schema/User/UserSchema"; +import token from "../model/token"; + + +class ChatService { + private user = UserSchema; + + /** + * Register a new user + */ + public async sendMessage( + name: string, + email: string, + password: string, + idFlad : string, + idSpotify : string + ): Promise { + try { + const user = await this.user.create({ + name, + email, + password, + idFlad, + idSpotify + }); + + const accessToken = token.createToken(user); + + return accessToken; + } catch (error : any) { + throw new Error(error.message); + } + } + + /** + * Attempt to login a user + */ + public async createConverssation( + email: string, + password: string + ): Promise { + try { + // should maybe creat a method base on id and other information for better security + // need to view with Emre + const user = await this.user.findOne({ email }); + // const user = await this.user.findById(idFlad); + + if (!user) { + throw new Error('Unable to find user with that email address'); + } + + if (await user.isValidPassword(password)) { + return token.createToken(user); + } else { + throw new Error('Wrong credentials given'); + } + } catch (error) { + throw new Error('Unable to create user'); + } + } +} + +export default ChatService; \ No newline at end of file diff --git a/src/Api/src/service/Notifier.ts b/src/Api/src/service/Notifier.ts new file mode 100644 index 0000000..e69de29 diff --git a/src/Api/src/service/interfaces/IChatService.ts b/src/Api/src/service/interfaces/IChatService.ts new file mode 100644 index 0000000..635d691 --- /dev/null +++ b/src/Api/src/service/interfaces/IChatService.ts @@ -0,0 +1,5 @@ +interface IChatService { + sendMessage() : Promise; + getHistory() : Promise;// pagination + createConverssation () :Promise; +}