Commit 3b1b2129 authored by Tyo Aditya YS's avatar Tyo Aditya YS
Browse files

first commit

parents
No related merge requests found
Pipeline #3526 failed with stages
in 1 minute and 22 seconds
Showing with 1127 additions and 0 deletions
+1127 -0
root = true
[*]
charset = utf-8
end_of_line = lf
indent_size = 4
indent_style = space
insert_final_newline = true
trim_trailing_whitespace = true
[*.md]
trim_trailing_whitespace = false
[*.{yml,yaml}]
indent_size = 2
[docker-compose.yml]
indent_size = 4
APP_NAME=Laravel
APP_ENV=local
APP_KEY=
APP_DEBUG=true
APP_URL=http://localhost
LOG_CHANNEL=stack
LOG_DEPRECATIONS_CHANNEL=null
LOG_LEVEL=debug
DB_CONNECTION=mysql
DB_HOST=127.0.0.1
DB_PORT=3306
DB_DATABASE=laravel
DB_USERNAME=root
DB_PASSWORD=
BROADCAST_DRIVER=log
CACHE_DRIVER=file
FILESYSTEM_DISK=local
QUEUE_CONNECTION=sync
SESSION_DRIVER=file
SESSION_LIFETIME=120
MEMCACHED_HOST=127.0.0.1
REDIS_HOST=127.0.0.1
REDIS_PASSWORD=null
REDIS_PORT=6379
MAIL_MAILER=smtp
MAIL_HOST=mailpit
MAIL_PORT=1025
MAIL_USERNAME=null
MAIL_PASSWORD=null
MAIL_ENCRYPTION=null
MAIL_FROM_ADDRESS="hello@example.com"
MAIL_FROM_NAME="${APP_NAME}"
AWS_ACCESS_KEY_ID=
AWS_SECRET_ACCESS_KEY=
AWS_DEFAULT_REGION=us-east-1
AWS_BUCKET=
AWS_USE_PATH_STYLE_ENDPOINT=false
PUSHER_APP_ID=
PUSHER_APP_KEY=
PUSHER_APP_SECRET=
PUSHER_HOST=
PUSHER_PORT=443
PUSHER_SCHEME=https
PUSHER_APP_CLUSTER=mt1
VITE_PUSHER_APP_KEY="${PUSHER_APP_KEY}"
VITE_PUSHER_HOST="${PUSHER_HOST}"
VITE_PUSHER_PORT="${PUSHER_PORT}"
VITE_PUSHER_SCHEME="${PUSHER_SCHEME}"
VITE_PUSHER_APP_CLUSTER="${PUSHER_APP_CLUSTER}"
* text=auto eol=lf
*.blade.php diff=html
*.css diff=css
*.html diff=html
*.md diff=markdown
*.php diff=php
/.github export-ignore
CHANGELOG.md export-ignore
.styleci.yml export-ignore
/.phpunit.cache
/node_modules
/public/build
/public/hot
/public/storage
/storage/*.key
/vendor
.env
.env.backup
.env.production
Homestead.json
Homestead.yaml
auth.json
npm-debug.log
yarn-error.log
/.fleet
/.idea
/.vscode
<p align="center"><a href="https://laravel.com" target="_blank"><img src="https://raw.githubusercontent.com/laravel/art/master/logo-lockup/5%20SVG/2%20CMYK/1%20Full%20Color/laravel-logolockup-cmyk-red.svg" width="400" alt="Laravel Logo"></a></p>
<p align="center">
<a href="https://github.com/laravel/framework/actions"><img src="https://github.com/laravel/framework/workflows/tests/badge.svg" alt="Build Status"></a>
<a href="https://packagist.org/packages/laravel/framework"><img src="https://img.shields.io/packagist/dt/laravel/framework" alt="Total Downloads"></a>
<a href="https://packagist.org/packages/laravel/framework"><img src="https://img.shields.io/packagist/v/laravel/framework" alt="Latest Stable Version"></a>
<a href="https://packagist.org/packages/laravel/framework"><img src="https://img.shields.io/packagist/l/laravel/framework" alt="License"></a>
</p>
## About Laravel
Laravel is a web application framework with expressive, elegant syntax. We believe development must be an enjoyable and creative experience to be truly fulfilling. Laravel takes the pain out of development by easing common tasks used in many web projects, such as:
- [Simple, fast routing engine](https://laravel.com/docs/routing).
- [Powerful dependency injection container](https://laravel.com/docs/container).
- Multiple back-ends for [session](https://laravel.com/docs/session) and [cache](https://laravel.com/docs/cache) storage.
- Expressive, intuitive [database ORM](https://laravel.com/docs/eloquent).
- Database agnostic [schema migrations](https://laravel.com/docs/migrations).
- [Robust background job processing](https://laravel.com/docs/queues).
- [Real-time event broadcasting](https://laravel.com/docs/broadcasting).
Laravel is accessible, powerful, and provides tools required for large, robust applications.
## Learning Laravel
Laravel has the most extensive and thorough [documentation](https://laravel.com/docs) and video tutorial library of all modern web application frameworks, making it a breeze to get started with the framework.
You may also try the [Laravel Bootcamp](https://bootcamp.laravel.com), where you will be guided through building a modern Laravel application from scratch.
If you don't feel like reading, [Laracasts](https://laracasts.com) can help. Laracasts contains over 2000 video tutorials on a range of topics including Laravel, modern PHP, unit testing, and JavaScript. Boost your skills by digging into our comprehensive video library.
## Laravel Sponsors
We would like to extend our thanks to the following sponsors for funding Laravel development. If you are interested in becoming a sponsor, please visit the Laravel [Patreon page](https://patreon.com/taylorotwell).
### Premium Partners
- **[Vehikl](https://vehikl.com/)**
- **[Tighten Co.](https://tighten.co)**
- **[Kirschbaum Development Group](https://kirschbaumdevelopment.com)**
- **[64 Robots](https://64robots.com)**
- **[Cubet Techno Labs](https://cubettech.com)**
- **[Cyber-Duck](https://cyber-duck.co.uk)**
- **[Many](https://www.many.co.uk)**
- **[Webdock, Fast VPS Hosting](https://www.webdock.io/en)**
- **[DevSquad](https://devsquad.com)**
- **[Curotec](https://www.curotec.com/services/technologies/laravel/)**
- **[OP.GG](https://op.gg)**
- **[WebReinvent](https://webreinvent.com/?utm_source=laravel&utm_medium=github&utm_campaign=patreon-sponsors)**
- **[Lendio](https://lendio.com)**
## Contributing
Thank you for considering contributing to the Laravel framework! The contribution guide can be found in the [Laravel documentation](https://laravel.com/docs/contributions).
## Code of Conduct
In order to ensure that the Laravel community is welcoming to all, please review and abide by the [Code of Conduct](https://laravel.com/docs/contributions#code-of-conduct).
## Security Vulnerabilities
If you discover a security vulnerability within Laravel, please send an e-mail to Taylor Otwell via [taylor@laravel.com](mailto:taylor@laravel.com). All security vulnerabilities will be promptly addressed.
## License
The Laravel framework is open-sourced software licensed under the [MIT license](https://opensource.org/licenses/MIT).
<?php
namespace App\Console;
use Illuminate\Console\Scheduling\Schedule;
use Illuminate\Foundation\Console\Kernel as ConsoleKernel;
class Kernel extends ConsoleKernel
{
/**
* Define the application's command schedule.
*/
protected function schedule(Schedule $schedule): void
{
// $schedule->command('inspire')->hourly();
}
/**
* Register the commands for the application.
*/
protected function commands(): void
{
$this->load(__DIR__.'/Commands');
require base_path('routes/console.php');
}
}
<?php
namespace App\Exceptions;
use Illuminate\Foundation\Exceptions\Handler as ExceptionHandler;
use Throwable;
class Handler extends ExceptionHandler
{
/**
* A list of exception types with their corresponding custom log levels.
*
* @var array<class-string<\Throwable>, \Psr\Log\LogLevel::*>
*/
protected $levels = [
//
];
/**
* A list of the exception types that are not reported.
*
* @var array<int, class-string<\Throwable>>
*/
protected $dontReport = [
//
];
/**
* A list of the inputs that are never flashed to the session on validation exceptions.
*
* @var array<int, string>
*/
protected $dontFlash = [
'current_password',
'password',
'password_confirmation',
];
/**
* Register the exception handling callbacks for the application.
*/
public function register(): void
{
$this->reportable(function (Throwable $e) {
//
});
}
}
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\Auth;
use Illuminate\Http\Request;
use App\Models\Instansi;
use App\Models\AdminAplikasi;
use App\Models\Pembayaran;
use App\Models\Conference;
use Carbon\Carbon;
use App\Models\Account;
use App\Models\SettingLanding;
use App\Models\Topik;
use App\Models\Paket;
use Alert;
class AdminAppController extends Controller
{
/**
* Display a listing of the resource.
*/
public function dashboardadmapp()
{
$jumlahinstansi = Instansi::count();
$jumlahconference = Conference::count();
$jumlahadmapp = AdminAplikasi::count();
$jumlahconferencediterima = Conference::where('is_paid',1)->count();
$jumlahconferencemenunggu = Conference::where('is_paid',0)->count();
return view('admapp.DashboardAdmApp')->with(compact('jumlahinstansi','jumlahconference',
'jumlahadmapp','jumlahconferencediterima','jumlahconferencemenunggu'));
}
public function dataadmapp()
{
$dataadmapp = AdminAplikasi::with('account')->get();
return view('admapp.DataAdmApp')->with(compact('dataadmapp'));
}
public function addadmapp()
{
return view('admapp.AddAdmApp');
}
public function prosesaddadmapp(Request $request)
{
$this->validate($request, [
'nama_lengkap' => 'required',
'email' => 'required',
'password' => 'required',
]);
$account = Account::create([
'email' => $request->email,
'password' => bcrypt($request->password),
'id_role' => '1'
]);
$admapp = AdminAplikasi::create([
'id_account' => $account->id,
'nama_lengkap' => $request->nama_lengkap
]);
return redirect('/admin/dataadmapp');
}
public function editadmapp($id)
{
//$dataadmapp = AdminAplikasi::with('account')->where('id',$id)->get();
$dataadmapp = AdminAplikasi::findOrFail($id);
//$account = Account::find($dataadmapp->id_account);
return view('admapp.EditAdmApp')->with(compact('dataadmapp','id'));
}
public function proseseditadmapp(Request $request, $id)
{
$this->validate($request, [
'nama_lengkap' => 'required',
'email' => 'required'
]);
$admapp = AdminAplikasi::findOrFail($id);
$account = Account::find($admapp->id_account);
$account->update([
'id' => $account->id,
'email' => $request->email,
'id_role' => '1'
]);
$admapp->update([
'id' => $id,
'id_account' => $account->id,
'nama_lengkap' => $request->nama_lengkap
]);
return redirect('/admin/dataadmapp');
}
public function hapusadmapp($id)
{
$admapp = AdminAplikasi::findOrFail($id);
$admapp->delete();
$account = Account::find($admapp->id_account)->delete();
return redirect('/admin/dataadmapp');
}
public function instansi()
{
//
$datainstansi = Instansi::with('account')->get();
return view('admapp.DataInstansi')->with(compact('datainstansi'));
}
public function conference()
{
$dataconference = Pembayaran::with('conference','paket')->get();
//$dataconference = Pembayaran::with(['conference'=>function ($query) { $query->with('instansi'); },'paket'])->get();
return view('admapp.DataPembayaranConference')->with(compact('dataconference'));
//return dd($dataconference);
//return response()->json($dataconference[0]);
}
public function detailpembayaran($id)
{
$dataconference = Pembayaran::with('conference','paket')->where('id',$id)->first();
//$dataconference = Pembayaran::with(['conference'=>function ($query) { $query->with('instansi'); },'paket'])->get();
return view('admapp.DetailPembayaranConference')->with(compact('dataconference'));
}
public function settinglanding()
{
$datalanding = SettingLanding::first();
return view('admapp.SettingLandingPage')->with(compact('datalanding'));
}
public function prosessettinglanding(Request $request)
{
$this->validate($request, [
'deskripsi' => 'required',
'pendaftaran' => 'required',
'no_telp' => 'required',
'alamat' => 'required',
'link_maps' => 'required',
'email' => 'required'
]);
$setting = SettingLanding::first();
if ($setting) {
$setting->update([
'deskripsi' => $request->deskripsi,
'pendaftaran' => $request->pendaftaran,
'no_telp' => $request->no_telp,
'alamat' => $request->alamat,
'link_maps' => $request->link_maps,
'email' => $request->email
]);
}
else {
$addsetting = SettingLanding::create([
'deskripsi' => $request->deskripsi,
'pendaftaran' => $request->pendaftaran,
'no_telp' => $request->no_telp,
'alamat' => $request->alamat,
'link_maps' => $request->link_maps,
'email' => $request->email
]);
}
return redirect('/admin/settinglanding');
}
public function landingpage()
{
$datalanding = SettingLanding::first();
$harga = Paket::all();
$account = Auth::user();
return view('admapp.LandingPage')->with(compact('datalanding','harga','account'));
}
public function datatopik()
{
$datatopik = Topik::all();
return view('admapp.DataTopik')->with(compact('datatopik'));
}
public function addtopik()
{
return view('admapp.AddTopik');
}
public function prosesaddtopik(Request $request)
{
$this->validate($request, [
'nama_topik' => 'required'
]);
$topik = Topik::create([
'nama_topik' => $request->nama_topik
]);
return redirect('/admin/datatopik');
}
public function hapustopik($id)
{
$topik = Topik::findOrFail($id);
$topik->delete();
return redirect('/admin/datatopik');
}
public function datapaket()
{
$datapaket = Paket::all();
return view('admapp.DataPaket')->with(compact('datapaket'));
}
public function addpaket()
{
return view('admapp.AddPaket');
}
public function prosesaddpaket(Request $request)
{
$this->validate($request, [
'nama_paket' => 'required',
'biaya' => 'required'
]);
$paket = Paket::create([
'nama_paket' => $request->nama_paket,
'biaya' => $request->biaya
]);
return redirect('/admin/datapaket');
}
public function hapuspaket($id)
{
$paket = Paket::findOrFail($id);
$paket->delete();
return redirect('/admin/datapaket');
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
//
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
//
}
/**
* Display the specified resource.
*/
public function show(string $id)
{
//
}
/**
* Show the form for editing the specified resource.
*/
public function edit(string $id)
{
//
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, string $id)
{
//
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
//
}
public function approve($id)
{
//
$date_now = Carbon::now();
$one_year = new Carbon($date_now);
$one_year = $date_now->addYear(1);
$two_year = new Carbon($one_year);
$two_year = $two_year->addYear(1);
$three_year = new Carbon($two_year);
$three_year = $three_year->addYear(1);
//return dd($one_year);
// $instansi = Instansi::findOrFail($id);
$conference = Conference::findOrFail($id);
$paid = '1';
//$cekpaket = Paket::where('email', $request->email)->first();
// $cekpaket = Pembayaran::where('id_instansi',auth()->user()->id)->first();
$cekpaket = Pembayaran::findOrFail($id);
if ($cekpaket->id_paket == '1') {
$conference->update([
'is_paid' => $paid,
'exp_date' => $one_year
]);
//return dd($instansi);
} else if ($cekpaket->id_paket == '2') {
$conference->update([
'is_paid' => $paid,
'exp_date' => $two_year
]);
} else if ($cekpaket->id_paket == '3') {
$conference->update([
'is_paid' => $paid,
'exp_date' => $three_year
]);
}
//return dd($cekpaket);
Alert::success('Success','Berhasil Memvalidasi Pembayaran');
return redirect('/admin/detailpembayaran/'.$id);
// $instansi = Instansi::findOrFail($id);
// $paid = '1';
// $instansi->update([
// 'is_paid' => $paid,
// 'exp_date' => $one_year
// ]);
// return redirect('/admin/dataconference');
}
public function unapprove($id)
{
//
$instansi = Instansi::findOrFail($id);
$paid = '1';
$instansi->update([
'is_paid' => $paid
]);
return redirect('/admin/datainstansi');
}
}
\ No newline at end of file
This diff is collapsed.
This diff is collapsed.
<?php
namespace App\Http\Controllers;
use Illuminate\Foundation\Auth\Access\AuthorizesRequests;
use Illuminate\Foundation\Validation\ValidatesRequests;
use Illuminate\Routing\Controller as BaseController;
class Controller extends BaseController
{
use AuthorizesRequests, ValidatesRequests;
}
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
use App\Models\Account;
use App\Models\Role;
use App\Models\Instansi;
use App\Models\Reviewer;
use App\Models\Author;
use Illuminate\Support\Facades\Auth;
//use Illuminate\Support\Facades\Crypt;
use Illuminate\Support\Facades\Session;
use Alert;
class LoginController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index()
{
//
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
//
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
//
}
/**
* Display the specified resource.
*/
public function show(string $id)
{
//
}
/**
* Show the form for editing the specified resource.
*/
public function edit(string $id)
{
//
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, string $id)
{
//
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
//
}
public function login()
{
//
return view('Login');
}
public function register()
{
//
return view('Register');
}
public function prosesregister(Request $request)
{
$this->validate($request, [
'nama_instansi' => 'required',
'no_telp' => 'required',
'email' => 'required|email|unique:account,email,$this->id,id',
'password' => 'required|min:8|required_with:password2|same:password2',
'password2' => 'required|min:8',
]);
// $file = request()->file('bukti_bayar');
// $fileName = time() . '.' . $file->getClientOriginalExtension();
// $destinationPath = base_path('public/bukti pembayaran/');
// $file->move($destinationPath, $fileName);
// 'bukti_bayar' => $fileName,
$addaccount = Account::create([
'email' => $request->email,
'password' => bcrypt($request->password),
'id_role' => 2,
]);
$addinstansi = Instansi::create([
'id_account' => $addaccount->id,
'nama_instansi' => $request->nama_instansi,
'no_telp' => $request->no_telp,
]);
return redirect('/login');
}
public function proseslogin(Request $request)
{
$this->validate($request, [
'email' => 'required|email',
'password' => 'required',
]);
$data = [
'email' => $request->input('email'),
'password' => $request->input('password'),
];
if (Auth::Attempt($data)) {
$account = \App\Models\Account::where('email', $request->email)->first();
if ($account->id_role == '1') {
return redirect('/admin/dashboard');
} elseif ($account->id_role == '2') {
$instansi = $account->instansi()->first();
//return redirect('/dashboardadmconf/'.$instansi->id);
return redirect('/dashboardadmconf');
} elseif ($account->id_role == '3') {
$admconf = $account->admconf()->first();
//return redirect('/dashboardadmconf/'.$admconf->id_instansi);
return redirect('/dashboardadmconf');
} elseif ($account->id_role == '4') {
$reviewer = $account->reviewer()->first();
//return dd($reviewer);
return redirect('/datapaper/'.$reviewer->id_instansi);
} elseif ($account->id_role == '5') {
$author = $account->author()->first();
//return dd($author);
return redirect('/dataconferenceauthor/'.$author->id);
}
}else{
Alert::error('Error','Username atau kata sandi yang anda masukkan salah');
return redirect('/loginauthor');
}
}
public function registerauthor()
{
//
return view('RegisterAuthor');
}
public function prosesregisterauthor(Request $request)
{
$this->validate($request, [
'nama_lengkap' => 'required',
'no_telp' => 'required',
'alamat' => 'required',
'institusi' => 'required',
'email' => 'required|email|unique:account,email,$this->id,id',
'password' => 'required|min:8|required_with:password2|same:password2',
'password2' => 'required|min:8',
]);
$addaccount = Account::create([
'email' => $request->email,
'password' => bcrypt($request->password),
'id_role' => 5,
]);
$addauthor = Author::create([
'id_account' => $addaccount->id,
'nama_lengkap' => $request->nama_lengkap,
'no_telp' => $request->no_telp,
'alamat' => $request->alamat,
'institusi' => $request->institusi,
]);
return redirect('/loginauthor');
}
public function loginauthor()
{
//
return view('LoginAuthor');
}
public function logout()
{
Auth::logout();
return redirect('/login');
}
public function logoutauthor()
{
Auth::logout();
return redirect('/loginauthor');
}
}
<?php
namespace App\Http\Controllers;
use Illuminate\Http\Request;
//use model mahasiswa agar tabelbisa digunakan
use App\Models\Mahasiswa;
use Illuminate\Support\Facades\Crypt;
class MahasiswaController extends Controller
{
/**
* Display a listing of the resource.
*/
public function index()
{
//menampilkan halaman list mahasiswa dengan data dari database tabel mahasiswa jika ada datanya
$datamhs = Mahasiswa::latest()->get();
return view('DataMhs', compact('datamhs'));
}
/**
* Show the form for creating a new resource.
*/
public function create()
{
//menampilkan halaman tambah data
return view('AddDataMhs');
}
/**
* Store a newly created resource in storage.
*/
public function store(Request $request)
{
//proses menambah data ke tabel mahasiswa dengan datanya dari inputan halaman tambah data
$addmhs = Mahasiswa::create([
'id' => $request->id,
'nim' => $request->nim,
'nama' => $request->nama,
'alamat' => $request->alamat,
'tanggal' => $request->tanggal,
'gender' => $request->gender,
'usia' => $request->usia,
]);
if ($addmhs){
return redirect('/datamhs');
}
}
/**
* Display the specified resource.
*/
public function show(string $id)
{
//
}
/**
* Show the form for editing the specified resource.
*/
public function edit(string $id)
{
////menampilkan halaman edit data mahasiswa dengan data yang sudah ada sesuai dengan id yang di klik
$datamhs = Mahasiswa::findOrFail(Crypt::decryptString($id));
return view('EditDataMhs', compact('datamhs'));
}
/**
* Update the specified resource in storage.
*/
public function update(Request $request, string $id)
{
//proses menambah data ke tabel mahasiswa dengan merubah data dari yang sudah ada
$editmhs = Mahasiswa::findOrFail($id);
$editmhs->update([
'id' => $request->id,
// 'nim' => $request->nim,
'nama' => $request->nama,
'alamat' => $request->alamat,
'tanggal' => $request->tanggal,
'gender' => $request->gender,
'usia' => $request->usia,
]);
return redirect('/datamhs');
}
/**
* Remove the specified resource from storage.
*/
public function destroy(string $id)
{
//proses menghapus data dari tabel mahasiswa sesuai dari id yang dipilih
$mahasiswa = Mahasiswa::findOrFail($id);
$mahasiswa->delete();
return redirect('/datamhs');
}
public function home()
{
//menampilkan halaman home dengan list mahasiswa dan totalnya
$total = Mahasiswa::count();
$totalL = Mahasiswa::where('gender', 'Laki-laki')->count();
$totalP = Mahasiswa::where('gender', 'Perempuan')->count();
$datamhs = Mahasiswa::latest()->get();
return view('Home', compact('datamhs','total', 'totalL', 'totalP'));
}
}
This diff is collapsed.
This diff is collapsed.
<?php
namespace App\Http;
use Illuminate\Foundation\Http\Kernel as HttpKernel;
class Kernel extends HttpKernel
{
/**
* The application's global HTTP middleware stack.
*
* These middleware are run during every request to your application.
*
* @var array<int, class-string|string>
*/
protected $middleware = [
// \App\Http\Middleware\TrustHosts::class,
\App\Http\Middleware\TrustProxies::class,
\Illuminate\Http\Middleware\HandleCors::class,
\App\Http\Middleware\PreventRequestsDuringMaintenance::class,
\Illuminate\Foundation\Http\Middleware\ValidatePostSize::class,
\App\Http\Middleware\TrimStrings::class,
\Illuminate\Foundation\Http\Middleware\ConvertEmptyStringsToNull::class,
];
/**
* The application's route middleware groups.
*
* @var array<string, array<int, class-string|string>>
*/
protected $middlewareGroups = [
'web' => [
\App\Http\Middleware\EncryptCookies::class,
\Illuminate\Cookie\Middleware\AddQueuedCookiesToResponse::class,
\Illuminate\Session\Middleware\StartSession::class,
\Illuminate\View\Middleware\ShareErrorsFromSession::class,
\App\Http\Middleware\VerifyCsrfToken::class,
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
'api' => [
// \Laravel\Sanctum\Http\Middleware\EnsureFrontendRequestsAreStateful::class,
\Illuminate\Routing\Middleware\ThrottleRequests::class.':api',
\Illuminate\Routing\Middleware\SubstituteBindings::class,
],
];
/**
* The application's middleware aliases.
*
* Aliases may be used to conveniently assign middleware to routes and groups.
*
* @var array<string, class-string|string>
*/
protected $middlewareAliases = [
'auth' => \App\Http\Middleware\Authenticate::class,
'berlangganan' => \App\Http\Middleware\CekBerlangganan::class,
'role' => \App\Http\Middleware\RoleAuth::class,
'approve' => \App\Http\Middleware\Approve::class,
'auth.basic' => \Illuminate\Auth\Middleware\AuthenticateWithBasicAuth::class,
'auth.session' => \Illuminate\Session\Middleware\AuthenticateSession::class,
'cache.headers' => \Illuminate\Http\Middleware\SetCacheHeaders::class,
'can' => \Illuminate\Auth\Middleware\Authorize::class,
'guest' => \App\Http\Middleware\RedirectIfAuthenticated::class,
'password.confirm' => \Illuminate\Auth\Middleware\RequirePassword::class,
'signed' => \App\Http\Middleware\ValidateSignature::class,
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
];
}
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
class Approve
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
// return $next($request);
if (\Auth::user() && \Auth::user()->id_role == 3) {
return $next($request);
} elseif (\Auth::user() && \Auth::user()->agency()->first()->is_aktif == true) {
return $next($request);
}
return back()->with('error','Akun anda belom diapprove admin !');
}
}
<?php
namespace App\Http\Middleware;
use Illuminate\Auth\Middleware\Authenticate as Middleware;
use Illuminate\Http\Request;
class Authenticate extends Middleware
{
/**
* Get the path the user should be redirected to when they are not authenticated.
*/
protected function redirectTo(Request $request): ?string
{
return $request->expectsJson() ? null : route('login');
}
}
<?php
namespace App\Http\Middleware;
use Closure;
use Illuminate\Http\Request;
use Symfony\Component\HttpFoundation\Response;
use Illuminate\Support\Facades\Auth;
use App\Models\Event;
class CekBerlangganan
{
/**
* Handle an incoming request.
*
* @param \Closure(\Illuminate\Http\Request): (\Symfony\Component\HttpFoundation\Response) $next
*/
public function handle(Request $request, Closure $next): Response
{
$currentDate = date('Y-m-d H:i:s');
$id_event = $request->route('id');
if ($id_event) {
$event = Event::where('id',$id_event)->get();
$topik = TopikEvent::where('id_event',$id_event);
} else {
$id_event = $request->route('id_event');
$event = Event::where('id',$id_event)->get();
}
//$id_event = $request->route('id_event');
//return dd($id_event);
$account = Auth::user();
if ($account->id_role == '2') {
//$event = $account->instansi()->first()->event()->first();
if ($event->where('exp_date', '<' ,$currentDate)->first()) {
return redirect()->back();
} else if ($event->where('exp_date',null)->first()) {
return redirect()->back();
} else {
return $next($request);
}
}
// if ($account->id_role == '2') {
// $event = $account->instansi()->first()->event()->first();
// return dd($event);
// if ($event->where('exp_date', '<' ,$currentDate)->first()) {
// return redirect()->back();
// } else if ($event->where('exp_date',null)->first()) {
// return redirect()->back();
// } else {
// return $next($request);
// }
// } else if ($account->id_role == '3') {
// $event = $account->admconf()->first()->instansi()->first()->event()->first();
// if ($event->where('exp_date', '<' ,$currentDate)->first()) {
// return redirect()->back();
// } else if ($event->where('exp_date',null)->first()) {
// return redirect()->back();
// } else {
// return $next($request);
// }
// }
return $next($request);
}
}
<?php
namespace App\Http\Middleware;
use Illuminate\Cookie\Middleware\EncryptCookies as Middleware;
class EncryptCookies extends Middleware
{
/**
* The names of the cookies that should not be encrypted.
*
* @var array<int, string>
*/
protected $except = [
//
];
}
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment