diff --git a/Alltracks.json b/Alltracks.json index 9f929a0..82f29f4 100644 --- a/Alltracks.json +++ b/Alltracks.json @@ -1,18 +1,10 @@ [ - { - "Song_id":"s10002", - "Singer_Name": "John", - "image-url":"", - "Singer-details":"", - "Description":"", - "Track":"BlackOut" - }, + { "Singer_Name": "Justin-Bieber", "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.", + "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.", + "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" }, @@ -22,19 +14,11 @@ "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", + "Track":"Loser" }, - { - "Singer_Name": "JohnCena", - "Song_id":"s10004", - "image-url":"", - "Singer-details":"", - "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", - - - "Track":"You-can-see-me" - }, + { "Singer_Name": "Akon", "Song_id":"s10005", @@ -42,28 +26,20 @@ "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", - + "trackSource":"https://pwdown.com/112531/01. Chammak Challo.mp3", "Track":"Chammak-Challo" - }, - { - "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.", - - "Track":"Oscar" - }, - { - "Singer_Name": "Pritam", - "Song_id":"s10007", + }, + { + "Singer_Name": "A.R. Rehman", + "Song_id":"s10011", "image-url":"", "Singer-details":"", "Description":"It was launched in 2002. At that Justin bieber age was 12 years.", - - "Track":"Black" + "trackSource":"songs/Dil-Bechara.mp3", + "Track":"Dil Bechara" }, + { "Singer_Name": "AlanWalker", "Song_id":"s10008", @@ -75,7 +51,7 @@ "Track":"Fade" }, { - "Singer_Name": "EDSheeran", + "Singer_Name": "CharliePuth", "Song_id":"s10009", "image-url":"", "Singer-details":"", diff --git a/index.js b/index.js index 9a93d83..4b1db59 100644 --- a/index.js +++ b/index.js @@ -20,7 +20,8 @@ app.use( async(ctx, next) => { console.log(`${ctx.method} ${ctx.path}`) ctx.hbs = { authorised: ctx.session.authorised, - host: `https://${ctx.host}` + host: `https://${ctx.host}`, + username:ctx.session.user } for(const key in ctx.query) ctx.hbs[key] = ctx.query[key] await next() diff --git a/modules/uploadTrack b/modules/uploadTrack deleted file mode 100644 index deeff7b..0000000 --- a/modules/uploadTrack +++ /dev/null @@ -1,49 +0,0 @@ - -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 index 425cdda..1f70df3 100644 --- a/modules/uploadTrack.js +++ b/modules/uploadTrack.js @@ -8,23 +8,25 @@ 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);' + const sql = 'CREATE TABLE IF NOT EXISTS uplorac\ + (id TEXT PRIMARY KEY , singer_name TEXT, singer_details TEXT, description TEXT,image_url TEXT, Track_name TEXT, trackSource 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}")` + async insert(id, singer_name, singer_details,description,track,image_url,src) { + const sql = `INSERT INTO uplorac(id, singer_name, singer_details,description,image_url,Track_name,trackSource) VALUES("${id}", "${singer_name}", "${singer_details}", "${description}", "${image_url}", "${track}","${src}")` await this.db.run(sql) console.log("Done") return true } async getAll() { -sql = `SELECT * FROM uploadTrack` - const record = await this.db.get(sql) + + const sql = `SELECT * FROM uplorac;` + const record = await this.db.all(sql) + console.log(record) return record diff --git a/modules/user.js b/modules/user.js index c13672f..1c69545 100644 --- a/modules/user.js +++ b/modules/user.js @@ -51,10 +51,11 @@ module.exports = class User { const records = await this.db.get(sql) if(!records.count) throw new Error(`username "${username}" not found`) sql = `SELECT pass FROM artist WHERE user = "${username}";` + const record = await this.db.get(sql) const valid = await bcrypt.compare(password, record.pass) if(valid === false) throw new Error(`invalid password for account "${username}"`) - return true + return username } async tearDown() { diff --git a/routes/public.js b/routes/public.js index c792122..c1b3316 100644 --- a/routes/public.js +++ b/routes/public.js @@ -97,8 +97,10 @@ router.post('/login', koaBody, async ctx => { const res= await user.login(body.user, body.pass) ctx.session.authorised = true - - return ctx.redirect('/secure?msg=you are now logged in...') + console.log(res) + ctx.session.user=res + + return ctx.redirect('/secure?msg=you are now logged in...',ctx) } catch (err) { ctx.hbs.msg = err.message await ctx.render('login', ctx.hbs) @@ -126,7 +128,7 @@ await ctx.render('listTrack', ctx.hbs) } console.log(ctx.hbs) } }) -router.get("/trackDetails/:track",koaBody,async ctx=>{ +router.get('/trackDetails/:track',koaBody,async ctx=>{ try { const value=ctx.params.track; @@ -142,7 +144,7 @@ router.get("/trackDetails/:track",koaBody,async ctx=>{ console.log(ctx.hbs)} }) -router.get("/uploadTrack/:id",koaBody,async ctx=>{ +router.get('/uploadTrack/:id',koaBody,async ctx=>{ console.log("enter") const value=ctx.params.id; console.log(value) @@ -154,7 +156,7 @@ router.get("/uploadTrack/:id",koaBody,async ctx=>{ 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) + 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,arrFound[0].trackSource) console.log('record inserted') return ctx.redirect('/playlist') @@ -166,12 +168,16 @@ router.get("/uploadTrack/:id",koaBody,async ctx=>{ console.log(ctx.hbs)} }) +router.get('/songs/:id',koaBody,async ctx=>{ + console.log("play") + await ctx.redirect('playlist',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 + ctx.hbs.playlist=records await ctx.render('playlist',ctx.hbs) } catch (err) { diff --git a/views/index.handlebars b/views/index.handlebars index 10b6320..438d72a 100644 --- a/views/index.handlebars +++ b/views/index.handlebars @@ -11,7 +11,7 @@
-

Home

+

HomePage

{{#if msg}}

{{msg}}

diff --git a/views/issues.handlebars b/views/issues.handlebars deleted file mode 100644 index ee5876f..0000000 --- a/views/issues.handlebars +++ /dev/null @@ -1,47 +0,0 @@ - - - - - - - Home Page - - - - - - - -
-
- {{#if msg}} -

{{msg}}

- {{/if}} - Username is : -
-
- - - - - - - {{#each record}} - - - - - {{/each}} -
ApplianceCompanyProblem
{{this.type_of_appliance}} {{this.appliance_manufacturer}}{{this.description}}
-
-
-
-

-

- -
-Click me

- - - - \ No newline at end of file diff --git a/views/listTrack.handlebars b/views/listTrack.handlebars index 7e42f41..56c6dc0 100644 --- a/views/listTrack.handlebars +++ b/views/listTrack.handlebars @@ -13,6 +13,10 @@
+
+
+ + Username is :{{username}}

List of Tracks

{{#if msg}} @@ -31,9 +35,10 @@ {{#each record}} + {{Singer_Name}} {{Track}} - - + + {{/each}}
diff --git a/views/playlist.handlebars b/views/playlist.handlebars index 2bbe188..be175c7 100644 --- a/views/playlist.handlebars +++ b/views/playlist.handlebars @@ -13,6 +13,10 @@
+
+
+ + Username is :{{username}}

PlayList

{{#if msg}} @@ -23,16 +27,19 @@
- + - + - {{#each record}} + {{#each playlist}} - - + + + {{/each}}
Singer-NameSingerName TrackActionPlay/Pause
{{Singer_Name}} {{Track_Name}}
{{singer_name}} {{Track_name}}

diff --git a/views/secure.handlebars b/views/secure.handlebars index 412771f..4e33d5b 100644 --- a/views/secure.handlebars +++ b/views/secure.handlebars @@ -11,7 +11,9 @@
- +
+
+ Username is :{{username}}
{{#if msg}}

{{msg}}

diff --git a/views/songs/Dil-Bechara.mp3 b/views/songs/Dil-Bechara.mp3 new file mode 100644 index 0000000..fc029a7 Binary files /dev/null and b/views/songs/Dil-Bechara.mp3 differ