summaryrefslogtreecommitdiff
path: root/src/server/api
diff options
context:
space:
mode:
Diffstat (limited to 'src/server/api')
-rw-r--r--src/server/api/endpoints/charts/user/drive.ts41
-rw-r--r--src/server/api/endpoints/charts/user/following.ts41
-rw-r--r--src/server/api/endpoints/charts/user/notes.ts41
3 files changed, 123 insertions, 0 deletions
diff --git a/src/server/api/endpoints/charts/user/drive.ts b/src/server/api/endpoints/charts/user/drive.ts
new file mode 100644
index 0000000000..d320887950
--- /dev/null
+++ b/src/server/api/endpoints/charts/user/drive.ts
@@ -0,0 +1,41 @@
+import $ from 'cafy';
+import getParams from '../../../get-params';
+import { perUserDriveStats } from '../../../../../services/stats';
+import ID from '../../../../../misc/cafy-id';
+
+export const meta = {
+ desc: {
+ 'ja-JP': 'ユーザーごとのドライブの統計を取得します。'
+ },
+
+ params: {
+ span: $.str.or(['day', 'hour']).note({
+ desc: {
+ 'ja-JP': '集計のスパン (day または hour)'
+ }
+ }),
+
+ limit: $.num.optional.range(1, 100).note({
+ default: 30,
+ desc: {
+ 'ja-JP': '最大数。例えば 30 を指定したとすると、スパンが"day"の場合は30日分のデータが、スパンが"hour"の場合は30時間分のデータが返ります。'
+ }
+ }),
+
+ userId: $.type(ID).note({
+ desc: {
+ 'ja-JP': '対象のユーザーのID',
+ 'en-US': 'Target user ID'
+ }
+ })
+ }
+};
+
+export default (params: any) => new Promise(async (res, rej) => {
+ const [ps, psErr] = getParams(meta, params);
+ if (psErr) throw psErr;
+
+ const stats = await perUserDriveStats.getChart(ps.span as any, ps.limit, ps.userId);
+
+ res(stats);
+});
diff --git a/src/server/api/endpoints/charts/user/following.ts b/src/server/api/endpoints/charts/user/following.ts
new file mode 100644
index 0000000000..dbb2b46df9
--- /dev/null
+++ b/src/server/api/endpoints/charts/user/following.ts
@@ -0,0 +1,41 @@
+import $ from 'cafy';
+import getParams from '../../../get-params';
+import { perUserFollowingStats } from '../../../../../services/stats';
+import ID from '../../../../../misc/cafy-id';
+
+export const meta = {
+ desc: {
+ 'ja-JP': 'ユーザーごとのフォロー/フォロワーの統計を取得します。'
+ },
+
+ params: {
+ span: $.str.or(['day', 'hour']).note({
+ desc: {
+ 'ja-JP': '集計のスパン (day または hour)'
+ }
+ }),
+
+ limit: $.num.optional.range(1, 100).note({
+ default: 30,
+ desc: {
+ 'ja-JP': '最大数。例えば 30 を指定したとすると、スパンが"day"の場合は30日分のデータが、スパンが"hour"の場合は30時間分のデータが返ります。'
+ }
+ }),
+
+ userId: $.type(ID).note({
+ desc: {
+ 'ja-JP': '対象のユーザーのID',
+ 'en-US': 'Target user ID'
+ }
+ })
+ }
+};
+
+export default (params: any) => new Promise(async (res, rej) => {
+ const [ps, psErr] = getParams(meta, params);
+ if (psErr) throw psErr;
+
+ const stats = await perUserFollowingStats.getChart(ps.span as any, ps.limit, ps.userId);
+
+ res(stats);
+});
diff --git a/src/server/api/endpoints/charts/user/notes.ts b/src/server/api/endpoints/charts/user/notes.ts
new file mode 100644
index 0000000000..a256ed96f9
--- /dev/null
+++ b/src/server/api/endpoints/charts/user/notes.ts
@@ -0,0 +1,41 @@
+import $ from 'cafy';
+import getParams from '../../../get-params';
+import { perUserNotesStats } from '../../../../../services/stats';
+import ID from '../../../../../misc/cafy-id';
+
+export const meta = {
+ desc: {
+ 'ja-JP': 'ユーザーごとの投稿の統計を取得します。'
+ },
+
+ params: {
+ span: $.str.or(['day', 'hour']).note({
+ desc: {
+ 'ja-JP': '集計のスパン (day または hour)'
+ }
+ }),
+
+ limit: $.num.optional.range(1, 100).note({
+ default: 30,
+ desc: {
+ 'ja-JP': '最大数。例えば 30 を指定したとすると、スパンが"day"の場合は30日分のデータが、スパンが"hour"の場合は30時間分のデータが返ります。'
+ }
+ }),
+
+ userId: $.type(ID).note({
+ desc: {
+ 'ja-JP': '対象のユーザーのID',
+ 'en-US': 'Target user ID'
+ }
+ })
+ }
+};
+
+export default (params: any) => new Promise(async (res, rej) => {
+ const [ps, psErr] = getParams(meta, params);
+ if (psErr) throw psErr;
+
+ const stats = await perUserNotesStats.getChart(ps.span as any, ps.limit, ps.userId);
+
+ res(stats);
+});