More schedule changes

This commit is contained in:
Dane Everitt 2017-09-13 21:46:43 -05:00
parent 457c910c35
commit 7f76684453
No known key found for this signature in database
GPG key ID: EEA66103B3D71F53
20 changed files with 365 additions and 348 deletions

View file

@ -48,13 +48,13 @@ class TaskController extends Controller
$this->authorize('list-tasks', $server); $this->authorize('list-tasks', $server);
$server->js(); $server->js();
return view('server.tasks.index', [ return view('server.schedules.index', [
'server' => $server, 'server' => $server,
'node' => $server->node, 'node' => $server->node,
'tasks' => $server->tasks, 'tasks' => $server->tasks,
'actions' => [ 'actions' => [
'command' => trans('server.tasks.actions.command'), 'command' => trans('server.schedules.actions.command'),
'power' => trans('server.tasks.actions.power'), 'power' => trans('server.schedules.actions.power'),
], ],
]); ]);
} }
@ -72,7 +72,7 @@ class TaskController extends Controller
$this->authorize('create-task', $server); $this->authorize('create-task', $server);
$server->js(); $server->js();
return view('server.tasks.new', [ return view('server.schedules.new', [
'server' => $server, 'server' => $server,
'node' => $server->node, 'node' => $server->node,
]); ]);
@ -96,9 +96,9 @@ class TaskController extends Controller
'_token', '_token',
])); ]));
return redirect()->route('server.tasks', $uuid); return redirect()->route('server.schedules', $uuid);
} catch (DisplayValidationException $ex) { } catch (DisplayValidationException $ex) {
return redirect()->route('server.tasks.new', $uuid)->withErrors(json_decode($ex->getMessage()))->withInput(); return redirect()->route('server.schedules.new', $uuid)->withErrors(json_decode($ex->getMessage()))->withInput();
} catch (DisplayException $ex) { } catch (DisplayException $ex) {
Alert::danger($ex->getMessage())->flash(); Alert::danger($ex->getMessage())->flash();
} catch (\Exception $ex) { } catch (\Exception $ex) {
@ -106,7 +106,7 @@ class TaskController extends Controller
Alert::danger('An unknown error occured while attempting to create this task.')->flash(); Alert::danger('An unknown error occured while attempting to create this task.')->flash();
} }
return redirect()->route('server.tasks.new', $uuid); return redirect()->route('server.schedules.new', $uuid);
} }
/** /**

View file

@ -24,8 +24,8 @@
namespace Pterodactyl\Http\Controllers\Server\Tasks; namespace Pterodactyl\Http\Controllers\Server\Tasks;
use Illuminate\Http\Request;
use Prologue\Alerts\AlertsMessageBag; use Prologue\Alerts\AlertsMessageBag;
use Pterodactyl\Http\Requests\Request;
use Illuminate\Contracts\Session\Session; use Illuminate\Contracts\Session\Session;
use Pterodactyl\Http\Controllers\Controller; use Pterodactyl\Http\Controllers\Controller;
use Pterodactyl\Contracts\Extensions\HashidsInterface; use Pterodactyl\Contracts\Extensions\HashidsInterface;
@ -99,11 +99,11 @@ class TaskManagementController extends Controller
$this->authorize('list-schedules', $server); $this->authorize('list-schedules', $server);
$this->injectJavascript(); $this->injectJavascript();
return view('server.tasks.index', [ return view('server.schedules.index', [
'schedules' => $this->repository->getServerSchedules($server->id), 'schedules' => $this->repository->getServerSchedules($server->id),
'actions' => [ 'actions' => [
'command' => trans('server.tasks.actions.command'), 'command' => trans('server.schedule.actions.command'),
'power' => trans('server.tasks.actions.power'), 'power' => trans('server.schedule.actions.power'),
], ],
]); ]);
} }
@ -121,7 +121,7 @@ class TaskManagementController extends Controller
$this->authorize('create-schedule', $server); $this->authorize('create-schedule', $server);
$this->injectJavascript(); $this->injectJavascript();
return view('server.tasks.new'); return view('server.schedules.new');
} }
/** /**
@ -138,9 +138,9 @@ class TaskManagementController extends Controller
$this->authorize('create-schedule', $server); $this->authorize('create-schedule', $server);
$schedule = $this->creationService->handle($server, $request->normalize(), $request->getTasks()); $schedule = $this->creationService->handle($server, $request->normalize(), $request->getTasks());
$this->alert->success(trans('server.tasks.task_created'))->flash(); $this->alert->success(trans('server.schedules.task_created'))->flash();
return redirect()->route('server.tasks.view', [ return redirect()->route('server.schedules.view', [
'server' => $server->uuidShort, 'server' => $server->uuidShort,
'task' => $schedule->hashid, 'task' => $schedule->hashid,
]); ]);
@ -149,7 +149,7 @@ class TaskManagementController extends Controller
/** /**
* Return a view to modify a schedule. * Return a view to modify a schedule.
* *
* @param \Pterodactyl\Http\Requests\Request $request * @param \Illuminate\Http\Request $request
* @return \Illuminate\View\View * @return \Illuminate\View\View
* @throws \Illuminate\Auth\Access\AuthorizationException * @throws \Illuminate\Auth\Access\AuthorizationException
*/ */
@ -165,7 +165,7 @@ class TaskManagementController extends Controller
}), }),
]); ]);
return view('server.tasks.view', ['schedule' => $schedule]); return view('server.schedules.view', ['schedule' => $schedule]);
} }
/** /**
@ -183,9 +183,9 @@ class TaskManagementController extends Controller
$this->authorize('edit-schedule', $server); $this->authorize('edit-schedule', $server);
// $this->updateService->handle($task, $request->normalize(), $request->getChainedTasks()); // $this->updateService->handle($task, $request->normalize(), $request->getChainedTasks());
$this->alert->success(trans('server.tasks.task_updated'))->flash(); // $this->alert->success(trans('server.schedules.task_updated'))->flash();
return redirect()->route('server.tasks.view', [ return redirect()->route('server.schedules.view', [
'server' => $server->uuidShort, 'server' => $server->uuidShort,
'task' => $schedule->hashid, 'task' => $schedule->hashid,
]); ]);
@ -194,7 +194,7 @@ class TaskManagementController extends Controller
/** /**
* Delete a parent task from the Panel. * Delete a parent task from the Panel.
* *
* @param \Pterodactyl\Http\Requests\Request $request * @param \Illuminate\Http\Request $request
* @return \Illuminate\Http\RedirectResponse * @return \Illuminate\Http\RedirectResponse
* *
* @throws \Illuminate\Auth\Access\AuthorizationException * @throws \Illuminate\Auth\Access\AuthorizationException
@ -205,7 +205,7 @@ class TaskManagementController extends Controller
$schedule = $request->attributes->get('schedule'); $schedule = $request->attributes->get('schedule');
$this->authorize('delete-schedule', $server); $this->authorize('delete-schedule', $server);
$this->repository->delete($task->id); $this->repository->delete($schedule->id);
return response('', 204); return response('', 204);
} }

View file

@ -77,10 +77,10 @@ class ScheduleAccess
{ {
$server = $this->session->get('server_data.model'); $server = $this->session->get('server_data.model');
$scheduleId = $this->hashids->decodeFirst($request->route()->parameter('task'), 0); $scheduleId = $this->hashids->decodeFirst($request->route()->parameter('schedule'), 0);
$schedule = $this->repository->getScheduleWithTasks($scheduleId); $schedule = $this->repository->getScheduleWithTasks($scheduleId);
if ($schedule->server_id !== $server->id) { if (object_get($schedule, 'server_id') !== $server->id) {
abort(404); abort(404);
} }

View file

@ -42,11 +42,11 @@ class ScheduleCreationFormRequest extends FrontendUserFormRequest
'cron_hour' => 'required|string', 'cron_hour' => 'required|string',
'cron_minute' => 'required|string', 'cron_minute' => 'required|string',
'tasks' => 'sometimes|array|size:4', 'tasks' => 'sometimes|array|size:4',
'tasks.time_value' => 'required_with:chain|max:5', 'tasks.time_value' => 'required_with:tasks|max:5',
'tasks.time_interval' => 'required_with:chain|max:5', 'tasks.time_interval' => 'required_with:tasks|max:5',
'tasks.action' => 'required_with:chain|max:5', 'tasks.action' => 'required_with:tasks|max:5',
'tasks.payload' => 'required_with:chain|max:5', 'tasks.payload' => 'required_with:tasks|max:5',
'tasks.time_value.*' => 'numeric|between:1,60', 'tasks.time_value.*' => 'numeric|between:0,59',
'tasks.time_interval.*' => 'string|in:s,m', 'tasks.time_interval.*' => 'string|in:s,m',
'tasks.action.*' => 'string|in:power,command', 'tasks.action.*' => 'string|in:power,command',
'tasks.payload.*' => 'string', 'tasks.payload.*' => 'string',

View file

@ -106,12 +106,13 @@ class Permission extends Model implements CleansAttributes
'download-files' => null, 'download-files' => null,
], ],
'task' => [ 'task' => [
'list-tasks' => null, 'list-schedules' => null,
'view-task' => null, 'view-schedule' => null,
'toggle-task' => null, 'toggle-schedule' => null,
'queue-task' => null, 'queue-schedule' => null,
'create-task' => null, 'edit-schedule' => null,
'delete-task' => null, 'create-schedule' => null,
'delete-schedule' => null,
], ],
'database' => [ 'database' => [
'view-databases' => null, 'view-databases' => null,

View file

@ -55,7 +55,7 @@ class Task extends Model implements CleansAttributes, ValidableContract
*/ */
protected $fillable = [ protected $fillable = [
'schedule_id', 'schedule_id',
'squence_id', 'sequence_id',
'action', 'action',
'payload', 'payload',
'time_offset', 'time_offset',
@ -70,7 +70,7 @@ class Task extends Model implements CleansAttributes, ValidableContract
protected $casts = [ protected $casts = [
'id' => 'integer', 'id' => 'integer',
'schedule_id' => 'integer', 'schedule_id' => 'integer',
'squence_id' => 'integer', 'sequence_id' => 'integer',
'time_offset' => 'integer', 'time_offset' => 'integer',
'is_queued' => 'boolean', 'is_queued' => 'boolean',
]; ];
@ -89,7 +89,7 @@ class Task extends Model implements CleansAttributes, ValidableContract
*/ */
protected static $applicationRules = [ protected static $applicationRules = [
'schedule_id' => 'required', 'schedule_id' => 'required',
'squence_id' => 'required', 'sequence_id' => 'required',
'action' => 'required', 'action' => 'required',
'payload' => 'required', 'payload' => 'required',
'time_offset' => 'required', 'time_offset' => 'required',
@ -100,7 +100,7 @@ class Task extends Model implements CleansAttributes, ValidableContract
*/ */
protected static $dataIntegrityRules = [ protected static $dataIntegrityRules = [
'schedule_id' => 'numeric|exists:schedules,id', 'schedule_id' => 'numeric|exists:schedules,id',
'squence_id' => 'numeric|min:1', 'sequence_id' => 'numeric|min:1',
'action' => 'string', 'action' => 'string',
'payload' => 'string', 'payload' => 'string',
'time_offset' => 'numeric|between:0,900', 'time_offset' => 'numeric|between:0,900',

View file

@ -0,0 +1,43 @@
<?php
use Illuminate\Support\Facades\DB;
use Illuminate\Database\Migrations\Migration;
class UpdateOldPermissionsToPointToNewScheduleSystem extends Migration
{
/**
* Run the migrations.
*/
public function up()
{
$permissions = DB::table('permissions')->where('permission', 'like', '%-task%')->get();
foreach ($permissions as $record) {
$parts = explode('-', $record->permission);
if (! in_array(array_get($parts, 1), ['tasks', 'task']) || count($parts) !== 2) {
continue;
}
$newPermission = $parts[0] . '-' . str_replace('task', 'schedule', $parts[1]);
DB::table('permissions')->where('id', '=', $record->id)->update(['permission' => $newPermission]);
}
}
/**
* Reverse the migrations.
*/
public function down()
{
$permissions = DB::table('permissions')->where('permission', 'like', '%-schedule%')->get();
foreach ($permissions as $record) {
$parts = explode('-', $record->permission);
if (! in_array(array_get($parts, 1), ['schedules', 'schedule']) || count($parts) !== 2) {
continue;
}
$newPermission = $parts[0] . '-' . str_replace('schedule', 'task', $parts[1]);
DB::table('permissions')->where('id', '=', $record->id)->update(['permission' => $newPermission]);
}
}
}

File diff suppressed because one or more lines are too long

View file

@ -19,24 +19,24 @@
// SOFTWARE. // SOFTWARE.
$(document).ready(function () { $(document).ready(function () {
$('[data-action="delete-task"]').click(function () { $('[data-action="delete-schedule"]').click(function () {
var self = $(this); var self = $(this);
swal({ swal({
type: 'error', type: 'error',
title: 'Delete Task?', title: 'Delete Schedule?',
text: 'Are you sure you want to delete this task? There is no undo.', text: 'Are you sure you want to delete this schedule? There is no undo.',
showCancelButton: true, showCancelButton: true,
allowOutsideClick: true, allowOutsideClick: true,
closeOnConfirm: false, closeOnConfirm: false,
confirmButtonText: 'Delete Task', confirmButtonText: 'Delete Schedule',
confirmButtonColor: '#d9534f', confirmButtonColor: '#d9534f',
showLoaderOnConfirm: true showLoaderOnConfirm: true
}, function () { }, function () {
$.ajax({ $.ajax({
method: 'DELETE', method: 'DELETE',
url: Router.route('server.tasks.delete', { url: Router.route('server.schedules.delete', {
server: Pterodactyl.server.uuidShort, server: Pterodactyl.server.uuidShort,
task: self.data('taskid'), schedule: self.data('schedule-id'),
}), }),
headers: { headers: {
'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content'), 'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content'),
@ -45,7 +45,7 @@ $(document).ready(function () {
swal({ swal({
type: 'success', type: 'success',
title: '', title: '',
text: 'Task has been deleted.' text: 'Schedule has been deleted.'
}); });
self.parent().parent().slideUp(); self.parent().parent().slideUp();
}).fail(function (jqXHR) { }).fail(function (jqXHR) {
@ -53,18 +53,18 @@ $(document).ready(function () {
swal({ swal({
type: 'error', type: 'error',
title: 'Whoops!', title: 'Whoops!',
text: 'An error occured while attempting to delete this task.' text: 'An error occured while attempting to delete this schedule.'
}); });
}); });
}); });
}); });
$('[data-action="toggle-task"]').click(function (event) { $('[data-action="toggle-schedule"]').click(function (event) {
var self = $(this); var self = $(this);
swal({ swal({
type: 'info', type: 'info',
title: 'Toggle Task', title: 'Toggle Schedule',
text: 'This will toggle the selected task.', text: 'This will toggle the selected schedule.',
showCancelButton: true, showCancelButton: true,
allowOutsideClick: true, allowOutsideClick: true,
closeOnConfirm: false, closeOnConfirm: false,
@ -73,9 +73,9 @@ $(document).ready(function () {
}, function () { }, function () {
$.ajax({ $.ajax({
method: 'POST', method: 'POST',
url: Router.route('server.tasks.toggle', { url: Router.route('server.schedules.toggle', {
server: Pterodactyl.server.uuidShort, server: Pterodactyl.server.uuidShort,
task: self.data('taskid'), schedule: self.data('schedule-id'),
}), }),
headers: { headers: {
'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content'), 'X-CSRF-TOKEN': $('meta[name="_token"]').attr('content'),
@ -84,7 +84,7 @@ $(document).ready(function () {
swal({ swal({
type: 'success', type: 'success',
title: '', title: '',
text: 'Task has been toggled.' text: 'Schedule has been toggled.'
}); });
if (data.status !== 1) { if (data.status !== 1) {
self.parent().parent().addClass('muted muted-hover'); self.parent().parent().addClass('muted muted-hover');
@ -96,7 +96,7 @@ $(document).ready(function () {
swal({ swal({
type: 'error', type: 'error',
title: 'Whoops!', title: 'Whoops!',
text: 'An error occured while attempting to toggle this task.' text: 'An error occured while attempting to toggle this schedule.'
}); });
}); });
}); });

View file

@ -20,9 +20,9 @@
$(document).ready(function () { $(document).ready(function () {
function setupSelect2() { function setupSelect2() {
$('select[name="chain[time_value][]"]').select2(); $('select[name="tasks[time_value][]"]').select2();
$('select[name="chain[time_interval][]"]').select2(); $('select[name="tasks[time_interval][]"]').select2();
$('select[name="chain[action][]"]').select2(); $('select[name="tasks[action][]"]').select2();
} }
setupSelect2(); setupSelect2();

View file

@ -18,7 +18,7 @@ return [
'create_file' => 'Create File', 'create_file' => 'Create File',
'upload_files' => 'Upload Files', 'upload_files' => 'Upload Files',
'subusers' => 'Subusers', 'subusers' => 'Subusers',
'task_management' => 'Task Management', 'schedules' => 'Schedules',
'configuration' => 'Configuration', 'configuration' => 'Configuration',
'port_allocations' => 'Port Allocations', 'port_allocations' => 'Port Allocations',
'sftp_settings' => 'SFTP Settings', 'sftp_settings' => 'SFTP Settings',

View file

@ -7,17 +7,30 @@ return [
'header_sub' => 'Control your server in real time.', 'header_sub' => 'Control your server in real time.',
], ],
'schedule' => [ 'schedule' => [
'header' => 'Schedule Manager',
'header_sub' => 'Manage all of this server\'s schedules in one place.',
'current' => 'Current Schedules',
'new' => [ 'new' => [
'header' => 'Create New Schedule', 'header' => 'Create New Schedule',
'header_sub' => 'Create a new set of scheduled tasks for this server.', 'header_sub' => 'Create a new set of scheduled tasks for this server.',
'submit' => 'Create Schedule', 'submit' => 'Create Schedule',
], ],
'manage' => [
'header' => 'Manage Schedule',
'submit' => 'Update Schedule',
'delete' => 'Delete Schedule',
],
'task' => [ 'task' => [
'time' => 'After', 'time' => 'After',
'action' => 'Perform Action', 'action' => 'Perform Action',
'payload' => 'With Payload', 'payload' => 'With Payload',
'add_more' => 'Add Another Task', 'add_more' => 'Add Another Task',
], ],
'actions' => [
'command' => 'Send Command',
'power' => 'Power Action',
],
'unnamed' => 'Unnamed Schedule',
'setup' => 'Schedule Setup', 'setup' => 'Schedule Setup',
'day_of_week' => 'Day of Week', 'day_of_week' => 'Day of Week',
'day_of_month' => 'Day of Month', 'day_of_month' => 'Day of Month',
@ -89,7 +102,7 @@ return [
'file_header' => 'File Management', 'file_header' => 'File Management',
'subuser_header' => 'Subuser Management', 'subuser_header' => 'Subuser Management',
'server_header' => 'Server Management', 'server_header' => 'Server Management',
'task_header' => 'Task Management', 'task_header' => 'Schedule Management',
'sftp_header' => 'SFTP Management', 'sftp_header' => 'SFTP Management',
'database_header' => 'Database Management', 'database_header' => 'Database Management',
'power_start' => [ 'power_start' => [
@ -188,29 +201,33 @@ return [
'title' => 'Edit Startup Command', 'title' => 'Edit Startup Command',
'description' => 'Allows a user to modify startup variables for a server.', 'description' => 'Allows a user to modify startup variables for a server.',
], ],
'list_tasks' => [ 'list_schedules' => [
'title' => 'List Tasks', 'title' => 'List Schedules',
'description' => 'Allows a user to list all tasks (enabled and disabled) on a server.', 'description' => 'Allows a user to list all schedules (enabled and disabled) for this server.',
], ],
'view_task' => [ 'view_schedule' => [
'title' => 'View Task', 'title' => 'View Schedule',
'description' => 'Allows a user to view a specific task\'s details.', 'description' => 'Allows a user to view a specific schedule\'s details including all of the assigned tasks.',
], ],
'toggle_task' => [ 'toggle_schedule' => [
'title' => 'Toggle Task', 'title' => 'Toggle Schedule',
'description' => 'Allows a user to toggle a task on or off.', 'description' => 'Allows a user to toggle a schedule to be active or inactive.',
], ],
'queue_task' => [ 'queue_schedule' => [
'title' => 'Queue Task', 'title' => 'Queue Schedule',
'description' => 'Allows a user to queue a task to run on next cycle.', 'description' => 'Allows a user to queue a schedule to run it\'s tasks on the next process cycle.',
], ],
'create_task' => [ 'edit_schedule' => [
'title' => 'Create Task', 'title' => 'Edit Schedule',
'description' => 'Allows a user to create new tasks.', 'description' => 'Allows a user to edit a schedule including all of the schedule\'s tasks. This will allow the user to remove individual tasks, but not delete the schedule itself.',
], ],
'delete_task' => [ 'create_schedule' => [
'title' => 'Delete Task', 'title' => 'Create Schedule',
'description' => 'Allows a user to delete a task.', 'description' => 'Allows a user to create a new schedule.',
],
'delete_schedule' => [
'title' => 'Delete Schedule',
'description' => 'Allows a user to delete a schedule from the server.',
], ],
'view_sftp' => [ 'view_sftp' => [
'title' => 'View SFTP Details', 'title' => 'View SFTP Details',

View file

@ -74,4 +74,13 @@ return [
'tasks' => 'Tasks', 'tasks' => 'Tasks',
'seconds' => 'Seconds', 'seconds' => 'Seconds',
'minutes' => 'Minutes', 'minutes' => 'Minutes',
'days' => [
'sun' => 'Sunday',
'mon' => 'Monday',
'tues' => 'Tuesday',
'wed' => 'Wednesday',
'thurs' => 'Thursday',
'fri' => 'Friday',
'sat' => 'Saturday',
],
]; ];

View file

@ -157,12 +157,12 @@
@endcan @endcan
@can('list-tasks', $server) @can('list-tasks', $server)
<li <li
@if(starts_with(Route::currentRouteName(), 'server.tasks')) @if(starts_with(Route::currentRouteName(), 'server.schedules'))
class="active" class="active"
@endif @endif
> >
<a href="{{ route('server.tasks', $server->uuidShort)}}"> <a href="{{ route('server.schedules', $server->uuidShort)}}">
<i class="fa fa-clock-o"></i> <span>@lang('navigation.server.task_management')</span> <i class="fa fa-clock-o"></i> <span>@lang('navigation.server.schedules')</span>
<span class="pull-right-container"> <span class="pull-right-container">
<span class="label label-primary pull-right">{{ \Pterodactyl\Models\Schedule::select('id')->where('server_id', $server->id)->where('is_active', 1)->count() }}</span> <span class="label label-primary pull-right">{{ \Pterodactyl\Models\Schedule::select('id')->where('server_id', $server->id)->where('is_active', 1)->count() }}</span>
</span> </span>

View file

@ -5,14 +5,14 @@
<label class="control-label">@lang('server.schedule.task.time')</label> <label class="control-label">@lang('server.schedule.task.time')</label>
<div class="row"> <div class="row">
<div class="col-xs-4"> <div class="col-xs-4">
<select name="chain[time_value][]" class="form-control"> <select name="tasks[time_value][]" class="form-control">
@foreach(range(0, 59) as $number) @foreach(range(0, 59) as $number)
<option value="{{ $number }}">{{ $number }}</option> <option value="{{ $number }}">{{ $number }}</option>
@endforeach @endforeach
</select> </select>
</div> </div>
<div class="col-xs-8"> <div class="col-xs-8">
<select name="chain[time_interval][]" class="form-control"> <select name="tasks[time_interval][]" class="form-control">
<option value="s">@lang('strings.seconds')</option> <option value="s">@lang('strings.seconds')</option>
<option value="m">@lang('strings.minutes')</option> <option value="m">@lang('strings.minutes')</option>
</select> </select>
@ -22,16 +22,16 @@
<div class="form-group col-md-3"> <div class="form-group col-md-3">
<label class="control-label">@lang('server.schedule.task.action')</label> <label class="control-label">@lang('server.schedule.task.action')</label>
<div> <div>
<select name="chain[action][]" class="form-control"> <select name="tasks[action][]" class="form-control">
<option value="command">@lang('server.tasks.actions.command')</option> <option value="command">@lang('server.schedule.actions.command')</option>
<option value="power">@lang('server.tasks.actions.power')</option> <option value="power">@lang('server.schedule.actions.power')</option>
</select> </select>
</div> </div>
</div> </div>
<div class="form-group col-md-6"> <div class="form-group col-md-6">
<label class="control-label">@lang('server.schedule.task.payload')</label> <label class="control-label">@lang('server.schedule.task.payload')</label>
<div data-attribute="remove-task-element"> <div data-attribute="remove-task-element">
<input type="text" name="chain[payload][]" class="form-control"> <input type="text" name="tasks[payload][]" class="form-control">
<div class="input-group-btn hidden"> <div class="input-group-btn hidden">
<button type="button" class="btn btn-danger" data-action="remove-task"><i class="fa fa-close"></i></button> <button type="button" class="btn btn-danger" data-action="remove-task"><i class="fa fa-close"></i></button>
</div> </div>

View file

@ -20,15 +20,15 @@
@extends('layouts.master') @extends('layouts.master')
@section('title') @section('title')
@lang('server.tasks.header') @lang('server.schedules.header')
@endsection @endsection
@section('content-header') @section('content-header')
<h1>@lang('server.tasks.header')<small>@lang('server.tasks.header_sub')</small></h1> <h1>@lang('server.schedule.header')<small>@lang('server.schedule.header_sub')</small></h1>
<ol class="breadcrumb"> <ol class="breadcrumb">
<li><a href="{{ route('index') }}">@lang('strings.home')</a></li> <li><a href="{{ route('index') }}">@lang('strings.home')</a></li>
<li><a href="{{ route('server.index', $server->uuidShort) }}">{{ $server->name }}</a></li> <li><a href="{{ route('server.index', $server->uuidShort) }}">{{ $server->name }}</a></li>
<li class="active">@lang('navigation.server.task_management')</li> <li class="active">@lang('navigation.server.schedules')</li>
</ol> </ol>
@endsection @endsection
@ -37,9 +37,9 @@
<div class="col-xs-12"> <div class="col-xs-12">
<div class="box"> <div class="box">
<div class="box-header with-border"> <div class="box-header with-border">
<h3 class="box-title">@lang('server.tasks.current')</h3> <h3 class="box-title">@lang('server.schedule.current')</h3>
<div class="box-tools"> <div class="box-tools">
<a href="{{ route('server.tasks.new', $server->uuidShort) }}"><button class="btn btn-primary btn-sm">Create New</button></a> <a href="{{ route('server.schedules.new', $server->uuidShort) }}"><button class="btn btn-primary btn-sm">Create New</button></a>
</div> </div>
</div> </div>
<div class="box-body table-responsive no-padding"> <div class="box-body table-responsive no-padding">
@ -58,9 +58,9 @@
<tr @if(! $schedule->is_active)class="muted muted-hover"@endif> <tr @if(! $schedule->is_active)class="muted muted-hover"@endif>
<td class="middle"> <td class="middle">
@can('edit-schedule', $server) @can('edit-schedule', $server)
<a href="{{ route('server.tasks.view', ['server' => $server->uuidShort, '$schedule' => $schedule->hashid]) }}">{{ $schedule->name }}</a> <a href="{{ route('server.schedules.view', ['server' => $server->uuidShort, '$schedule' => $schedule->hashid]) }}">{{ $schedule->name }}</a>
@else @else
{{ $schedule->name }} {{ $schedule->name ?? trans('server.schedule.unnamed') }}
@endcan @endcan
</td> </td>
<td class="middle text-center"> <td class="middle text-center">
@ -90,10 +90,10 @@
@endif @endif
</td> </td>
@can('delete-schedule', $server) @can('delete-schedule', $server)
<td class="text-center middle"><a href="#" data-action="delete-task" data-taskid="{{ $schedule->hashid }}"><i class="fa fa-fw fa-trash-o text-danger" data-toggle="tooltip" data-placement="top" title="@lang('strings.delete')"></i></a></td> <td class="text-center middle"><a href="#" data-action="delete-schedule" data-schedule-id="{{ $schedule->hashid }}"><i class="fa fa-fw fa-trash-o text-danger" data-toggle="tooltip" data-placement="top" title="@lang('strings.delete')"></i></a></td>
@endcan @endcan
@can('toggle-schedule', $server) @can('toggle-schedule', $server)
<td class="text-center middle"><a href="#" data-action="toggle-task" data-active="{{ $schedule->active }}" data-taskid="{{ $schedule->hashid }}"><i class="fa fa-fw fa-eye-slash text-primary" data-toggle="tooltip" data-placement="top" title="@lang('server.tasks.toggle')"></i></a></td> <td class="text-center middle"><a href="#" data-action="toggle-schedule" data-active="{{ $schedule->active }}" data-schedule-id="{{ $schedule->hashid }}"><i class="fa fa-fw fa-eye-slash text-primary" data-toggle="tooltip" data-placement="top" title="@lang('server.schedules.toggle')"></i></a></td>
@endcan @endcan
</tr> </tr>
@endforeach @endforeach

View file

@ -20,7 +20,7 @@
@extends('layouts.master') @extends('layouts.master')
@section('title') @section('title')
@lang('server.tasks.new.header') @lang('server.schedules.new.header')
@endsection @endsection
@section('scripts') @section('scripts')
@ -34,13 +34,13 @@
<ol class="breadcrumb"> <ol class="breadcrumb">
<li><a href="{{ route('index') }}">@lang('strings.home')</a></li> <li><a href="{{ route('index') }}">@lang('strings.home')</a></li>
<li><a href="{{ route('server.index', $server->uuidShort) }}">{{ $server->name }}</a></li> <li><a href="{{ route('server.index', $server->uuidShort) }}">{{ $server->name }}</a></li>
<li><a href="{{ route('server.tasks', $server->uuidShort) }}">@lang('navigation.server.task_management')</a></li> <li><a href="{{ route('server.schedules', $server->uuidShort) }}">@lang('navigation.server.schedules')</a></li>
<li class="active">@lang('server.schedule.new.header')</li> <li class="active">@lang('server.schedule.new.header')</li>
</ol> </ol>
@endsection @endsection
@section('content') @section('content')
<form action="{{ route('server.tasks.new', $server->uuidShort) }}" method="POST"> <form action="{{ route('server.schedules.new', $server->uuidShort) }}" method="POST">
<div class="row"> <div class="row">
<div class="col-xs-12"> <div class="col-xs-12">
<div class="box box-primary"> <div class="box box-primary">
@ -61,26 +61,26 @@
<div class="form-group"> <div class="form-group">
<label for="scheduleDayOfWeek" class="control-label">@lang('server.schedule.day_of_week')</label> <label for="scheduleDayOfWeek" class="control-label">@lang('server.schedule.day_of_week')</label>
<div> <div>
<select data-action="update-field" data-field="day_of_week" class="form-control" multiple> <select data-action="update-field" data-field="cron_day_of_week" class="form-control" multiple>
<option value="0">@lang('server.tasks.new.sun')</option> <option value="0">@lang('strings.days.sun')</option>
<option value="1">@lang('server.tasks.new.mon')</option> <option value="1">@lang('strings.days.mon')</option>
<option value="2">@lang('server.tasks.new.tues')</option> <option value="2">@lang('strings.days.tues')</option>
<option value="3">@lang('server.tasks.new.wed')</option> <option value="3">@lang('strings.days.wed')</option>
<option value="4">@lang('server.tasks.new.thurs')</option> <option value="4">@lang('strings.days.thurs')</option>
<option value="5">@lang('server.tasks.new.fri')</option> <option value="5">@lang('strings.days.fri')</option>
<option value="6">@lang('server.tasks.new.sat')</option> <option value="6">@lang('strings.days.sat')</option>
</select> </select>
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
<input type="text" id="scheduleDayOfWeek" class="form-control" name="day_of_week" value="{{ old('day_of_week') }}" /> <input type="text" id="scheduleDayOfWeek" class="form-control" name="cron_day_of_week" value="{{ old('cron_day_of_week') }}" />
</div> </div>
</div> </div>
<div class="col-xs-6 col-md-3"> <div class="col-xs-6 col-md-3">
<div class="form-group"> <div class="form-group">
<label for="scheduleDayOfMonth" class="control-label">@lang('server.schedule.day_of_month')</label> <label for="scheduleDayOfMonth" class="control-label">@lang('server.schedule.day_of_month')</label>
<div> <div>
<select data-action="update-field" data-field="day_of_month" class="form-control" multiple> <select data-action="update-field" data-field="cron_day_of_month" class="form-control" multiple>
@foreach(range(1, 31) as $i) @foreach(range(1, 31) as $i)
<option value="{{ $i }}">{{ $i }}</option> <option value="{{ $i }}">{{ $i }}</option>
@endforeach @endforeach
@ -88,14 +88,14 @@
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
<input type="text" id="scheduleDayOfMonth" class="form-control" name="day_of_month" value="{{ old('day_of_month') }}" /> <input type="text" id="scheduleDayOfMonth" class="form-control" name="cron_day_of_month" value="{{ old('cron_day_of_month') }}" />
</div> </div>
</div> </div>
<div class="col-xs-6 col-md-3"> <div class="col-xs-6 col-md-3">
<div class="form-group col-md-12"> <div class="form-group col-md-12">
<label for="scheduleHour" class="control-label">@lang('server.schedule.hour')</label> <label for="scheduleHour" class="control-label">@lang('server.schedule.hour')</label>
<div> <div>
<select data-action="update-field" data-field="hour" class="form-control" multiple> <select data-action="update-field" data-field="cron_hour" class="form-control" multiple>
@foreach(range(0, 23) as $i) @foreach(range(0, 23) as $i)
<option value="{{ $i }}">{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}:00</option> <option value="{{ $i }}">{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}:00</option>
@endforeach @endforeach
@ -103,14 +103,14 @@
</div> </div>
</div> </div>
<div class="form-group col-md-12"> <div class="form-group col-md-12">
<input type="text" id="scheduleHour" class="form-control" name="hour" value="{{ old('hour') }}" /> <input type="text" id="scheduleHour" class="form-control" name="cron_hour" value="{{ old('cron_hour') }}" />
</div> </div>
</div> </div>
<div class="col-xs-6 col-md-3"> <div class="col-xs-6 col-md-3">
<div class="form-group"> <div class="form-group">
<label for="scheduleMinute" class="control-label">@lang('server.schedule.minute')</label> <label for="scheduleMinute" class="control-label">@lang('server.schedule.minute')</label>
<div> <div>
<select data-action="update-field" data-field="minute" class="form-control" multiple> <select data-action="update-field" data-field="cron_minute" class="form-control" multiple>
@foreach(range(0, 55) as $i) @foreach(range(0, 55) as $i)
@if($i % 5 === 0) @if($i % 5 === 0)
<option value="{{ $i }}">_ _:{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}</option> <option value="{{ $i }}">_ _:{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}</option>
@ -120,7 +120,7 @@
</div> </div>
</div> </div>
<div class="form-group"> <div class="form-group">
<input type="text" id="scheduleMinute" class="form-control" name="minute" value="{{ old('minute') }}" /> <input type="text" id="scheduleMinute" class="form-control" name="cron_minute" value="{{ old('cron_minute') }}" />
</div> </div>
</div> </div>
</div> </div>
@ -136,7 +136,7 @@
<div class="box box-primary" id="containsTaskList"> <div class="box box-primary" id="containsTaskList">
@include('partials.schedules.task-template') @include('partials.schedules.task-template')
<div class="box-footer with-border" id="taskAppendBefore"> <div class="box-footer with-border" id="taskAppendBefore">
<div class="pull-left"> <div>
<p class="text-muted small">@lang('server.schedule.task_help')</p> <p class="text-muted small">@lang('server.schedule.task_help')</p>
</div> </div>
<div class="pull-right"> <div class="pull-right">

View file

@ -0,0 +1,177 @@
{{-- Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com> --}}
{{-- Permission is hereby granted, free of charge, to any person obtaining a copy --}}
{{-- of this software and associated documentation files (the "Software"), to deal --}}
{{-- in the Software without restriction, including without limitation the rights --}}
{{-- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell --}}
{{-- copies of the Software, and to permit persons to whom the Software is --}}
{{-- furnished to do so, subject to the following conditions: --}}
{{-- The above copyright notice and this permission notice shall be included in all --}}
{{-- copies or substantial portions of the Software. --}}
{{-- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR --}}
{{-- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, --}}
{{-- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE --}}
{{-- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER --}}
{{-- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, --}}
{{-- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE --}}
{{-- SOFTWARE. --}}
@extends('layouts.master')
@section('title')
@lang('server.schedules.edit.header')
@endsection
@section('scripts')
{{-- This has to be loaded before the AdminLTE theme to avoid dropdown issues. --}}
{!! Theme::css('vendor/select2/select2.min.css') !!}
@parent
@endsection
@section('content-header')
<h1>@lang('server.schedule.manage.header')<small>{{ $schedule->name }}</small></h1>
<ol class="breadcrumb">
<li><a href="{{ route('index') }}">@lang('strings.home')</a></li>
<li><a href="{{ route('server.index', $server->uuidShort) }}">{{ $server->name }}</a></li>
<li><a href="{{ route('server.schedules', $server->uuidShort) }}">@lang('navigation.server.schedules')</a></li>
<li class="active">@lang('server.schedule.manage.header')</li>
</ol>
@endsection
@section('content')
<form action="{{ route('server.schedules.view', ['server' => $server->uuidShort, 'schedule' => $schedule->hashid]) }}" method="POST">
<div class="row">
<div class="col-xs-12">
<div class="box box-primary">
<div class="box-body">
<div class="row">
<div class="form-group col-xs-12">
<label class="control-label" for="scheduleName">@lang('strings.name') <span class="field-optional"></span></label>
<div>
<input type="text" name="name" class="form-control" id="scheduleName" value="{{ old('name', $schedule->name) }}" />
</div>
</div>
</div>
<div class="row">
<div class="col-xs-6 col-md-3">
<div class="form-group">
<label for="scheduleDayOfWeek" class="control-label">@lang('server.schedule.day_of_week')</label>
<div>
<select data-action="update-field" data-field="cron_day_of_week" class="form-control" multiple>
<option value="0">@lang('strings.days.sun')</option>
<option value="1">@lang('strings.days.mon')</option>
<option value="2">@lang('strings.days.tues')</option>
<option value="3">@lang('strings.days.wed')</option>
<option value="4">@lang('strings.days.thurs')</option>
<option value="5">@lang('strings.days.fri')</option>
<option value="6">@lang('strings.days.sat')</option>
</select>
</div>
</div>
<div class="form-group">
<input type="text" id="scheduleDayOfWeek" class="form-control" name="cron_day_of_week" value="{{ old('cron_day_of_week', $schedule->cron_day_of_week) }}" />
</div>
</div>
<div class="col-xs-6 col-md-3">
<div class="form-group">
<label for="scheduleDayOfMonth" class="control-label">@lang('server.schedule.day_of_month')</label>
<div>
<select data-action="update-field" data-field="cron_day_of_month" class="form-control" multiple>
@foreach(range(1, 31) as $i)
<option value="{{ $i }}">{{ $i }}</option>
@endforeach
</select>
</div>
</div>
<div class="form-group">
<input type="text" id="scheduleDayOfMonth" class="form-control" name="cron_day_of_month" value="{{ old('cron_day_of_month', $schedule->cron_day_of_month) }}" />
</div>
</div>
<div class="col-xs-6 col-md-3">
<div class="form-group col-md-12">
<label for="scheduleHour" class="control-label">@lang('server.schedule.hour')</label>
<div>
<select data-action="update-field" data-field="cron_hour" class="form-control" multiple>
@foreach(range(0, 23) as $i)
<option value="{{ $i }}">{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}:00</option>
@endforeach
</select>
</div>
</div>
<div class="form-group col-md-12">
<input type="text" id="scheduleHour" class="form-control" name="cron_hour" value="{{ old('cron_hour', $schedule->cron_hour) }}" />
</div>
</div>
<div class="col-xs-6 col-md-3">
<div class="form-group">
<label for="scheduleMinute" class="control-label">@lang('server.schedule.minute')</label>
<div>
<select data-action="update-field" data-field="cron_minute" class="form-control" multiple>
@foreach(range(0, 55) as $i)
@if($i % 5 === 0)
<option value="{{ $i }}">_ _:{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}</option>
@endif
@endforeach
</select>
</div>
</div>
<div class="form-group">
<input type="text" id="scheduleMinute" class="form-control" name="cron_minute" value="{{ old('cron_minute', $schedule->cron_minute) }}" />
</div>
</div>
</div>
</div>
<div class="box-footer with-border">
<p class="small text-muted no-margin-bottom">@lang('server.schedule.time_help')</p>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-12">
<div class="box box-primary" id="containsTaskList">
@include('partials.schedules.task-template')
<div class="box-footer with-border" id="taskAppendBefore">
<div>
<p class="text-muted small">@lang('server.schedule.task_help')</p>
</div>
<div class="pull-left">
<button type="submit" class="btn btn-sm btn-danger muted muted-hover" id="deleteButton" name="_method" value="DELETE"><i class="fa fa-trash-o"></i></button>
</div>
<div class="pull-right">
{!! csrf_field() !!}
<button type="button" class="btn btn-sm btn-default" data-action="add-new-task"><i class="fa fa-plus"></i> @lang('server.schedule.task.add_more')</button>
<button type="submit" class="btn btn-sm btn-success" name="_method" value="PATCH">@lang('server.schedule.manage.submit')</button>
</div>
</div>
</div>
</div>
</div>
</form>
@endsection
@section('footer-scripts')
@parent
{!! Theme::js('js/frontend/server.socket.js') !!}
{!! Theme::js('vendor/select2/select2.full.min.js') !!}
{!! Theme::js('js/frontend/tasks/view-actions.js') !!}
<script>
$(document).ready(function () {
$('#deleteButton').on('mouseenter', function () {
$(this).find('i').html(' @lang('server.schedule.manage.delete')');
}).on('mouseleave', function () {
$(this).find('i').html('');
});
$.each(Pterodactyl.tasks, function (index, value) {
var element = (index !== 0) ? $('button[data-action="add-new-task"]').trigger('click').data('element') : $('div[data-target="task-clone"]');
var timeValue = (value.time_offset > 59) ? value.time_offset / 60 : value.time_offset;
var timeInterval = (value.time_offset > 59) ? 'm' : 's';
element.find('select[name="tasks[time_value][]"]').val(timeValue).trigger('change');
element.find('select[name="tasks[time_interval][]"]').val(timeInterval).trigger('change');
element.find('select[name="tasks[action][]"]').val(value.action).trigger('change');
element.find('input[name="tasks[payload][]"]').val(value.payload);
});
});
</script>
@endsection

View file

@ -1,230 +0,0 @@
{{-- Copyright (c) 2015 - 2017 Dane Everitt <dane@daneeveritt.com> --}}
{{-- Permission is hereby granted, free of charge, to any person obtaining a copy --}}
{{-- of this software and associated documentation files (the "Software"), to deal --}}
{{-- in the Software without restriction, including without limitation the rights --}}
{{-- to use, copy, modify, merge, publish, distribute, sublicense, and/or sell --}}
{{-- copies of the Software, and to permit persons to whom the Software is --}}
{{-- furnished to do so, subject to the following conditions: --}}
{{-- The above copyright notice and this permission notice shall be included in all --}}
{{-- copies or substantial portions of the Software. --}}
{{-- THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR --}}
{{-- IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, --}}
{{-- FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE --}}
{{-- AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER --}}
{{-- LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, --}}
{{-- OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE --}}
{{-- SOFTWARE. --}}
@extends('layouts.master')
@section('title')
@lang('server.tasks.edit.header')
@endsection
@section('scripts')
{{-- This has to be loaded before the AdminLTE theme to avoid dropdown issues. --}}
{!! Theme::css('vendor/select2/select2.min.css') !!}
@parent
@endsection
@section('content-header')
<h1>@lang('server.tasks.edit.header')<small>{{ $task->name }}</small></h1>
<ol class="breadcrumb">
<li><a href="{{ route('index') }}">@lang('strings.home')</a></li>
<li><a href="{{ route('server.index', $server->uuidShort) }}">{{ $server->name }}</a></li>
<li><a href="{{ route('server.tasks', $server->uuidShort) }}">@lang('navigation.server.task_management')</a></li>
<li class="active">@lang('server.users.update')</li>
</ol>
@endsection
@section('content')
<form action="{{ route('server.tasks.view', ['server' => $server->uuidShort, 'task' => $task->hashid]) }}" method="POST">
<div class="row">
<div class="col-xs-12">
<div class="box box-primary">
<div class="box-body">
<div class="row">
<div class="form-group col-xs-12">
<label class="control-label">@lang('server.tasks.new.task_name'):</label>
<div>
<input type="text" name="name" class="form-control" value="{{ old('name', $task->name) }}" />
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-md-3 col-sm-6">
<div class="box">
<div class="box-header with-border">
<h3 class="box-title">@lang('server.tasks.new.day_of_week')</h3>
</div>
<div class="box-body">
<div class="row">
<div class="form-group col-md-12">
<div>
<select data-action="update-field" data-field="day_of_week" class="form-control" multiple>
<option value="0">@lang('server.tasks.new.sun')</option>
<option value="1">@lang('server.tasks.new.mon')</option>
<option value="2">@lang('server.tasks.new.tues')</option>
<option value="3">@lang('server.tasks.new.wed')</option>
<option value="4">@lang('server.tasks.new.thurs')</option>
<option value="5">@lang('server.tasks.new.fri')</option>
<option value="6">@lang('server.tasks.new.sat')</option>
</select>
</div>
</div>
<div class="form-group col-md-12">
<label class="control-label">@lang('server.tasks.new.custom')</label>
<div>
<input type="text" class="form-control" name="day_of_week" value="{{ old('day_of_week', $task->day_of_week) }}"/>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="col-md-3 col-sm-6">
<div class="box">
<div class="box-header with-border">
<h3 class="box-title">@lang('server.tasks.new.day_of_month')</h3>
</div>
<div class="box-body">
<div class="row">
<div class="form-group col-md-12">
<div>
<select data-action="update-field" data-field="day_of_month" class="form-control" multiple>
@foreach(range(1, 31) as $i)
<option value="{{ $i }}">{{ $i }}</option>
@endforeach
</select>
</div>
</div>
<div class="form-group col-md-12">
<label class="control-label">@lang('server.tasks.new.custom')</label>
<div>
<input type="text" class="form-control" name="day_of_month" value="{{ old('day_of_month', $task->day_of_month) }}"/>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="col-md-3 col-sm-6">
<div class="box">
<div class="box-header with-border">
<h3 class="box-title">@lang('server.tasks.new.hour')</h3>
</div>
<div class="box-body">
<div class="row">
<div class="form-group col-md-12">
<div>
<select data-action="update-field" data-field="hour" class="form-control" multiple>
@foreach(range(0, 23) as $i)
<option value="{{ $i }}">{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}:00</option>
@endforeach
</select>
</div>
</div>
<div class="form-group col-md-12">
<label class="control-label">@lang('server.tasks.new.custom')</label>
<div>
<input type="text" class="form-control" name="hour" value="{{ old('hour', $task->hour) }}"/>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="col-md-3 col-sm-6">
<div class="box">
<div class="box-header with-border">
<h3 class="box-title">@lang('server.tasks.new.minute')</h3>
</div>
<div class="box-body">
<div class="row">
<div class="form-group col-md-12">
<div>
<select data-action="update-field" data-field="minute" class="form-control" multiple>
@foreach(range(0, 55) as $i)
@if($i % 5 === 0)
<option value="{{ $i }}">_ _:{{ str_pad($i, 2, '0', STR_PAD_LEFT) }}</option>
@endif
@endforeach
</select>
</div>
</div>
<div class="form-group col-md-12">
<label class="control-label">@lang('server.tasks.new.custom')</label>
<div>
<input type="text" class="form-control" name="minute" value="{{ old('minute', $task->minute) }}"/>
</div>
</div>
</div>
</div>
</div>
</div>
</div>
<div class="row">
<div class="col-xs-12">
<div class="box box-primary">
<div class="box-body">
<div class="row">
<div class="form-group col-md-4">
<label class="control-label">@lang('server.tasks.new.type'):</label>
<div>
<select name="action" class="form-control">
<option value="command" @if($task->action === 'command')selected @endif>@lang('server.tasks.actions.command')</option>
<option value="power" @if($task->action === 'power')selected @endif>@lang('server.tasks.actions.power')</option>
</select>
</div>
</div>
<div class="form-group col-md-8">
<label class="control-label">@lang('server.tasks.new.payload'):</label>
<div>
<input type="text" name="data" class="form-control" value="{{ old('data', $task->data) }}">
<span class="text-muted small">@lang('server.tasks.new.payload_help')</span>
</div>
</div>
</div>
</div>
<div class="box-footer with-border" id="chainLastSegment">
<div class="pull-left">
<p class="text-muted small">Times for chain arguments are relative to the previous argument.</p>
</div>
<div class="pull-right">
{!! csrf_field() !!}
<button type="button" class="btn btn-sm btn-default" data-action="add-chain"><i class="fa fa-plus"></i> New Chain Argument</button>
<button type="submit" name="_method" value="PATCH" class="btn btn-sm btn-success">@lang('server.tasks.edit.submit')</button>
</div>
</div>
</div>
</div>
</div>
</form>
@include('partials.tasks.chain-template')
@endsection
@section('footer-scripts')
@parent
{!! Theme::js('js/frontend/server.socket.js') !!}
{!! Theme::js('vendor/select2/select2.full.min.js') !!}
{!! Theme::js('js/frontend/tasks/view-actions.js') !!}
<script>
$(document).ready(function () {
$.each(Pterodactyl.chained, function (index, value) {
var element = $('button[data-action="add-chain"]').trigger('click').data('element');
var timeValue = (value.chain_delay > 60) ? value.chain_delay / 60 : value.chain_delay;
var timeInterval = (value.chain_delay > 60) ? 'm' : 's';
element.find('select[name="chain[time_value][]"]').val(timeValue).trigger('change');
element.find('select[name="chain[time_interval][]"]').val(timeInterval).trigger('change');
element.find('select[name="chain[action][]"]').val(value.action).trigger('change');
element.find('input[name="chain[payload][]"]').val(value.data);
});
});
</script>
@endsection

View file

@ -91,16 +91,16 @@ Route::group(['prefix' => 'users'], function () {
| |
*/ */
Route::group(['prefix' => 'schedules'], function () { Route::group(['prefix' => 'schedules'], function () {
Route::get('/', 'Tasks\TaskManagementController@index')->name('server.tasks'); Route::get('/', 'Tasks\TaskManagementController@index')->name('server.schedules');
Route::get('/new', 'Tasks\TaskManagementController@create')->name('server.tasks.new'); Route::get('/new', 'Tasks\TaskManagementController@create')->name('server.schedules.new');
Route::get('/view/{schedule}', 'Tasks\TaskManagementController@view')->middleware(ScheduleAccess::class)->name('server.tasks.view'); Route::get('/view/{schedule}', 'Tasks\TaskManagementController@view')->middleware(ScheduleAccess::class)->name('server.schedules.view');
Route::post('/new', 'Tasks\TaskManagementController@store'); Route::post('/new', 'Tasks\TaskManagementController@store');
Route::patch('/view/{schedule}', 'Tasks\TaskManagementController@update')->middleware(ScheduleAccess::class); Route::patch('/view/{schedule}', 'Tasks\TaskManagementController@update')->middleware(ScheduleAccess::class);
Route::patch('/view/{schedule}/toggle', 'Tasks\TaskToggleController@index')->middleware(ScheduleAccess::class)->name('server.tasks.toggle'); Route::patch('/view/{schedule}/toggle', 'Tasks\TaskToggleController@index')->middleware(ScheduleAccess::class)->name('server.schedules.toggle');
Route::delete('/view/{schedule}/delete', 'Tasks\TaskManagementController@delete')->middleware(ScheduleAccess::class)->name('server.tasks.delete'); Route::delete('/view/{schedule}/delete', 'Tasks\TaskManagementController@delete')->middleware(ScheduleAccess::class)->name('server.schedules.delete');
}); });
/* /*