382 lines
13 KiB
PHP
382 lines
13 KiB
PHP
<?php
|
|
|
|
/*
|
|
* To change this license header, choose License Headers in Project Properties.
|
|
* To change this template file, choose Tools | Templates
|
|
* and open the template in the editor.
|
|
*/
|
|
|
|
namespace app\api\controller;
|
|
|
|
use think\Controller;
|
|
use think\Db;
|
|
use think\Queue;
|
|
|
|
/**
|
|
* @title 领域接口
|
|
* @description 领域接口
|
|
*/
|
|
class Major extends Controller {
|
|
|
|
protected $article_obj = '';
|
|
protected $user_obj = '';
|
|
protected $user_act_obj = '';
|
|
protected $journal_obj = '';
|
|
protected $user_log_obj = '';
|
|
protected $user_reviewer_info_obj = '';
|
|
protected $reviewer_major_obj = '';
|
|
protected $reviewer_to_journal_obj = '';
|
|
protected $article_reviewer_question_obj = '';
|
|
protected $article_msg_obj = '';
|
|
protected $article_file_obj = '';
|
|
protected $article_reviewer_obj = '';
|
|
protected $article_author_obj = '';
|
|
protected $article_transfer_obj = '';
|
|
protected $chief_to_journal_obj = '';
|
|
protected $login_auto_obj = '';
|
|
protected $major_obj = "";
|
|
protected $major_to_journal_obj = '';
|
|
protected $sync_obj = '';
|
|
|
|
public function __construct(\think\Request $request = null) {
|
|
parent::__construct($request);
|
|
$this->user_obj = Db::name('user');
|
|
$this->user_act_obj = Db::name('user_act');
|
|
$this->article_obj = Db::name('article');
|
|
$this->journal_obj = Db::name('journal');
|
|
$this->user_log_obj = Db::name('user_log');
|
|
$this->user_reviewer_info_obj = Db::name("user_reviewer_info");
|
|
$this->reviewer_major_obj = Db::name('reviewer_major');
|
|
$this->reviewer_to_journal_obj = Db::name('reviewer_to_journal');
|
|
$this->article_reviewer_question_obj = Db::name('article_reviewer_question');
|
|
$this->article_msg_obj = Db::name('article_msg');
|
|
$this->article_file_obj = Db::name('article_file');
|
|
$this->article_reviewer_obj = Db::name('article_reviewer');
|
|
$this->article_author_obj = Db::name('article_author');
|
|
$this->article_transfer_obj = Db::name('article_transfer');
|
|
$this->chief_to_journal_obj = Db::name('chief_to_journal');
|
|
$this->login_auto_obj = Db::name('login_auto');
|
|
$this->major_obj = Db::name("major");
|
|
$this->major_to_journal_obj = Db::name('major_to_journal');
|
|
$this->sync_obj = Db::name("sync");
|
|
}
|
|
|
|
/**
|
|
* @title 添加领域
|
|
* @description 添加领域
|
|
* @author wangjinlei
|
|
* @url /api/Major/addMajor
|
|
* @method POST
|
|
*
|
|
* @param name:major_title type:string require:1 desc:领域名
|
|
* @param name:nickname type:string require:0 desc:别称
|
|
* @param name:major_sort type:int require:0 desc:权重
|
|
* @param name:pid type:int require:1 desc:父级id(0代表顶级)
|
|
*
|
|
*/
|
|
public function addMajor() {
|
|
$data = $this->request->post();
|
|
$insert['major_title'] = trim($data['major_title']);
|
|
$insert['pid'] = $data['pid'];
|
|
if (isset($data['nickname'])) {
|
|
$insert['nickname'] = trim($data['nickname']);
|
|
}
|
|
if (isset($data['major_sort'])) {
|
|
$insert['major_sort'] = $data['major_sort'];
|
|
}
|
|
if ($data['pid'] == 0) {
|
|
$insert['major_level'] = 1;
|
|
} else {
|
|
$p_major = $this->major_obj->where('major_id', $data['pid'])->find();
|
|
$insert['major_level'] = $p_major['major_level'] + 1;
|
|
}
|
|
$insert['major_ctime'] = time();
|
|
$this->major_obj->insert($insert);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 编辑领域
|
|
* @description 编辑领域
|
|
* @author wangjinlei
|
|
* @url /api/Major/editMajor
|
|
* @method POST
|
|
*
|
|
* @param name:major_id type:int require:1 desc:领域id
|
|
* @param name:major_title type:string require:1 desc:领域名
|
|
* @param name:nickname type:string require:0 desc:别称
|
|
* @param name:major_sort type:int require:0 desc:权重
|
|
*
|
|
*/
|
|
public function editMajor() {
|
|
$data = $this->request->post();
|
|
$update['major_title'] = trim($data['major_title']);
|
|
if (isset($data['nickname'])) {
|
|
$update['nickname'] = trim($data['nickname']);
|
|
}
|
|
if (isset($data['major_sort'])) {
|
|
$update['major_sort'] = $data['major_sort'];
|
|
}
|
|
$this->major_obj->where("major_id", $data['major_id'])->update($update);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 删除大池子领域
|
|
* @description 删除大池子领域
|
|
* @author wangjinlei
|
|
* @url /api/Major/delMajor
|
|
* @method POST
|
|
*
|
|
* @param name:major_id type:int require:1 desc:领域id
|
|
*
|
|
*/
|
|
public function delMajor() {
|
|
$data = $this->request->post();
|
|
//判断是否有子集
|
|
$check_child = $this->major_obj->where('pid', $data['major_id'])->where('major_state', 0)->select();
|
|
if ($check_child) {
|
|
return jsonError("存在子集不能删除");
|
|
}
|
|
//判断是否存在引用
|
|
$check_journal = $this->major_to_journal_obj->where('major_id', $data['major_id'])->where("mtj_state", 0)->select();
|
|
if ($check_journal) {
|
|
return jsonError("期刊存在引用,不能删除");
|
|
}
|
|
$this->major_obj->where("major_id", $data['major_id'])->update(['major_state' => 1]);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取领域树
|
|
* @description 获取领域树
|
|
* @author wangjinlei
|
|
* @url /api/Major/getMajorList
|
|
* @method POST
|
|
*
|
|
* @return majors:领域树
|
|
*/
|
|
public function getMajorList() {
|
|
//查询顶级
|
|
$list = $this->major_obj->where('pid', 0)->where('major_state', 0)->order('major_sort desc')->select();
|
|
foreach ($list as $k => $v) {
|
|
$cache_child = $this->getMajorChild($v);
|
|
if ($cache_child != null) {
|
|
$list[$k]['children'] = $cache_child;
|
|
}
|
|
}
|
|
|
|
$re['majors'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 添加期刊领域
|
|
* @description 添加期刊领域
|
|
* @author wangjinlei
|
|
* @url /api/Major/addJournalMajor
|
|
* @method POST
|
|
*
|
|
* @param name:major_id type:int require:1 desc:领域id
|
|
* @param name:journal_issn type:string require:1 desc:期刊issn
|
|
*
|
|
*/
|
|
public function addJournalMajor() {
|
|
$data = $this->request->post();
|
|
//判断major父级是否存在
|
|
$major_info = $this->major_obj->where('major_id', $data['major_id'])->where("major_state", 0)->find();
|
|
$check_major = $this->major_to_journal_obj->where('major_id', $major_info['pid'])->where('journal_issn',trim($data['journal_issn']))->where('mtj_state', 0)->find();
|
|
if ($major_info['pid'] != 0 && $check_major == null) {
|
|
return jsonError("父级必须存在");
|
|
}
|
|
//判断是否重复添加
|
|
$check = $this->major_to_journal_obj->where('major_id', $data['major_id'])->where('journal_issn', trim($data['journal_issn']))->where('mtj_state', 0)->find();
|
|
if ($check) {
|
|
return jsonError("重复添加");
|
|
}
|
|
|
|
$has = $this->major_to_journal_obj->where('major_id', $data['major_id'])->where('journal_issn', trim($data['journal_issn']))->where('mtj_state', 1)->find();
|
|
|
|
if ($has) {
|
|
$this->major_to_journal_obj->where('major_id', $data['major_id'])->where('journal_issn', trim($data['journal_issn']))->where('mtj_state', 1)->update(['mtj_state' => 0]);
|
|
} else {
|
|
$insert['major_id'] = $data['major_id'];
|
|
$insert['journal_issn'] = trim($data['journal_issn']);
|
|
$insert['mtj_ctime'] = time();
|
|
$this->major_to_journal_obj->insert($insert);
|
|
}
|
|
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 删除期刊领域
|
|
* @description 删除期刊领域
|
|
* @author wangjinlei
|
|
* @url /api/Major/delJournalMajor
|
|
* @method POST
|
|
*
|
|
* @param name:major_id type:int require:1 desc:领域id
|
|
* @param name:journal_issn type:string require:1 desc:期刊issn
|
|
*
|
|
*/
|
|
public function delJournalMajor() {
|
|
$data = $this->request->post();
|
|
//判断是否有子集
|
|
$check = $this->major_to_journal_obj
|
|
->join("t_major","t_major.major_id = t_major_to_journal.major_id","left")
|
|
->where("t_major_to_journal.journal_issn", trim($data['journal_issn']))
|
|
->where("t_major_to_journal.mtj_state",0)
|
|
->where("t_major.pid",$data['major_id'])
|
|
->select();
|
|
if($check){
|
|
return jsonError("存在子集不能删除");
|
|
}
|
|
|
|
$this->major_to_journal_obj->where('major_id', $data['major_id'])->where('journal_issn', $data['journal_issn'])->update(['mtj_state'=> 1]);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取期刊领域树
|
|
* @description 获取期刊领域树
|
|
* @author wangjinlei
|
|
* @url /api/Major/getJournalMajorList
|
|
* @method POST
|
|
*
|
|
* @param name:journal_issn type:string require:1 desc:期刊issn号
|
|
*
|
|
* @return majors:领域信息#
|
|
*/
|
|
public function getJournalMajorList() {
|
|
$data = $this->request->post();
|
|
if (!isset($data['journal_issn'])) {
|
|
return jsonError("参数异常");
|
|
}
|
|
// $data['journal_issn'] = '2815-7125';
|
|
//获取主节点
|
|
$list = $this->major_to_journal_obj
|
|
->field('t_major.*')
|
|
->join("t_major", 't_major.major_id = t_major_to_journal.major_id', 'left')
|
|
->where("t_major_to_journal.journal_issn", trim($data['journal_issn']))
|
|
->where("t_major.pid", 0)
|
|
->where("t_major_to_journal.mtj_state", 0)
|
|
->select();
|
|
foreach ($list as $k => $v) {
|
|
$cache_child = $this->getJournalMajorChild($v, trim($data['journal_issn']));
|
|
if ($cache_child != null) {
|
|
$list[$k]['children'] = $cache_child;
|
|
}
|
|
}
|
|
$re['majors'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 获取全部期刊
|
|
* @description 获取全部期刊
|
|
* @author wangjinlei
|
|
* @url /api/Major/getAllJournals
|
|
* @method POST
|
|
*
|
|
* @return journals:期刊信息#
|
|
*/
|
|
public function getAllJournals() {
|
|
$list = $this->journal_obj->where('state', 0)->select();
|
|
|
|
$re['journals'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 同步大池子数据
|
|
* @description 同步大池子数据
|
|
* @author wangjinlei
|
|
* @url /api/Major/synchronization
|
|
* @method POST
|
|
*
|
|
*/
|
|
public function synchronization(){
|
|
$url = "http://journalapi.tmrjournals.com/public/index.php/master/Major/sync_all";
|
|
$url1 = "http://api.tmrjournals.cn/public/index.php/master/Major/sync_all";
|
|
$list = $this->major_obj->select();
|
|
myPost($url, ['majors'=> json_encode($list)]);
|
|
myPost($url1, ['majors'=> json_encode($list)]);
|
|
$this->sync_obj->where('akey',1)->update(['all_major'=> time()]);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 同步小池子数据
|
|
* @description 同步小池子数据
|
|
* @author wangjinlei
|
|
* @url /api/Major/synchronizationJournal
|
|
* @method POST
|
|
*
|
|
*/
|
|
public function synchronizationJournal(){
|
|
$url = "http://journalapi.tmrjournals.com/public/index.php/master/Major/sync_journal";
|
|
$url1 = "http://api.tmrjournals.cn/public/index.php/master/Major/sync_journal";
|
|
$list = $this->major_to_journal_obj->select();
|
|
myPost($url, ['majors'=> json_encode($list)]);
|
|
myPost($url1, ['majors'=> json_encode($list)]);
|
|
$this->sync_obj->where('akey',1)->update(['journal_major'=> time()]);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取大池子最后同步时间
|
|
* @description 获取大池子最后同步时间
|
|
* @author wangjinlei
|
|
* @url /api/Major/getLastSyncTime
|
|
* @method POST
|
|
*
|
|
* @return sync:同步时间记录#
|
|
*/
|
|
public function getLastSyncTime(){
|
|
$d = $this->sync_obj->where('akey',1)->find();
|
|
$re['sync'] = $d;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* 获取领域子树
|
|
*/
|
|
private function getMajorChild($major) {
|
|
$list = $this->major_obj->where('pid', $major['major_id'])->where('major_state', 0)->order("major_sort desc")->select();
|
|
if ($list == null) {
|
|
return null;
|
|
}
|
|
foreach ($list as $k => $v) {
|
|
$cache_child = $this->getMajorChild($v);
|
|
if ($cache_child != null) {
|
|
$list[$k]['children'] = $cache_child;
|
|
}
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* 获取期刊领域树子集
|
|
* @param type $major
|
|
* @param type $issn
|
|
*/
|
|
private function getJournalMajorChild($major, $issn) {
|
|
$list = $this->major_to_journal_obj
|
|
->field("t_major.*")
|
|
->join("t_major", "t_major_to_journal.major_id=t_major.major_id", 'left')
|
|
->where("pid", $major['major_id'])
|
|
->where("t_major_to_journal.journal_issn", $issn)
|
|
->where("t_major_to_journal.mtj_state", 0)
|
|
->select();
|
|
foreach ($list as $k => $v) {
|
|
$cache_child = $this->getJournalMajorChild($v, $issn);
|
|
if ($cache_child != null) {
|
|
$list[$k]['children'] = $cache_child;
|
|
}
|
|
}
|
|
return $list;
|
|
}
|
|
|
|
}
|