More updates

master
Jonatan Nilsson 2019-02-22 14:53:43 +00:00
parent 18c7c25eed
commit cc025b2393
14 changed files with 140 additions and 17 deletions

View File

@ -18,7 +18,7 @@ export function restrict(level = orgAccess.Normal) {
return ctx.throw(403, 'Authentication token was not found (did you forget to login?)')
}
if (!ctx.state.user || !ctx.state.user.id || !ctx.state.user.level) {
if (!ctx.state.user || !ctx.state.user.email || !ctx.state.user.level) {
return ctx.throw(403, 'You must be authenticated to access this resource')
}

View File

@ -53,8 +53,7 @@ export default class Jwt {
static jwtMiddleware() {
return koaJwt({
secret: (header, payload) =>
Staff.getSingle(payload.id)
.then(staff => `${config.get('jwt:secret')}${staff.get('password')}`),
`${config.get('jwt:secret')}${payload.email}`,
passthrough: true,
})
}

View File

@ -1,6 +1,7 @@
import http from 'http'
import path from 'path'
import fs from 'fs'
import Agent from 'socks5-http-client/lib/Agent'
let stub
@ -38,6 +39,11 @@ export function uploadFile(token, file) {
'Content-Type': 'multipart/form-data; boundary=' + boundary,
'Content-Length': multipartBody.length,
},
agentClass: Agent,
agentOptions: {
socksHost: '127.0.0.1',
socksPort: 5555,
},
}
const req = http.request(options)

View File

@ -21,6 +21,11 @@ article.editcat {
}
}
fileupload {
margin: 0 20px 20px;
min-height: 100px;
}
form {
align-items: center;
align-self: center;
@ -31,7 +36,7 @@ article.editcat {
margin-bottom: 20px;
}
.loading-spinner {
& > .loading-spinner {
width: 240px;
height: 50px;
position: relative;

View File

@ -1,5 +1,6 @@
const m = require('mithril')
const Authentication = require('../authentication')
const FileUpload = require('../widgets/fileupload')
const EditCategory = {
loading: true,
@ -16,7 +17,9 @@ const EditCategory = {
: m('div.admin-wrapper',
m('article.editcat', [
m('header', m('h1', 'Edit category')),
m(FileUpload),
m('form.editcat', [
])
])
)

20
app/api/common.js Normal file
View File

@ -0,0 +1,20 @@
const m = require('mithril')
const Authentication = require('../authentication')
exports.sendRequest = function(options) {
let token = Authentication.getToken()
if (token) {
options.headers = options.headers || {}
options.headers['Authorization'] = 'Bearer ' + token
}
return m.request(options)
.catch(function (error) {
if (error.code === 403) {
Authentication.clearToken()
m.route.set('/login', { redirect: m.route.get() })
}
return Promise.reject(error)
})
}

13
app/api/media.js Normal file
View File

@ -0,0 +1,13 @@
const m = require('mithril')
const { sendRequest } = require('./common')
exports.uploadMedia = function(file) {
let formData = new FormData()
formData.append('file', file)
return sendRequest({
method: 'POST',
url: '/api/media',
data: formData,
})
}

View File

@ -110,3 +110,4 @@ article {
@import 'menu/menu';
@import 'login/login';
@import 'admin/admin';
@import 'widgets/common';

View File

@ -44,13 +44,13 @@ const Authentication = {
gscript.src = 'https://apis.google.com/js/platform.js?onload=googleLoaded'
document.body.appendChild(gscript)
})
}
},
getToken: function() {
return localStorage.getItem(storageName)
},
}
Authentication.updateToken(localStorage.getItem(storageName))
if (Authentication.currentUser) {
// Authentication.createGoogleScript()
}
module.exports = Authentication

View File

@ -4,6 +4,7 @@ const Authentication = require('../authentication')
const Login = {
loadedGoogle: false,
loading: false,
redirect: '',
error: '',
initGoogleButton: function() {
@ -29,7 +30,7 @@ const Login = {
})
.then(function(result) {
Authentication.updateToken(result.token)
m.route.set('/')
m.route.set(Login.redirect || '/')
})
.catch(function(error) {
Login.error = 'Error while logging into NFP! ' + error.code + ': ' + error.response.message
@ -48,7 +49,8 @@ const Login = {
Authentication.createGoogleScript()
},
oninit: function() {
oninit: function(vnode) {
Login.redirect = vnode.attrs.redirect || ''
if (Authentication.currentUser) return m.route.set('/')
Login.error = ''
},

View File

@ -0,0 +1,47 @@
fileupload {
position: relative;
display: flex;
align-items: stretch;
.showicon,
.display {
border: 3px solid $title-fg;
border-style: dashed;
flex-grow: 2;
}
.showicon {
background-image: url('');
background-position: center;
background-repeat: no-repeat;
background-size: 32px;
}
.display {
border: none;
background-size: contain;
}
.loading-spinner {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
background: #33333388;
width: 100%;
}
input {
position: absolute;
top: 0;
left: 0;
right: 0;
bottom: 0;
opacity: 0.01;
width: 100%;
cursor: pointer;
text-indent: -9999px;
z-index: 2;
}
}

View File

@ -1,7 +1,27 @@
const m = require('mithril')
const { uploadMedia } = require('../api/media')
const FileUpload = {
uploadFile(vnode, event) {
if (!event.target.files[0]) return
vnode.state.loading = true
uploadMedia(event.target.files[0])
.then(function(res) {
vnode.state.media = res
console.log(vnode.state.media)
})
.catch(function(err) {
console.log(err)
})
.then(function() {
vnode.state.loading = false
m.redraw()
})
},
const Login = {
oninit: function(vnode) {
vnode.state.loading = false
vnode.state.media = null
vnode.state.error = ''
},
@ -11,16 +31,22 @@ const Login = {
return m('fileupload', [
(media ?
m('a', {
m('a.display', {
href: media.large_url,
style: {
'background-image': 'url(' + media.medium_url + ')',
}
}) :
m('div.empty')
m('div.showicon')
),
m('input', {
accept: 'image/*',
type: 'file',
onchange: FileUpload.uploadFile.bind(this, vnode),
}),
(vnode.state.loading ? m('div.loading-spinner') : null),
])
}
}
module.exports = Login
module.exports = FileUpload

View File

@ -38,6 +38,6 @@
"fileSize": 524288000,
"upload": {
"name": "nfpmoe-dev",
"secret": "TJlAbWgpQy0zMGu01XoW"
"secret": "nfpmoe-dev"
}
}

View File

@ -45,7 +45,8 @@
"multer": "^1.4.1",
"nconf": "^0.10.0",
"pg": "^7.8.0",
"sharp": "^0.21.3"
"sharp": "^0.21.3",
"socks5-http-client": "^1.0.4"
},
"devDependencies": {
"browserify": "^16.2.3",