2020-01-04 21:59:57 +00:00
|
|
|
'use strict'
|
|
|
|
|
|
|
|
const archiver = require('archiver')
|
|
|
|
const async = require('async')
|
|
|
|
|
2020-01-04 22:30:23 +00:00
|
|
|
const response = require('../response')
|
|
|
|
const config = require('../config')
|
|
|
|
const models = require('../models')
|
|
|
|
const logger = require('../logger')
|
|
|
|
const { generateAvatar } = require('../letter-avatars')
|
2020-01-04 21:59:57 +00:00
|
|
|
|
|
|
|
exports.getMe = async (req, res) => {
|
|
|
|
if (!req.isAuthenticated()) {
|
2020-02-26 02:25:12 +00:00
|
|
|
return res.status(401).send({
|
2020-01-04 21:59:57 +00:00
|
|
|
status: 'forbidden'
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
const user = await models.User.findOne({
|
|
|
|
where: {
|
|
|
|
id: req.user.id
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
if (!user) {
|
2020-02-26 03:20:42 +00:00
|
|
|
return response.errorNotFound(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
}
|
|
|
|
const profile = models.User.getProfile(user)
|
|
|
|
|
|
|
|
res.send({
|
|
|
|
status: 'ok',
|
|
|
|
id: req.user.id,
|
|
|
|
name: profile.name,
|
|
|
|
photo: profile.photo
|
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.deleteUser = async (req, res) => {
|
|
|
|
if (!req.isAuthenticated()) {
|
2020-02-26 03:13:45 +00:00
|
|
|
return response.errorForbidden(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const user = await models.User.findOne({
|
|
|
|
where: {
|
|
|
|
id: req.user.id
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
if (!user) {
|
2020-02-26 03:20:42 +00:00
|
|
|
return response.errorNotFound(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (user.deleteToken !== req.params.token) {
|
2020-02-26 03:13:45 +00:00
|
|
|
return response.errorForbidden(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
await user.destroy()
|
|
|
|
return res.redirect(config.serverURL + '/')
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.exportMyData = (req, res) => {
|
|
|
|
if (!req.isAuthenticated()) {
|
2020-02-26 03:13:45 +00:00
|
|
|
return response.errorForbidden(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
const archive = archiver('zip', {
|
|
|
|
zlib: { level: 3 } // Sets the compression level.
|
|
|
|
})
|
|
|
|
|
|
|
|
res.setHeader('Content-Type', 'application/zip')
|
|
|
|
res.attachment('archive.zip')
|
|
|
|
archive.pipe(res)
|
|
|
|
archive.on('error', function (err) {
|
|
|
|
logger.error('export user data failed: ' + err)
|
2020-02-26 03:26:01 +00:00
|
|
|
return response.errorInternalError(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
})
|
|
|
|
|
|
|
|
models.User.findOne({
|
|
|
|
where: {
|
|
|
|
id: req.user.id
|
|
|
|
}
|
|
|
|
}).then(function (user) {
|
|
|
|
models.Note.findAll({
|
|
|
|
where: {
|
|
|
|
ownerId: user.id
|
|
|
|
}
|
|
|
|
}).then(function (notes) {
|
|
|
|
const filenames = {}
|
|
|
|
async.each(notes, function (note, callback) {
|
|
|
|
const basename = note.title.replace(/\//g, '-') // Prevent subdirectories
|
|
|
|
let filename
|
|
|
|
let suffix = 0
|
|
|
|
do {
|
|
|
|
const separator = suffix === 0 ? '' : '-'
|
|
|
|
filename = basename + separator + suffix + '.md'
|
|
|
|
suffix++
|
|
|
|
} while (filenames[filename])
|
|
|
|
filenames[filename] = true
|
|
|
|
|
|
|
|
logger.debug('Write: ' + filename)
|
|
|
|
archive.append(Buffer.from(note.content), { name: filename, date: note.lastchangeAt })
|
|
|
|
callback(null, null)
|
|
|
|
}, function (err) {
|
|
|
|
if (err) {
|
2020-02-26 03:26:01 +00:00
|
|
|
return response.errorInternalError(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
archive.finalize()
|
|
|
|
})
|
|
|
|
})
|
|
|
|
}).catch(function (err) {
|
|
|
|
logger.error('export user data failed: ' + err)
|
2020-02-26 03:26:01 +00:00
|
|
|
return response.errorInternalError(req, res)
|
2020-01-04 21:59:57 +00:00
|
|
|
})
|
|
|
|
}
|
|
|
|
|
|
|
|
exports.getMyAvatar = (req, res) => {
|
|
|
|
res.setHeader('Content-Type', 'image/svg+xml')
|
|
|
|
res.setHeader('Cache-Control', 'public, max-age=86400')
|
|
|
|
res.send(generateAvatar(req.params.username))
|
|
|
|
}
|