Add server deletion to a queue.
This action allows servers to be deleted, but only be soft-deleted for 10 minutes. After that time period the server will be completely removed from the database and daemon. This allows some safety if a server is accidentally deleted. Force deleting a server will still work. If the daemon is in-accessible the server will fail to be deleted. When server is soft-deleted admins can still view its information page in the admin CP, however the server will be suspended and inaccessible on the front-end or though the daemon. Admins can manually delete the server ahead of the delete timer, or if it failed to delete previously they can do an immediate retry.
This commit is contained in:
parent
dbec99498d
commit
6fd7c78f0c
12 changed files with 377 additions and 38 deletions
|
@ -49,8 +49,21 @@
|
|||
</thead>
|
||||
<tbody>
|
||||
@foreach ($servers as $server)
|
||||
<tr @if($server->suspended === 1)class="warning"@endif data-server="{{ $server->uuidShort }}">
|
||||
<td><a href="/admin/servers/view/{{ $server->id }}">{{ $server->name }}</a>@if($server->suspended === 1) <span class="label label-warning">Suspended</span>@endif</td>
|
||||
<tr
|
||||
@if($server->suspended === 1 && !$server->trashed())
|
||||
class="warning"
|
||||
@elseif($server->trashed())
|
||||
class="danger"
|
||||
@endif
|
||||
data-server="{{ $server->uuidShort }}">
|
||||
<td>
|
||||
<a href="/admin/servers/view/{{ $server->id }}">{{ $server->name }}</a>
|
||||
@if($server->suspended === 1 && !$server->trashed())
|
||||
<span class="label label-warning">Suspended</span>
|
||||
@elseif($server->trashed())
|
||||
<span class="label label-danger">Pending Deletion</span>
|
||||
@endif
|
||||
</td>
|
||||
<td><a href="/admin/users/view/{{ $server->owner }}">{{ $server->a_ownerEmail }}</a></td>
|
||||
<td><a href="/admin/nodes/view/{{ $server->node }}">{{ $server->a_nodeName }}</a></td>
|
||||
<td class="hidden-xs"><code>{{ $server->username }}</code></td>
|
||||
|
|
|
@ -30,10 +30,21 @@
|
|||
<li><a href="/admin/servers">Servers</a></li>
|
||||
<li class="active">{{ $server->name }} ({{ $server->uuidShort}})</li>
|
||||
</ul>
|
||||
@if($server->suspended === 1)
|
||||
<div class="alert alert-warning">
|
||||
This server is suspended and has no user access. Processes cannot be started and files cannot be modified. All API access is disabled unless using a master token.
|
||||
</div>
|
||||
@if($server->suspended === 1 && !$server->trashed())
|
||||
<div class="alert alert-warning">
|
||||
This server is suspended and has no user access. Processes cannot be started and files cannot be modified. All API access is disabled unless using a master token.
|
||||
</div>
|
||||
@elseif($server->trashed())
|
||||
<div class="alert alert-danger">
|
||||
This server is marked for deletion <strong>{{ Carbon::parse($server->deleted_at)->addMinutes(env('APP_DELETE_MINUTES', 10))->diffForHumans() }}</strong>. If you want to cancel this action simply click the button below.
|
||||
<br /><br />
|
||||
<form action="{{ route('admin.servers.post.queuedDeletion', $server->id) }}" method="POST">
|
||||
<button class="btn btn-sm btn-default" name="cancel" value="1">Cancel Deletion</button>
|
||||
<button class="btn btn-sm btn-danger pull-right" name="force_delete" value="1"><strong>Force</strong> Delete</button>
|
||||
<button class="btn btn-sm btn-danger pull-right" name="delete" style="margin-right:10px;" value="1">Delete</button>
|
||||
{!! csrf_field() !!}
|
||||
</form>
|
||||
</div>
|
||||
@endif
|
||||
@if($server->installed === 0)
|
||||
<div class="alert alert-warning">
|
||||
|
@ -55,7 +66,7 @@
|
|||
@if($server->installed !== 2)
|
||||
<li><a href="#tab_manage" data-toggle="tab">Manage</a></li>
|
||||
@endif
|
||||
<li><a href="#tab_delete" data-toggle="tab">Delete</a></li>
|
||||
@if(!$server->trashed())<li><a href="#tab_delete" data-toggle="tab">Delete</a></li>@endif
|
||||
</ul>
|
||||
<div class="tab-content">
|
||||
<div class="tab-pane active" id="tab_about">
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue