diff --git a/Alltracks.json b/Alltracks.json index b7376ca..9f929a0 100644 --- a/Alltracks.json +++ b/Alltracks.json @@ -1,6 +1,7 @@ [ { - "Singer_Name": "John", + "Song_id":"s10002", + "Singer_Name": "John", "image-url":"", "Singer-details":"", "Description":"", @@ -8,16 +9,16 @@ }, { "Singer_Name": "Justin-Bieber", - - "image-url":"", - "Singer-details":"", - "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", + "Song_id":"s10001", + "image-url":"", + "Singer-details":"Justin Drew Bieber (/ˈbiːbər/; born March 1, 1994) is a Canadian singer, songwriter, and actor. Discovered at 13 years old by talent manager Scooter Braun after he had watched his YouTube cover song videos, Bieber was signed to RBMG Records in 2008. With Bieber's debut EP My World, released in late 2009, Bieber became the first artist to have seven songs from a debut record chart on the Billboard Hot 100.", + "Description":"Baby is a song by Canadian recording artist Justin Bieber, alongside rapper Ludacris. It was released as the lead single on Bieber's debut album, My World 2.0. The track was written by Bieber with Christina Milian, Christopher Tricky Stewart who worked with Bieber on a previous single One Time, and R&B singer The-Dream, and produced by the latter two.", "Track":"Baby" }, { "Singer_Name": "ChainSmoker", - + "Song_id":"s10003", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", @@ -26,7 +27,7 @@ }, { "Singer_Name": "JohnCena", - + "Song_id":"s10004", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", @@ -36,7 +37,7 @@ }, { "Singer_Name": "Akon", - + "Song_id":"s10005", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", @@ -46,7 +47,7 @@ }, { "Singer_Name": "A.R-Rehman", - + "Song_id":"s10006", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", @@ -55,7 +56,7 @@ }, { "Singer_Name": "Pritam", - + "Song_id":"s10007", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", @@ -65,7 +66,7 @@ }, { "Singer_Name": "AlanWalker", - + "Song_id":"s10008", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", @@ -75,7 +76,7 @@ }, { "Singer_Name": "EDSheeran", - + "Song_id":"s10009", "image-url":"", "Singer-details":"", "Description":"", diff --git a/modules/list.js b/modules/list.js index 3c1e0dc..548924c 100644 --- a/modules/list.js +++ b/modules/list.js @@ -1,18 +1,16 @@ -const bcrypt = require('bcrypt-promise') const sqlite = require('sqlite-async') -const saltRounds = 10 module.exports = class List { constructor(dbName = ':memory:') { return (async() => { this.db = await sqlite.open(dbName) - /*we need this table to store the user track + //we need this table to store the user track const sql = 'CREATE TABLE IF NOT EXISTS uploadTrack\ - (id INTEGER PRIMARY KEY AUTOINCREMENT, user TEXT, pass TEXT, email TEXT);' - await this.db.run(sql)*/ + (id INTEGER PRIMARY KEY AUTOINCREMENT, singer_name TEXT, singer_details TEXT, description TEXT,image_url TEXT, Track_name TEXT;' + await this.db.run(sql) return this console.log("Track open") })() diff --git a/modules/uploadTrack b/modules/uploadTrack new file mode 100644 index 0000000..deeff7b --- /dev/null +++ b/modules/uploadTrack @@ -0,0 +1,49 @@ + +const sqlite = require('sqlite-async') + + +module.exports = class List { + + constructor(dbName = ':memory:') { + return (async() => { + this.db = await sqlite.open(dbName) + //we need this table to store the user track + const sql = 'CREATE TABLE IF NOT EXISTS uploadTrack\ + (id TEXT, singer_name TEXT, singer_details TEXT, description TEXT,image_url TEXT, Track_name TEXT;' + await this.db.run(sql) + return this + console.log("Track open") + })() + } + + /** + * checks to see if a set of login credentials are valid + * @param {String} username the username to check + * @param {String} password the password to check + * @returns {Boolean} returns true if credentials are valid + */ + async register(user, pass, email) { + Array.from(arguments).forEach( val => { + if(val.length === 0) throw new Error('missing field') + }) + let sql = `SELECT COUNT(id) as records FROM artist WHERE user="${user}";` + const data = await this.db.get(sql) + if(data.records !== 0) throw new Error(`username "${user}" already in use`) + sql = `SELECT COUNT(id) as records FROM artist WHERE email="${email}";` + const emails = await this.db.get(sql) + if(emails.records !== 0) throw new Error(`email address "${email}" is already in use`) + pass = await bcrypt.hash(pass, saltRounds) + sql = `INSERT INTO artist(user, pass, email) VALUES("${user}", "${pass}", "${email}")` + await this.db.run(sql) + return true + } + + async getAll() { + + + } + + async tearDown() { + await this.db.close() + } +} diff --git a/modules/uploadTrack.js b/modules/uploadTrack.js new file mode 100644 index 0000000..425cdda --- /dev/null +++ b/modules/uploadTrack.js @@ -0,0 +1,36 @@ + +const sqlite = require('sqlite-async') + + +module.exports = class UploadTrack { + +constructor(dbName = ':memory:') { + console.log("constructor") + return (async() => { + this.db = await sqlite.open(dbName) + const sql = 'CREATE TABLE IF NOT EXISTS uploadTrack\ + (id TEXT, singer_name TEXT, singer_details TEXT, description TEXT,image_url TEXT, Track_name TEXT);' + await this.db.run(sql) + return this + })() + } + + async insert(id, singer_name, singer_details,description,track,image_url) { + sql = `INSERT INTO uploadTrack(id, singer_name, singer_details,description,image_url,Track_name) VALUES("${id}", "${singer_name}", "${singer_details}", "${description}", "${image_url}", "${track}")` + await this.db.run(sql) + console.log("Done") + return true + } + + async getAll() { +sql = `SELECT * FROM uploadTrack` + const record = await this.db.get(sql) + return record + + + } + + async tearDown() { + await this.db.close() + } +} diff --git a/modules/user.js b/modules/user.js index f6ec2f0..c13672f 100644 --- a/modules/user.js +++ b/modules/user.js @@ -7,6 +7,7 @@ const saltRounds = 10 module.exports = class User { constructor(dbName = ':memory:') { + console.log("constructor") return (async() => { this.db = await sqlite.open(dbName) // we need this table to store the user accounts diff --git a/routes/public.js b/routes/public.js index ded8a0b..c792122 100644 --- a/routes/public.js +++ b/routes/public.js @@ -9,6 +9,7 @@ const tracks=require("../Alltracks.json") const User = require('../modules/user') const dbName = 'website.db' const List=require('../modules/list') +const UploadTrack=require('../modules/uploadTrack') /** * The secure home page. * @@ -141,7 +142,47 @@ router.get("/trackDetails/:track",koaBody,async ctx=>{ console.log(ctx.hbs)} }) +router.get("/uploadTrack/:id",koaBody,async ctx=>{ + console.log("enter") + const value=ctx.params.id; + console.log(value) + const upload = await new UploadTrack(dbName) + + try + { var arrFound = tracks.filter(function(item) { + return item.Song_id == value; +}); + console.log(arrFound[0]) + const res= await upload.insert(arrFound[0].Song_id,arrFound[0].Singer_Name , arrFound[0].Singer_Details,arrFound[0].Description,arrFound[0].Track,arrFound[0].image_url) + console.log('record inserted') + return ctx.redirect('/playlist') + + + } + catch(err){ console.log(err) + ctx.hbs.msg = err.message + ctx.hbs.body = ctx.request.body + console.log(ctx.hbs)} + +}) +router.get('/playlist',koaBody,async ctx=>{ + const upload= await new UploadTrack(dbName) + try{ + const records= await upload.getAll() + console.log(records) + ctx.hbs.record=records + await ctx.render('playlist',ctx.hbs) + } + catch (err) { + console.log(err) + ctx.hbs.msg = err.message + ctx.hbs.body = ctx.request.body + console.log(ctx.hbs) + }finally { + upload.tearDown() + } +}) /* router.post('/issues', koaBody,async ctx => { const iss = await new Issues(dbName) diff --git a/views/listTrack.handlebars b/views/listTrack.handlebars index 17080d1..7e42f41 100644 --- a/views/listTrack.handlebars +++ b/views/listTrack.handlebars @@ -25,13 +25,14 @@ Singer-Name Track + Upload {{#each record}} {{Singer_Name}} {{Track}} - + {{/each}} diff --git a/views/playlist.handlebars b/views/playlist.handlebars new file mode 100644 index 0000000..2bbe188 --- /dev/null +++ b/views/playlist.handlebars @@ -0,0 +1,46 @@ + + + + + + + Playlist + + + + + + + +
+

PlayList

+
+ {{#if msg}} +

{{msg}}

+ {{/if}} + +
+
+ + + + + + + + {{#each record}} + + + + + {{/each}} +
Singer-NameTrackAction
{{Singer_Name}} {{Track_Name}}
+
+ +
Logout
+ + + + + + \ No newline at end of file diff --git a/views/secure.handlebars b/views/secure.handlebars index ff0f1fc..412771f 100644 --- a/views/secure.handlebars +++ b/views/secure.handlebars @@ -18,7 +18,9 @@ {{/if}}

Display all tracks

+

Playlist

Logout

+