Backend parkir - itcn.co.id
This commit is contained in:
63
app/Http/Controllers/Api/V1/ConfigParameter.php
Normal file
63
app/Http/Controllers/Api/V1/ConfigParameter.php
Normal file
@@ -0,0 +1,63 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\NamaPos;
|
||||
use App\Models\SoftSettings;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
class ConfigParameter extends Controller
|
||||
{
|
||||
public function index(Request $request)
|
||||
{
|
||||
// $query = $request->query('gate');
|
||||
$query = $_GET['gate'] ?? null;
|
||||
|
||||
Log::info('Query Params:', $request->query());
|
||||
Log::info('Gate Param:', [$request->query('gate')]);
|
||||
|
||||
if (!array_key_exists('gate', $_GET)) {
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'desc' => 'Parameter undefined',
|
||||
],400);
|
||||
|
||||
}
|
||||
|
||||
if ($query === '') {
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'desc' => 'Parameter gate tidak boleh kosong',
|
||||
], 400);
|
||||
}
|
||||
|
||||
|
||||
$getLocation = SoftSettings::first();
|
||||
|
||||
$location = [
|
||||
'namaSoftware' => $getLocation->namasoft,
|
||||
'namaSystem' => $getLocation->namasystem,
|
||||
'LocatioName' => $getLocation->namalokasi,
|
||||
'locationAddress' => $getLocation->alamatlokasi ?? 'location Undefined',
|
||||
'CompanyName' => $getLocation->namaperusahaan,
|
||||
'merchantID' => $getLocation->cabang_lokasi,
|
||||
];
|
||||
|
||||
if($query) {
|
||||
$getPos = NamaPos::where('id', $request->query('gate'))->with('posParams','posHardware')->first();
|
||||
$location['gateDetails'] = $getPos;
|
||||
// Log::info($getPos->toSql());
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'details' => $location
|
||||
]);
|
||||
}
|
||||
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'details' => $location,
|
||||
]);
|
||||
}
|
||||
}
|
||||
314
app/Http/Controllers/Api/V1/TransaksiMember.php
Normal file
314
app/Http/Controllers/Api/V1/TransaksiMember.php
Normal file
@@ -0,0 +1,314 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\CardMember;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Str;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
class TransaksiMember extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
|
||||
private function getData(Request $request)
|
||||
{
|
||||
// return DB::table('mergetransaksistikerdetail');
|
||||
|
||||
$allowedPath = ['nama', 'nopol','card'];
|
||||
|
||||
foreach ( $request->query() as $key => $value ) {
|
||||
if (!in_array($key, $allowedPath)) {
|
||||
return response()->json([
|
||||
'error' => 'Parameter tidak ditemukan',
|
||||
'suggest' => 'Jangan menebak parameter',
|
||||
'invalid_parameter' => $key,
|
||||
], 400);
|
||||
}
|
||||
|
||||
if (empty($value)) {
|
||||
return response()->json([
|
||||
'error' => 'Nilai parameter tidak dimasukkan',
|
||||
'parameter' => $key,
|
||||
], 400);
|
||||
}
|
||||
}
|
||||
|
||||
$nama = $request->query('nama');
|
||||
$nopol = $request->query('nopol');
|
||||
$card = $request->query('card');
|
||||
|
||||
if (!$nama && !$nopol && !$card) {
|
||||
return response()->json([
|
||||
"application" => [
|
||||
"name" => "Transaksi Stiker",
|
||||
"environment" => env('APP_ENV'),
|
||||
"version" => "v1.0",
|
||||
"author" => "itcn.co.id",
|
||||
"description" => 'make sure your subscription has been renewed :)'
|
||||
]
|
||||
]);
|
||||
}
|
||||
|
||||
$query = DB::table('mergetransaksistikerdetail');
|
||||
|
||||
if ($nama) {
|
||||
$query->where('nama', Str::upper($nama));
|
||||
} elseif ($nopol) {
|
||||
$query->where('nopol', Str::upper($nopol));
|
||||
} elseif ($card) {
|
||||
$notrans = CardMember::where('no_card', $card);
|
||||
// if (!$notrans) {
|
||||
// // return response()->json(['status' => 'failed', 'result' => 'Kartu tidak ditemukan/tidak terdaftar'], 400);
|
||||
// return null;
|
||||
// }
|
||||
$query->where('no_id', $notrans);
|
||||
}
|
||||
|
||||
return $query;
|
||||
|
||||
}
|
||||
|
||||
public function index(Request $request)
|
||||
{
|
||||
|
||||
// $allowedPath = ['nama', 'nopol','card'];
|
||||
|
||||
// foreach ( $request->query() as $key => $value ) {
|
||||
// if (!in_array($key, $allowedPath)) {
|
||||
// return response()->json([
|
||||
// 'error' => 'Parameter tidak ditemukan',
|
||||
// 'suggest' => 'Jangan menebak parameter',
|
||||
// 'invalid_parameter' => $key,
|
||||
// ], 400);
|
||||
// }
|
||||
|
||||
// if (empty($value)) {
|
||||
// return response()->json([
|
||||
// 'error' => 'Nilai parameter tidak dimasukkan',
|
||||
// 'parameter' => $key,
|
||||
// ], 400);
|
||||
// }
|
||||
// }
|
||||
|
||||
// $nama = $request->query('nama');
|
||||
// $nopol = $request->query('nopol');
|
||||
// $card = $request->query('card');
|
||||
|
||||
// if (!$nama && !$nopol && !$card) {
|
||||
// return response()->json([
|
||||
// "application" => [
|
||||
// "name" => "Transaksi Stiker",
|
||||
// "environment" => env('APP_ENV'),
|
||||
// "version" => "v1.0",
|
||||
// "author" => "itcn.co.id",
|
||||
// "description" => 'make sure your subscription has been renewed :)'
|
||||
// ]
|
||||
// ]);
|
||||
// }
|
||||
|
||||
// // $query = DB::table('mergetransaksistikerdetail')
|
||||
|
||||
|
||||
// if ($nama) {
|
||||
// // $query->where('nama', Str::upper($nama));
|
||||
// $query = $this->getData()->where('nama', Str::upper($nama));
|
||||
// }
|
||||
|
||||
// if ($nopol) {
|
||||
// // $query->where('nopol', Str::upper($nopol));
|
||||
// $query = $this->getData()->where('nopol', Str::upper($nopol));
|
||||
// }
|
||||
|
||||
// if ($card) {
|
||||
// // Log::info($card);
|
||||
// // $query->where('nama', Str::upper($nama));
|
||||
// $notrans = CardMember::where('no_card', $card)->first();
|
||||
// Log::info('ketemu : ' .$notrans->notrans);
|
||||
// // $query->where('no_id', $notrans->notrans);
|
||||
// $query = $this->getData()->where('no_id', $notrans->notrans);
|
||||
// }
|
||||
|
||||
// $query = $query
|
||||
// Log::info('Data : yg di cari : ' . $request);
|
||||
$query = $this->getData($request)
|
||||
->whereRaw('? BETWEEN awal AND akhir', [now()])
|
||||
->first();
|
||||
Log::info($query->toSql());
|
||||
|
||||
// Log::info('Data : ' . $query);
|
||||
if ($query) {
|
||||
$today = Carbon::now();
|
||||
$endDate = $query->akhir;
|
||||
$dayCount = $today->diffInDays($endDate);
|
||||
$monthCount = $today->diffInMonths($endDate);
|
||||
$yearCount = $today->diffInYears($endDate);
|
||||
Log::info($query->akhir);
|
||||
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'status_langganan' => 'active',
|
||||
'masa_aktif' => $dayCount . ' Hari.',
|
||||
'result' => $query,
|
||||
]);
|
||||
} else {
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'result' => 'Tidak ditemukan data',
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
public function status (Request $request)
|
||||
{
|
||||
|
||||
// $allowedPath = ['nama', 'nopol','card'];
|
||||
|
||||
// foreach ( $request->query() as $key => $value ) {
|
||||
// if (!in_array($key, $allowedPath)) {
|
||||
// return response()->json([
|
||||
// 'error' => 'Parameter tidak ditemukan',
|
||||
// 'suggest' => 'Jangan menebak parameter',
|
||||
// 'invalid_parameter' => $key,
|
||||
// ], 400);
|
||||
// }
|
||||
|
||||
// if (empty($value)) {
|
||||
// return response()->json([
|
||||
// 'error' => 'Nilai parameter tidak dimasukkan',
|
||||
// 'parameter' => $key,
|
||||
// ], 400);
|
||||
// }
|
||||
// }
|
||||
|
||||
// $nama = $request->query('nama');
|
||||
// $nopol = $request->query('nopol');
|
||||
// $card = $request->query('card');
|
||||
|
||||
// if (!$nama && !$nopol && !$card) {
|
||||
// return response()->json([
|
||||
// "application" => [
|
||||
// "name" => "Transaksi Stiker",
|
||||
// "environment" => env('APP_ENV'),
|
||||
// "version" => "v1.0",
|
||||
// "author" => "itcn.co.id",
|
||||
// "description" => 'make sure your subscription has been renewed :)'
|
||||
// ]
|
||||
// ]);
|
||||
// }
|
||||
|
||||
// if ($nama) {
|
||||
// // $query->where('nama', Str::upper($nama));
|
||||
// $query = $this->getData()->where('nama', Str::upper($nama));
|
||||
// }
|
||||
|
||||
// if ($nopol) {
|
||||
// // $query->where('nopol', Str::upper($nopol));
|
||||
// $query = $this->getData()->where('nopol', Str::upper($nopol));
|
||||
// }
|
||||
|
||||
// if ($card) {
|
||||
// // Log::info($card);
|
||||
// // $query->where('nama', Str::upper($nama));
|
||||
// $notrans = CardMember::where('no_card', $card)->first();
|
||||
// // Log::info('ketemu : ' .$notrans->notrans);
|
||||
// // $query->where('no_id', $notrans->notrans);
|
||||
// $query = $this->getData()->where('no_id', $notrans->notrans);
|
||||
// }
|
||||
|
||||
// $data = $query
|
||||
$data = $this->getData($request)
|
||||
->orderBy('tanggal', 'desc')
|
||||
->get();
|
||||
|
||||
Log::info('Data yg ditemukan : ' . $data);
|
||||
|
||||
if ($data->isNotEmpty()) {
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'result' => $data,
|
||||
]);
|
||||
} else {
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'result' => 'Tidak ditemukan data',
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
||||
159
app/Http/Controllers/Api/V1/TransaksiParkir.php
Normal file
159
app/Http/Controllers/Api/V1/TransaksiParkir.php
Normal file
@@ -0,0 +1,159 @@
|
||||
<?php
|
||||
|
||||
namespace App\Http\Controllers\Api\V1;
|
||||
|
||||
use Carbon\Carbon;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\CardMember;
|
||||
use App\Models\TransaksiParkir as TransPark;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Str;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
|
||||
|
||||
class TransaksiParkir extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function index(Request $request)
|
||||
{
|
||||
$query = $request->query('find');
|
||||
|
||||
if ($query) {
|
||||
|
||||
$data = $request->query('find');
|
||||
Log::info($data);
|
||||
|
||||
$card = CardMember::where('no_card', Str::upper($data))->first();
|
||||
|
||||
if (!$card) {
|
||||
$trans = TransPark::where('no_pol', Str::upper($data))->where('status', 1)->first();
|
||||
|
||||
if ($trans) {
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'desc' => 'Nomor Polisi/Kartu masih di dalam'
|
||||
]);
|
||||
}
|
||||
} else {
|
||||
Log::info($card);
|
||||
$validMember = DB::table('mergetransaksistikerdetail')->where('no_id', $card->notrans)->first();
|
||||
if (!$validMember) {
|
||||
return response()->json([
|
||||
'status' => 'ok'
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'desc' => 'Tidak ditemukan data'
|
||||
]);
|
||||
|
||||
} else {
|
||||
return response()->json([
|
||||
'status' => 'failed',
|
||||
'desc' => 'parameter tidak ditemukan'
|
||||
]);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
*
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
Log::info($request->no_pol);
|
||||
$gateID = $request->id_pintu_masuk ?? '00';
|
||||
$dateNow = Carbon::now()->format('Y-m-d H:i:s');
|
||||
$idTrans = TransPark::select('id')->orderBy('id', 'desc')->first();
|
||||
if (!$idTrans) {
|
||||
$newTrans = 0;
|
||||
} else {
|
||||
Log::info('data sebelumnya ' . $idTrans->id);
|
||||
$newTrans = $idTrans->id + 1;
|
||||
Log::info('setelah dijumlah ' . $newTrans);
|
||||
}
|
||||
$trans = str_pad($newTrans, 4, '0', STR_PAD_LEFT);
|
||||
Log::info($newTrans);
|
||||
|
||||
Log::info('Tanggal hari ini : ' . $dateNow);
|
||||
$transaksi = TransPark::create([
|
||||
'id' => $gateID . $trans,
|
||||
'no_pol' => $request->no_pol ?? $gateID . $trans . Carbon::now()->format('YmdHis'),
|
||||
'id_kendaraan' => 'A',
|
||||
'id_pintu_masuk' => $request->id_pintu_masuk ?? $gateID,
|
||||
'status' => 1,
|
||||
'status_transaksi' => $request->status_transaksi,
|
||||
'waktu_masuk' => $request->waktu_masuk ?? $dateNow,
|
||||
'tanggal' => $request->waktu_masuk ?? $dateNow,
|
||||
]);
|
||||
|
||||
return $transaksi;
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\Http\Response
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user