mirror of
				https://github.com/cp6/my-idlers.git
				synced 2025-10-30 22:09:10 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			132 lines
		
	
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			132 lines
		
	
	
	
		
			4.2 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
| <?php
 | |
| 
 | |
| namespace App\Http\Controllers;
 | |
| 
 | |
| use App\Models\DNS;
 | |
| use App\Models\Labels;
 | |
| use App\Models\Reseller;
 | |
| use App\Models\Server;
 | |
| use App\Models\Domains;
 | |
| use App\Models\Shared;
 | |
| use Carbon\Carbon;
 | |
| use Illuminate\Http\Request;
 | |
| use Illuminate\Support\Facades\DB;
 | |
| use Illuminate\Support\Str;
 | |
| 
 | |
| class DNSController extends Controller
 | |
| {
 | |
|     public function index()
 | |
|     {
 | |
|         $dn = DB::table('d_n_s')->get();
 | |
|         return view('dns.index', compact(['dn']));
 | |
|     }
 | |
| 
 | |
|     public function create()
 | |
|     {
 | |
|         $Servers = Server::all();
 | |
|         $Domains = Domains::all();
 | |
|         $Shareds = Shared::all();
 | |
|         $Resellers = Reseller::all();
 | |
|         return view('dns.create', compact(['Servers', 'Domains', 'Shareds', 'Resellers']));
 | |
|     }
 | |
| 
 | |
|     public function store(Request $request)
 | |
|     {
 | |
|         $request->validate([
 | |
|             'hostname' => 'required|min:2',
 | |
|             'address' => 'required|min:2',
 | |
|             'dns_type' => 'required'
 | |
|         ]);
 | |
| 
 | |
|         $dns_id = Str::random(8);
 | |
| 
 | |
|         DNS::create([
 | |
|             'id' => $dns_id,
 | |
|             'hostname' => $request->hostname,
 | |
|             'dns_type' => $request->dns_type,
 | |
|             'address' => $request->address,
 | |
|             'server_id' => ($request->server_id !== 'null') ? $request->server_id : null,
 | |
|             'shared_id' => ($request->shared_id !== 'null') ? $request->shared_id : null,
 | |
|             'reseller_id' => ($request->reseller_id !== 'null') ? $request->reseller_id : null,
 | |
|             'domain_id' => ($request->domain_id !== 'null') ? $request->domain_id : null
 | |
|         ]);
 | |
| 
 | |
|         $labels_array = [$request->label1, $request->label2, $request->label3, $request->label4];
 | |
| 
 | |
|         for ($i = 1; $i <= 4; $i++) {
 | |
|             if (!is_null($labels_array[($i - 1)])) {
 | |
|                 DB::insert('INSERT IGNORE INTO labels_assigned (label_id, service_id) values (?, ?)', [$labels_array[($i - 1)], $dns_id]);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return redirect()->route('dns.index')
 | |
|             ->with('success', 'DNS Created Successfully.');
 | |
|     }
 | |
| 
 | |
|     public function show(DNS $dn)
 | |
|     {
 | |
|         $dns = DNS::findOrFail($dn->id);
 | |
|         return view('dns.show', compact(['dn', 'dns']));
 | |
|     }
 | |
| 
 | |
|     public function edit(DNS $dn)
 | |
|     {
 | |
|         $Servers = Server::all();
 | |
|         $Domains = Domains::all();
 | |
|         $Shareds = Shared::all();
 | |
|         $Resellers = Reseller::all();
 | |
|         $dn = DNS::findOrFail($dn->id);
 | |
|         $labels = DB::table('labels_assigned as l')
 | |
|             ->join('labels', 'l.label_id', '=', 'labels.id')
 | |
|             ->where('l.service_id', '=', $dn->id)
 | |
|             ->get(['labels.id', 'labels.label']);
 | |
| 
 | |
|         return view('dns.edit', compact(['dn', 'labels','Servers', 'Domains', 'Shareds', 'Resellers']));
 | |
|     }
 | |
| 
 | |
|     public function update(Request $request, DNS $dn)
 | |
|     {
 | |
|         $request->validate([
 | |
|             'hostname' => 'required|min:2',
 | |
|             'address' => 'required|min:2',
 | |
|             'dns_type' => 'required'
 | |
|         ]);
 | |
| 
 | |
|         $dn->update([
 | |
|             'hostname' => $request->hostname,
 | |
|             'dns_type' => $request->dns_type,
 | |
|             'address' => $request->address,
 | |
|             'server_id' => ($request->server_id !== 'null') ? $request->server_id : null,
 | |
|             'shared_id' => ($request->shared_id !== 'null') ? $request->shared_id : null,
 | |
|             'reseller_id' => ($request->reseller_id !== 'null') ? $request->reseller_id : null,
 | |
|             'domain_id' => ($request->domain_id !== 'null') ? $request->domain_id : null
 | |
|         ]);
 | |
| 
 | |
| 
 | |
|         $deleted = DB::table('labels_assigned')->where('service_id', '=', $dn->id)->delete();
 | |
| 
 | |
|         $labels_array = [$request->label1, $request->label2, $request->label3, $request->label4];
 | |
| 
 | |
|         for ($i = 1; $i <= 4; $i++) {
 | |
|             if (!is_null($labels_array[($i - 1)])) {
 | |
|                 DB::insert('INSERT IGNORE INTO labels_assigned ( label_id, service_id) values (?, ?)', [$labels_array[($i - 1)], $dn->id]);
 | |
|             }
 | |
|         }
 | |
| 
 | |
|         return redirect()->route('dns.index')
 | |
|             ->with('success', 'DNS updated Successfully.');
 | |
|     }
 | |
| 
 | |
|     public function destroy(DNS $dn)
 | |
|     {
 | |
|         $id = $dn->id;
 | |
|         $items = DNS::find($id);
 | |
| 
 | |
|         $items->delete();
 | |
| 
 | |
|         Labels::deleteLabelsAssignedTo($id);
 | |
| 
 | |
|         return redirect()->route('dns.index')
 | |
|             ->with('success', 'DNS was deleted Successfully.');
 | |
|     }
 | |
| }
 |