2016-01-24 02:30:03 +00:00
|
|
|
{{-- Copyright (c) 2015 - 2016 Dane Everitt <dane@daneeveritt.com> --}}
|
2016-01-22 04:53:48 +00:00
|
|
|
|
2016-01-24 02:30:03 +00:00
|
|
|
{{-- 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: --}}
|
2016-01-22 04:53:48 +00:00
|
|
|
|
2016-01-24 02:30:03 +00:00
|
|
|
{{-- The above copyright notice and this permission notice shall be included in all --}}
|
|
|
|
{{-- copies or substantial portions of the Software. --}}
|
2016-01-22 04:53:48 +00:00
|
|
|
|
2016-01-24 02:30:03 +00:00
|
|
|
{{-- 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. --}}
|
2016-01-22 04:53:48 +00:00
|
|
|
@extends('layouts.master')
|
|
|
|
|
|
|
|
@section('title')
|
|
|
|
Server Settings
|
|
|
|
@endsection
|
|
|
|
|
|
|
|
@section('content')
|
|
|
|
<div class="col-md-12">
|
|
|
|
<h3 class="nopad">Server Settings</h3><hr />
|
|
|
|
<ul class="nav nav-tabs tabs_with_panel" id="config_tabs">
|
|
|
|
@can('view-sftp', $server)<li class="active"><a href="#tab_sftp" data-toggle="tab">SFTP Settings</a></li>@endcan
|
|
|
|
@can('view-startup', $server)<li><a href="#tab_startup" data-toggle="tab">Startup Configuration</a></li>@endcan
|
2016-02-15 02:43:20 +00:00
|
|
|
@can('view-databases', $server)<li><a href="#tab_databases" data-toggle="tab">Databases</a></li>@endcan
|
2016-01-22 04:53:48 +00:00
|
|
|
</ul>
|
|
|
|
<div class="tab-content">
|
|
|
|
@can('view-sftp', $server)
|
|
|
|
<div class="tab-pane active" id="tab_sftp">
|
|
|
|
<div class="panel panel-default">
|
|
|
|
<div class="panel-heading"></div>
|
|
|
|
<div class="panel-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="form-group col-md-6">
|
|
|
|
<label class="control-label">SFTP Connection Address:</label>
|
|
|
|
<div>
|
|
|
|
<input type="text" readonly="readonly" class="form-control" value="{{ $node->fqdn }}:{{ $node->daemonSFTP }}" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="form-group col-md-6">
|
|
|
|
<label class="control-label">SFTP Username:</label>
|
|
|
|
<div>
|
|
|
|
<input type="text" readonly="readonly" class="form-control" value="{{ $server->username }}" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
2016-09-02 23:26:48 +00:00
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12">
|
|
|
|
<div id="gen_pass" class=" alert alert-success" style="display:none;margin-bottom: 10px;"></div>
|
|
|
|
</div>
|
|
|
|
<div class="form-group col-md-6">
|
|
|
|
@can('reset-sftp', $server)
|
|
|
|
<form action="{{ route('server.settings.sftp', $server->uuidShort) }}" method="POST">
|
2016-01-22 04:53:48 +00:00
|
|
|
<label class="control-label">New SFTP Password:</label>
|
2016-09-02 23:26:48 +00:00
|
|
|
<div class="input-group">
|
|
|
|
<input type="password" class="form-control" name="sftp_pass" />
|
|
|
|
<span class="input-group-btn">
|
|
|
|
{!! csrf_field() !!}
|
|
|
|
<input type="submit" class="btn btn-primary btn-sm" value="Reset" />
|
|
|
|
</span>
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
2016-09-02 23:26:48 +00:00
|
|
|
<p class="text-muted"><small>Passwords must meet the following requirements: at least one uppercase character, one lowercase character, one digit, and be at least 8 characters in length. <a href="#" data-action="generate-password">Click here</a> to generate one to use.</small></p>
|
|
|
|
</form>
|
|
|
|
@endcan
|
|
|
|
</div>
|
|
|
|
<div class="form-group col-md-6">
|
|
|
|
@can('view-sftp-password', $server)
|
|
|
|
<label class="control-label">Current Password:</label>
|
|
|
|
<div>
|
|
|
|
<input type="text" readonly="readonly" class="form-control" value="@if(!is_null($server->sftp_password)){{ Crypt::decrypt($server->sftp_password) }} @endif" />
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
2016-09-02 23:26:48 +00:00
|
|
|
@endcan
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
2016-09-02 23:26:48 +00:00
|
|
|
</div>
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@endcan
|
|
|
|
@can('view-startup', $server)
|
|
|
|
<div class="tab-pane" id="tab_startup">
|
2016-01-23 00:40:48 +00:00
|
|
|
<form action="{{ route('server.settings.startup', $server->uuidShort) }}" method="POST">
|
|
|
|
<div class="panel panel-default">
|
|
|
|
<div class="panel-heading"></div>
|
|
|
|
<div class="panel-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="form-group col-md-12">
|
|
|
|
<label class="control-label">Startup Command:</label>
|
|
|
|
<div class="input-group">
|
|
|
|
<span class="input-group-addon">{{ $service->executable }}</span>
|
|
|
|
<input type="text" class="form-control" readonly="readonly" value="{{ $processedStartup }}" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@can('edit-startup', $server)
|
|
|
|
<div class="panel-heading" style="border-top: 1px solid #ddd;"></div>
|
|
|
|
<div class="panel-body">
|
|
|
|
<div class="row">
|
|
|
|
@foreach($variables as $item)
|
|
|
|
<div class="form-group col-md-6">
|
|
|
|
<label class="control-label">
|
|
|
|
@if($item->required === 1)<span class="label label-primary">Required</span> @endif
|
|
|
|
{{ $item->name }}
|
|
|
|
</label>
|
|
|
|
<div>
|
|
|
|
<input type="text"
|
|
|
|
@if($item->user_editable === 1)
|
|
|
|
name="{{ $item->env_variable }}"
|
|
|
|
@else
|
|
|
|
readonly="readonly"
|
|
|
|
@endif
|
|
|
|
class="form-control" value="{{ old($item->env_variable, $item->a_serverValue) }}" data-action="matchRegex" data-regex="{{ $item->regex }}" />
|
|
|
|
</div>
|
2016-09-16 00:29:05 +00:00
|
|
|
<p class="text-muted"><small>{!! $item->description !!}<br />Regex: <code>{{ $item->regex }}</code><br />Access as: <code>{{{{$item->env_variable}}}}</code></small></p>
|
2016-01-23 00:40:48 +00:00
|
|
|
</div>
|
|
|
|
@endforeach
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<div class="panel-heading" style="border-top: 1px solid #ddd;"></div>
|
|
|
|
<div class="panel-body">
|
|
|
|
<div class="row">
|
|
|
|
<div class="col-md-12">
|
|
|
|
{!! csrf_field() !!}
|
|
|
|
<input type="submit" class="btn btn-primary btn-sm" value="Update Startup Arguments" />
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@endcan
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
2016-01-23 00:40:48 +00:00
|
|
|
</form>
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
|
|
|
@endcan
|
2016-02-15 02:43:20 +00:00
|
|
|
@can('view-databases', $server)
|
2016-08-16 02:42:11 +00:00
|
|
|
<div class="tab-pane" id="tab_databases">
|
2016-02-15 02:43:20 +00:00
|
|
|
<div class="panel panel-default">
|
|
|
|
<div class="panel-heading"></div>
|
|
|
|
<div class="panel-body">
|
|
|
|
@if(count($databases) > 0)
|
|
|
|
<table class="table table-bordered table-hover" style="margin-bottom:0;">
|
|
|
|
<thead>
|
|
|
|
<tr>
|
|
|
|
<th>Database</th>
|
2016-08-16 04:07:10 +00:00
|
|
|
<th>Username</th>
|
2016-02-15 02:43:20 +00:00
|
|
|
<th>Password</th>
|
|
|
|
<th>DB Server</th>
|
|
|
|
</th>
|
|
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
@foreach($databases as $database)
|
|
|
|
<tr>
|
|
|
|
<td>{{ $database->database }}</td>
|
2016-08-16 04:07:10 +00:00
|
|
|
<td>{{ $database->username }}</td>
|
2016-08-17 21:36:06 +00:00
|
|
|
<td><code>{{ Crypt::decrypt($database->password) }}</code> @can('reset-db-password', $server)<a href="#" data-action="reset-database-password" data-id="{{ $database->id }}"><i class="fa fa-refresh pull-right"></i></a>@endcan</td>
|
2016-02-15 02:43:20 +00:00
|
|
|
<td><code>{{ $database->a_host }}:{{ $database->a_port }}</code></td>
|
|
|
|
</tr>
|
|
|
|
@endforeach
|
|
|
|
</tbody>
|
|
|
|
</table>
|
|
|
|
@else
|
|
|
|
<div class="alert alert-info" style="margin-bottom:0;">
|
|
|
|
There are no databases configured for this server.
|
|
|
|
@if(Auth::user()->root_admin === 1)
|
|
|
|
<a href="{{ route('admin.servers.view', [
|
|
|
|
'id' => $server->id,
|
|
|
|
'tab' => 'tab_database'
|
|
|
|
]) }}" target="_blank">Add a new database.</a>
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
@endif
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
@endcan
|
2016-01-22 04:53:48 +00:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<script>
|
|
|
|
$(document).ready(function () {
|
|
|
|
$('.server-settings').addClass('active');
|
2016-01-23 00:40:48 +00:00
|
|
|
$('[data-action="matchRegex"]').keyup(function (event) {
|
|
|
|
if (!$(this).data('regex')) return;
|
|
|
|
var input = $(this).val();
|
|
|
|
console.log(escapeRegExp($(this).data('regex')));
|
|
|
|
var regex = new RegExp(escapeRegExp($(this).data('regex')));
|
|
|
|
console.log(regex);
|
|
|
|
if (!regex.test(input)) {
|
|
|
|
$(this).parent().parent().removeClass('has-success').addClass('has-error');
|
|
|
|
} else {
|
|
|
|
$(this).parent().parent().removeClass('has-error').addClass('has-success');
|
|
|
|
}
|
|
|
|
});
|
2016-08-16 02:42:11 +00:00
|
|
|
$('[data-action="generate-password"]').click(function(e){
|
|
|
|
e.preventDefault();
|
|
|
|
$.ajax({
|
|
|
|
type: "GET",
|
|
|
|
url: "/password-gen/12",
|
|
|
|
headers: {
|
|
|
|
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
|
|
|
},
|
|
|
|
success: function(data) {
|
|
|
|
$("#gen_pass").html('<strong>Generated Password:</strong> ' + data).slideDown();
|
|
|
|
$('input[name="sftp_pass"]').val(data);
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
return false;
|
|
|
|
});
|
2016-08-16 04:07:10 +00:00
|
|
|
$('[data-action="reset-database-password"]').click(function (e) {
|
|
|
|
e.preventDefault();
|
|
|
|
var block = $(this);
|
|
|
|
$(this).find('i').addClass('fa-spin');
|
|
|
|
$.ajax({
|
|
|
|
type: 'POST',
|
|
|
|
url: '{{ route('server.ajax.reset-database-password', $server->uuidShort) }}',
|
|
|
|
headers: {
|
|
|
|
'X-CSRF-TOKEN': '{{ csrf_token() }}'
|
|
|
|
},
|
|
|
|
data: {
|
|
|
|
'database': $(this).data('id')
|
|
|
|
}
|
|
|
|
}).done(function (data) {
|
|
|
|
block.parent().find('code').html(data);
|
|
|
|
}).fail(function(jqXHR, textStatus, errorThrown) {
|
|
|
|
console.error(jqXHR);
|
|
|
|
var error = 'An error occured while trying to process this request.';
|
|
|
|
if (typeof jqXHR.responseJSON !== 'undefined' && typeof jqXHR.responseJSON.error !== 'undefined') {
|
|
|
|
error = jqXHR.responseJSON.error;
|
|
|
|
}
|
|
|
|
swal({
|
|
|
|
type: 'error',
|
|
|
|
title: 'Whoops!',
|
|
|
|
text: error
|
|
|
|
});
|
|
|
|
}).always(function () {
|
|
|
|
block.find('i').removeClass('fa-spin');
|
|
|
|
});
|
|
|
|
});
|
2016-01-22 04:53:48 +00:00
|
|
|
});
|
|
|
|
</script>
|
|
|
|
@endsection
|