mirror of
https://github.com/misskey-dev/misskey.git
synced 2025-01-06 00:09:20 +09:00
7199e6f4e0
* Update reaction.vue
* fix bug
* wip
* wip
* wjio
* wip
* Revert "wip"
This reverts commit e427f2160a
.
* wip
* wip
* wip
* Update init.ts
* Update drive-window.vue
* wip
* wip
* Use PascalCase for components
* Use PascalCase for components
* update dep
* wip
* wip
* wip
* Update init.ts
* wip
* Update paging.ts
* Update test.vue
* watch deep
* wip
* lint
* wip
* wip
* wip
* wip
* wiop
* wip
* Update webpack.config.ts
* alllow null poll
* wip
* wip
* wip
* wiop
* UI redesign & refactor (#6714)
* wip
* wip
* wip
* wip
* wip
* Update drive.vue
* Update word-mute.vue
* wip
* wip
* wip
* clean up
* wip
* Update default.vue
* wip
* Update notes.vue
* Update mfm.ts
* Update index.home.vue
* Update post-form.vue
* Update post-form-attaches.vue
* wip
* Update post-form.vue
* Update sidebar.vue
* wip
* wip
* Update index.vue
* wip
* Update default.vue
* Update index.vue
* Update index.vue
* wip
* Update post-form-attaches.vue
* Update note.vue
* wip
* clean up
* Update notes.vue
* wip
* wip
* Update ja-JP.yml
* wip
* wip
* Update index.vue
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* wip
* Update default.vue
* wip
* Update _dark.json5
* wip
* wip
* wip
* clean up
* wip
* wip
* Update index.vue
* Update test.vue
* wip
* wip
* fix
* wip
* wip
* wip
* wip
* clena yop
* wip
* wip
* Update store.ts
* Update messaging-room.vue
* Update default.widgets.vue
* fix
* wip
* wip
* Update modal.vue
* wip
* Update os.ts
* Update os.ts
* Update deck.vue
* Update init.ts
* wip
* Update ja-JP.yml
* v-sizeは単にwindowのresizeを監視するだけで良いかもしれない
* Update modal.vue
* wip
* Update tooltip.ts
* wip
* wip
* wip
* wip
* wip
* Update image-viewer.vue
* wip
* wip
* Update style.scss
* Update style.scss
* Update visitor.vue
* wip
* Update init.ts
* Update init.ts
* wip
* wip
* Update visitor.vue
* Update visitor.vue
* Update visitor.vue
* Update visitor.vue
* wip
* wip
* Update modal.vue
* Update header.vue
* Update menu.vue
* Update about.vue
* Update about-misskey.vue
* wip
* wip
* Update visitor.vue
* Update tooltip.ts
* wip
* Update drive.vue
* wip
* Update style.scss
* Update header.vue
* wip
* wip
* Update users.user.vue
* Update announcements.vue
* wip
* wip
* wip
* Update emojis.vue
* wip
* Update emojis.vue
* Update style.scss
* Update users.vue
* wip
* Update style.scss
* wip
* Update welcome.entrance.vue
* Update radio.vue
* Update size.ts
* Update emoji-edit-dialog.vue
* wip
* Update emojis.vue
* wip
* Update emojis.vue
* Update emojis.vue
* Update emojis.vue
* wip
* wip
* wip
* wip
* Update file-dialog.vue
* wip
* wip
* Update token-generate-window.vue
* Update notification-setting-window.vue
* wip
* wip
* Update _error_.vue
* Update ja-JP.yml
* wip
* wip
* Update store.ts
* Update emojis.vue
* Update emojis.vue
* Update emojis.vue
* Update announcements.vue
* Update store.ts
* wip
* Update page-editor.vue
* wip
* wip
* Update modal.vue
* wip
* Update select-file.ts
* Update timeline.vue
* Update emojis.vue
* Update os.ts
* wip
* Update user-select.vue
* Update mfm.ts
* Update get-file-info.ts
* Update drive.vue
* Update init.ts
* Update mfm.ts
* wip
* wip
* Update window.vue
* Update note.vue
* wip
* wip
* Update user-info.vue
* wip
* wip
* wip
* wip
* wip
* Update header.vue
* Update header.vue
* wip
* Update explore.vue
* wip
* wip
* wip
* Update webpack.config.ts
* wip
* wip
* wip
* wip
* wip
* wip
* Update autocomplete.ts
* wip
* wip
* wip
* Update toast.vue
* wip
* Update post-form-dialog.vue
* wip
* wip
* wip
* wip
* wip
* Update users.vue
* wip
* Update explore.vue
* wip
* wip
* wip
* Update package.json
* wip
* Update icon-dialog.vue
* wip
* wip
* Update user-preview.ts
* wip
* wip
* wip
* wip
* wip
* Update instance.vue
* Update user-name.vue
* Update federation.vue
* Update instance.vue
* wip
* wip
* Update tag.vue
* wip
* wip
* wip
* wip
* wip
* Update instance.vue
* wip
* Update os.ts
* Update os.ts
* wip
* wip
* wip
* Update router.ts
* wip
* Update init.ts
* Update note.vue
* Update messages.vue
* wip
* wip
* wip
* wip
* wip
* google
* wip
* wip
* wip
* wip
* Update theme-editor.vue
* wip
* wip
* Update room.vue
* Update channel-editor.vue
* wip
* Update window.vue
* Update window.vue
* wip
* Update window.vue
* Update window.vue
* wip
* Update menu.vue
* wip
* wip
* wip
* wip
* Update messaging-room.vue
* wip
* Update post-form.vue
* Update default.widgets.vue
* Update window.vue
* wip
559 lines
24 KiB
Vue
559 lines
24 KiB
Vue
<template>
|
|
<div v-if="meta">
|
|
<section class="_section info">
|
|
<div class="_title"><Fa :icon="faInfoCircle"/> {{ $t('basicInfo') }}</div>
|
|
<div class="_content">
|
|
<MkInput v-model:value="name">{{ $t('instanceName') }}</MkInput>
|
|
<MkTextarea v-model:value="description">{{ $t('instanceDescription') }}</MkTextarea>
|
|
<MkInput v-model:value="iconUrl"><template #icon><Fa :icon="faLink"/></template>{{ $t('iconUrl') }}</MkInput>
|
|
<MkInput v-model:value="bannerUrl"><template #icon><Fa :icon="faLink"/></template>{{ $t('bannerUrl') }}</MkInput>
|
|
<MkInput v-model:value="tosUrl"><template #icon><Fa :icon="faLink"/></template>{{ $t('tosUrl') }}</MkInput>
|
|
<MkInput v-model:value="maintainerName">{{ $t('maintainerName') }}</MkInput>
|
|
<MkInput v-model:value="maintainerEmail" type="email"><template #icon><Fa :icon="faEnvelope"/></template>{{ $t('maintainerEmail') }}</MkInput>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section info">
|
|
<div class="_content">
|
|
<MkInput v-model:value="maxNoteTextLength" type="number" :save="() => save()" style="margin:0;"><template #icon><Fa :icon="faPencilAlt"/></template>{{ $t('maxNoteTextLength') }}</MkInput>
|
|
</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="enableLocalTimeline" @update:value="save()">{{ $t('enableLocalTimeline') }}</MkSwitch>
|
|
<MkSwitch v-model:value="enableGlobalTimeline" @update:value="save()">{{ $t('enableGlobalTimeline') }}</MkSwitch>
|
|
<MkInfo>{{ $t('disablingTimelinesInfo') }}</MkInfo>
|
|
</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="useStarForReactionFallback" @update:value="save()">{{ $t('useStarForReactionFallback') }}</MkSwitch>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section info">
|
|
<div class="_title"><Fa :icon="faUser"/> {{ $t('registration') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="enableRegistration" @update:value="save()">{{ $t('enableRegistration') }}</MkSwitch>
|
|
<MkButton v-if="!enableRegistration" @click="invite">{{ $t('invite') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faShieldAlt"/> {{ $t('hcaptcha') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="enableHcaptcha">{{ $t('enableHcaptcha') }}</MkSwitch>
|
|
<template v-if="enableHcaptcha">
|
|
<MkInput v-model:value="hcaptchaSiteKey" :disabled="!enableHcaptcha"><template #icon><Fa :icon="faKey"/></template>{{ $t('hcaptchaSiteKey') }}</MkInput>
|
|
<MkInput v-model:value="hcaptchaSecretKey" :disabled="!enableHcaptcha"><template #icon><Fa :icon="faKey"/></template>{{ $t('hcaptchaSecretKey') }}</MkInput>
|
|
</template>
|
|
</div>
|
|
<div class="_content" v-if="enableHcaptcha">
|
|
<header>{{ $t('preview') }}</header>
|
|
<captcha v-if="enableHcaptcha" provider="hcaptcha" :sitekey="hcaptchaSiteKey || '10000000-ffff-ffff-ffff-000000000001'"/>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faShieldAlt"/> {{ $t('recaptcha') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="enableRecaptcha" ref="enableRecaptcha">{{ $t('enableRecaptcha') }}</MkSwitch>
|
|
<template v-if="enableRecaptcha">
|
|
<MkInput v-model:value="recaptchaSiteKey" :disabled="!enableRecaptcha"><template #icon><Fa :icon="faKey"/></template>{{ $t('recaptchaSiteKey') }}</MkInput>
|
|
<MkInput v-model:value="recaptchaSecretKey" :disabled="!enableRecaptcha"><template #icon><Fa :icon="faKey"/></template>{{ $t('recaptchaSecretKey') }}</MkInput>
|
|
</template>
|
|
</div>
|
|
<div class="_content" v-if="enableRecaptcha && recaptchaSiteKey">
|
|
<header>{{ $t('preview') }}</header>
|
|
<captcha v-if="enableRecaptcha" provider="grecaptcha" :sitekey="recaptchaSiteKey"/>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faEnvelope" /> {{ $t('emailConfig') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="enableEmail" @update:value="save()">{{ $t('enableEmail') }}<template #desc>{{ $t('emailConfigInfo') }}</template></MkSwitch>
|
|
<MkInput v-model:value="email" type="email" :disabled="!enableEmail">{{ $t('email') }}</MkInput>
|
|
<div><b>{{ $t('smtpConfig') }}</b></div>
|
|
<div class="_inputs">
|
|
<MkInput v-model:value="smtpHost" :disabled="!enableEmail">{{ $t('smtpHost') }}</MkInput>
|
|
<MkInput v-model:value="smtpPort" type="number" :disabled="!enableEmail">{{ $t('smtpPort') }}</MkInput>
|
|
</div>
|
|
<div class="_inputs">
|
|
<MkInput v-model:value="smtpUser" :disabled="!enableEmail">{{ $t('smtpUser') }}</MkInput>
|
|
<MkInput v-model:value="smtpPass" type="password" :disabled="!enableEmail">{{ $t('smtpPass') }}</MkInput>
|
|
</div>
|
|
<MkInfo>{{ $t('emptyToDisableSmtpAuth') }}</MkInfo>
|
|
<MkSwitch v-model:value="smtpSecure" :disabled="!enableEmail">{{ $t('smtpSecure') }}<template #desc>{{ $t('smtpSecureInfo') }}</template></MkSwitch>
|
|
<div>
|
|
<MkButton :disabled="!enableEmail" inline @click="testEmail()">{{ $t('testEmail') }}</MkButton>
|
|
<MkButton :disabled="!enableEmail" primary inline @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faBolt"/> {{ $t('serviceworker') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="enableServiceWorker">{{ $t('enableServiceworker') }}<template #desc>{{ $t('serviceworkerInfo') }}</template></MkSwitch>
|
|
<template v-if="enableServiceWorker">
|
|
<div class="_inputs">
|
|
<MkInput v-model:value="swPublicKey" :disabled="!enableServiceWorker"><template #icon><Fa :icon="faKey"/></template>Public key</MkInput>
|
|
<MkInput v-model:value="swPrivateKey" :disabled="!enableServiceWorker"><template #icon><Fa :icon="faKey"/></template>Private key</MkInput>
|
|
</div>
|
|
</template>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faThumbtack"/> {{ $t('pinnedUsers') }}</div>
|
|
<div class="_content">
|
|
<MkTextarea v-model:value="pinnedUsers">
|
|
<template #desc>{{ $t('pinnedUsersDescription') }} <button class="_textButton" @click="addPinUser">{{ $t('addUser') }}</button></template>
|
|
</MkTextarea>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faCloud"/> {{ $t('files') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="cacheRemoteFiles">{{ $t('cacheRemoteFiles') }}<template #desc>{{ $t('cacheRemoteFilesDescription') }}</template></MkSwitch>
|
|
<MkSwitch v-model:value="proxyRemoteFiles">{{ $t('proxyRemoteFiles') }}<template #desc>{{ $t('proxyRemoteFilesDescription') }}</template></MkSwitch>
|
|
<MkInput v-model:value="localDriveCapacityMb" type="number">{{ $t('driveCapacityPerLocalAccount') }}<template #suffix>MB</template><template #desc>{{ $t('inMb') }}</template></MkInput>
|
|
<MkInput v-model:value="remoteDriveCapacityMb" type="number" :disabled="!cacheRemoteFiles" style="margin-bottom: 0;">{{ $t('driveCapacityPerRemoteAccount') }}<template #suffix>MB</template><template #desc>{{ $t('inMb') }}</template></MkInput>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faCloud"/> {{ $t('objectStorage') }}</div>
|
|
<div class="_content">
|
|
<MkSwitch v-model:value="useObjectStorage">{{ $t('useObjectStorage') }}</MkSwitch>
|
|
<template v-if="useObjectStorage">
|
|
<MkInput v-model:value="objectStorageBaseUrl" :disabled="!useObjectStorage">{{ $t('objectStorageBaseUrl') }}<template #desc>{{ $t('objectStorageBaseUrlDesc') }}</template></MkInput>
|
|
<div class="_inputs">
|
|
<MkInput v-model:value="objectStorageBucket" :disabled="!useObjectStorage">{{ $t('objectStorageBucket') }}<template #desc>{{ $t('objectStorageBucketDesc') }}</template></MkInput>
|
|
<MkInput v-model:value="objectStoragePrefix" :disabled="!useObjectStorage">{{ $t('objectStoragePrefix') }}<template #desc>{{ $t('objectStoragePrefixDesc') }}</template></MkInput>
|
|
</div>
|
|
<MkInput v-model:value="objectStorageEndpoint" :disabled="!useObjectStorage">{{ $t('objectStorageEndpoint') }}<template #desc>{{ $t('objectStorageEndpointDesc') }}</template></MkInput>
|
|
<div class="_inputs">
|
|
<MkInput v-model:value="objectStorageRegion" :disabled="!useObjectStorage">{{ $t('objectStorageRegion') }}<template #desc>{{ $t('objectStorageRegionDesc') }}</template></MkInput>
|
|
</div>
|
|
<div class="_inputs">
|
|
<MkInput v-model:value="objectStorageAccessKey" :disabled="!useObjectStorage"><template #icon><Fa :icon="faKey"/></template>Access key</MkInput>
|
|
<MkInput v-model:value="objectStorageSecretKey" :disabled="!useObjectStorage"><template #icon><Fa :icon="faKey"/></template>Secret key</MkInput>
|
|
</div>
|
|
<MkSwitch v-model:value="objectStorageUseSSL" :disabled="!useObjectStorage">{{ $t('objectStorageUseSSL') }}<template #desc>{{ $t('objectStorageUseSSLDesc') }}</template></MkSwitch>
|
|
<MkSwitch v-model:value="objectStorageUseProxy" :disabled="!useObjectStorage">{{ $t('objectStorageUseProxy') }}<template #desc>{{ $t('objectStorageUseProxyDesc') }}</template></MkSwitch>
|
|
<MkSwitch v-model:value="objectStorageSetPublicRead" :disabled="!useObjectStorage">{{ $t('objectStorageSetPublicRead') }}</MkSwitch>
|
|
</template>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faGhost"/> {{ $t('proxyAccount') }}</div>
|
|
<div class="_content">
|
|
<MkInput :value="proxyAccount ? proxyAccount.username : null" style="margin: 0;" disabled><template #prefix>@</template>{{ $t('proxyAccount') }}<template #desc>{{ $t('proxyAccountDescription') }}</template></MkInput>
|
|
<MkButton primary @click="chooseProxyAccount">{{ $t('chooseProxyAccount') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faBan"/> {{ $t('blockedInstances') }}</div>
|
|
<div class="_content">
|
|
<MkTextarea v-model:value="blockedHosts">
|
|
<template #desc>{{ $t('blockedInstancesDescription') }}</template>
|
|
</MkTextarea>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faShareAlt"/> {{ $t('integration') }}</div>
|
|
<div class="_content">
|
|
<header><Fa :icon="faTwitter"/> Twitter</header>
|
|
<MkSwitch v-model:value="enableTwitterIntegration">{{ $t('enable') }}</MkSwitch>
|
|
<template v-if="enableTwitterIntegration">
|
|
<MkInfo>Callback URL: {{ `${url}/api/tw/cb` }}</MkInfo>
|
|
<MkInput v-model:value="twitterConsumerKey" :disabled="!enableTwitterIntegration"><template #icon><Fa :icon="faKey"/></template>Consumer Key</MkInput>
|
|
<MkInput v-model:value="twitterConsumerSecret" :disabled="!enableTwitterIntegration"><template #icon><Fa :icon="faKey"/></template>Consumer Secret</MkInput>
|
|
</template>
|
|
</div>
|
|
<div class="_content">
|
|
<header><Fa :icon="faGithub"/> GitHub</header>
|
|
<MkSwitch v-model:value="enableGithubIntegration">{{ $t('enable') }}</MkSwitch>
|
|
<template v-if="enableGithubIntegration">
|
|
<MkInfo>Callback URL: {{ `${url}/api/gh/cb` }}</MkInfo>
|
|
<MkInput v-model:value="githubClientId" :disabled="!enableGithubIntegration"><template #icon><Fa :icon="faKey"/></template>Client ID</MkInput>
|
|
<MkInput v-model:value="githubClientSecret" :disabled="!enableGithubIntegration"><template #icon><Fa :icon="faKey"/></template>Client Secret</MkInput>
|
|
</template>
|
|
</div>
|
|
<div class="_content">
|
|
<header><Fa :icon="faDiscord"/> Discord</header>
|
|
<MkSwitch v-model:value="enableDiscordIntegration">{{ $t('enable') }}</MkSwitch>
|
|
<template v-if="enableDiscordIntegration">
|
|
<MkInfo>Callback URL: {{ `${url}/api/dc/cb` }}</MkInfo>
|
|
<MkInput v-model:value="discordClientId" :disabled="!enableDiscordIntegration"><template #icon><Fa :icon="faKey"/></template>Client ID</MkInput>
|
|
<MkInput v-model:value="discordClientSecret" :disabled="!enableDiscordIntegration"><template #icon><Fa :icon="faKey"/></template>Client Secret</MkInput>
|
|
</template>
|
|
</div>
|
|
<div class="_footer">
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
|
|
<section class="_section">
|
|
<div class="_title"><Fa :icon="faArchway" /> Summaly Proxy</div>
|
|
<div class="_content">
|
|
<MkInput v-model:value="summalyProxy">URL</MkInput>
|
|
<MkButton primary @click="save(true)"><Fa :icon="faSave"/> {{ $t('save') }}</MkButton>
|
|
</div>
|
|
</section>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts">
|
|
import { defineComponent, defineAsyncComponent } from 'vue';
|
|
import { faPencilAlt, faShareAlt, faGhost, faCog, faPlus, faCloud, faInfoCircle, faBan, faSave, faServer, faLink, faThumbtack, faUser, faShieldAlt, faKey, faBolt, faArchway } from '@fortawesome/free-solid-svg-icons';
|
|
import { faTrashAlt, faEnvelope } from '@fortawesome/free-regular-svg-icons';
|
|
import { faTwitter, faDiscord, faGithub } from '@fortawesome/free-brands-svg-icons';
|
|
import MkButton from '@/components/ui/button.vue';
|
|
import MkInput from '@/components/ui/input.vue';
|
|
import MkTextarea from '@/components/ui/textarea.vue';
|
|
import MkSwitch from '@/components/ui/switch.vue';
|
|
import MkInfo from '@/components/ui/info.vue';
|
|
import { url } from '@/config';
|
|
import getAcct from '../../../misc/acct/render';
|
|
import * as os from '@/os';
|
|
|
|
export default defineComponent({
|
|
components: {
|
|
MkButton,
|
|
MkInput,
|
|
MkTextarea,
|
|
MkSwitch,
|
|
MkInfo,
|
|
Captcha: defineAsyncComponent(() => import('@/components/captcha.vue')),
|
|
},
|
|
|
|
data() {
|
|
return {
|
|
INFO: {
|
|
header: [{
|
|
title: this.$t('instance'),
|
|
icon: faCog,
|
|
}],
|
|
},
|
|
url,
|
|
proxyAccount: null,
|
|
proxyAccountId: null,
|
|
cacheRemoteFiles: false,
|
|
proxyRemoteFiles: false,
|
|
localDriveCapacityMb: 0,
|
|
remoteDriveCapacityMb: 0,
|
|
blockedHosts: '',
|
|
pinnedUsers: '',
|
|
maintainerName: null,
|
|
maintainerEmail: null,
|
|
name: null,
|
|
description: null,
|
|
tosUrl: null as string | null,
|
|
enableEmail: false,
|
|
email: null,
|
|
bannerUrl: null,
|
|
iconUrl: null,
|
|
maxNoteTextLength: 0,
|
|
enableRegistration: false,
|
|
enableLocalTimeline: false,
|
|
enableGlobalTimeline: false,
|
|
enableHcaptcha: false,
|
|
hcaptchaSiteKey: null,
|
|
hcaptchaSecretKey: null,
|
|
enableRecaptcha: false,
|
|
recaptchaSiteKey: null,
|
|
recaptchaSecretKey: null,
|
|
enableServiceWorker: false,
|
|
swPublicKey: null,
|
|
swPrivateKey: null,
|
|
useObjectStorage: false,
|
|
objectStorageBaseUrl: null,
|
|
objectStorageBucket: null,
|
|
objectStoragePrefix: null,
|
|
objectStorageEndpoint: null,
|
|
objectStorageRegion: null,
|
|
objectStoragePort: null,
|
|
objectStorageAccessKey: null,
|
|
objectStorageSecretKey: null,
|
|
objectStorageUseSSL: false,
|
|
objectStorageUseProxy: false,
|
|
objectStorageSetPublicRead: false,
|
|
enableTwitterIntegration: false,
|
|
twitterConsumerKey: null,
|
|
twitterConsumerSecret: null,
|
|
enableGithubIntegration: false,
|
|
githubClientId: null,
|
|
githubClientSecret: null,
|
|
enableDiscordIntegration: false,
|
|
discordClientId: null,
|
|
discordClientSecret: null,
|
|
useStarForReactionFallback: false,
|
|
smtpSecure: false,
|
|
smtpHost: '',
|
|
smtpPort: 0,
|
|
smtpUser: '',
|
|
smtpPass: '',
|
|
summalyProxy: '',
|
|
faPencilAlt, faTwitter, faDiscord, faGithub, faShareAlt, faTrashAlt, faGhost, faCog, faPlus, faCloud, faInfoCircle, faBan, faSave, faServer, faLink, faEnvelope, faThumbtack, faUser, faShieldAlt, faKey, faBolt, faArchway
|
|
}
|
|
},
|
|
|
|
computed: {
|
|
meta() {
|
|
return this.$store.state.instance.meta;
|
|
},
|
|
},
|
|
|
|
created() {
|
|
this.name = this.meta.name;
|
|
this.description = this.meta.description;
|
|
this.tosUrl = this.meta.tosUrl;
|
|
this.bannerUrl = this.meta.bannerUrl;
|
|
this.iconUrl = this.meta.iconUrl;
|
|
this.enableEmail = this.meta.enableEmail;
|
|
this.email = this.meta.email;
|
|
this.maintainerName = this.meta.maintainerName;
|
|
this.maintainerEmail = this.meta.maintainerEmail;
|
|
this.maxNoteTextLength = this.meta.maxNoteTextLength;
|
|
this.enableRegistration = !this.meta.disableRegistration;
|
|
this.enableLocalTimeline = !this.meta.disableLocalTimeline;
|
|
this.enableGlobalTimeline = !this.meta.disableGlobalTimeline;
|
|
this.enableHcaptcha = this.meta.enableHcaptcha;
|
|
this.hcaptchaSiteKey = this.meta.hcaptchaSiteKey;
|
|
this.hcaptchaSecretKey = this.meta.hcaptchaSecretKey;
|
|
this.enableRecaptcha = this.meta.enableRecaptcha;
|
|
this.recaptchaSiteKey = this.meta.recaptchaSiteKey;
|
|
this.recaptchaSecretKey = this.meta.recaptchaSecretKey;
|
|
this.proxyAccountId = this.meta.proxyAccountId;
|
|
this.cacheRemoteFiles = this.meta.cacheRemoteFiles;
|
|
this.proxyRemoteFiles = this.meta.proxyRemoteFiles;
|
|
this.localDriveCapacityMb = this.meta.driveCapacityPerLocalUserMb;
|
|
this.remoteDriveCapacityMb = this.meta.driveCapacityPerRemoteUserMb;
|
|
this.blockedHosts = this.meta.blockedHosts.join('\n');
|
|
this.pinnedUsers = this.meta.pinnedUsers.join('\n');
|
|
this.enableServiceWorker = this.meta.enableServiceWorker;
|
|
this.swPublicKey = this.meta.swPublickey;
|
|
this.swPrivateKey = this.meta.swPrivateKey;
|
|
this.useObjectStorage = this.meta.useObjectStorage;
|
|
this.objectStorageBaseUrl = this.meta.objectStorageBaseUrl;
|
|
this.objectStorageBucket = this.meta.objectStorageBucket;
|
|
this.objectStoragePrefix = this.meta.objectStoragePrefix;
|
|
this.objectStorageEndpoint = this.meta.objectStorageEndpoint;
|
|
this.objectStorageRegion = this.meta.objectStorageRegion;
|
|
this.objectStoragePort = this.meta.objectStoragePort;
|
|
this.objectStorageAccessKey = this.meta.objectStorageAccessKey;
|
|
this.objectStorageSecretKey = this.meta.objectStorageSecretKey;
|
|
this.objectStorageUseSSL = this.meta.objectStorageUseSSL;
|
|
this.objectStorageUseProxy = this.meta.objectStorageUseProxy;
|
|
this.objectStorageSetPublicRead = this.meta.objectStorageSetPublicRead;
|
|
this.enableTwitterIntegration = this.meta.enableTwitterIntegration;
|
|
this.twitterConsumerKey = this.meta.twitterConsumerKey;
|
|
this.twitterConsumerSecret = this.meta.twitterConsumerSecret;
|
|
this.enableGithubIntegration = this.meta.enableGithubIntegration;
|
|
this.githubClientId = this.meta.githubClientId;
|
|
this.githubClientSecret = this.meta.githubClientSecret;
|
|
this.enableDiscordIntegration = this.meta.enableDiscordIntegration;
|
|
this.discordClientId = this.meta.discordClientId;
|
|
this.discordClientSecret = this.meta.discordClientSecret;
|
|
this.useStarForReactionFallback = this.meta.useStarForReactionFallback;
|
|
this.smtpSecure = this.meta.smtpSecure;
|
|
this.smtpHost = this.meta.smtpHost;
|
|
this.smtpPort = this.meta.smtpPort;
|
|
this.smtpUser = this.meta.smtpUser;
|
|
this.smtpPass = this.meta.smtpPass;
|
|
this.summalyProxy = this.meta.summalyProxy;
|
|
|
|
if (this.proxyAccountId) {
|
|
os.api('users/show', { userId: this.proxyAccountId }).then(proxyAccount => {
|
|
this.proxyAccount = proxyAccount;
|
|
});
|
|
}
|
|
},
|
|
|
|
mounted() {
|
|
this.$watch('enableHcaptcha', () => {
|
|
if (this.enableHcaptcha && this.enableRecaptcha) {
|
|
os.dialog({
|
|
type: 'question', // warning だと間違って cancel するかもしれない
|
|
showCancelButton: true,
|
|
title: this.$t('settingGuide'),
|
|
text: this.$t('avoidMultiCaptchaConfirm'),
|
|
}).then(({ canceled }) => {
|
|
if (canceled) {
|
|
return;
|
|
}
|
|
|
|
this.enableRecaptcha = false;
|
|
});
|
|
}
|
|
});
|
|
|
|
this.$watch('enableRecaptcha', () => {
|
|
if (this.enableRecaptcha && this.enableHcaptcha) {
|
|
os.dialog({
|
|
type: 'question', // warning だと間違って cancel するかもしれない
|
|
showCancelButton: true,
|
|
title: this.$t('settingGuide'),
|
|
text: this.$t('avoidMultiCaptchaConfirm'),
|
|
}).then(({ canceled }) => {
|
|
if (canceled) {
|
|
return;
|
|
}
|
|
|
|
this.enableHcaptcha = false;
|
|
});
|
|
}
|
|
});
|
|
},
|
|
|
|
methods: {
|
|
invite() {
|
|
os.api('admin/invite').then(x => {
|
|
os.dialog({
|
|
type: 'info',
|
|
text: x.code
|
|
});
|
|
}).catch(e => {
|
|
os.dialog({
|
|
type: 'error',
|
|
text: e
|
|
});
|
|
});
|
|
},
|
|
|
|
addPinUser() {
|
|
os.selectUser().then(user => {
|
|
this.pinnedUsers = this.pinnedUsers.trim();
|
|
this.pinnedUsers += '\n@' + getAcct(user);
|
|
this.pinnedUsers = this.pinnedUsers.trim();
|
|
});
|
|
},
|
|
|
|
chooseProxyAccount() {
|
|
os.selectUser().then(user => {
|
|
this.proxyAccount = user;
|
|
this.proxyAccountId = user.id;
|
|
this.save(true);
|
|
});
|
|
},
|
|
|
|
async testEmail() {
|
|
os.api('admin/send-email', {
|
|
to: this.maintainerEmail,
|
|
subject: 'Test email',
|
|
text: 'Yo'
|
|
}).then(x => {
|
|
os.dialog({
|
|
type: 'success',
|
|
splash: true
|
|
});
|
|
}).catch(e => {
|
|
os.dialog({
|
|
type: 'error',
|
|
text: e
|
|
});
|
|
});
|
|
},
|
|
|
|
save(withDialog = false) {
|
|
os.api('admin/update-meta', {
|
|
name: this.name,
|
|
description: this.description,
|
|
tosUrl: this.tosUrl,
|
|
bannerUrl: this.bannerUrl,
|
|
iconUrl: this.iconUrl,
|
|
maintainerName: this.maintainerName,
|
|
maintainerEmail: this.maintainerEmail,
|
|
maxNoteTextLength: this.maxNoteTextLength,
|
|
disableRegistration: !this.enableRegistration,
|
|
disableLocalTimeline: !this.enableLocalTimeline,
|
|
disableGlobalTimeline: !this.enableGlobalTimeline,
|
|
enableHcaptcha: this.enableHcaptcha,
|
|
hcaptchaSiteKey: this.hcaptchaSiteKey,
|
|
hcaptchaSecretKey: this.hcaptchaSecretKey,
|
|
enableRecaptcha: this.enableRecaptcha,
|
|
recaptchaSiteKey: this.recaptchaSiteKey,
|
|
recaptchaSecretKey: this.recaptchaSecretKey,
|
|
proxyAccountId: this.proxyAccountId,
|
|
cacheRemoteFiles: this.cacheRemoteFiles,
|
|
proxyRemoteFiles: this.proxyRemoteFiles,
|
|
localDriveCapacityMb: parseInt(this.localDriveCapacityMb, 10),
|
|
remoteDriveCapacityMb: parseInt(this.remoteDriveCapacityMb, 10),
|
|
blockedHosts: this.blockedHosts.split('\n') || [],
|
|
pinnedUsers: this.pinnedUsers ? this.pinnedUsers.split('\n') : [],
|
|
enableServiceWorker: this.enableServiceWorker,
|
|
swPublicKey: this.swPublicKey,
|
|
swPrivateKey: this.swPrivateKey,
|
|
useObjectStorage: this.useObjectStorage,
|
|
objectStorageBaseUrl: this.objectStorageBaseUrl ? this.objectStorageBaseUrl : null,
|
|
objectStorageBucket: this.objectStorageBucket ? this.objectStorageBucket : null,
|
|
objectStoragePrefix: this.objectStoragePrefix ? this.objectStoragePrefix : null,
|
|
objectStorageEndpoint: this.objectStorageEndpoint ? this.objectStorageEndpoint : null,
|
|
objectStorageRegion: this.objectStorageRegion ? this.objectStorageRegion : null,
|
|
objectStoragePort: this.objectStoragePort ? this.objectStoragePort : null,
|
|
objectStorageAccessKey: this.objectStorageAccessKey ? this.objectStorageAccessKey : null,
|
|
objectStorageSecretKey: this.objectStorageSecretKey ? this.objectStorageSecretKey : null,
|
|
objectStorageUseSSL: this.objectStorageUseSSL,
|
|
objectStorageUseProxy: this.objectStorageUseProxy,
|
|
objectStorageSetPublicRead: this.objectStorageSetPublicRead,
|
|
enableTwitterIntegration: this.enableTwitterIntegration,
|
|
twitterConsumerKey: this.twitterConsumerKey,
|
|
twitterConsumerSecret: this.twitterConsumerSecret,
|
|
enableGithubIntegration: this.enableGithubIntegration,
|
|
githubClientId: this.githubClientId,
|
|
githubClientSecret: this.githubClientSecret,
|
|
enableDiscordIntegration: this.enableDiscordIntegration,
|
|
discordClientId: this.discordClientId,
|
|
discordClientSecret: this.discordClientSecret,
|
|
enableEmail: this.enableEmail,
|
|
email: this.email,
|
|
smtpSecure: this.smtpSecure,
|
|
smtpHost: this.smtpHost,
|
|
smtpPort: this.smtpPort,
|
|
smtpUser: this.smtpUser,
|
|
smtpPass: this.smtpPass,
|
|
summalyProxy: this.summalyProxy,
|
|
useStarForReactionFallback: this.useStarForReactionFallback,
|
|
}).then(() => {
|
|
this.$store.dispatch('instance/fetch');
|
|
if (withDialog) {
|
|
os.success();
|
|
}
|
|
}).catch(e => {
|
|
os.dialog({
|
|
type: 'error',
|
|
text: e
|
|
});
|
|
});
|
|
}
|
|
}
|
|
});
|
|
</script>
|