summaryrefslogtreecommitdiff
path: root/src/api/endpoints/channels/create.ts
diff options
context:
space:
mode:
authorこぴなたみぽ <Syuilotan@yahoo.co.jp>2017-11-06 19:10:10 +0900
committerGitHub <noreply@github.com>2017-11-06 19:10:10 +0900
commit03e86ec05216d49f9a1af5dd92f0fa12f2da4825 (patch)
tree9257b5d2d0abc626187a9ba9640097bc5624d158 /src/api/endpoints/channels/create.ts
parentchore(package): update @types/serve-favicon to version 2.2.29 (diff)
parentMerge pull request #870 from syuilo/greenkeeper/@types/multer-1.3.5 (diff)
downloadmisskey-03e86ec05216d49f9a1af5dd92f0fa12f2da4825.tar.gz
misskey-03e86ec05216d49f9a1af5dd92f0fa12f2da4825.tar.bz2
misskey-03e86ec05216d49f9a1af5dd92f0fa12f2da4825.zip
Merge branch 'master' into greenkeeper/@types/serve-favicon-2.2.29
Diffstat (limited to 'src/api/endpoints/channels/create.ts')
-rw-r--r--src/api/endpoints/channels/create.ts39
1 files changed, 39 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..a8d7c29dc1
--- /dev/null
+++ b/src/api/endpoints/channels/create.ts
@@ -0,0 +1,39 @@
+/**
+ * Module dependencies
+ */
+import $ from 'cafy';
+import Channel from '../../models/channel';
+import Watching from '../../models/channel-watching';
+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,
+ watching_count: 1
+ });
+
+ // Response
+ res(await serialize(channel));
+
+ // Create Watching
+ await Watching.insert({
+ created_at: new Date(),
+ user_id: user._id,
+ channel_id: channel._id
+ });
+});