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