| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268 |
- {% extends '../layout/admin.html' %}
- {% block html_title %}アプリ設定 · {% endblock %}
- {% block content_head %}
- <div class="header-wrap">
- <header id="page-header">
- <h1 class="title" id="">アプリ設定</h1>
- </header>
- </div>
- {% endblock %}
- {% block content_main %}
- <div class="content-main">
- {% set smessage = req.flash('successMessage') %}
- {% if smessage.length %}
- <div class="alert alert-success">
- {{ smessage }}
- </div>
- {% endif %}
- {% set emessage = req.flash('errorMessage') %}
- {% if emessage.length %}
- <div class="alert alert-danger">
- {{ emessage }}
- </div>
- {% endif %}
- <div class="row">
- <div class="col-md-3">
- {% include './widget/menu.html' with {current: 'app'} %}
- </div>
- <div class="col-md-9">
- <form action="/_api/admin/settings/app" method="post" class="form-horizontal" id="appSettingForm" role="form">
- <fieldset>
- <legend>アプリ設定</legend>
- <div class="form-group">
- <label for="settingForm[app:title]" class="col-xs-3 control-label">Wikiの名前</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[app:title]" value="{{ settingForm['app:title'] }}">
- <p class="help-block">ヘッダーやHTMLタイトルに使用されるWikiの名前を変更できます。</p>
- </div>
- </div>
- <div class="form-group">
- <label for="settingForm[app:confidential]" class="col-xs-3 control-label">コンフィデンシャル表示</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[app:confidential]" value="{{ settingForm['app:confidential'] }}" placeholder="例: 社外秘">
- <p class="help-block">ここに入力した内容は、ヘッダー等に表示されます。</p>
- </div>
- </div>
- <div class="form-group">
- <div class="col-xs-offset-3 col-xs-6">
- <input type="checkbox" name="settingForm[app:fileUpload]" value="1"
- {% if settingForm['app:fileUpload'] %}
- checked
- {% endif %}
- {% if not isUploadable() %}
- disabled="disabled"
- {% else %}
- {% endif %}
- >
- <label for="settingForm[app:fileUpload]" class="">画像以外のファイルアップロードを許可</label>
- <p class="help-block">
- ファイルアップロードの設定を有効にしている場合にのみ、選択可能です。<br>
- 許可をしている場合、画像以外のファイルをページに添付可能になります。
- </p>
- </div>
- </div>
- <div class="form-group">
- <div class="col-xs-offset-3 col-xs-6">
- <input type="hidden" name="_csrf" value="{{ csrf() }}">
- <button type="submit" class="btn btn-primary">更新</button>
- </div>
- </div>
- </fieldset>
- </form>
- <form action="/_api/admin/settings/mail" method="post" class="form-horizontal" id="mailSettingForm" role="form">
- <fieldset>
- <legend>メールの設定</legend>
- <p class="well">SMTPの設定がされている場合、それが利用されます。SMTP設定がなく、AWSの設定がある場合、SESでの送信を試みます。<br>どちらの設定もない場合、メールは送信されません。</p>
- <div class="form-group">
- <label for="settingForm[mail.from]" class="col-xs-3 control-label">Fromアドレス</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[mail:from]" placeholder="例: mail@crowi.wiki" value="{{ settingForm['mail:from'] }}">
- </div>
- </div>
- <div class="form-group">
- <label class="col-xs-3 control-label">SMTP設定</label>
- <div class="col-xs-4">
- <label for="">ホスト</label>
- <input class="form-control" type="text" name="settingForm[mail:smtpHost]" value="{{ settingForm['mail:smtpHost']|default('') }}">
- </div>
- <div class="col-xs-2">
- <label for="">ポート</label>
- <input class="form-control" type="text" name="settingForm[mail:smtpPort]" value="{{ settingForm['mail:smtpPort']|default('') }}">
- </div>
- </div>
- <div class="form-group">
- <div class="col-xs-3 col-xs-offset-3">
- <label for="">ユーザー</label>
- <input class="form-control" type="text" name="settingForm[mail:smtpUser]" value="{{ settingForm['mail:smtpUser']|default('') }}">
- </div>
- <div class="col-xs-3">
- <label for="">パスワード</label>
- <input class="form-control" type="password" name="settingForm[mail:smtpPassword]" value="{{ settingForm['mail:smtpPassword']|default('') }}">
- </div>
- </div>
- <div class="form-group">
- <div class="col-xs-offset-3 col-xs-6">
- <input type="hidden" name="_csrf" value="{{ csrf() }}">
- <button type="submit" class="btn btn-primary">更新</button>
- </div>
- </div>
- </fieldset>
- </form>
- <form action="/_api/admin/settings/aws" method="post" class="form-horizontal" id="awsSettingForm" role="form">
- <fieldset>
- <legend>AWS設定</legend>
- <p class="well">AWS にアクセスするための設定を行います。AWS の設定を完了させると、ファイルアップロード機能、プロフィール写真機能などが有効になります。<br>
- また、SMTP の設定が無い場合、SES を利用したメール送信が行われます。FromメールアドレスのVerify、プロダクション利用設定をする必要があります。<br>
- <br>
- <span class="text-danger"><i class="fa fa-warning"></i> この設定を途中で変更すると、これまでにアップロードしたファイル等へのアクセスができなくなりますのでご注意下さい。</span>
- </p>
- <div class="form-group">
- <label for="settingForm[app.region]" class="col-xs-3 control-label">リージョン</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[aws:region]" placeholder="例: ap-northeast-1" value="{{ settingForm['aws:region'] }}">
- </div>
- </div>
- <div class="form-group">
- <label for="settingForm[aws:bucket]" class="col-xs-3 control-label">バケット名</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[aws:bucket]" placeholder="例: crowi" value="{{ settingForm['aws:bucket'] }}">
- </div>
- </div>
- <div class="form-group">
- <label for="settingForm[aws:accessKeyId]" class="col-xs-3 control-label">Access Key ID</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[aws:accessKeyId]" value="{{ settingForm['aws:accessKeyId'] }}">
- </div>
- </div>
- <div class="form-group">
- <label for="settingForm[aws:secretAccessKey]" class="col-xs-3 control-label">Secret Access Key</label>
- <div class="col-xs-6">
- <input class="form-control" type="text" name="settingForm[aws:secretAccessKey]" value="{{ settingForm['aws:secretAccessKey'] }}">
- </div>
- </div>
- <div class="form-group">
- <div class="col-xs-offset-3 col-xs-6">
- <input type="hidden" name="_csrf" value="{{ csrf() }}">
- <button type="submit" class="btn btn-primary">更新</button>
- </div>
- </div>
- </fieldset>
- </form>
- <form action="/_api/admin/settings/plugin" method="post" class="form-horizontal" id="pluginSettingForm" role="form">
- <fieldset>
- <legend>プラグイン設定</legend>
- <p class="well">プラグインの読み込みを有効にします。</p>
- <div class="form-group">
- <label for="settingForm[plugin:isEnabledPlugins]" class="col-xs-3 control-label">プラグインを読み込む</label>
- <div class="col-xs-6">
- <div class="btn-group btn-toggle" data-toggle="buttons">
- <label class="btn btn-default {% if settingForm['plugin:isEnabledPlugins'] %}active{% endif %}" data-active-class="primary">
- <input name="settingForm[plugin:isEnabledPlugins]" value="true" type="radio"
- {% if true === settingForm['plugin:isEnabledPlugins'] %}checked{% endif %}> 有効
- </label>
- <label class="btn btn-default {% if !settingForm['plugin:isEnabledPlugins'] %}active{% endif %}" data-active-class="primary">
- <input name="settingForm[plugin:isEnabledPlugins]" value="false" type="radio"
- {% if !settingForm['plugin:isEnabledPlugins'] %}checked{% endif %}> 無効
- </label>
- </div>
- </div>
- </div>
- <div class="form-group">
- <div class="col-xs-offset-3 col-xs-6">
- <input type="hidden" name="_csrf" value="{{ csrf() }}">
- <button type="submit" class="btn btn-primary">更新</button>
- </div>
- </div>
- </fieldset>
- </form>
- </div>
- </div>
- <script>
- $('#appSettingForm, #mailSettingForm, #awsSettingForm, #pluginSettingForm').each(function() {
- $(this).submit(function()
- {
- function showMessage(formId, msg, status) {
- $('#' + formId + ' .alert').remove();
- if (!status) {
- status = 'success';
- }
- var $message = $('<p class="alert"></p>');
- $message.addClass('alert-' + status);
- $message.html(msg.replace('\n', '<br>'));
- $message.insertAfter('#' + formId + ' legend');
- if (status == 'success') {
- setTimeout(function()
- {
- $message.fadeOut({
- complete: function() {
- $message.remove();
- }
- });
- }, 5000);
- }
- }
- var $form = $(this);
- var $id = $form.attr('id');
- var $button = $('button', this);
- $button.attr('disabled', 'disabled');
- var jqxhr = $.post($form.attr('action'), $form.serialize(), function(data)
- {
- if (data.status) {
- showMessage($id, '更新しました');
- } else {
- showMessage($id, data.message, 'danger');
- }
- })
- .fail(function() {
- showMessage($id, 'エラーが発生しました', 'danger');
- })
- .always(function() {
- $button.prop('disabled', false);
- });
- return false;
- });
- });
- </script>
- </div>
- {% endblock content_main %}
- {% block content_footer %}
- {% endblock content_footer %}
|