diff options
| author | syuilo <syuilotan@yahoo.co.jp> | 2019-05-10 17:30:28 +0900 |
|---|---|---|
| committer | syuilo <syuilotan@yahoo.co.jp> | 2019-05-10 17:30:28 +0900 |
| commit | 8e6da3a0d9f2f6dbd8f1009e1accdb4e4ebae169 (patch) | |
| tree | 464f6e908de12e86eec16ec918adfe3be387b166 /src | |
| parent | テキストのリスト内で変数埋め込みできるように (diff) | |
| download | sharkey-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.vue | 13 | ||||
| -rw-r--r-- | src/client/app/common/views/pages/explore.vue | 4 | ||||
| -rw-r--r-- | src/models/entities/meta.ts | 5 | ||||
| -rw-r--r-- | src/server/api/endpoints/admin/update-meta.ts | 11 | ||||
| -rw-r--r-- | src/server/api/endpoints/meta.ts | 1 | ||||
| -rw-r--r-- | src/server/api/endpoints/pinned-users.ts | 33 |
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 }); +}); |