Add comprehensive cloud-init script management interface in the Security section, allowing users to create, edit, delete, and reuse cloud-init scripts across their team. New Components: - CloudInitScripts: Main listing page with grid view of scripts - CloudInitScriptForm: Modal form for create/edit operations Features: - Create new cloud-init scripts with name and content - Edit existing scripts - Delete scripts with confirmation (requires typing script name) - View script preview (first 200 characters) - Scripts are encrypted in database - Full authorization using CloudInitScriptPolicy - Real-time updates via Livewire events UI Location: - Added to Security section nav: /security/cloud-init-scripts - Positioned between Cloud Tokens and API Tokens - Follows existing security UI patterns Files Created: - app/Livewire/Security/CloudInitScripts.php - app/Livewire/Security/CloudInitScriptForm.php - resources/views/livewire/security/cloud-init-scripts.blade.php - resources/views/livewire/security/cloud-init-script-form.blade.php Files Modified: - routes/web.php - Added route - resources/views/components/security/navbar.blade.php - Added nav link 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude <noreply@anthropic.com>
24 lines
926 B
PHP
24 lines
926 B
PHP
<div class="pb-6">
|
|
<h1>Security</h1>
|
|
<div class="subtitle">Security related settings.</div>
|
|
<div class="navbar-main">
|
|
<nav class="flex items-center gap-6 scrollbar min-h-10">
|
|
<a href="{{ route('security.private-key.index') }}">
|
|
<button>Private Keys</button>
|
|
</a>
|
|
@can('viewAny', App\Models\CloudProviderToken::class)
|
|
<a href="{{ route('security.cloud-tokens') }}">
|
|
<button>Cloud Tokens</button>
|
|
</a>
|
|
@endcan
|
|
@can('viewAny', App\Models\CloudInitScript::class)
|
|
<a href="{{ route('security.cloud-init-scripts') }}">
|
|
<button>Cloud-Init Scripts</button>
|
|
</a>
|
|
@endcan
|
|
<a href="{{ route('security.api-tokens') }}">
|
|
<button>API Tokens</button>
|
|
</a>
|
|
</nav>
|
|
</div>
|
|
</div>
|