2023-10-08 15:59:42 +07:00
|
|
|
package entity
|
|
|
|
|
|
|
|
|
|
import (
|
2024-06-03 14:40:50 +07:00
|
|
|
"furtuna-be/internal/constants/role"
|
2023-10-08 15:59:42 +07:00
|
|
|
"time"
|
|
|
|
|
)
|
|
|
|
|
|
2024-06-03 14:40:50 +07:00
|
|
|
type CreatePartnerRequest struct {
|
|
|
|
|
Name string `json:"name" validate:"required"`
|
|
|
|
|
Address string `json:"address"`
|
|
|
|
|
Username string `json:"username" validate:"required"`
|
|
|
|
|
FullName string `json:"full_name"`
|
|
|
|
|
Email string `json:"email"`
|
|
|
|
|
Password string `json:"password" validate:"required"`
|
|
|
|
|
NIK string `json:"nik"`
|
|
|
|
|
PhoneNumber string `json:"phone_number"`
|
|
|
|
|
BankName string `json:"bank_name"`
|
|
|
|
|
BankAccountNumber string `json:"bank_account_number"`
|
|
|
|
|
BankAccountHolderName string `json:"bank_account_holder_name"`
|
|
|
|
|
}
|
|
|
|
|
|
2023-10-08 15:59:42 +07:00
|
|
|
type Partner struct {
|
2024-06-03 14:40:50 +07:00
|
|
|
ID int64 `gorm:"primaryKey;autoIncrement;column:id"`
|
|
|
|
|
Name string `gorm:"type:varchar(255);not null;column:name"`
|
|
|
|
|
Status string `gorm:"type:varchar(50);column:status"`
|
|
|
|
|
LicenseExpiredDate *time.Time `gorm:"type:date;column:license_expired_date"`
|
|
|
|
|
Address string `gorm:"type:varchar(255);column:address"`
|
|
|
|
|
BankName string `gorm:"type:varchar(255);column:bank_name"`
|
|
|
|
|
BankAccountNumber string `gorm:"type:varchar(50);column:bank_account_number"`
|
|
|
|
|
BankAccountHolderName string `gorm:"type:varchar(255);column:bank_account_holder_name"`
|
|
|
|
|
CreatedAt time.Time `gorm:"autoCreateTime;column:created_at"`
|
|
|
|
|
UpdatedAt time.Time `gorm:"autoUpdateTime;column:updated_at"`
|
|
|
|
|
DeletedAt *time.Time `gorm:"column:deleted_at"`
|
|
|
|
|
CreatedBy int64 `gorm:"type:int;column:created_by"`
|
|
|
|
|
UpdatedBy int64 `gorm:"type:int;column:updated_by"`
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (Partner) TableName() string {
|
|
|
|
|
return "partners"
|
2023-10-08 15:59:42 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type PartnerSearch struct {
|
|
|
|
|
Search string
|
|
|
|
|
Name string
|
|
|
|
|
Limit int
|
|
|
|
|
Offset int
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
type PartnerList []*PartnerDB
|
|
|
|
|
|
|
|
|
|
type PartnerDB struct {
|
|
|
|
|
Partner
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (p *Partner) ToPartnerDB() *PartnerDB {
|
|
|
|
|
return &PartnerDB{
|
|
|
|
|
Partner: *p,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (PartnerDB) TableName() string {
|
|
|
|
|
return "partners"
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *PartnerDB) ToPartner() *Partner {
|
|
|
|
|
return &Partner{
|
|
|
|
|
ID: e.ID,
|
|
|
|
|
Name: e.Name,
|
|
|
|
|
Status: e.Status,
|
|
|
|
|
Address: e.Address,
|
|
|
|
|
CreatedAt: e.CreatedAt,
|
|
|
|
|
UpdatedAt: e.UpdatedAt,
|
|
|
|
|
CreatedBy: e.CreatedBy,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (p *PartnerList) ToPartnerList() []*Partner {
|
|
|
|
|
var partners []*Partner
|
|
|
|
|
for _, partner := range *p {
|
|
|
|
|
partners = append(partners, partner.ToPartner())
|
|
|
|
|
}
|
|
|
|
|
return partners
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (o *PartnerDB) ToUpdatedPartner(updatedBy int64, req Partner) {
|
|
|
|
|
o.UpdatedBy = updatedBy
|
|
|
|
|
|
|
|
|
|
if req.Name != "" {
|
|
|
|
|
o.Name = req.Name
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if req.Status != "" {
|
|
|
|
|
o.Status = req.Status
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if req.Address != "" {
|
|
|
|
|
o.Address = req.Address
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (o *PartnerDB) SetDeleted(updatedBy int64) {
|
|
|
|
|
currentTime := time.Now()
|
|
|
|
|
o.DeletedAt = ¤tTime
|
|
|
|
|
o.UpdatedBy = updatedBy
|
|
|
|
|
}
|
2024-06-03 14:40:50 +07:00
|
|
|
|
|
|
|
|
func (c *CreatePartnerRequest) ToUserAdmin(partnerID int64) *User {
|
|
|
|
|
return &User{
|
|
|
|
|
Name: c.FullName,
|
|
|
|
|
Password: c.Password,
|
|
|
|
|
Email: c.Email,
|
|
|
|
|
NIK: c.NIK,
|
|
|
|
|
Status: "active",
|
|
|
|
|
RoleID: role.PartnerAdmin,
|
|
|
|
|
PartnerID: &partnerID,
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *CreatePartnerRequest) ToPartnerDB(createdBy int64) *PartnerDB {
|
|
|
|
|
twoDays := 48 * time.Hour
|
|
|
|
|
licenseExpiredDate := time.Now().Add(twoDays)
|
|
|
|
|
|
|
|
|
|
return &PartnerDB{
|
|
|
|
|
Partner: Partner{
|
|
|
|
|
Name: e.Name,
|
|
|
|
|
Status: "inactive",
|
|
|
|
|
Address: e.Address,
|
|
|
|
|
CreatedBy: createdBy,
|
|
|
|
|
CreatedAt: time.Now(),
|
|
|
|
|
UpdatedAt: time.Now(),
|
|
|
|
|
BankAccountHolderName: e.BankAccountHolderName,
|
|
|
|
|
BankAccountNumber: e.BankAccountNumber,
|
|
|
|
|
BankName: e.BankName,
|
|
|
|
|
LicenseExpiredDate: &licenseExpiredDate,
|
|
|
|
|
},
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
func (e *CreatePartnerRequest) ToWallet(partnerID int64) *Wallet {
|
|
|
|
|
return &Wallet{
|
|
|
|
|
PartnerID: partnerID,
|
|
|
|
|
Balance: 0,
|
|
|
|
|
Currency: "IDR",
|
|
|
|
|
Status: "active",
|
|
|
|
|
CreatedAt: time.Now(),
|
|
|
|
|
UpdatedAt: time.Now(),
|
|
|
|
|
}
|
|
|
|
|
}
|