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;
- }
- }
|