芝麻web文件管理V1.00
编辑当前文件:/home/pulsehostuk9/public_html/portal.pulsehost.co.uk/modules/reports/services.php
'ID', 'userid' => 'User ID', 'clientname' => 'Client Name', 'orderid' => 'Order ID', 'packageid' => 'Product ID', 'server' => 'Server ID', 'regdate' => 'Registration Date', 'domain' => 'Domain Name', 'dedicatedip' => 'Dedicated IP', 'assignedips' => 'Assigned IPs', 'firstpaymentamount' => 'First Payment Amount', 'amount' => 'Recurring Amount', 'billingcycle' => 'Billing Cycle', 'nextduedate' => 'Next Due Date', 'paymentmethod' => 'Payment Method', 'termination_date' => 'Termination Date', 'completed_date' => 'Completed Date', 'domainstatus' => 'Status', 'username' => 'Username', 'password' => 'Password', 'notes' => 'Notes', 'subscriptionid' => 'Subscription ID', 'suspendreason' => 'Suspend Reason' ]; $dateRangeFields = [ 'regdate' => 'Registration Date', 'nextduedate' => 'Next Due Date', 'termination_date' => 'Termination Date', 'completed_date' => 'Completed Date', ]; $removedDateRangeFields = array_diff($filterfields, $dateRangeFields); $reportdata["description"] = $reportdata["headertext"] = ''; $incfields = $whmcs->get_req_var('incfields'); $filterfield = $whmcs->get_req_var('filterfield'); $filtertype = $whmcs->get_req_var('filtertype'); $filterq = $whmcs->get_req_var('filterq'); $regDateRange = App::getFromRequest('regDateRange'); $nextDueDateRange = App::getFromRequest('nextDueDateRange'); $termDateRange = App::getFromRequest('termDateRange'); $completedDateRange = App::getFromRequest('completedDateRange'); if (!is_array($incfields)) { $incfields = []; } if (!is_array($filterfield)) { $filterfield = []; } if (!is_array($filtertype)) { $filtertype = []; } if (!is_array($filterq)) { $filterq = []; } if (!$print) { $reportdata["description"] = "This report can be used to generate a custom export of" . " services by applying up to 5 filters. CSV Export is available via the Tools menu to the right."; $reportdata["headertext"] = '
Fields to Include
'; $i=0; foreach ($filterfields as $k => $v) { $reportdata["headertext"] .= '
' . $v . '
'; $i++; if (($i%5)==0) { $reportdata["headertext"] .= '
'; } } $reportdata["headertext"] .= '
'; for ($i = 1; $i <= 5; $i ++) { $reportdata["headertext"] .= '
Filter ' . $i . '
None
'; foreach ($removedDateRangeFields as $k => $v) { $reportdata["headertext"] .= '
'; } $reportdata["headertext"] .= '
' . '
Exact Match
'; } $reportdata["headertext"] .= <<
Registration Date Range
Next Due Date Range
Termination Date Range
Completed Date Range
HTML; } if (count($incfields)) { $query = Capsule::table('tblhosting'); foreach ($filterfield as $i => $val) { if ($val && array_key_exists($val, $filterfields)) { if ($filtertype[$i] == 'like') { $filterq[$i] = "%{$filterq[$i]}%"; } if ($val == 'clientname') { $query->whereRaw( "concat(tblclients.firstname, ' ', tblclients.lastname) " . "{$filtertype[$i]} '{$filterq[$i]}'" ); } else { $query->where( "tblhosting.{$filterfield[$i]}", $filtertype[$i], $filterq[$i] ); } } } foreach ($incfields as $fieldname) { if (array_key_exists($fieldname, $filterfields)) { $reportdata["tableheadings"][] = $filterfields[$fieldname]; if ($fieldname == "clientname") { $query->addSelect(Capsule::raw("concat(tblclients.firstname, ' ', tblclients.lastname)")); } else { $query->addSelect("tblhosting.{$fieldname}"); } } } if ($regDateRange) { $dateRange = Carbon::parseDateRangeValue($regDateRange); $fromdate = $dateRange['from']->toDateTimeString(); $todate = $dateRange['to']->toDateTimeString(); $query->whereBetween('regdate', [$fromdate, $todate]); } if ($nextDueDateRange) { $dateRange = Carbon::parseDateRangeValue($nextDueDateRange); $fromdate = $dateRange['from']->toDateTimeString(); $todate = $dateRange['to']->toDateTimeString(); $query->whereBetween('nextduedate', [$fromdate, $todate]); } if ($termDateRange) { $dateRange = Carbon::parseDateRangeValue($termDateRange); $fromdate = $dateRange['from']->toDateTimeString(); $todate = $dateRange['to']->toDateTimeString(); $query->whereBetween('termination_date', [$fromdate, $todate]); } if ($completedDateRange) { $dateRange = Carbon::parseDateRangeValue($completedDateRange); $fromdate = $dateRange['from']->toDateTimeString(); $todate = $dateRange['to']->toDateTimeString(); $query->whereBetween('completed_date', [$fromdate, $todate]); } $results = $query ->join('tblclients', 'tblclients.id', '=', 'tblhosting.userid') ->get() ->all(); foreach ($results as $result) { $result = (array) $result; if (isset($result['paymentmethod'])) { $result['paymentmethod'] = $gateways->getDisplayName($result['paymentmethod']); } if (isset($result['password'])) { $result['password'] = decrypt($result['password']); } $reportdata["tablevalues"][] = $result; } }