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

use App\Models\Domain\DomainInfo;
use App\Models\Product\Category;
use App\Models\Product\Product;
use App\Models\Project\OnlineCheck;
use App\Models\Project\Project;
use App\Models\RouteMap\RouteMap;
use App\Services\ProjectServer;
use Illuminate\Http\Request;

/**
 * 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')
            ->whereIn('gl_project.type', [Project::TYPE_TWO, Project::TYPE_FOUR])
            ->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);
    }
}