hujiao-gui/app/Http/Controllers/ApiController.php

290 lines
10 KiB
PHP

<?php
namespace App\Http\Controllers;
use App\Models\Cdr;
use App\Models\CustomerRemark;
use App\Models\Department;
use App\Models\Node;
use App\Models\Order;
use App\Models\OrderPay;
use App\Models\OrderRemark;
use App\Models\Permission;
use App\Models\Role;
use App\Models\Sip;
use App\Models\User;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Log;
use Illuminate\Support\Facades\Redis;
use Illuminate\Support\Facades\Storage;
class ApiController extends Controller
{
public function getPermissionByRoleId(Request $request)
{
$role_id = $request->input('role_id');
$role = null;
$checkedIds = [];
if ($role_id) {
$role = Role::query()->where('id', $role_id)->first();
}
$permissions = Permission::query()->orderByDesc('id')->get();
foreach ($permissions as $permission) {
if ($role != null) {
if ($role->hasPermissionTo($permission)) {
array_push($checkedIds, $permission->id);
}
}
}
return $this->success('ok', ['trees' => $permissions, 'checkedId' => $checkedIds]);
}
public function getRoleByUserId(Request $request)
{
$user_id = $request->input('user_id');
$user = null;
if ($user_id) {
$user = User::query()->where('id', $user_id)->first();
}
$roles = Role::query()->orderByDesc('id')->get();
foreach ($roles as $role) {
$role->selected = $user != null && $user->hasRole($role);
}
return $this->success('ok', $roles);
}
public function getDepartmentByUserId(Request $request)
{
$user_id = $request->input('user_id');
$user = null;
if ($user_id) {
$user = User::query()->where('id', $user_id)->first();
}
$departments = Department::query()->orderByDesc('id')->get();
foreach ($departments as $d) {
$d->selected = $user != null && $user->department_id == $d->id;
}
$data = recursive($departments);
return $this->success('ok', $data);
}
public function getUser(Request $request)
{
$user_id = $request->input('user_id');
$users = User::query()->get();
foreach ($users as $user){
$user->selected = $user_id == $user->id;
}
return $this->success('ok',$users);
}
public function getNode(Request $request)
{
$node_id = $request->input('node_id');
$type = $request->input('type');
$nodes = Node::query()
->whereIn('type',[1,$type])
->orderBy('sort','asc')
->orderBy('id','asc')
->get();
foreach ($nodes as $node){
$node->selected = $node_id == $node->id;
}
return $this->success('ok',$nodes);
}
public function remarkList(Request $request)
{
$node_type = $request->input('type');
$id = $request->input('id');
if ($node_type == 2){
$res = CustomerRemark::query()->where('customer_id','=',$id)->orderByDesc('id')->paginate($request->get('limit', 2));
}elseif ($node_type == 3){
$res = OrderRemark::query()->where('order_id','=',$id)->orderByDesc('id')->paginate($request->get('limit', 2));
}
return $this->success('ok',['list'=>$res->items(),'lastPage'=>$res->lastPage()]);
}
/**
* 呼叫接口
* @param Request $request
* @return \Illuminate\Http\JsonResponse
*/
public function call(Request $request)
{
$user_id = $request->input('user_id');
$caller = $request->input('caller');
$callee = $request->input('callee');
$user_data = $request->input('user_data');
if ($caller != null){
$sip = Sip::query()->where('username',$caller)->first();
if ($sip == null){
return $this->error('外呼号不存在');
}
if ($sip->status != 1) {
return $this->error('外呼号未在线');
}
$user = User::query()->where('sip_id', '=', $sip->id)->first();
}else{
$user = User::query()->with('sip')->where('id', '=', $user_id)->first();
if ($user == null){
return $this->error('用户ID不存在');
}
if ($user->sip == null) {
return $this->error('用户未分配外呼号');
}
if ($user->sip->status != 1) {
return $this->error('用户外呼号未在线');
}
$sip = $user->sip;
}
try {
$cdr = Cdr::create([
'uuid' => uuid_generate(),
'aleg_uuid' => uuid_generate(),
'bleg_uuid' => uuid_generate(),
'caller' => $sip->username,
'callee' => $callee,
'department_id' => $user->department_id??0,
'user_id' => $user->id??0,
'user_nickname' => $user->nickname??null,
'sip_id' => $sip->id,
'user_data' => $user_data,
'gateway_id' => $sip->gateway_id ?? 0,
]);
Redis::rpush(config('freeswitch.redis_key.dial'), $cdr->uuid);
return $this->success('呼叫成功', [
'uuid' => $cdr->uuid,
'call_time' => date('Y-m-d H:i:s'),
]);
} catch (\Exception $exception) {
Log::error('呼叫异常:' . $exception->getMessage());
return $this->error('呼叫失败');
}
}
public function hangup(Request $request)
{
$uuid = $request->input('uuid');
if($uuid == null){
return $this->error('参数错误');
}
$cdr = Cdr::query()->where('uuid',$uuid)->first();
if ($cdr==null){
return $this->error('参数错误');
}
if (!$cdr->end_time){
Redis::rpush(config('freeswitch.redis_key.api'),'uuid_kill '.$cdr->aleg_uuid);
}
return $this->success('已挂断');
}
public function chanspy(Request $request)
{
$data = $request->all(['fromExten','toExten','type']);
$toSip = Sip::where('username',$data['toExten'])->first();
if ($toSip->status == 0){
return $this->error('监听分机未在线');
}
//验证监听,是否登录
$fromSip = Sip::where('username',$data['fromExten'])->first();
if ($fromSip->status == 0){
return $this->error('被监听分机未在线');
}
$cdr = Cdr::query()
->where('caller',$toSip)
->whereNotNull('answer_time')
->whereNull('end_time')
->orderByDesc('id')
->first();
if ($cdr == null){
return $this->error('被监听分机未在通话中');
}
$dailStr = "originate {origination_caller_id_number=".$data['fromExten']."}";
$dailStr .= "{origination_caller_id_name=".$data['fromExten']."}";
$dailStr .= "user/".$data['fromExten'];
if ($data['type']==3){
$dailStr .= " &three_way(".$cdr->aleg_uuid.")";
}elseif ($data['type']==2){
$dailStr .= " &{eavesdrop_whisper_aleg=false}{eavesdrop_whisper_bleg=false}eavesdrop(".$cdr->aleg_uuid.")";
}elseif ($data['type']==1){
$dailStr .= " &{eavesdrop_whisper_aleg=true}{eavesdrop_whisper_bleg=false}eavesdrop(".$cdr->aleg_uuid.")";
}else{
return $this->error('监听模式错误');
}
Redis::rpush(config('freeswitch.redis_key.api'),$dailStr);
return $this->success('监听成功');
}
//文件上传
public function upload(Request $request)
{
//上传文件最大大小,单位M
$maxSize = 10;
//支持的上传图片类型
$allowed_extensions = ["png", "jpg", "gif", "xlsx", "xls"];
$file = $request->file('file');
//检查文件是否上传完成
if ($file->isValid()) {
//检测图片类型
$ext = $file->getClientOriginalExtension();
if (!in_array(strtolower($ext), $allowed_extensions)) {
return $this->success("请上传" . implode(",", $allowed_extensions) . "格式的图片");
}
//检测图片大小
if ($file->getSize() > $maxSize * 1024 * 1024) {
return $this->success("图片大小限制" . $maxSize . "M");
}
} else {
return $this->error('文件不完整');
}
try {
$newFile = date('Y/m/d/') . uuid_generate() . "." . $file->getClientOriginalExtension();
$disk = Storage::disk('uploads');
$res = $disk->put($newFile, file_get_contents($file->getRealPath()));
if ($res) {
$data = [
'url' => '/uploads/' . $newFile,
];
return $this->success('上传成功', $data);
} else {
Log::error('文件上传错误:' . $file->getErrorMessage());
$this->error('上传失败');
}
}catch (\Exception $exception){
Log::error('文件上传异常:' . $exception->getMessage());
$this->error('系统异常');
}
}
public function payList(Request $request)
{
$id = $request->input('id');
$res = OrderPay::query()->where('order_id','=',$id)->orderByDesc('id')->paginate($request->get('limit', 2));
return $this->success('ok',['list'=>$res->items(),'lastPage'=>$res->lastPage()]);
}
public function getSipsByQueueId(Request $request)
{
$queueId = $request->input('queue_id');
$lists = Sip::with('user')->get();
$values = [];
if ($queueId){
$values = DB::table('queue_sip')->where('queue_id',$queueId)->pluck('sip_id')->toArray();
}
foreach ($lists as $item){
$item->checked = in_array($item->id,$values) ? true : false;
}
return $this->success('ok',['lists'=>$lists,'values'=>$values]);
}
}