first commit, after modifying client section
This commit is contained in:
200
app/Http/Controllers/ClickInfrastructureController.php
Executable file
200
app/Http/Controllers/ClickInfrastructureController.php
Executable file
@@ -0,0 +1,200 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers;
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use App\Models;
|
||||
use Session;
|
||||
|
||||
class ClickInfrastructureController extends Controller
|
||||
{
|
||||
|
||||
public function servers(){
|
||||
// dd(session('current_user'));
|
||||
// die;
|
||||
$servers = Models\ClickServer::with('direct_connections_info', 'credentials_info')->get();
|
||||
$data = [
|
||||
'page_title' => 'Servers',
|
||||
'servers' => $servers
|
||||
];
|
||||
return view('infrastructure.index', $data);
|
||||
|
||||
}
|
||||
public function domains(){
|
||||
|
||||
}
|
||||
public function create_direct($id)
|
||||
{
|
||||
|
||||
$server = Models\ClickServer::find($id);
|
||||
$data = [
|
||||
'page_title' => 'Servers',
|
||||
'server' => $server,
|
||||
'connection_types' => ['vpn' => 'VPN', 'fqdn' => 'FQDN' ]
|
||||
];
|
||||
return view('infrastructure.create_direct_connection', $data);
|
||||
}
|
||||
public function store_direct(Request $request){
|
||||
// dd($request->all());
|
||||
|
||||
$request->validate([
|
||||
'direct_partner' => 'required',
|
||||
'server_id' => 'required',
|
||||
'connection_type' => 'required',
|
||||
'port' => 'required_with:main_ip_address,domain_name',
|
||||
'main_ip_address' => 'sometimes|nullable|ip',
|
||||
'private_ip_address' => 'sometimes|nullable|ip',
|
||||
'domain_name' => 'required_if:connection_type,fqdn|nullable|regex:/^([a-zA-Z0-9][a-zA-Z0-9-_]*\.)*[a-zA-Z0-9]*[a-zA-Z0-9-_]*[[a-zA-Z0-9]+$/',
|
||||
'vpn_peer_ip' => 'required_if:connection_type,vpn|nullable|ip',
|
||||
'connection_form' => 'sometimes|nullable|max:2000|mimes:doc,docx,xlx,xlsx,png,jpg,jpeg,bmp,pdf',
|
||||
]);
|
||||
// dd($request->all());
|
||||
if ($request->main_ip_address == null && $request->domain_name == null ) {
|
||||
return redirect()->back()->withInput()->withErrors(['You need either an IP address or a Domain name']);
|
||||
}
|
||||
$direct_arr = $request->except('_token');
|
||||
$direct_arr['last_modified_by'] = session('current_user.id');
|
||||
|
||||
if ($request->hasFile('connection_form')) {
|
||||
if ($request->file('connection_form')->isValid()) {
|
||||
$filename = "connection_document_" . time() . "." . $request->connection_form->extension();
|
||||
$request->connection_form->storeAs('connection_files', $filename, 'public');
|
||||
$direct_arr['connection_document'] = $filename;
|
||||
}
|
||||
}
|
||||
// dd($direct_arr);
|
||||
|
||||
$result = Models\DirectConnection::create($direct_arr);
|
||||
Session::flash('success_message', 'Direct connection successfully added');
|
||||
return redirect(url('infrastructure/servers'));
|
||||
}
|
||||
|
||||
public function edit_direct($id)
|
||||
{
|
||||
|
||||
$direct_connection = Models\DirectConnection::find($id);
|
||||
// dump($direct_connection);
|
||||
// TNM_CLICKB_NOSIR_NEW_SMSC
|
||||
$server = Models\ClickServer::find($direct_connection->server_id);
|
||||
// dd($server);
|
||||
$data = [
|
||||
'page_title' => 'Servers',
|
||||
'server' => $server,
|
||||
'direct_connection' => $direct_connection,
|
||||
'connection_types' => ['vpn' => 'VPN', 'fqdn' => 'FQDN' ]
|
||||
];
|
||||
return view('infrastructure.edit_direct_connection', $data);
|
||||
}
|
||||
public function update_direct(Request $request){
|
||||
|
||||
$request->validate([
|
||||
'direct_partner' => 'required',
|
||||
'server_id' => 'required',
|
||||
'connection_type' => 'required',
|
||||
'port' => 'required_with:main_ip_address,domain_name',
|
||||
'main_ip_address' => 'sometimes|nullable|ip',
|
||||
'private_ip_address' => 'sometimes|nullable|ip',
|
||||
'domain_name' => 'sometimes|nullable|regex:/^([a-zA-Z0-9][a-zA-Z0-9-_]*\.)*[a-zA-Z0-9]*[a-zA-Z0-9-_]*[[a-zA-Z0-9]+$/',
|
||||
'vpn_peer_ip' => 'required_if:connection_type,vpn|nullable|ip',
|
||||
'connection_form' => 'sometimes|nullable|max:2000|mimes:doc,docx,xlx,xlsx,png,jpg,jpeg,bmp',
|
||||
]);
|
||||
if ($request->direct_id == null) {
|
||||
return redirect()->back()->withInput()->withErrors(['Your request could not be handled at this time. Try again!']);
|
||||
}
|
||||
$direct_connection = Models\DirectConnection::find($request->direct_id);
|
||||
|
||||
if ($request->main_ip_address == null && $request->domain_name == null ) {
|
||||
return redirect()->back()->withInput()->withErrors(['You need either an IP address or a Domain name']);
|
||||
}
|
||||
$direct_arr = $request->except('_token');
|
||||
$direct_arr['last_modified_by'] = session('current_user.id');
|
||||
// dd($direct_arr);
|
||||
|
||||
if ($request->hasFile('connection_form')) {
|
||||
if ($request->file('connection_form')->isValid()) {
|
||||
$filename = "connection_document_" . time() . "." . $request->connection_form->extension();
|
||||
$request->connection_form->storeAs('connection_files', $filename, 'public');
|
||||
$direct_arr['connection_document'] = $filename;
|
||||
}
|
||||
}
|
||||
|
||||
$result = $direct_connection->update($direct_arr);
|
||||
Session::flash('success_message', 'Direct connection successfully updated');
|
||||
return redirect(url('infrastructure/servers'));
|
||||
}
|
||||
public function server_list(){
|
||||
|
||||
$servers = Models\ClickServer::with('credentials_info')->get();
|
||||
// dd($servers[0]->credentials_info->where('username', 'root')->first());
|
||||
$data = [
|
||||
'page_title' => 'Servers',
|
||||
'servers' => $servers
|
||||
];
|
||||
return view('infrastructure.server_list', $data);
|
||||
|
||||
}
|
||||
public function edit_server($id)
|
||||
{
|
||||
$server = Models\ClickServer::find($id);
|
||||
$credentials = Models\ServerCredential::where('username', 'root')->where('server_id', $server->id) ->first();
|
||||
|
||||
$data = [
|
||||
'page_title' => 'Servers',
|
||||
'server' => $server,
|
||||
'credentials' => $credentials
|
||||
];
|
||||
return view('infrastructure.edit_server', $data);
|
||||
}
|
||||
public function updateserver(Request $request){
|
||||
$request->validate([
|
||||
'friendly_name' => 'required',
|
||||
'server_id' => 'required',
|
||||
'public_ip_address' => 'sometimes|ip',
|
||||
'private_ip_address' => 'sometimes|nullable|ip',
|
||||
'main_use' => 'required',
|
||||
'remarks' => 'nullable',
|
||||
'password' => 'nullable',
|
||||
]);
|
||||
$server = Models\ClickServer::findOrFail($request->server_id);
|
||||
$server_arr = $request->except('_token', 'password', 'server_id');
|
||||
$server_arr['last_modified_by'] = session('current_user.id');
|
||||
if ($request->password !== null) {
|
||||
// dd('foo bar');
|
||||
$credentials_arr = [
|
||||
'server_id' => $request->server_id,
|
||||
'username' => 'root',
|
||||
'password' => encrypt($request->password),
|
||||
'last_modified_by' => session('current_user.id')
|
||||
];
|
||||
$retval = Models\ServerCredential::find($request->server_id);
|
||||
if ($retval) {
|
||||
$retval->update($credentials_arr);
|
||||
}
|
||||
else{
|
||||
$result = Models\ServerCredential::create($credentials_arr);
|
||||
}
|
||||
}
|
||||
$result = $server->update($server_arr);
|
||||
Session::flash('success_message', 'Server Details successfully updated');
|
||||
return redirect(url('infrastructure/server-list'));
|
||||
}
|
||||
public function reveal_password($id){
|
||||
$server = Models\ClickServer::find($id);
|
||||
if ($server) {
|
||||
$response_arr = [
|
||||
'code' => 1,
|
||||
'password' => decrypt($server->root_password)
|
||||
];
|
||||
}
|
||||
else{
|
||||
$response_arr = [
|
||||
'code' => 3,
|
||||
'msg' => 'not found'
|
||||
];
|
||||
}
|
||||
return response()->json($response_arr);
|
||||
}
|
||||
}
|
||||
//LJ School Location
|
||||
//5.637192,-0.158916
|
||||
//5.637093,-0.159269
|
||||
Reference in New Issue
Block a user