mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-10-31 16:36:52 +01:00 
			
		
		
		
	 fd9f1a68eb
			
		
	
	
		fd9f1a68eb
		
			
		
	
	
	
	
		
			
			Still in progress, need to do a lot of controller cleanup first and add node deletion as well.
		
			
				
	
	
		
			144 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			144 lines
		
	
	
		
			6.7 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| {{-- 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>
 | |
|                 <li class="tab-danger"><a href="{{ route('admin.nodes.view.delete', $node->id) }}">Delete</a></li>
 | |
|             </ul>
 | |
|         </div>
 | |
|     </div>
 | |
| </div>
 | |
| <div class="row">
 | |
|     <div class="col-sm-8">
 | |
|         <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-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
 |