340 lines
28 KiB
PHP
340 lines
28 KiB
PHP
@section('title', '创建储存策略')
|
|
|
|
<x-app-layout>
|
|
<div class="my-6 md:my-9">
|
|
@include('admin.strategy.tips')
|
|
|
|
<div class="md:mt-0 md:col-span-2">
|
|
<form action="{{ route('admin.strategy.create') }}" method="POST">
|
|
<div class="overflow-hidden rounded-md">
|
|
<div class="px-4 py-5 bg-white sm:p-6 space-y-4">
|
|
<div class="col-span-6">
|
|
<label class="block">
|
|
<span class="text-gray-700">选择角色组</span>
|
|
<x-select name="groups[]" class="block w-full mt-1 form-multiselect" multiple>
|
|
@foreach(\App\Models\Group::query()->get() as $group)
|
|
<option value="{{ $group->id }}">{{ $group->name }}</option>
|
|
@endforeach
|
|
</x-select>
|
|
</label>
|
|
</div>
|
|
|
|
<div class="col-span-6">
|
|
<label for="name" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>名称</label>
|
|
<x-input type="text" name="name" id="name" placeholder="请输入策略名称" autocomplete="name" />
|
|
</div>
|
|
|
|
<div class="col-span-6">
|
|
<label for="intro" class="block text-sm font-medium text-gray-700">简介</label>
|
|
<x-textarea id="intro" name="intro" rows="3" placeholder="请输入简介,可为空"></x-textarea>
|
|
</div>
|
|
|
|
<div class="col-span-6 sm:col-span-3">
|
|
<label for="key" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>储存策略</label>
|
|
<x-select id="key" name="key" autocomplete="key" required>
|
|
@foreach(\App\Models\Strategy::DRIVERS as $key => $driver)
|
|
<option value="{{ $key }}" {{ $loop->first ? 'selected' : '' }}>{{ $driver }}</option>
|
|
@endforeach
|
|
</x-select>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Local }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问网址</label>
|
|
<x-input type="text" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名,需要加 http(s)://" />
|
|
<small class="text-orange-500"><i class="fas fa-exclamation"></i>
|
|
本地储存的访问网址必须有根路径,例如:https://www.lsky.pro/uploads 中的 uploads 就是根路径,且根路径不能和其他策略重复。修改根路径直接影响已经上传并已使用的链接的访问。
|
|
</small>
|
|
</div>
|
|
<div class="col-span-6">
|
|
<div class="col-span-6 sm:col-span-3 mb-4">
|
|
<label for="configs[root]" class="block text-sm font-medium text-gray-700">储存路径</label>
|
|
<x-input type="text" name="configs[root]" id="configs[root]" autocomplete="text" placeholder="图片保存位置,默认:{{ config('filesystems.disks.uploads.root') }}" />
|
|
<small class="text-orange-500"><i class="fas fa-exclamation"></i> 储存路径为绝对路径,设置错误或没有读写权限可能会导致图片保存失败。如果储存路径与其他策略相同,那么请注意使用角色组的路径命名规则、文件命名规则来区分不同文件夹,否则可能会因为名称重复而导致图片物理文件被覆盖。</small>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::S3 }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[access_key_id]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>AccessKeyId</label>
|
|
<x-input type="text" name="configs[access_key_id]" id="configs[access_key_id]" placeholder="请输入 AccessKeyId" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[secret_access_key]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>SecretAccessKey</label>
|
|
<x-input type="password" name="configs[secret_access_key]" id="configs[secret_access_key]" placeholder="请输入 SecretAccessKey" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[region]" class="block text-sm font-medium text-gray-700">区域(region)</label>
|
|
<x-input type="text" name="configs[region]" id="configs[region]" placeholder="请输入区域,例如:us-east-1" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[bucket]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>储存桶名称</label>
|
|
<x-input type="text" name="configs[bucket]" id="configs[bucket]" placeholder="请输入储存桶名称" />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Oss }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[access_key_id]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>AccessKeyId</label>
|
|
<x-input type="text" name="configs[access_key_id]" id="configs[access_key_id]" placeholder="请输入 AccessKeyId" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[access_key_secret]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>AccessKeySecret</label>
|
|
<x-input type="password" name="configs[access_key_secret]" id="configs[access_key_secret]" placeholder="请输入 AccessKeySecret" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[endpoint]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>地域节点(Endpoint)</label>
|
|
<x-input type="text" name="configs[endpoint]" id="configs[endpoint]" placeholder="请输入所属地域节点,例如:oss-cn-beijing.aliyuncs.com" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[bucket]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>Bucket 名称</label>
|
|
<x-input type="text" name="configs[bucket]" id="configs[bucket]" placeholder="请输入 Bucket 名称" />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Cos }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[app_id]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>AppId</label>
|
|
<x-input type="text" name="configs[app_id]" id="configs[app_id]" placeholder="请输入 AppId" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[secret_id]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>SecretId</label>
|
|
<x-input type="text" name="configs[secret_id]" id="configs[secret_id]" placeholder="请输入 SecretId" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[secret_key]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>SecretKey</label>
|
|
<x-input type="password" name="configs[secret_key]" id="configs[secret_key]" placeholder="请输入 SecretKey" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[region]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>所属地域</label>
|
|
<x-input type="text" name="configs[region]" id="configs[region]" placeholder="请输入所属地域,例如:ap-chengdu" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[bucket]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>储存桶名称</label>
|
|
<x-input type="text" name="configs[bucket]" id="configs[bucket]" placeholder="请输入储存桶名称" />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Kodo }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[access_key]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>AccessKey</label>
|
|
<x-input type="text" name="configs[access_key]" id="configs[access_key]" placeholder="请输入 AccessKey" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[secret_key]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>SecretKey</label>
|
|
<x-input type="password" name="configs[secret_key]" id="configs[secret_key]" placeholder="请输入 SecretKey" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[bucket]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>Bucket</label>
|
|
<x-input type="text" name="configs[bucket]" id="configs[bucket]" placeholder="请输入 Bucket" />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Uss }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[service]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>服务名称</label>
|
|
<x-input type="text" name="configs[service]" id="configs[service]" placeholder="请输入服务名称" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[operator]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>操作员名称</label>
|
|
<x-input type="text" name="configs[operator]" id="configs[operator]" placeholder="请输入操作员名称" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[password]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>操作员密码</label>
|
|
<x-input type="password" name="configs[password]" id="configs[password]" placeholder="请输入操作员密码" />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Sftp }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-6">
|
|
<div class="col-span-6 sm:col-span-3 mb-4">
|
|
<label for="configs[root]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>根目录</label>
|
|
<x-input type="text" name="configs[root]" id="configs[root]" autocomplete="text" placeholder="请输入根目录路径" value="/" />
|
|
</div>
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[host]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>主机地址</label>
|
|
<x-input type="text" name="configs[host]" id="configs[host]" placeholder="请输入主机地址,例如:127.0.0.1" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[port]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>连接端口</label>
|
|
<x-input type="number" name="configs[port]" id="configs[port]" placeholder="请输入连接端口" value="22" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[username]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>用户名</label>
|
|
<x-input type="text" name="configs[username]" id="configs[username]" placeholder="请输入用户名" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[password]" class="block text-sm font-medium text-gray-700"><span class="text-yellow-500">*</span>密码</label>
|
|
<x-input type="password" name="configs[password]" id="configs[password]" placeholder="如果使用私钥连接,可为空" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[private_key]" class="block text-sm font-medium text-gray-700"><span class="text-yellow-500">*</span>私钥</label>
|
|
<x-textarea name="configs[private_key]" id="configs[private_key]" placeholder="输入私钥文本内容,如果使用密码连接,可为空"></x-textarea>
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[passphrase]" class="block text-sm font-medium text-gray-700">私钥口令</label>
|
|
<x-input type="password" name="configs[passphrase]" id="configs[passphrase]" placeholder="如果未设置私钥或私钥未设置口令,可为空" />
|
|
</div>
|
|
<div class="col-span-6">
|
|
<label for="configs[use_agent]" class="block text-sm font-medium mb-2 text-gray-700">是否使用代理</label>
|
|
<x-switch id="configs[use_agent]" name="configs[use_agent]" value="1"></x-switch>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Ftp }}">
|
|
@if(! extension_loaded('ftp'))
|
|
<p class="bg-yellow-500 p-2 mb-4 rounded text-sm text-white">
|
|
<i class="fas fa-exclamation-circle"></i> 系统检测到 ftp 拓展未启用,可能无法正常使用 FTP 储存方式。
|
|
</p>
|
|
@endif
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-6">
|
|
<div class="col-span-6 sm:col-span-3 mb-4">
|
|
<label for="configs[root]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>根目录</label>
|
|
<x-input type="text" name="configs[root]" id="configs[root]" autocomplete="text" placeholder="请输入根目录路径" value="/" />
|
|
</div>
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[host]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>主机地址</label>
|
|
<x-input type="text" name="configs[host]" id="configs[host]" placeholder="请输入主机地址,例如:127.0.0.1" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[port]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>连接端口</label>
|
|
<x-input type="number" name="configs[port]" id="configs[port]" placeholder="请输入连接端口 21/20" value="20" />
|
|
<small class="text-gray-500"><i class="fas fa-exclamation-circle"></i> 通常情况下,FTP 的被动模式连接端口为 21,主动模式为 20</small>
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[username]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>用户名</label>
|
|
<x-input type="text" name="configs[username]" id="configs[username]" placeholder="请输入用户名" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[password]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>密码</label>
|
|
<x-input type="password" name="configs[password]" id="configs[password]" placeholder="请输入密码" />
|
|
</div>
|
|
<div class="col-span-6">
|
|
<label for="configs[ssl]" class="block text-sm font-medium mb-2 text-gray-700">加密连接</label>
|
|
<x-switch id="configs[ssl]" name="configs[ssl]" value="1"></x-switch>
|
|
</div>
|
|
<div class="col-span-6">
|
|
<label for="configs[passive]" class="block text-sm font-medium my-2 text-gray-700">被动模式</label>
|
|
<x-switch id="configs[passive]" name="configs[passive]" value="1"></x-switch>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Webdav }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[base_uri]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>连接地址</label>
|
|
<x-input type="url" name="configs[base_uri]" id="configs[base_uri]" placeholder="请输入连接地址" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[username]" class="block text-sm font-medium text-gray-700">用户名</label>
|
|
<x-input type="text" name="configs[username]" id="configs[username]" placeholder="请输入用户名" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[password]" class="block text-sm font-medium text-gray-700">密码</label>
|
|
<x-input type="password" name="configs[password]" id="configs[password]" placeholder="请输入密码" />
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-span-6 mb-4 hidden" data-driver="{{ \App\Enums\StrategyKey::Minio }}">
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[url]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>访问域名</label>
|
|
<x-input type="url" name="configs[url]" id="configs[url]" placeholder="请输入图片访问域名 http(s)://" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[endpoint]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>连接地址</label>
|
|
<x-input type="url" name="configs[endpoint]" id="configs[endpoint]" placeholder="请输入连接地址" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[access_key]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>AccessKey</label>
|
|
<x-input type="text" name="configs[access_key]" id="configs[access_key]" placeholder="请输入 AccessKey" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[secret_key]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>SecretKey</label>
|
|
<x-input type="password" name="configs[secret_key]" id="configs[secret_key]" placeholder="请输入 SecretKey" />
|
|
</div>
|
|
<div class="col-span-3 sm:col-span-2 mb-4">
|
|
<label for="configs[bucket]" class="block text-sm font-medium text-gray-700"><span class="text-red-600">*</span>Bucket 名称</label>
|
|
<x-input type="text" name="configs[bucket]" id="configs[bucket]" placeholder="请输入 Bucket 名称" />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<div class="px-4 py-3 bg-gray-50 text-right sm:px-6">
|
|
<x-button type="button" class="bg-gray-500" onclick="history.go(-1)">取消</x-button>
|
|
<x-button>确认创建</x-button>
|
|
</div>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
@push('scripts')
|
|
<script>
|
|
// 设置选中驱动
|
|
let setSelected = function () {
|
|
$('[data-driver]').each(function () {
|
|
if ($('#key').val() == $(this).data('driver')) {
|
|
$(this).show().find('input').attr('disabled', false);
|
|
} else {
|
|
$(this).hide().find('input').attr('disabled', true);
|
|
}
|
|
});
|
|
};
|
|
|
|
setSelected();
|
|
|
|
$('#key').change(function () {
|
|
setSelected();
|
|
});
|
|
|
|
$('form').submit(function (e) {
|
|
e.preventDefault();
|
|
axios.post(this.action, $(this).serialize()).then(response => {
|
|
if (response.data.status) {
|
|
toastr.success(response.data.message);
|
|
setTimeout(function () {
|
|
window.location.href = '{{ route('admin.strategies') }}';
|
|
}, 3000);
|
|
} else {
|
|
toastr.error(response.data.message);
|
|
}
|
|
});
|
|
});
|
|
</script>
|
|
@endpush
|
|
|
|
</x-app-layout>
|