| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251 | <?php/** * Created by PhpStorm. * User: Administrator * Date: 2019/4/29 0029 * Time: 17:16 */namespace App\Http\Logics\Admin;use App\Http\Models\Role;use App\Http\Models\SiteProcess;use Illuminate\Http\Request;use Illuminate\Support\Facades\DB;use function GuzzleHttp\Psr7\str;class InquireLogic{    /**     * 项目详情中的询盘和客户询盘记录筛选     * @param Request $request     * @param $server     * @param $site     * @param $condition     * @param int $isDelete     * @return array     */    public function pageRecords(Request $request, $server, $site, $condition, $isDelete = null)    {        //流程程序开发流程 部署        $config = [            'connection_name' => sprintf('connection_name_%s', $site->id),            'host' => $server->server_ip,            'port' => '3306',            'database' => $site->database,            'username' => $server->mysql_user_name,            'password' => $server->mysql_passwd,        ];        config_connection($config);        $builder = DB::connection($config['connection_name'])->table('user_msg')->where($condition);        $nowUser = auth()->user();        if ($nowUser->role_id == Role::TYPE_TYPE_CUSTOMER_STAFF) {            $inquireIds = DB::table('user_has_inquire')->where(['user_id' => $nowUser->id])->get()->pluck('inquire_id')->toArray();            $builder->whereIn('id', $inquireIds);        }        //是否真实询盘筛选        if (isset($isDelete)) {            $builder->where('is_delete', $isDelete);        }        $records = $builder->orderBy('create_time', 'desc')            ->paginate($request->input('pageSize') ?? TABLE_PAGE_SIZE);        $items = $records->items();        array_walk($items, function ($item) {            $item->created_at = date('Y-m-d H:i:s', $item->create_time);            $item->is_read = $item->is_read ? '已读' : '未读';            preg_match('/(?:\()(.*)(?:\))/i', $item->content, $match);            preg_match("/(?:\()(.*)(?:\))/i", $match[0] ?? '', $result);            preg_match('/\d{10,}/', $item->content, $match2);            $item->location = $result[1] ?? '';            $item->phone = $match2[0] ?? '';            $item->mail_date = '详情';            if (!in_array($item->mail_time, [-1, 0])) {                $item->mail_date = date('Y-m-d H:i:s', $item->mail_time);            }        });        $condition['is_delete'] = 0;        $realInquire = DB::connection($config['connection_name'])->table('user_msg')->where($condition)->count();        return [$records, $realInquire];    }    public function PageRecordsExport(Request $request, $server, $site, $condition)    {        //流程程序开发流程 部署        $config = [            'connection_name' => sprintf('connection_name_%s', $site->id),            'host' => $server->server_ip,            'port' => '3306',            'database' => $site->database,            'username' => $server->mysql_user_name,            'password' => $server->mysql_passwd,        ];        config_connection($config);        $builder = DB::connection($config['connection_name'])->table('user_msg')->select([            'sender_name',            'sender_email',            'create_time',            'title',            'content',            'is_delete',            'is_read'        ])->where($condition);        if (!$request->input('notCustomer')) {            $nowUser = auth()->user();            if ($nowUser->role_id == Role::TYPE_TYPE_CUSTOMER_STAFF) {                $inquireIds = DB::table('user_has_inquire')->where(['user_id' => $nowUser->id])->get()->pluck('inquire_id')->toArray();                $builder->whereIn('id', $inquireIds);            }        }        $records = $builder->get()->toArray();        $resultsRecord = [];        foreach ($records as $record) {            preg_match('/(?:\()(.*)(?:\))/i', $record->content, $match);            preg_match("/(?:\()(.*)(?:\))/i", $match[0] ?? '', $result);            preg_match('/\d{10,}/', $record->content, $match2);//            $content = preg_replace('/\r|\n/', '', $record->content);//            preg_match('/留言\:\<\/td\>.*?\<\/div>/i', $content, $m1);//            $m1[0] = str_replace('留言:', '', $m1[0]);            $memo = explode('留言:', strip_tags($record->content));            if (!empty($memo[1])) {                $memo1 = explode('URL:', $memo[1]);                if (!empty($memo1[1])) {                    $url = explode('温馨提示:', $memo1[1]);                }            }            $resultsRecord[] = [                'sender_name' => $record->sender_name,                'sender_email' => $record->sender_email,                'phone' => $match2[0] ?? '',                'location' => $result[1] ?? '',                'create_time' => date('Y-m-d', $record->create_time),                'title' => $record->title,                'content' => strip_tags($record->content),                'is_delete' => $record->is_read ? '是' : '否',                'is_read' => $record->is_read ? '已读' : '未读',                'memo' => $memo1[0] ?? '',                'url' => $url[0] ?? '',            ];        }        return $resultsRecord;    }    public function PageRecordsAllExport($server, $site)    {        $config = [            'connection_name' => sprintf('connection_name_%s', $site->id),            'host' => $server->server_ip,            'port' => '3306',            'database' => $site->database,            'username' => $server->mysql_user_name,            'password' => $server->mysql_passwd,        ];        config_connection($config);        $builder = DB::connection($config['connection_name'])            ->table('user_log')            ->whereBetween('create_time', [strtotime(date('Y-m-d', strtotime("first day of last month"))), strtotime("now")])            ->where('user_id', 1)->select('id', 'user_id', 'notice', 'url', 'request', 'cookie', 'client_ip', 'create_time')->get();        $resultsRecord = [];        foreach ($builder as $record) {            $resultsRecord[] = [                'id' => $record->id,                'user_id' => $record->user_id,                'notice' => $record->notice,                'url' => $record->url,                'request' => $record->request,                'cookie' => $record->cookie,                'client_ip' => long2ip($record->client_ip),                'create_time' => date('Y-m-d', $record->create_time),            ];        }        return $resultsRecord;    }    public function pageRecordsExportBak(Request $request, $server, $site, $condition)    {        //流程程序开发流程 部署        $config = [            'connection_name' => sprintf('connection_name_%s', $site->id),            'host' => $server->server_ip,            'port' => '3306',            'database' => $site->database,            'username' => $server->mysql_user_name,            'password' => $server->mysql_passwd,        ];        config_connection($config);        $builder = DB::connection($config['connection_name'])->table('user_msg')->select([            'sender_name',            'sender_email',            'create_time',            'title',            'content',            'is_delete',            'is_read'        ])->where($condition);        $records = $builder->get()->toArray();        $resultsRecord = [];        foreach ($records as $record) {            preg_match('/(?:\()(.*)(?:\))/i', $record->content, $match);            preg_match("/(?:\()(.*)(?:\))/i", $match[0] ?? '', $result);            preg_match('/\d{10,}/', $record->content, $match2);//            $content = preg_replace('/\r|\n/', '', $record->content);//            preg_match('/留言\:\<\/td\>.*?\<\/div>/i', $content, $m1);//            $m1[0] = str_replace('留言:', '', $m1[0]);            $resultsRecord[] = [                'sender_name' => $record->sender_name,                'sender_email' => $record->sender_email,                'phone' => $match2[0] ?? '',                'location' => $result[1] ?? '',                'create_time' => date('Y-m-d', $record->create_time),                'title' => $record->title,                'content' => str_replace('留言:', '', strip_tags($record->content)),                'is_delete' => $record->is_read ? '是' : '否',                'is_read' => $record->is_read ? '已读' : '未读',            ];        }        return $resultsRecord;    }}
 |