PrivateController.php 11.5 KB
<?php
/**
 * Created by PhpStorm.
 * User: zhl
 * Date: 2024/1/6
 * Time: 17:41
 */
namespace App\Http\Controllers\Api;

use App\Enums\Common\Code;
use App\Http\Logic\Bside\User\UserLoginLogic;
use App\Models\Domain\DomainInfo;
use App\Models\Product\Category;
use App\Models\Product\CategoryRelated;
use App\Models\Product\Keyword;
use App\Models\Product\Product;
use App\Models\Project\OnlineCheck;
use App\Models\Project\Project;
use App\Models\RouteMap\RouteMap;
use App\Models\User\User;
use App\Models\WebSetting\WebLanguage;
use App\Services\ProjectServer;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\Cache;
use Illuminate\Support\Facades\DB;

/**
 * Class PrivateController
 * @package App\Http\Controllers\Api
 */
class PrivateController extends BaseController
{
    /**
     * 优化中项目列表
     * @param Request $request
     * @return false|string
     */
    public function optimizeProjectList(Request $request)
    {
        $page_size = $request->input('page_size', 20);
        $field = ['gl_project.id', 'gl_project.company', 'gl_project.is_upgrade', 'b.start_date', 'd.domain'];
        $result = Project::select($field)->leftJoin('gl_project_deploy_optimize as b', 'gl_project.id', '=', 'b.project_id')
            ->leftJoin('gl_project_online_check as c', 'gl_project.id', '=', 'c.project_id')
            ->leftJoin('gl_domain_info as d', 'gl_project.id', '=', 'd.project_id')
            ->where('gl_project.type', Project::TYPE_TWO)
            ->where('gl_project.extend_type', 0) // 是否续费是由extend_type字段控制
            ->where('gl_project.delete_status', Project::IS_DEL_FALSE)
            ->where(function ($subQuery) {
                $subQuery->orwhere('c.qa_status', OnlineCheck::STATUS_ONLINE_TRUE)->orwhere('gl_project.is_upgrade', Project::IS_UPGRADE_TRUE);
            })
            ->paginate($page_size)
            ->toArray();
        return $this->success($result);
    }

    /**
     * 获取项目链接
     * FIXME 当前直接获取的产品和产品分类, 后期需要封装到内部, 需要添加完整的链接规则
     * @param Request $request
     * @return false|string
     */
    public function getProjectRoute(Request $request)
    {
        $project_id = intval($request->input('project_id'));
//        $type = $request->input('type');
        $type = [RouteMap::SOURCE_PRODUCT, RouteMap::SOURCE_PRODUCT_CATE];

        $project = Project::where(['id' => $project_id])->first();
        if (empty($project))
            return $this->error('未发现需要查找的项目!');

        $project = ProjectServer::useProject($project_id);

        $domain = DomainInfo::where(['project_id' => $project_id])->first();
        $host = FALSE == empty($domain) ? 'https://' . $domain->domain . '/' : $project->deploy_build->test_domain;

        // 需要标题, 不能直接查询map表
//        $list = RouteMap::where(['project_id' => $project_id])
//            ->when($type, function ($query) use ($type) {
//                return $query->whereIn('source', $type);
//            })
//            ->get();
//
//        $result = [];
//        foreach ($list as $val) {
//            // 排除首页
//            if ($val->source == RouteMap::SOURCE_PAGE && in_array($val->route, ['index', '']))
//                continue;
//            $result[$val->source][] = $host . $val->route;
//        }
        $result = [];
        $product = Product::where(['status' => Product::STATUS_ON])->get(['title', 'route'])->toArray();
        foreach ($product as $val) {
            $val['route'] = $host . $val['route'];
            // FALSE == preg_match('/(\.html|\.htm)$/', $val['route'])
            if (FALSE === strpos($val['route'], '.htm')) {
                $val['route'] .= '/';
            }
            $result[RouteMap::SOURCE_PRODUCT][] = $val;
        }
        $product_category= Category::get(['title', 'route'])->toArray();
        foreach ($product_category as $val) {
            $val['route'] = $host . $val['route'];
            if (FALSE === strpos($val['route'], '.htm')) {
                $val['route'] .= '/';
            }
            $result[RouteMap::SOURCE_PRODUCT_CATE][] = $val;
        }
        return $this->success($result);
    }

    /**
     * 验证当前用户是否存在
     * TODO 查询手机号码是否是项目用户, 如果升级项目未上线项目return false;
     * @param Request $request
     * @return false|string
     */
    public function hasUser(Request $request)
    {
        // 获取数据,初始化信息
        $mobile = trim($request->input('mobile'));
        $result = ['mobile' => $mobile, 'v6_user' => false];

        // 获取用户,验证用户
        $project_ids = User::where(['mobile' => $mobile])->pluck('project_id')->toArray();
        if (empty($project_ids))
            return $this->success($result);

        $projects = Project::whereIn('id', $project_ids)->where('delete_status', 0)->get();
        foreach ($projects as $project) {
            // 如果是升级项目 并且未上线状态,不算做有效用户
            if ($project->is_upgrade == Project::IS_UPGRADE_TRUE && $project->type <= Project::TYPE_ONE)
                continue;
            $result['v6_user'] = true;
        }

        return $this->success($result);
    }

    /**
     * v6 有效用户
     * @param Request $request
     * @return false|string
     */
    public function validUser(Request $request)
    {
        // 排除演示项目数据
        $valid_user = User::select(['gl_project_user.mobile'])->leftJoin('gl_project', 'gl_project.id', '=', 'gl_project_user.project_id')->where(['delete_status' => 0, 'is_upgrade' => Project::IS_UPGRADE_FALSE])->where('gl_project.id', '>', 1)->pluck('mobile')->toArray();
        $upgrade_user = User::select(['gl_project_user.mobile'])->leftJoin('gl_project', 'gl_project.id', '=', 'gl_project_user.project_id')->where(['delete_status' => 0, 'is_upgrade' => Project::IS_UPGRADE_TRUE])->where('gl_project.type', '>', Project::TYPE_ONE)->pluck('mobile')->toArray();
        $user = array_unique(array_merge($valid_user, $upgrade_user));
        return $this->success($user);
    }

    /**
     * 模拟登录返回token
     */
    public function getAutoToken(){
        $this->request->validate([
            'project_id' => 'required',
        ], [
            'project_id.required' => '项目id不能为空',
        ]);
        //获取当前用户的管理员
        $userModel = new User();
        $userInfo = $userModel->read(['project_id'=>$this->param['project_id'],'role_id'=>0]);
        $userLoginLogicModel = new UserLoginLogic();
        $info = $userLoginLogicModel->autoAssembleParam($userInfo);
        //生成新token
        $token = md5(uniqid().'auto'.$info['id']);
        //存储缓存
        $info['token'] = $token;
        Cache::add($token,$info,3600);
        $languageModel = new WebLanguage();
        $languageInfo = $languageModel->read(['id'=>$info['main_lang_id']],['short','english','chinese']);
        $data = ['token'=>$token,'main_lang_id'=>$info['main_lang_id'],'language_info'=>$languageInfo];
        $this->response('success',Code::SUCCESS,$data);
    }

    /**
     * 项目 有效产品路由列表
     * @param Request $request
     * @return false|string
     */
    public function getProductRoute(Request $request)
    {
        $domain = trim($request->input('domain'));
        if (empty($domain)) {
            return $this->error('非法参数!');
        }

        $project = Project::getProjectByDomain($domain);
        if (empty($project)) {
            return $this->error('未找到当前域名对应的项目!');
        }
        ProjectServer::useProject($project->id);
        $feature_category = Category::whereIn('title', ['Featured','featured', 'Featured Products'])->pluck('id');
        $feature_product = CategoryRelated::whereIn('cate_id',$feature_category)->pluck('product_id')->unique()->toArray();
        $product_route = Product::where(['status' => Product::STATUS_ON])->whereNotIn('id', $feature_product)->pluck('route')->toArray();
        return $this->success($product_route);
    }

    /**
     * 获取项目信息---站群服务
     * @param Request $request
     * @return false|string
     */
    public function getProjectByDomain(Request $request)
    {
        $domain = trim($request->input('domain'));
        if (empty($domain)) {
            return $this->error('非法参数!');
        }

        $project = Project::getProjectByDomain($domain);
        if (empty($project)) {
            return $this->error('未找到当前域名对应的项目!');
        }
        $optimize = $project->optimize;
        $keyword = $project->project_keyword;
        $keywords = explode("\r\n", $keyword ? $keyword->main_keyword : []);
        $result = [
            'company' => $project->company,
            'company_en_name' => $optimize ? $optimize->company_en_name : '',
            'company_en_description' => $optimize ? $optimize->company_en_description : '',
            'keywords' => $keywords
        ];
        return $this->success($result);
    }

    /**
     * 获取产品信息---站群服务
     * @param Request $request
     * @return false|string
     */
    public function getProjectProduct(Request $request)
    {
        $domain = trim($request->input('domain'));
        $page_size = intval($request->input('page_size', 20));
        if (empty($domain)) {
            return $this->error('非法参数!');
        }

        $project = Project::getProjectByDomain($domain);
        if (empty($project)) {
            return $this->error('未找到当前域名对应的项目!');
        }
        ProjectServer::useProject($project->id);
        $products = Product::with('category')->where(['status' => Product::STATUS_ON])->paginate($page_size);

//        $products_ids = $products->pluck('id')->toArray();
//        $category_ids = CategoryRelated::whereIn('product_id', $products_ids)->pluck('cate_id')->toArray();
//        $category = Category::whereIn('id', $category_ids)->pluck('title', 'id')->toArray();

        $keyword_id = $products->pluck('keyword_id')->toArray();
        $keyword_ids = array_reduce($keyword_id, 'array_merge', array());
        $keyword = Keyword::whereIn('id', $keyword_ids)->pluck('title', 'id')->toArray();

        $result = [];
        foreach ($products as $product) {
            $product_keyword = [];
            foreach ($product->keyword_id as $k_id) {
                array_push($product_keyword, $keyword[$k_id]);
            }
            $product_category = $product->category->pluck('title')->toArray();
            $result[] = [
                'title' => $product->title,
                'thumb' => $product->thumb,
                'gallery' => $product->gallery,
                'intro' => $product->intro,
                'content' => $product->content,
                'category' => $product_category,
                'keyword' => $product_keyword,
                'route' => $product->route
            ];
        }
        return $this->success($result);
    }

    /**
     * 获取上线项目 --- 监控服务
     * @param Request $request
     * @return false|string
     */
    public function getProjectOnline(Request $request)
    {
        $page_size = intval($request->input('page_size', 20));
        $projects = Project::select(['id', 'title', 'company', 'type', 'finish_remain_day', 'remain_day'])->whereIn('type', [2, 3, 4, 6])->where('delete_status', 0)->paginate($page_size);
        foreach ($projects as $project) {
            $project->domain = $project->domainInfo ? $project->domainInfo->domain : '';
        }
        return $this->success($projects);
    }
}