actual work
This commit is contained in:
parent
3a70d13339
commit
3711e8354e
6 changed files with 68 additions and 31 deletions
|
@ -1,8 +1,17 @@
|
|||
# node stuff
|
||||
node_modules
|
||||
npm-debug.log
|
||||
|
||||
# big files
|
||||
**/*.xcf
|
||||
**/*.bundle.js
|
||||
|
||||
# docker stuff
|
||||
Dockerfile
|
||||
.dockerignore
|
||||
docker-compose.yml
|
||||
|
||||
# container volumes
|
||||
src
|
||||
views
|
||||
public_html
|
||||
|
|
|
@ -9,6 +9,6 @@ services:
|
|||
- "${PWD}/src:/app/src"
|
||||
- "${PWD}/views:/app/views:ro"
|
||||
- "${PWD}/public_html:/app/public_html"
|
||||
- "${PWD}/fftcg.db:/app/fftcg.db"
|
||||
# - "${PWD}/fftcg.db:/app/fftcg.db"
|
||||
ports:
|
||||
- "3000:3000"
|
||||
|
|
BIN
fftcg.db
BIN
fftcg.db
Binary file not shown.
|
@ -2,38 +2,53 @@
|
|||
bcrypt = (require 'bcrypt')
|
||||
sqlite3 = (require 'sqlite3').verbose()
|
||||
|
||||
FFTCGDB =
|
||||
open: (filename) ->
|
||||
FFTCGDB = (filename) ->
|
||||
@filename = filename
|
||||
|
||||
@db = new sqlite3.Database @filename, (err) ->
|
||||
if err
|
||||
console.error err.message
|
||||
console.log 'Connected to', @filename
|
||||
|
||||
@db.run """
|
||||
CREATE TABLE IF NOT EXISTS users (
|
||||
nick text NOT NULL,
|
||||
login text NOT NULL,
|
||||
nickname text,
|
||||
pwd text NOT NULL,
|
||||
socket text
|
||||
socket text,
|
||||
UNIQUE(login)
|
||||
);
|
||||
"""
|
||||
console.log 'Connected to', @filename
|
||||
return
|
||||
|
||||
close: ->
|
||||
db.close (err) ->
|
||||
FFTCGDB::close = ->
|
||||
@db.close (err) ->
|
||||
if err
|
||||
console.error err.message
|
||||
console.log 'Closed', @filename
|
||||
|
||||
adduser: (name, password) ->
|
||||
FFTCGDB::register = (login, password) ->
|
||||
that = @
|
||||
# bruteforce countermeasure
|
||||
saltRounds = 13
|
||||
|
||||
new Promise (resolve, reject) ->
|
||||
# validate username
|
||||
login = login.toLowerCase()
|
||||
# hash password
|
||||
bcrypt.hash password, saltRounds, (err, hash) ->
|
||||
reject 'bcrypt fail' if err
|
||||
# try creating row in users table
|
||||
that.db.run "INSERT INTO users (login, pwd) VALUES ('#{login}', '#{hash}');", (err, result) ->
|
||||
reject 'sqlite fail' if err
|
||||
# registration successful
|
||||
resolve login
|
||||
|
||||
FFTCGDB::login = (login, password) ->
|
||||
that = @
|
||||
|
||||
bcrypt.hash password, saltRounds, (err, hash) ->
|
||||
that.db.run "INSERT INTO users (nick, pwd) VALUES ('#{name}', '#{hash}');", (err, result) ->
|
||||
if err
|
||||
console.error err.message
|
||||
console.log 'Result:', result
|
||||
new Promise (resolve, reject) ->
|
||||
|
||||
|
||||
module.exports = FFTCGDB
|
||||
|
||||
|
|
|
@ -6,8 +6,9 @@ path = (require 'path')
|
|||
socketio = (require 'socket.io')
|
||||
|
||||
# my libraries
|
||||
fftcgdb = (require './inc/fftcgdb')
|
||||
fftcgdb.open path.resolve(__dirname, 'fftcg.db')
|
||||
FFTCGDB = (require './inc/fftcgdb')
|
||||
|
||||
fftcgdb = new FFTCGDB path.resolve(__dirname, 'fftcg.db')
|
||||
|
||||
# express + socket.io framework
|
||||
app = express()
|
||||
|
@ -33,9 +34,21 @@ io.on 'connection', (socket) ->
|
|||
console.log 'a user disconnected'
|
||||
return
|
||||
|
||||
socket.on 'register', (login, password) ->
|
||||
console.log 'message:', login, password
|
||||
fftcgdb.register login, password
|
||||
.then (login) ->
|
||||
console.log 'registered "%s"', login
|
||||
.catch (err) ->
|
||||
console.error 'error: "%s"', err
|
||||
|
||||
socket.on 'login', (uname, password) ->
|
||||
console.log 'message:', uname, password
|
||||
fftcgdb.adduser uname, password
|
||||
fftcgdb.login uname, password
|
||||
.then (login) ->
|
||||
console.log 'Login OK "%s"', login
|
||||
.catch (err) ->
|
||||
console.error 'error: "%s"', err
|
||||
|
||||
# Create server
|
||||
web.listen 3000, ->
|
||||
|
|
|
@ -12,7 +12,7 @@ html
|
|||
h1 Hello World!
|
||||
h2 App under development, please don't send valuable data!
|
||||
|
||||
div.container
|
||||
div.container.bg-light
|
||||
div.row
|
||||
|
||||
div.col-md-6
|
||||
|
|
Reference in a new issue