{{-- 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.admin') @section('title') {{ $node->name }} @endsection @section('content-header') <h1>{{ $node->name }}<small>A quick overview of your node.</small></h1> <ol class="breadcrumb"> <li><a href="{{ route('admin.index') }}">Admin</a></li> <li><a href="{{ route('admin.nodes') }}">Nodes</a></li> <li class="active">{{ $node->name }}</li> </ol> @endsection @section('content') <div class="row"> <div class="col-xs-12"> <div class="nav-tabs-custom nav-tabs-floating"> <ul class="nav nav-tabs"> <li class="active"><a href="{{ route('admin.nodes.view', $node->id) }}">About</a></li> <li><a href="{{ route('admin.nodes.view.settings', $node->id) }}">Settings</a></li> <li><a href="{{ route('admin.nodes.view.configuration', $node->id) }}">Configuration</a></li> <li><a href="{{ route('admin.nodes.view.allocation', $node->id) }}">Allocation</a></li> <li><a href="{{ route('admin.nodes.view.servers', $node->id) }}">Servers</a></li> </ul> </div> </div> </div> <div class="row"> <div class="col-sm-8"> <div class="row"> <div class="col-xs-12"> <div class="box box-primary"> <div class="box-header with-border"> <h3 class="box-title">Information</h3> </div> <div class="box-body table-responsive no-padding"> <table class="table table-hover"> <tr> <td>Daemon Version</td> <td><code data-attr="info-version"><i class="fa fa-refresh fa-fw fa-spin"></i></code> (Latest: <code>{{ Version::getDaemon() }}</code>)</td> </tr> <tr> <td>System Information</td> <td data-attr="info-system"><i class="fa fa-refresh fa-fw fa-spin"></i></td> </tr> <tr> <td>Total CPU Cores</td> <td data-attr="info-cpus"><i class="fa fa-refresh fa-fw fa-spin"></i></td> </tr> </table> </div> </div> </div> <div class="col-xs-12"> <div class="box box-danger"> <div class="box-header with-border"> <h3 class="box-title">Delete Node</h3> </div> <div class="box-body"> <p class="no-margin">Deleting a node is a irreversable action and will immediately remove this node from the panel. There must be no servers associated with this node in order to continue.</p> </div> <div class="box-footer"> <form action="{{ route('admin.nodes.view.delete', $node->id) }}" method="POST"> {!! csrf_field() !!} {!! method_field('DELETE') !!} <button type="submit" class="btn btn-danger btn-sm pull-right" {{ ($node->servers_count < 1) ?: 'disabled' }}>Yes, Delete This Node</button> </form> </div> </div> </div> </div> </div> <div class="col-sm-4"> <div class="box box-primary"> <div class="box-header with-border"> <h3 class="box-title">At-a-Glance</h3> </div> <div class="box-body"> <div class="row"> <div class="col-sm-12"> <div class="info-box bg-{{ $stats['disk']['css'] }}"> <span class="info-box-icon"><i class="ion ion-ios-folder-outline"></i></span> <div class="info-box-content" style="padding: 15px 10px 0;"> <span class="info-box-text">Disk Space Allocated</span> <span class="info-box-number">{{ $stats['disk']['value'] }} Mb</span> <div class="progress"> <div class="progress-bar" style="width: {{ $stats['disk']['percent'] }}%"></div> </div> </div> </div> </div> <div class="col-sm-12"> <div class="info-box bg-{{ $stats['memory']['css'] }}"> <span class="info-box-icon"><i class="ion ion-ios-barcode-outline"></i></span> <div class="info-box-content" style="padding: 15px 10px 0;"> <span class="info-box-text">Memory Allocated</span> <span class="info-box-number">{{ $stats['memory']['value'] }} Mb</span> <div class="progress"> <div class="progress-bar" style="width: {{ $stats['memory']['percent'] }}%"></div> </div> </div> </div> </div> <div class="col-sm-12"> <div class="info-box bg-gray"> <span class="info-box-icon"><i class="ion ion-social-buffer-outline"></i></span> <div class="info-box-content" style="padding: 23px 10px 0;"> <span class="info-box-text">Total Servers</span> <span class="info-box-number">{{ $node->servers_count }}</span> </div> </div> </div> </div> </div> </div> </div> </div> @endsection @section('footer-scripts') @parent <script> (function getInformation() { $.ajax({ method: 'GET', url: '{{ $node->scheme }}://{{ $node->fqdn }}:{{ $node->daemonListen }}', timeout: 5000, headers: { 'X-Access-Token': '{{ $node->daemonSecret }}' }, }).done(function (data) { $('[data-attr="info-version"]').html(data.version); $('[data-attr="info-system"]').html(data.system.type + '(' + data.system.arch + ') <code>' + data.system.release + '</code>'); $('[data-attr="info-cpus"]').html(data.system.cpus); }).fail(function (jqXHR) { }).always(function() { setTimeout(getInformation, 10000); }); })(); </script> @endsection