File "child-panels.php"

Full Path: /home/cananyalcin/public_html/core/module/admin/child-panels.php
File size: 6.59 KB
MIME-type: text/x-php
Charset: utf-8

<?php

  if( $user["access"]["child_panels"] != 1  ):
    header("Location:".site_url("admin"));
    exit();
  endif;

if( route(2) && is_numeric(route(2)) ):
  $page = route(2);
else:
  $page = 1;
endif;

   $statusList = ["all","active","pending","completed","canceled","expired"];
    if( route(3) && in_array(route(3),$statusList) ):
      $status   = route(3);
    elseif( !route(3) || !in_array(route(3),$statusList) ):
      $status   = "all";
    endif;

/* Sorgulama */

        /* All */ 
     if( $_GET["status"] == "all" && $_GET["status"] ):
        $status = $_GET["status"];
        $search_link  = "?status=pending";
        
        /* Active */ 
     elseif( $_GET["status"] == "active" && $_GET["status"] ):
          $status = $_GET["status"];
        $search       = " panel_status='active' ";
        $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id = child_panels.client_id WHERE {$search}");
        $count        -> execute(array());
        $count        = $count->rowCount();
        $search       = "WHERE {$search}";
        $search_link  = "?status=active";
        
        /* Pending */ 
    elseif( $_GET["status"] == "pending" && $_GET["status"] ):
          $status = $_GET["status"];
        $search       = " panel_status='pending' ";
        $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id = child_panels.client_id WHERE {$search}");
        $count        -> execute(array());
        $count        = $count->rowCount();
        $search       = "WHERE {$search}";
        $search_link  = "?status=pending";
        
        /* Completed */ 
    elseif( $_GET["status"] == "frozen" && $_GET["status"] ):
          $status = $_GET["status"];
        $search       = " panel_status='frozen' ";
        $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id = child_panels.client_id WHERE {$search}");
        $count        -> execute(array());
        $count        = $count->rowCount();
        $search       = "WHERE {$search}";
        $search_link  = "?status=frozen";    
        
        /* Expired */ 
    elseif( $_GET["status"] == "expired" && $_GET["status"] ):
          $status = $_GET["status"];
        $search       = " panel_status='expired' ";
        $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id = child_panels.client_id WHERE {$search}");
        $count        -> execute(array());
        $count        = $count->rowCount();
        $search       = "WHERE {$search}";
        $search_link  = "?status=expired";  
        
        /* Canceled */ 
    elseif( $_GET["status"] == "canceled" && $_GET["status"] ):
          $status = $_GET["status"];
        $search       = " panel_status='canceled' ";
        $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id = child_panels.client_id WHERE {$search}");
        $count        -> execute(array());
        $count        = $count->rowCount();
        $search       = "WHERE {$search}";
        $search_link  = "?status=canceled";


/* Sorgulama Kısmı */        

elseif( $_GET["search_type"] == "username" && $_GET["search"] && countRow(["table"=>"clients","where"=>["username"=>$_GET["search"]]]) ):
    
  $search_where = $_GET["search_type"];
  $search_word  = urldecode($_GET["search"]);
  $clients      = $conn->prepare("SELECT client_id FROM clients WHERE username LIKE '%".$search_word."%' ");
  $clients     -> execute(array());
  $clients      = $clients->fetchAll(PDO::FETCH_ASSOC);
  $id=  "("; foreach ($clients as $client) { $id.=$client["client_id"].","; } if( substr($id,-1) == "," ):  $id = substr($id,0,-1); endif; $id.=")";
  $search       = " child_panels.client_id IN ".$id;
  $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id=child_panels.client_id WHERE {$search} ");
  $count        -> execute(array());
  $count        = $count->rowCount();
  $search       = "WHERE {$search} ";
  $search_link  = "?search=".$search_word."&search_type=".$search_where;
  
elseif( $_GET["search_type"] == "domain" && $_GET["search"] && countRow(["table"=>"child_panels","where"=>["panel_domain"=>$_GET["search"]]])  ):
  $search_where = $_GET["search_type"];
  
  $search_word  = urldecode($_GET["search"]);
  $count        = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id=child_panels.client_id WHERE child_panels.panel_domain LIKE '%".$search_word."%' ");
  $count        -> execute(array());
  $count        = $count->rowCount();
  $search       = "WHERE child_panels.panel_domain LIKE '%".$search_word."%' ";
  $search_link  = "?search=".$search_word."&search_type=".$search_where;
else:
  $count          = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id=child_panels.client_id ");
  $count        ->execute(array());
  $count          = $count->rowCount();
  $search         = "";
endif;

  $to             = 50;
  $pageCount      = ceil($count/$to); if( $page > $pageCount ): $page = 1; endif;
  $where          = ($page*$to)-$to;
  $paginationArr  = ["count"=>$pageCount,"current"=>$page,"next"=>$page+1,"previous"=>$page-1];
  $panels = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id=child_panels.client_id $search ORDER BY child_panels.id DESC LIMIT $where,$to ");
  $panels->execute(array());
  $panels = $panels->fetchAll(PDO::FETCH_ASSOC);

 if( route(2) == "cancel" ):
    $id     = route(3);
    $panel  = $conn->prepare("SELECT * FROM child_panels INNER JOIN clients ON clients.client_id = child_panels.client_id WHERE child_panels.id=:id ");
    $panel ->execute(array("id"=>$id));
    $panel  = $panel->fetch(PDO::FETCH_ASSOC);
    $balance= $panel["balance"]+$panel["panel_price"];
    $spent  = $panel["spent"]-$panel["panel_price"];
    $conn->beginTransaction();
    
    $update = $conn->prepare("UPDATE child_panels SET panel_status=:status, panel_price=:price WHERE id=:id ");
    $update = $update->execute(array("price"=>0,"status"=>"canceled","id"=>$id));
    
    $update2= $conn->prepare("UPDATE clients SET balance=:balance, spent=:spent WHERE client_id=:id ");
    $update2= $update2->execute(array("id"=>$panel["client_id"],"balance"=>$balance,"spent"=>$spent ));
    
      if( $update && $update2 ):
 $conn->commit();
        unset($_SESSION["data"]);
        $success    = 1;
        $successText= "Transaction Successful";
      
      else:
        $conn->rollBack();
        $error      = 1;
        $errorText  = "Operation Failed";
      endif;
    endif;

require admin_view('child-panels');