summaryrefslogtreecommitdiff
path: root/src/api/endpoints/channels/create.ts
diff options
context:
space:
mode:
authorこぴなたみぽ <Syuilotan@yahoo.co.jp>2017-11-01 04:18:32 +0900
committerGitHub <noreply@github.com>2017-11-01 04:18:32 +0900
commit2a00930150207c983a2f6e111d03f2db33b897b9 (patch)
treef41dc9bcc5498ac89839057e07910b9c2d81fed3 /src/api/endpoints/channels/create.ts
parentv2752 (diff)
parentv2769 (diff)
downloadsharkey-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.ts30
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));
+});