feat: setup database migrations and models for all roles
This commit is contained in:
parent
5095aa52e6
commit
b28b6b2e66
|
|
@ -0,0 +1,21 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
||||||
|
use Illuminate\Notifications\Notifiable;
|
||||||
|
|
||||||
|
class Admin extends Authenticatable
|
||||||
|
{
|
||||||
|
use Notifiable;
|
||||||
|
|
||||||
|
protected $table = 'admins'; protected $primaryKey = 'id';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'nama', 'username', 'password',
|
||||||
|
];
|
||||||
|
|
||||||
|
protected $hidden = [
|
||||||
|
'password',
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,31 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
|
class DetailTransaksi extends Model
|
||||||
|
{
|
||||||
|
use HasFactory;
|
||||||
|
|
||||||
|
protected $table = 'detail_transaksis';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'transaksi_id',
|
||||||
|
'produk_id',
|
||||||
|
'jumlah',
|
||||||
|
'harga_satuan',
|
||||||
|
'subtotal'
|
||||||
|
];
|
||||||
|
|
||||||
|
public function transaksi()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Transaksi::class, 'transaksi_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function produk()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Produk::class, 'produk_id');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,30 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Auth\User as Authenticatable;
|
||||||
|
use Illuminate\Notifications\Notifiable;
|
||||||
|
|
||||||
|
class Pembeli extends Authenticatable
|
||||||
|
{
|
||||||
|
use Notifiable;
|
||||||
|
|
||||||
|
protected $table = 'pembelis';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'nama_lengkap',
|
||||||
|
'username',
|
||||||
|
'password',
|
||||||
|
'no_hp',
|
||||||
|
'alamat'
|
||||||
|
];
|
||||||
|
|
||||||
|
protected $hidden = [
|
||||||
|
'password',
|
||||||
|
];
|
||||||
|
|
||||||
|
public function transaksis()
|
||||||
|
{
|
||||||
|
return $this->hasMany(Transaksi::class, 'pembeli_id');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,23 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
|
class Pesan extends Model
|
||||||
|
{
|
||||||
|
use HasFactory;
|
||||||
|
|
||||||
|
protected $table = 'pesans';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'pengirim_id',
|
||||||
|
'pengirim_type',
|
||||||
|
'penerima_id',
|
||||||
|
'penerima_type',
|
||||||
|
'isi_pesan',
|
||||||
|
'sudah_dibaca'
|
||||||
|
];
|
||||||
|
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Foundation\Auth\User as Authenticatable; // PENTING: Ganti ini
|
||||||
|
use Illuminate\Notifications\Notifiable;
|
||||||
|
|
||||||
|
class Petani extends Authenticatable
|
||||||
|
{
|
||||||
|
use Notifiable;
|
||||||
|
|
||||||
|
protected $table = 'petanis';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'nama_lengkap',
|
||||||
|
'username',
|
||||||
|
'password',
|
||||||
|
'no_hp',
|
||||||
|
'alamat',
|
||||||
|
'nama_usaha',
|
||||||
|
'status_akun'
|
||||||
|
];
|
||||||
|
|
||||||
|
protected $hidden = [
|
||||||
|
'password',
|
||||||
|
];
|
||||||
|
|
||||||
|
public function produks()
|
||||||
|
{
|
||||||
|
return $this->hasMany(Produk::class, 'petani_id');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
|
class Produk extends Model
|
||||||
|
{
|
||||||
|
use HasFactory;
|
||||||
|
|
||||||
|
protected $table = 'produks';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'petani_id',
|
||||||
|
'nama_produk',
|
||||||
|
'harga',
|
||||||
|
'stok',
|
||||||
|
'deskripsi',
|
||||||
|
'foto_produk'
|
||||||
|
];
|
||||||
|
|
||||||
|
public function petani()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Petani::class, 'petani_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function detailTransaksis()
|
||||||
|
{
|
||||||
|
return $this->hasMany(DetailTransaksi::class, 'produk_id');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
namespace App\Models;
|
||||||
|
|
||||||
|
use Illuminate\Database\Eloquent\Factories\HasFactory;
|
||||||
|
use Illuminate\Database\Eloquent\Model;
|
||||||
|
|
||||||
|
class Transaksi extends Model
|
||||||
|
{
|
||||||
|
use HasFactory;
|
||||||
|
|
||||||
|
protected $table = 'transaksis';
|
||||||
|
|
||||||
|
protected $fillable = [
|
||||||
|
'pembeli_id',
|
||||||
|
'tanggal_transaksi',
|
||||||
|
'alamat_pengiriman',
|
||||||
|
'total_harga',
|
||||||
|
'status',
|
||||||
|
'kode_invoice'
|
||||||
|
];
|
||||||
|
|
||||||
|
public function pembeli()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Pembeli::class, 'pembeli_id');
|
||||||
|
}
|
||||||
|
|
||||||
|
public function details()
|
||||||
|
{
|
||||||
|
return $this->hasMany(DetailTransaksi::class, 'transaksi_id');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -1,41 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
use Illuminate\Database\Migrations\Migration;
|
|
||||||
use Illuminate\Database\Schema\Blueprint;
|
|
||||||
use Illuminate\Support\Facades\Schema;
|
|
||||||
|
|
||||||
return new class extends Migration
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Run the migrations.
|
|
||||||
*/
|
|
||||||
public function up(): void
|
|
||||||
{
|
|
||||||
Schema::create('users', function (Blueprint $table) {
|
|
||||||
$table->id();
|
|
||||||
$table->string('name');
|
|
||||||
$table->string('username')->unique();
|
|
||||||
$table->string('email')->unique()->nullable();
|
|
||||||
$table->string('password');
|
|
||||||
|
|
||||||
// Role: admin, petani, pembeli
|
|
||||||
$table->enum('role', ['admin', 'petani', 'pembeli']);
|
|
||||||
|
|
||||||
$table->string('no_hp')->nullable();
|
|
||||||
$table->text('alamat')->nullable();
|
|
||||||
|
|
||||||
// Khusus Petani
|
|
||||||
$table->enum('status_akun', ['pending', 'aktif', 'ditolak'])->default('aktif');
|
|
||||||
$table->string('nama_bank')->nullable();
|
|
||||||
$table->string('no_rekening')->nullable();
|
|
||||||
|
|
||||||
$table->rememberToken();
|
|
||||||
$table->timestamps();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public function down(): void
|
|
||||||
{
|
|
||||||
Schema::dropIfExists('users');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
@ -1,30 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
use Illuminate\Database\Migrations\Migration;
|
|
||||||
use Illuminate\Database\Schema\Blueprint;
|
|
||||||
use Illuminate\Support\Facades\Schema;
|
|
||||||
|
|
||||||
return new class extends Migration
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Run the migrations.
|
|
||||||
*/
|
|
||||||
public function up(): void
|
|
||||||
{
|
|
||||||
Schema::create('produk', function (Blueprint $table) {
|
|
||||||
$table->id();
|
|
||||||
$table->foreignId('petani_id')->constrained('users')->onDelete('cascade');
|
|
||||||
$table->string('nama_produk');
|
|
||||||
$table->text('deskripsi')->nullable();
|
|
||||||
$table->decimal('harga', 12, 2);
|
|
||||||
$table->integer('stok');
|
|
||||||
$table->string('foto')->nullable();
|
|
||||||
$table->timestamps();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public function down(): void
|
|
||||||
{
|
|
||||||
Schema::dropIfExists('produk');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
@ -1,46 +0,0 @@
|
||||||
<?php
|
|
||||||
|
|
||||||
use Illuminate\Database\Migrations\Migration;
|
|
||||||
use Illuminate\Database\Schema\Blueprint;
|
|
||||||
use Illuminate\Support\Facades\Schema;
|
|
||||||
|
|
||||||
return new class extends Migration
|
|
||||||
{
|
|
||||||
/**
|
|
||||||
* Run the migrations.
|
|
||||||
*/
|
|
||||||
public function up(): void
|
|
||||||
{
|
|
||||||
Schema::create('transaksi', function (Blueprint $table) {
|
|
||||||
$table->id();
|
|
||||||
$table->string('kode_transaksi')->unique();
|
|
||||||
|
|
||||||
$table->foreignId('pembeli_id')->constrained('users')->onDelete('cascade');
|
|
||||||
$table->foreignId('petani_id')->constrained('users')->onDelete('cascade');
|
|
||||||
|
|
||||||
$table->date('tanggal_transaksi');
|
|
||||||
$table->decimal('total_harga', 12, 2);
|
|
||||||
|
|
||||||
$table->enum('status', [
|
|
||||||
'menunggu_pembayaran',
|
|
||||||
'menunggu_verifikasi',
|
|
||||||
'diproses',
|
|
||||||
'dikirim',
|
|
||||||
'selesai',
|
|
||||||
'ditolak'
|
|
||||||
])->default('menunggu_pembayaran');
|
|
||||||
|
|
||||||
$table->string('bukti_transfer')->nullable();
|
|
||||||
$table->decimal('biaya_ongkir', 12, 2)->default(0);
|
|
||||||
$table->string('resi_pengiriman')->nullable();
|
|
||||||
$table->text('alamat_pengiriman');
|
|
||||||
|
|
||||||
$table->timestamps();
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
public function down(): void
|
|
||||||
{
|
|
||||||
Schema::dropIfExists('transaksi');
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
@ -0,0 +1,30 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('admins', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('nama');
|
||||||
|
$table->string('username')->unique();
|
||||||
|
$table->string('password');
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('admins');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,37 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('petanis', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('nama_lengkap');
|
||||||
|
$table->string('username')->unique();
|
||||||
|
$table->string('password');
|
||||||
|
$table->string('no_hp', 15);
|
||||||
|
$table->text('alamat');
|
||||||
|
$table->string('nama_usaha')->nullable();
|
||||||
|
|
||||||
|
// Status Verifikasi
|
||||||
|
$table->enum('status_akun', ['menunggu', 'aktif', 'ditolak'])->default('menunggu');
|
||||||
|
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('petanis');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('pembelis', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->string('nama_lengkap');
|
||||||
|
$table->string('username')->unique();
|
||||||
|
$table->string('password');
|
||||||
|
$table->string('no_hp', 15);
|
||||||
|
$table->text('alamat');
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('pembelis');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,35 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('produks', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->foreignId('petani_id')->constrained('petanis')->onDelete('cascade');
|
||||||
|
|
||||||
|
$table->string('nama_produk');
|
||||||
|
$table->decimal('harga', 12, 0);
|
||||||
|
$table->integer('stok');
|
||||||
|
$table->text('deskripsi');
|
||||||
|
$table->string('foto_produk')->nullable();
|
||||||
|
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('produks');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,35 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('transaksis', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->foreignId('pembeli_id')->constrained('pembelis')->onDelete('cascade');
|
||||||
|
$table->dateTime('tanggal_transaksi');
|
||||||
|
$table->text('alamat_pengiriman');
|
||||||
|
$table->decimal('total_harga', 15, 0);
|
||||||
|
$table->enum('status', ['menunggu_konfirmasi', 'diproses', 'dikirim', 'selesai', 'batal'])
|
||||||
|
->default('menunggu_konfirmasi');
|
||||||
|
|
||||||
|
$table->string('kode_invoice')->unique()->nullable();
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('transaksis');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('detail_transaksis', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->foreignId('transaksi_id')->constrained('transaksis')->onDelete('cascade');
|
||||||
|
$table->foreignId('produk_id')->constrained('produks')->onDelete('cascade');
|
||||||
|
$table->integer('jumlah');
|
||||||
|
$table->decimal('harga_satuan', 12, 0);
|
||||||
|
$table->decimal('subtotal', 15, 0);
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('detail_transaksis');
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
@ -0,0 +1,34 @@
|
||||||
|
<?php
|
||||||
|
|
||||||
|
use Illuminate\Database\Migrations\Migration;
|
||||||
|
use Illuminate\Database\Schema\Blueprint;
|
||||||
|
use Illuminate\Support\Facades\Schema;
|
||||||
|
|
||||||
|
return new class extends Migration
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Run the migrations.
|
||||||
|
*/
|
||||||
|
public function up(): void
|
||||||
|
{
|
||||||
|
Schema::create('pesans', function (Blueprint $table) {
|
||||||
|
$table->id();
|
||||||
|
$table->unsignedBigInteger('pengirim_id');
|
||||||
|
$table->string('pengirim_type');
|
||||||
|
$table->unsignedBigInteger('penerima_id');
|
||||||
|
$table->string('penerima_type');
|
||||||
|
$table->text('isi_pesan');
|
||||||
|
$table->boolean('sudah_dibaca')->default(false);
|
||||||
|
|
||||||
|
$table->timestamps();
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*/
|
||||||
|
public function down(): void
|
||||||
|
{
|
||||||
|
Schema::dropIfExists('pesans');
|
||||||
|
}
|
||||||
|
};
|
||||||
Loading…
Reference in New Issue