Major refactoring of get_session(), get_account(), get_nodemailer(), introduces ...
[ndcode_site.git] / api / account / change_details / set.json.jst
1 let XDate = require('xdate')
2
3 return async env => {
4   let get_account = await _require('/_lib/get_account.jst')
5   let get_session = await _require('/_lib/get_session.jst')
6   let post_request = await _require('/_lib/post_request.jst')
7   let Problem = await _require('/_lib/Problem.jst')
8
9   await post_request(
10     // env
11     env,
12     // handler
13     async details => {
14       details = {
15         given_names: details.given_names.slice(0, 256),
16         family_name: details.family_name.slice(0, 256),
17         contact_me: details.contact_me ? true : false
18       }
19       if (details.given_names.length === 0)
20         throw new Problem(
21           'Bad request',
22           'Minimum length check failed',
23           400
24         )
25
26       let transaction = await env.site.database.Transaction()
27       try {
28         let root = await transaction.get({})
29         let session = await get_session(env, root)
30
31         let account = await get_account(root, session)
32         if (account === undefined)
33           throw new Problem('Unauthorized', 'Please sign in first.', 401)
34
35         account.set_json('given_names', details.given_names)
36         account.set_json('family_name', details.family_name)
37         account.set_json('contact_me', details.contact_me)
38         await transaction.commit()
39       }
40       catch (error) {
41         transaction.rollback()
42         throw error
43       }
44     }
45   )
46 }