Skip to content

mmarno024/ci4-api

Repository files navigation

INSTALL :

  • Clone Code
  • Open terminal, cd to directory project and run "composer install"
  • Create "Database" in MySQL
  • Copy "env" and rename to ".env"
  • Edit "Connection Database" in .env
  • Open terminal, run "php spark make:migration create_users_table"
  • Run "php spark make:migration create_products_table"
  • Run "php spark db:seed UserSeeder"
  • Run "php spark db:seed ProductSeeder"
  • Run "php spark serve"

Security - JWT Authentication (JSON Web Token): Authorization - Role Access Control User: Endpoint Filtering - Validation: Validasi input pada setiap form - HTTP Header: meminimalisir serangan dari protocol HTTP - ORM: meminimalisir serangan Query
Description - API ini menyediakan layanan CRUD untuk produk dan manajemen pengguna dengan peran khusus
Access Roles - admin: Hanya dapat mengakses endpoint untuk mengelola produk (CRUD) - user: Hanya dapat mengakses halaman dashboard
Usage - Authorization: Gunakan header \Authorization: Bearer \ untuk autentikasi di semua endpoint - Note: Hanya admin yang bisa mengakses endpoint produk
Route

Auth

  • POST /auth/login => 'Login dan dapatkan token JWT untuk autentikasi

Dashboard

  • GET /dashboard => 'Menampilkan halaman informasi umum (hanya untuk role user)

Products

  • GET /products => 'Mendapatkan daftar produk (hanya untuk role admin)
  • POST /products => 'Menambahkan produk baru (hanya untuk role admin)
  • GET /products/{id} => 'Mendapatkan daftar produk berdasarkan ID (hanya untuk role admin)
  • PUT /products/{id} => 'Mengupdate data produk berdasarkan ID (hanya untuk role admin)
  • DELETE /products/{id} => 'Menghapus produk berdasarkan ID (hanya untuk role admin)

Response DataTable Server Side ada pada Halaman Dashboard


Screen Shoot

Login Login

Dashboard - OK Dashboard - OK

Dashboard - Failed Dashboard - Failed

Product List - OK Product List - OK

Product List - Failed Product List - Failed

Product Create Product Create

Product By ID Product By ID

Product Update Product Update

Product Delete Product Delete

DataTable Server Side DataTable Server Side

CodeIgniter 4 Application Starter

What is CodeIgniter?

CodeIgniter is a PHP full-stack web framework that is light, fast, flexible and secure. More information can be found at the official site.

This repository holds a composer-installable app starter. It has been built from the development repository.

More information about the plans for version 4 can be found in CodeIgniter 4 on the forums.

You can read the user guide corresponding to the latest version of the framework.

Installation & updates

composer create-project codeigniter4/appstarter then composer update whenever there is a new release of the framework.

When updating, check the release notes to see if there are any changes you might need to apply to your app folder. The affected files can be copied or merged from vendor/codeigniter4/framework/app.

Setup

Copy env to .env and tailor for your app, specifically the baseURL and any database settings.

Important Change with index.php

index.php is no longer in the root of the project! It has been moved inside the public folder, for better security and separation of components.

This means that you should configure your web server to "point" to your project's public folder, and not to the project root. A better practice would be to configure a virtual host to point there. A poor practice would be to point your web server to the project root and expect to enter public/..., as the rest of your logic and the framework are exposed.

Please read the user guide for a better explanation of how CI4 works!

Repository Management

We use GitHub issues, in our main repository, to track BUGS and to track approved DEVELOPMENT work packages. We use our forum to provide SUPPORT and to discuss FEATURE REQUESTS.

This repository is a "distribution" one, built by our release preparation script. Problems with it can be raised on our forum, or as issues in the main repository.

Server Requirements

PHP version 8.1 or higher is required, with the following extensions installed:

Warning

  • The end of life date for PHP 7.4 was November 28, 2022.
  • The end of life date for PHP 8.0 was November 26, 2023.
  • If you are still using PHP 7.4 or 8.0, you should upgrade immediately.
  • The end of life date for PHP 8.1 will be December 31, 2025.

Additionally, make sure that the following extensions are enabled in your PHP:

  • json (enabled by default - don't turn it off)
  • mysqlnd if you plan to use MySQL
  • libcurl if you plan to use the HTTP\CURLRequest library

About

ci4-api

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published