<?php
namespace App\Models;
use App\Constants\SupportTicketConst;
use Illuminate\Database\Eloquent\Model;
use Illuminate\Database\Eloquent\Factories\HasFactory;
class SupportTicket extends Model
{
use HasFactory;
protected $guarded = ['id'];
protected $with = [
'user',
'attachments'
];
protected $appends = ['stringStatus'];
protected $casts = [
'id' => 'integer',
'user_id' => 'integer',
'token' => 'string',
'type' => 'string',
'name' => 'string',
'email' => 'string',
'desc' => 'string',
'subject' => 'string',
'status' => 'integer',
'created_at' => 'datetime',
'updated_at' => 'datetime',
];
public function authSolution() {
$data = [
'class' => "",
'foreign' => "",
];
if(get_auth_guard() == 'web') {
$data = [
'class' => User::class,
'foreign' => "user_id",
];
}
return (object) $data;
}
public function scopeAuthTickets($query) {
$foreign_key = $this->authSolution()->foreign;
return $query->where($foreign_key,auth()->user()->id);
}
public function user() {
return $this->belongsTo(User::class);
}
public function getCreatorAttribute() {
if($this->type == SupportTicketConst::TYPE_USER) {
return $this->user()->first();
}else if($this->type == SupportTicketConst::TYPE_AGENT) {
return $this->agent()->first();
}
return null;
}
public function attachments() {
return $this->hasMany(SupportTicketAttachment::class);
}
public function conversations() {
return $this->hasMany(SupportChat::class,"support_ticket_id");
}
public function scopePending($query) {
return $query->where("status",SupportTicketConst::PENDING)->orWhere("status",SupportTicketConst::DEFAULT);
}
public function scopeActive($query) {
return $query->where("status",SupportTicketConst::ACTIVE);
}
public function scopeSolved($query) {
return $query->where("status",SupportTicketConst::SOLVED);
}
public function scopeNotSolved($query,$token) {
$query->where('token',$token)->where('status','!=',SupportTicketConst::SOLVED);
}
public function getStringStatusAttribute() {
$status = $this->status;
$data = [
'class' => "",
'value' => "",
];
if($status == SupportTicketConst::ACTIVE) {
$data = [
'class' => "badge badge--info",
'value' => __("Active"),
];
}else if($status == SupportTicketConst::DEFAULT) {
$data = [
'class' => "badge badge--warning",
'value' => __("Default"),
];
}else if($status == SupportTicketConst::PENDING) {
$data = [
'class' => "badge badge--warning",
'value' => __("Pending"),
];
}else if($status == SupportTicketConst::SOLVED) {
$data = [
'class' => "badge badge--success",
'value' => __("Solved"),
];
}
return (object) $data;
}
}
Initiates a new payment transaction.
create-order
| Parameter | Type | Details |
|---|---|---|
| amount | decimal | Your Amount , Must be rounded at 2 precision. |
| currency | string | Currency Code, Must be in Upper Case (Alpha-3 code) |
| success_url | string | Enter your return or success URL |
| cancel_url | string (optional) | Enter your cancel or failed URL |
Request Example (guzzle)
<?php
require_once('vendor/autoload.php');
$client = new \GuzzleHttp\Client();
$response = $client->request('POST', $base_url.'create-order', [
'headers' => [
'Authorization' => 'Bearer '. $authorizationToken,
'accept' => 'application/json',
'content-type' => 'application/json',
],
'form_params' => [
'amount' => '$amount',
'currency' => 'currency',
'success_url' => 'success_url',
'cancel_url' => 'cancel_url',
],
]);
echo $response->getBody();
**Response: SUCCESS (200 OK)**
{
"message": {
"success": [
"Order created successfully."
]
},
"data": {
"redirect_url":"https://example.com/login/OISADFDFSDFSF",
"order_details":{
"amount" : "10",
"fixed_charge" : 2,
"percent_charge" : 1,
"total_charge" : 3,
"total_payable" : 13,
"currency" : "USD",
"expiry_time": "2024-04-25T06:48:35.984285Z",
"success_url": "http://127.0.0.1/nfcpay/user/transaction/success",
"cancel_url": "http://127.0.0.1/nfcpay/user/transaction/cancel"
}
},
"type": "success"
}
**Response: ERROR (400 FAILED)**
{
"message": {
"error": [
"Invalid token."
]
},
"data": null,
"type": "error"
}