diff options
| author | こぴなたみぽ <Syuilotan@yahoo.co.jp> | 2017-11-01 04:18:32 +0900 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2017-11-01 04:18:32 +0900 |
| commit | 2a00930150207c983a2f6e111d03f2db33b897b9 (patch) | |
| tree | f41dc9bcc5498ac89839057e07910b9c2d81fed3 /src/api/endpoints/channels/create.ts | |
| parent | v2752 (diff) | |
| parent | v2769 (diff) | |
| download | sharkey-2a00930150207c983a2f6e111d03f2db33b897b9.tar.gz sharkey-2a00930150207c983a2f6e111d03f2db33b897b9.tar.bz2 sharkey-2a00930150207c983a2f6e111d03f2db33b897b9.zip | |
Merge pull request #854 from syuilo/bbs
Bbs
Diffstat (limited to 'src/api/endpoints/channels/create.ts')
| -rw-r--r-- | src/api/endpoints/channels/create.ts | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/api/endpoints/channels/create.ts b/src/api/endpoints/channels/create.ts new file mode 100644 index 0000000000..e0c0e0192a --- /dev/null +++ b/src/api/endpoints/channels/create.ts @@ -0,0 +1,30 @@ +/** + * Module dependencies + */ +import $ from 'cafy'; +import Channel from '../../models/channel'; +import serialize from '../../serializers/channel'; + +/** + * Create a channel + * + * @param {any} params + * @param {any} user + * @return {Promise<any>} + */ +module.exports = async (params, user) => new Promise(async (res, rej) => { + // Get 'title' parameter + const [title, titleErr] = $(params.title).string().range(1, 100).$; + if (titleErr) return rej('invalid title param'); + + // Create a channel + const channel = await Channel.insert({ + created_at: new Date(), + user_id: user._id, + title: title, + index: 0 + }); + + // Response + res(await serialize(channel)); +}); |