summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorsyuilo <syuilotan@yahoo.co.jp>2019-05-10 17:30:28 +0900
committersyuilo <syuilotan@yahoo.co.jp>2019-05-10 17:30:28 +0900
commit8e6da3a0d9f2f6dbd8f1009e1accdb4e4ebae169 (patch)
tree464f6e908de12e86eec16ec918adfe3be387b166 /src
parentテキストのリスト内で変数埋め込みできるように (diff)
downloadsharkey-8e6da3a0d9f2f6dbd8f1009e1accdb4e4ebae169.tar.gz
sharkey-8e6da3a0d9f2f6dbd8f1009e1accdb4e4ebae169.tar.bz2
sharkey-8e6da3a0d9f2f6dbd8f1009e1accdb4e4ebae169.zip
インスタンス運営者がピン留めユーザーを設定できるように
Related #4892
Diffstat (limited to 'src')
-rw-r--r--src/client/app/admin/views/instance.vue13
-rw-r--r--src/client/app/common/views/pages/explore.vue4
-rw-r--r--src/models/entities/meta.ts5
-rw-r--r--src/server/api/endpoints/admin/update-meta.ts11
-rw-r--r--src/server/api/endpoints/meta.ts1
-rw-r--r--src/server/api/endpoints/pinned-users.ts33
6 files changed, 66 insertions, 1 deletions
diff --git a/src/client/app/admin/views/instance.vue b/src/client/app/admin/views/instance.vue
index cca4e5f669..d81edc8fe6 100644
--- a/src/client/app/admin/views/instance.vue
+++ b/src/client/app/admin/views/instance.vue
@@ -83,6 +83,14 @@
</ui-card>
<ui-card>
+ <template #title>{{ $t('pinned-users') }}</template>
+ <section>
+ <ui-textarea v-model="pinnedUsers"></ui-textarea>
+ <ui-button @click="updateMeta">{{ $t('save') }}</ui-button>
+ </section>
+ </ui-card>
+
+ <ui-card>
<template #title>{{ $t('invite') }}</template>
<section>
<ui-button @click="invite">{{ $t('invite') }}</ui-button>
@@ -190,6 +198,7 @@ export default Vue.extend({
enableServiceWorker: false,
swPublicKey: null,
swPrivateKey: null,
+ pinnedUsers: [],
faHeadset, faShieldAlt, faGhost, faUserPlus, farEnvelope, faBolt
};
},
@@ -239,6 +248,7 @@ export default Vue.extend({
this.enableServiceWorker = meta.enableServiceWorker;
this.swPublicKey = meta.swPublickey;
this.swPrivateKey = meta.swPrivateKey;
+ this.pinnedUsers = meta.pinnedUsers.join('\n');
});
},
@@ -297,7 +307,8 @@ export default Vue.extend({
smtpPass: this.smtpAuth ? this.smtpPass : '',
enableServiceWorker: this.enableServiceWorker,
swPublicKey: this.swPublicKey,
- swPrivateKey: this.swPrivateKey
+ swPrivateKey: this.swPrivateKey,
+ pinnedUsers: this.pinnedUsers.split('\n')
}).then(() => {
this.$root.dialog({
type: 'success',
diff --git a/src/client/app/common/views/pages/explore.vue b/src/client/app/common/views/pages/explore.vue
index 107603d69e..d0e98035f8 100644
--- a/src/client/app/common/views/pages/explore.vue
+++ b/src/client/app/common/views/pages/explore.vue
@@ -26,6 +26,9 @@
</mk-user-list>
<template v-if="tag == null">
+ <mk-user-list :make-promise="pinnedUsers">
+ <fa :icon="faBookmark" fixed-width/>{{ $t('pinned-users') }}
+ </mk-user-list>
<mk-user-list :make-promise="popularUsers">
<fa :icon="faChartLine" fixed-width/>{{ $t('popular-users') }}
</mk-user-list>
@@ -57,6 +60,7 @@ export default Vue.extend({
data() {
return {
+ pinnedUsers: () => this.$root.api('pinned-users'),
popularUsers: () => this.$root.api('users', {
state: 'alive',
origin: 'local',
diff --git a/src/models/entities/meta.ts b/src/models/entities/meta.ts
index be41cf3589..2c36b8333f 100644
--- a/src/models/entities/meta.ts
+++ b/src/models/entities/meta.ts
@@ -72,6 +72,11 @@ export class Meta {
@Column('varchar', {
length: 256, array: true, default: '{}'
})
+ public pinnedUsers: string[];
+
+ @Column('varchar', {
+ length: 256, array: true, default: '{}'
+ })
public hiddenTags: string[];
@Column('varchar', {
diff --git a/src/server/api/endpoints/admin/update-meta.ts b/src/server/api/endpoints/admin/update-meta.ts
index 1f5dd5364f..8a2019fcc1 100644
--- a/src/server/api/endpoints/admin/update-meta.ts
+++ b/src/server/api/endpoints/admin/update-meta.ts
@@ -56,6 +56,13 @@ export const meta = {
}
},
+ pinnedUsers: {
+ validator: $.optional.nullable.arr($.str),
+ desc: {
+ 'ja-JP': 'ピン留めユーザー'
+ }
+ },
+
hiddenTags: {
validator: $.optional.nullable.arr($.str),
desc: {
@@ -353,6 +360,10 @@ export default define(meta, async (ps) => {
set.useStarForReactionFallback = ps.useStarForReactionFallback;
}
+ if (Array.isArray(ps.pinnedUsers)) {
+ set.pinnedUsers = ps.pinnedUsers;
+ }
+
if (Array.isArray(ps.hiddenTags)) {
set.hiddenTags = ps.hiddenTags;
}
diff --git a/src/server/api/endpoints/meta.ts b/src/server/api/endpoints/meta.ts
index 793eb5a204..5667e7fbb4 100644
--- a/src/server/api/endpoints/meta.ts
+++ b/src/server/api/endpoints/meta.ts
@@ -160,6 +160,7 @@ export default define(meta, async (ps, me) => {
if (me && (me.isAdmin || me.isModerator)) {
response.useStarForReactionFallback = instance.useStarForReactionFallback;
+ response.pinnedUsers = instance.pinnedUsers;
response.hiddenTags = instance.hiddenTags;
response.recaptchaSecretKey = instance.recaptchaSecretKey;
response.proxyAccount = instance.proxyAccount;
diff --git a/src/server/api/endpoints/pinned-users.ts b/src/server/api/endpoints/pinned-users.ts
new file mode 100644
index 0000000000..de0e17a2ec
--- /dev/null
+++ b/src/server/api/endpoints/pinned-users.ts
@@ -0,0 +1,33 @@
+import define from '../define';
+import { Users } from '../../../models';
+import { types, bool } from '../../../misc/schema';
+import { fetchMeta } from '../../../misc/fetch-meta';
+import parseAcct from '../../../misc/acct/parse';
+import { User } from '../../../models/entities/user';
+
+export const meta = {
+ tags: ['users'],
+
+ requireCredential: false,
+
+ params: {
+ },
+
+ res: {
+ type: types.array,
+ optional: bool.false, nullable: bool.false,
+ items: {
+ type: types.object,
+ optional: bool.false, nullable: bool.false,
+ ref: 'User',
+ }
+ },
+};
+
+export default define(meta, async (ps, me) => {
+ const meta = await fetchMeta();
+
+ const users = await Promise.all(meta.pinnedUsers.map(acct => Users.findOne(parseAcct(acct))));
+
+ return await Users.packMany(users.filter(x => x !== undefined) as User[], me, { detail: true });
+});