123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246 |
- <?php
- /**
- * SPDX-FileCopyrightText: 2016-2024 Nextcloud GmbH and Nextcloud contributors
- * SPDX-FileCopyrightText: 2012-2016 ownCloud, Inc.
- * SPDX-License-Identifier: AGPL-3.0-only
- */
- use OCA\Files_External\Lib\Auth\AuthMechanism;
- use OCA\Files_External\Lib\Backend\Backend;
- use OCA\Files_External\Lib\DefinitionParameter;
- use OCA\Files_External\Service\BackendService;
- /** @var array $_ */
- $canCreateMounts = $_['visibilityType'] === BackendService::VISIBILITY_ADMIN || $_['allowUserMounting'];
- $l->t('Enable encryption');
- $l->t('Enable previews');
- $l->t('Enable sharing');
- $l->t('Check for changes');
- $l->t('Never');
- $l->t('Once every direct access');
- $l->t('Read only');
- script('files_external', [
- 'settings',
- 'templates'
- ]);
- style('files_external', 'settings');
- // load custom JS
- foreach ($_['backends'] as $backend) {
- /** @var Backend $backend */
- $scripts = $backend->getCustomJs();
- foreach ($scripts as $script) {
- script('files_external', $script);
- }
- }
- foreach ($_['authMechanisms'] as $authMechanism) {
- /** @var AuthMechanism $authMechanism */
- $scripts = $authMechanism->getCustomJs();
- foreach ($scripts as $script) {
- script('files_external', $script);
- }
- }
- function writeParameterInput($parameter, $options, $classes = []) {
- $value = '';
- if (isset($options[$parameter->getName()])) {
- $value = $options[$parameter->getName()];
- }
- $placeholder = $parameter->getText();
- $is_optional = $parameter->isFlagSet(DefinitionParameter::FLAG_OPTIONAL);
- switch ($parameter->getType()) {
- case DefinitionParameter::VALUE_PASSWORD: ?>
- <?php if ($is_optional) {
- $classes[] = 'optional';
- } ?>
- <input type="password"
- <?php if (!empty($classes)): ?> class="<?php p(implode(' ', $classes)); ?>"<?php endif; ?>
- data-parameter="<?php p($parameter->getName()); ?>"
- value="<?php p($value); ?>"
- placeholder="<?php p($placeholder); ?>"
- />
- <?php
- break;
- case DefinitionParameter::VALUE_BOOLEAN: ?>
- <?php $checkboxId = uniqid('checkbox_'); ?>
- <div>
- <label>
- <input type="checkbox"
- id="<?php p($checkboxId); ?>"
- <?php if (!empty($classes)): ?> class="checkbox <?php p(implode(' ', $classes)); ?>"<?php endif; ?>
- data-parameter="<?php p($parameter->getName()); ?>"
- <?php if ($value === true): ?> checked="checked"<?php endif; ?>
- />
- <?php p($placeholder); ?>
- </label>
- </div>
- <?php
- break;
- case DefinitionParameter::VALUE_HIDDEN: ?>
- <input type="hidden"
- <?php if (!empty($classes)): ?> class="<?php p(implode(' ', $classes)); ?>"<?php endif; ?>
- data-parameter="<?php p($parameter->getName()); ?>"
- value="<?php p($value); ?>"
- />
- <?php
- break;
- default: ?>
- <?php if ($is_optional) {
- $classes[] = 'optional';
- } ?>
- <input type="text"
- <?php if (!empty($classes)): ?> class="<?php p(implode(' ', $classes)); ?>"<?php endif; ?>
- data-parameter="<?php p($parameter->getName()); ?>"
- value="<?php p($value); ?>"
- placeholder="<?php p($placeholder); ?>"
- />
- <?php
- }
- }
- ?>
- <div class="emptyfilelist emptycontent hidden">
- <div class="icon-external"></div>
- <h2><?php p($l->t('No external storage configured or you don\'t have the permission to configure them')); ?></h2>
- </div>
- <?php
- $canCreateNewLocalStorage = \OC::$server->getConfig()->getSystemValue('files_external_allow_create_new_local', true);
- ?>
- <form data-can-create="<?php echo $canCreateMounts?'true':'false' ?>" data-can-create-local="<?php echo $canCreateNewLocalStorage?'true':'false' ?>" id="files_external" class="section" data-encryption-enabled="<?php echo $_['encryptionEnabled']?'true': 'false'; ?>">
- <h2 class="inlineblock" data-anchor-name="external-storage"><?php p($l->t('External storage')); ?></h2>
- <a target="_blank" rel="noreferrer" class="icon-info" title="<?php p($l->t('Open documentation'));?>" href="<?php p(link_to_docs('admin-external-storage')); ?>"></a>
- <p class="settings-hint"><?php p($l->t('External storage enables you to mount external storage services and devices as secondary Nextcloud storage devices. You may also allow people to mount their own external storage services.')); ?></p>
- <?php if (isset($_['dependencies']) and ($_['dependencies'] !== '') and $canCreateMounts) {
- print_unescaped(''.$_['dependencies'].'');
- } ?>
- <table id="externalStorage" class="grid" data-admin='<?php print_unescaped(json_encode($_['visibilityType'] === BackendService::VISIBILITY_ADMIN)); ?>'>
- <thead>
- <tr>
- <th></th>
- <th><?php p($l->t('Folder name')); ?></th>
- <th><?php p($l->t('External storage')); ?></th>
- <th><?php p($l->t('Authentication')); ?></th>
- <th><?php p($l->t('Configuration')); ?></th>
- <?php if ($_['visibilityType'] === BackendService::VISIBILITY_ADMIN) {
- print_unescaped('<th>'.$l->t('Available for').'</th>');
- } ?>
- <th> </th>
- <th> </th>
- <th> </th>
- </tr>
- </thead>
- <tbody>
- <tr class="externalStorageLoading">
- <td colspan="8">
- <span id="externalStorageLoading" class="icon icon-loading"></span>
- </td>
- </tr>
- <tr id="addMountPoint"
- <?php if (!$canCreateMounts): ?>
- style="display: none;"
- <?php endif; ?>
- >
- <td class="status">
- <span data-placement="right" title="<?php p($l->t('Click to recheck the configuration')); ?>" style="display: none;"></span>
- </td>
- <td class="mountPoint"><input type="text" name="mountPoint" value=""
- placeholder="<?php p($l->t('Folder name')); ?>">
- </td>
- <td class="backend">
- <select id="selectBackend" class="selectBackend" data-configurations='<?php p(json_encode($_['backends'])); ?>'>
- <option value="" disabled selected
- style="display:none;">
- <?php p($l->t('Add storage')); ?>
- </option>
- <?php
- $sortedBackends = array_filter($_['backends'], function ($backend) use ($_) {
- return $backend->isVisibleFor($_['visibilityType']);
- });
- uasort($sortedBackends, function ($a, $b) {
- return strcasecmp($a->getText(), $b->getText());
- });
- ?>
- <?php foreach ($sortedBackends as $backend): ?>
- <?php if ($backend->getDeprecateTo() || (!$canCreateNewLocalStorage && $backend->getIdentifier() == 'local')) {
- continue;
- } // ignore deprecated backends?>
- <option value="<?php p($backend->getIdentifier()); ?>"><?php p($backend->getText()); ?></option>
- <?php endforeach; ?>
- </select>
- </td>
- <td class="authentication" data-mechanisms='<?php p(json_encode($_['authMechanisms'])); ?>'></td>
- <td class="configuration"></td>
- <?php if ($_['visibilityType'] === BackendService::VISIBILITY_ADMIN): ?>
- <td class="applicable" align="right">
- <label><input type="checkbox" class="applicableToAllUsers" checked="" /><?php p($l->t('All people')); ?></label>
- <div class="applicableUsersContainer">
- <input type="hidden" class="applicableUsers" style="width:20em;" value="" />
- </div>
- </td>
- <?php endif; ?>
- <td class="mountOptionsToggle hidden">
- <button type="button" class="icon-more" aria-expanded="false" title="<?php p($l->t('Advanced settings')); ?>"></button>
- <input type="hidden" class="mountOptions" value="" />
- </td>
- <td class="save hidden">
- <button type="button" class="icon-checkmark" title="<?php p($l->t('Save')); ?>"></button>
- </td>
- </tr>
- </tbody>
- </table>
- <?php if ($_['visibilityType'] === BackendService::VISIBILITY_ADMIN): ?>
- <input type="checkbox" name="allowUserMounting" id="allowUserMounting" class="checkbox"
- value="1" <?php if ($_['allowUserMounting']) {
- print_unescaped(' checked="checked"');
- } ?> />
- <label for="allowUserMounting"><?php p($l->t('Allow people to mount external storage')); ?></label> <span id="userMountingMsg" class="msg"></span>
- <p id="userMountingBackends"<?php if (!$_['allowUserMounting']): ?> class="hidden"<?php endif; ?>>
- <?php
- $userBackends = array_filter($_['backends'], function ($backend) {
- return $backend->isAllowedVisibleFor(BackendService::VISIBILITY_PERSONAL);
- });
- ?>
- <?php $i = 0;
- foreach ($userBackends as $backend): ?>
- <?php if ($deprecateTo = $backend->getDeprecateTo()): ?>
- <input type="hidden" id="allowUserMountingBackends<?php p($i); ?>" name="allowUserMountingBackends[]" value="<?php p($backend->getIdentifier()); ?>" data-deprecate-to="<?php p($deprecateTo->getIdentifier()); ?>" />
- <?php else: ?>
- <input type="checkbox" id="allowUserMountingBackends<?php p($i); ?>" class="checkbox" name="allowUserMountingBackends[]" value="<?php p($backend->getIdentifier()); ?>" <?php if ($backend->isVisibleFor(BackendService::VISIBILITY_PERSONAL)) {
- print_unescaped(' checked="checked"');
- } ?> />
- <label for="allowUserMountingBackends<?php p($i); ?>"><?php p($backend->getText()); ?></label> <br />
- <?php endif; ?>
- <?php $i++; ?>
- <?php endforeach; ?>
- </p>
- <?php endif; ?>
- </form>
- <div class="followupsection">
- <form autocomplete="false" action="#"
- id="global_credentials" method="post"
- class="<?php if (isset($_['visibilityType']) && $_['visibilityType'] === BackendService::VISIBILITY_PERSONAL) {
- print_unescaped('global_credentials__personal');
- } ?>">
- <h2><?php p($l->t('Global credentials')); ?></h2>
- <p class="settings-hint"><?php p($l->t('Global credentials can be used to authenticate with multiple external storages that have the same credentials.')); ?></p>
- <input type="text" name="username"
- autocomplete="false"
- value="<?php p($_['globalCredentials']['user']); ?>"
- placeholder="<?php p($l->t('Login')) ?>"/>
- <input type="password" name="password"
- autocomplete="false"
- value="<?php p($_['globalCredentials']['password']); ?>"
- placeholder="<?php p($l->t('Password')) ?>"/>
- <input type="hidden" name="uid"
- value="<?php p($_['globalCredentialsUid']); ?>"/>
- <input type="submit" value="<?php p($l->t('Save')) ?>"/>
- </form>
- </div>
|