1845 lines
108 KiB
PHP
1845 lines
108 KiB
PHP
<?php
|
|
|
|
namespace app\master\controller;
|
|
|
|
use Exception;
|
|
use think\Controller;
|
|
use think\Db;
|
|
use think\Queue;
|
|
use think\Validate;
|
|
|
|
/**
|
|
* @title 文章接口
|
|
* @description 文章相关操作
|
|
* @group 文章相关
|
|
*/
|
|
class Article extends Controller {
|
|
|
|
//put your code here
|
|
protected $admin_obj = '';
|
|
protected $journal_obj = '';
|
|
protected $article_obj = '';
|
|
protected $article_author_obj = '';
|
|
protected $article_organ_obj = '';
|
|
protected $article_ltai_obj = '';
|
|
protected $article_cite_obj = '';
|
|
protected $author_to_organ_obj = '';
|
|
protected $article_to_topic_obj = '';
|
|
protected $journal_topic_obj = '';
|
|
protected $journal_stage_obj = '';
|
|
protected $journal_special_obj = '';
|
|
protected $country_obj = '';
|
|
protected $subscribe_journal_obj = '';
|
|
protected $subscribe_topic_obj = '';
|
|
protected $base_topic_obj = '';
|
|
protected $subscribe_base_topic_obj = '';
|
|
protected $medicament_obj = '';
|
|
protected $article_to_medicament_obj = '';
|
|
|
|
public function __construct(\think\Request $request = null) {
|
|
parent::__construct($request);
|
|
$this->admin_obj = Db::name('admin');
|
|
$this->journal_obj = Db::name('journal');
|
|
$this->article_obj = Db::name('article');
|
|
$this->article_author_obj = Db::name('article_author');
|
|
$this->article_organ_obj = Db::name('article_organ');
|
|
$this->article_ltai_obj = Db::name('article_ltai');
|
|
$this->article_cite_obj = Db::name('article_cite');
|
|
$this->author_to_organ_obj = Db::name('article_author_to_organ');
|
|
$this->article_to_topic_obj = Db::name('article_to_topic');
|
|
$this->journal_topic_obj = Db::name('journal_topic');
|
|
$this->journal_stage_obj = Db::name('journal_stage');
|
|
$this->journal_special_obj = Db::name('journal_special');
|
|
$this->country_obj = Db::name('country');
|
|
$this->subscribe_journal_obj = Db::name('subscribe_journal');
|
|
$this->subscribe_topic_obj = Db::name('subscribe_topic');
|
|
$this->base_topic_obj = Db::name('base_topic');
|
|
$this->subscribe_base_topic_obj = Db::name('subscribe_base_topic');
|
|
$this->medicament_obj = Db::name('medicament');
|
|
$this->article_to_medicament_obj = Db::name('ArticleToMedicament');
|
|
}
|
|
|
|
/**
|
|
* @title 获取期刊和分期
|
|
* @description 获取期刊和分期
|
|
* @author wangjinleichang
|
|
* @url /master/Article/getJournalAndStage
|
|
* @method POST
|
|
*
|
|
* @param name:editor_id type:int require:1 desc:编辑id
|
|
*
|
|
* @return joutaglist:array#
|
|
*
|
|
*/
|
|
public function getJournalAndStage() {
|
|
$data = $this->request->post();
|
|
$journal_list = $this->journal_obj->where('editor_id', $data['editor_id'])->where('state', 0)->select();
|
|
$frag = [];
|
|
foreach ($journal_list as $v) {
|
|
$v['journal_stage_id'] = $v['journal_id'];
|
|
$cache_list = $this->journal_stage_obj->where('journal_id', $v['journal_id'])->where('state', 0)->select();
|
|
foreach ($cache_list as $k => $vv) {
|
|
$cache_list[$k]['title'] = $vv['stage_year'] . ' Vol.' . $vv['stage_vol'] . ' issue.' . $vv['stage_no'] . $vv['stage_pagename'] . $vv['stage_page'];
|
|
}
|
|
if (count($cache_list) > 0) {
|
|
$v['children'] = $cache_list;
|
|
} else {
|
|
$v['children'] = [];
|
|
}
|
|
$frag[] = $v;
|
|
}
|
|
return json(['code' => 0, 'msg' => 'success', 'data' => ['joutaglist' => $frag]]);
|
|
}
|
|
|
|
/**
|
|
* @title 添加文章基本信息
|
|
* @description 添加文章基本信息
|
|
* @author wangjinleichang
|
|
* @url /master/Article/addArticleBase
|
|
* @method POST
|
|
*
|
|
* @param name:journal_id type:int require:1 desc:期刊id
|
|
* @param name:journal_stage_id type:int require:1 desc:分期id
|
|
* @param name:sort type:int require:1 default:0 desc:权重
|
|
* @param name:title type:string require:1 desc:标题
|
|
*/
|
|
public function addArticleBase() {
|
|
$data = $this->request->post();
|
|
$insert_data['journal_id'] = $data['journal_id'];
|
|
$insert_data['journal_stage_id'] = $data['journal_stage_id'];
|
|
$insert_data['title'] = $data['title'];
|
|
$insert_data['sort'] = $data['sort'];
|
|
$insert_data['ctime'] = time();
|
|
$res = $this->article_obj->insert($insert_data);
|
|
if ($res) {
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => 'system error']);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 删除文章
|
|
* @description 删除文章
|
|
* @author wangjinleichang
|
|
* @url /master/Article/delArticle
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
*/
|
|
public function delArticle() {
|
|
$data = $this->request->post();
|
|
$res = $this->article_obj->where('article_id', $data['article_id'])->update(['state' => 1]);
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
}
|
|
|
|
/**
|
|
* @title 添加文章作者
|
|
* @description 添加文章作者
|
|
* @author wangjinleichang
|
|
* @url /master/Article/addArticleAuthor
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:article_id
|
|
* @param name:author_name type:string require:1 desc:作者名字
|
|
* @param name:author_country type:string require:1 desc:国家
|
|
* @param name:orcid type:string require:0 desc:orcid
|
|
* @param name:is_first type:boolean require:1 default:0 desc:是否第一作者(1yes0no)
|
|
* @param name:is_report type:boolean require:1 default:0 desc:是否通讯作者(1yes0no)
|
|
* @param name:email type:string require:0 desc:邮箱
|
|
* @param name:organs type:string require:1 desc:array
|
|
*
|
|
*/
|
|
public function addArticleAuthor() {
|
|
$data = $this->request->post();
|
|
|
|
$insert_author['article_id'] = $data['article_id'];
|
|
$insert_author['author_name'] = trim($data['author_name']);
|
|
//处理名字
|
|
$ca = explode(' ', $insert_author['author_name']);
|
|
$caf = '';
|
|
$cal = '';
|
|
if (isset($ca[0])) {
|
|
$caf = str_replace('-', '', $ca[0]);
|
|
}
|
|
if (isset($ca[1])) {
|
|
$cal = $ca[1];
|
|
}
|
|
$insert_author['first_name'] = $caf;
|
|
$insert_author['last_name'] = $cal;
|
|
$insert_author['orcid'] = isset($data['orcid']) ? $data['orcid'] : '';
|
|
$insert_author['author_country'] = $data['author_country'];
|
|
$insert_author['is_first'] = $data['is_first'];
|
|
$insert_author['is_report'] = $data['is_report'];
|
|
$insert_author['email'] = intval($data['is_report']) == 1 ? $data['email'] : '';
|
|
Db::startTrans();
|
|
$insert_id = $this->article_author_obj->insertGetId($insert_author);
|
|
$or_res = true;
|
|
if (isset($data['organs']) && is_array($data['organs'])) {
|
|
foreach ($data['organs'] as $k => $v) {
|
|
$cache_ins['article_id'] = $data['article_id'];
|
|
$cache_ins['article_author_id'] = $insert_id;
|
|
$cache_ins['article_organ_id'] = $v;
|
|
$or_res = $this->author_to_organ_obj->insert($cache_ins) ? true : false;
|
|
}
|
|
}
|
|
if ($insert_id && $or_res) {
|
|
Db::commit();
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
} else {
|
|
Db::rollback();
|
|
return json(['code' => 1, 'msg' => 'system error']);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 编辑文章作者
|
|
* @description 编辑文章作者
|
|
* @author wangjinleichang
|
|
* @url /master/Article/editArticleAuthor
|
|
* @method POST
|
|
*
|
|
* @param name:article_author_id type:int require:1 desc:article_id
|
|
* @param name:author_name type:string require:1 desc:作者名字
|
|
* @param name:orcid type:string require:0 desc:orcid
|
|
* @param name:author_country type:string require:1 desc:国家
|
|
* @param name:is_first type:boolean require:1 default:0 desc:是否第一作者(1yes0no)
|
|
* @param name:is_report type:boolean require:1 default:0 desc:是否通讯作者(1yes0no)
|
|
* @param name:email type:string require:0 desc:邮箱
|
|
* @param name:organs type:string require:1 desc:array
|
|
*
|
|
*/
|
|
public function editArticleAuthor() {
|
|
$data = $this->request->post();
|
|
|
|
// $data['article_author_id'] = 21;
|
|
// $data['article_id'] = 38;
|
|
// $data['author_name'] = '作者3';
|
|
// $data['author_country'] = 'Netherlands';
|
|
// $data['is_first'] = 1;
|
|
// $data['is_report'] = 1;
|
|
// $data['email'] = 'xl37@163.com';
|
|
// $data['organs'] = ['1','2','3'];
|
|
|
|
$old_article_author_info = $this->article_author_obj->where('article_author_id', $data['article_author_id'])->find();
|
|
$update_author['author_name'] = trim($data['author_name']);
|
|
//处理名字
|
|
$ca = explode(' ', $update_author['author_name']);
|
|
$caf = '';
|
|
$cal = '';
|
|
if (isset($ca[0])) {
|
|
$caf = str_replace('-', '', $ca[0]);
|
|
}
|
|
if (isset($ca[1])) {
|
|
$cal = $ca[1];
|
|
}
|
|
$update_author['first_name'] = $caf;
|
|
$update_author['last_name'] = $cal;
|
|
$update_author['orcid'] = isset($data['orcid']) ? $data['orcid'] : '';
|
|
$update_author['author_country'] = $data['author_country'];
|
|
$update_author['is_first'] = $data['is_first'];
|
|
$update_author['is_report'] = $data['is_report'];
|
|
$update_author['email'] = intval($data['is_report']) == 1 ? $data['email'] : '';
|
|
$this->article_author_obj->where('article_author_id', $data['article_author_id'])->update($update_author);
|
|
if (is_array($data['organs'])) {
|
|
$has_ids = [];
|
|
foreach ($data['organs'] as $v) {
|
|
$cache_one = $this->author_to_organ_obj->where('article_author_id', $data['article_author_id'])->where('article_organ_id', $v)->where('state', 0)->find();
|
|
if ($cache_one == null) {
|
|
$insert['article_id'] = $old_article_author_info['article_id'];
|
|
$insert['article_author_id'] = $data['article_author_id'];
|
|
$insert['article_organ_id'] = $v;
|
|
$this->author_to_organ_obj->insert($insert);
|
|
}
|
|
$has_ids[] = intval($v);
|
|
}
|
|
$this->author_to_organ_obj->where('article_author_id', $data['article_author_id'])->where('state', 0)->where('article_organ_id', 'not in', $has_ids)->update(['state' => 1]);
|
|
} else {
|
|
$this->author_to_organ_obj->where('article_author_id', $data['article_author_id'])->where('state', 0)->update(['state' => 1]);
|
|
}
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
}
|
|
|
|
/**
|
|
* @title 删除文章作者
|
|
* @description 删除文章作者
|
|
* @author wangjinleichang
|
|
* @url /master/Article/delArticleAuthor
|
|
* @method POST
|
|
*
|
|
* @param name:article_author_id type:int require:1 desc:article_id
|
|
*
|
|
*/
|
|
public function delArticleAuthor() {
|
|
$data = $this->request->post();
|
|
//删除作者和机构的关系
|
|
$this->author_to_organ_obj->where('article_author_id', $data['article_author_id'])->update(['state' => 1]);
|
|
$this->article_author_obj->where('article_author_id', $data['article_author_id'])->update(['state' => 1]);
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章作者和机构
|
|
* @description 获取文章作者和机构
|
|
* @author wangjinleichang
|
|
* @url /master/Article/getArticleAuthor
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:article_id
|
|
*
|
|
* @return authorList:array#
|
|
* @return organList:array#
|
|
*/
|
|
public function getArticleAuthor() {
|
|
$data = $this->request->post();
|
|
$author_list = $this->article_author_obj->where('article_id', $data['article_id'])->where('state', 0)->select();
|
|
foreach ($author_list as $k => $v) {
|
|
$cache_to = $this->author_to_organ_obj
|
|
->field('j_article_author_to_organ.*,j_article_organ.organ_name')
|
|
->join('j_article_organ', 'j_article_organ.article_organ_id = j_article_author_to_organ.article_organ_id')
|
|
->where('j_article_author_to_organ.article_author_id', $v['article_author_id'])
|
|
->where('j_article_author_to_organ.state', 0)
|
|
->select();
|
|
$cache_frag = [];
|
|
foreach ($cache_to as $vv) {
|
|
$cache_frag[] = $vv;
|
|
}
|
|
$author_list[$k]['organs'] = $cache_frag;
|
|
}
|
|
$organ_list = $this->article_organ_obj->where('article_id', $data['article_id'])->where('state', 0)->select();
|
|
return json(['code' => 0, 'msg' => 'success', 'data' => ['authorList' => $author_list, 'organList' => $organ_list]]);
|
|
}
|
|
|
|
/**
|
|
* @title 添加文章作者机构
|
|
* @description 添加文章作者机构
|
|
* @author wangjinleichang
|
|
* @url /master/Article/addArticleOrgan
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:article_id
|
|
* @param name:organ_name type:string require:1 desc:机构名字
|
|
*/
|
|
public function addArticleOrgan() {
|
|
$data = $this->request->post();
|
|
$insert_data['article_id'] = $data['article_id'];
|
|
$insert_data['organ_name'] = $data['organ_name'];
|
|
$res = $this->article_organ_obj->insert($insert_data);
|
|
if ($res) {
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => 'system error']);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 编辑文章作者机构
|
|
* @description 编辑文章作者机构
|
|
* @author wangjinleichang
|
|
* @url /master/Article/editArticleOrgan
|
|
* @method POST
|
|
*
|
|
* @param name:article_organ_id type:int require:1 desc:article_organ_id
|
|
* @param name:organ_name type:string require:1 desc:机构名字
|
|
*/
|
|
public function editArticleOrgan() {
|
|
$data = $this->request->post();
|
|
$this->article_organ_obj->where('article_organ_id', $data['article_organ_id'])->update(['organ_name' => $data['organ_name']]);
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
}
|
|
|
|
/**
|
|
* @title 删除文章作者机构
|
|
* @description 删除文章作者机构
|
|
* @author wangjinleichang
|
|
* @url /master/Article/delArticleOrgan
|
|
* @method POST
|
|
*
|
|
* @param name:article_organ_id type:int require:1 desc:article_organ_id
|
|
*/
|
|
public function delArticleOrgan() {
|
|
$data = $this->request->post();
|
|
//删除作者和机构的关系
|
|
$this->author_to_organ_obj->where('article_organ_id', $data['article_organ_id'])->update(['state' => 1]);
|
|
$this->article_organ_obj->where('article_organ_id', $data['article_organ_id'])->update(['state' => 1]);
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
}
|
|
|
|
/**
|
|
* 添加文章通过投稿系统
|
|
*/
|
|
public function addArticleForSubmission(){
|
|
$data = $this->request->post();
|
|
$rule = new Validate([
|
|
'title' => 'require',
|
|
'journal_stage_id' => 'require',
|
|
'issn' => 'require',
|
|
'type' => 'require',
|
|
'abbr' => 'require',
|
|
'doi' => 'require',
|
|
'abstract' => 'require',
|
|
'file_pdf' => 'require',
|
|
'pub_date' => 'require',
|
|
'keywords' => 'require',
|
|
'npp'=>'require'
|
|
]);
|
|
if (!$rule->check($data)) {
|
|
return jsonError($rule->getError());
|
|
}
|
|
|
|
$journal_info = $this->journal_obj->where('issn',$data['issn'])->find();
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'articlePDF'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'articlePDF'.DS.date('Ymd'));
|
|
}
|
|
$file_name = substr($data['file_pdf'],strripos($data['file_pdf'],'/')+1);
|
|
$co = @copy("http://api.tmrjournals.com/public/".$data['file_pdf'],ROOT_PATH.'public'.DS.'articlePDF'.DS.date('Ymd').DS.$file_name);
|
|
if($co!=1){
|
|
return jsonError('copy error!');
|
|
}
|
|
//处理基本信息
|
|
$insert['title'] = trim($data['title']);
|
|
$insert['journal_id'] = $journal_info['journal_id'];
|
|
$insert['journal_stage_id'] = $data['journal_stage_id'];
|
|
$insert['type'] = $data['type'];
|
|
if(isset($data['icon'])&&$data['icon']!=''){
|
|
$cfile_name = substr($data['icon'],strripos($data['icon'],'/')+1);
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'articleicon'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'articleicon'.DS.date('Ymd'));
|
|
}
|
|
$co = @copy("http://api.tmrjournals.com/public/articleicon/".$data['icon'],ROOT_PATH.'public'.DS.'articleicon'.DS.date('Ymd').DS.$cfile_name);
|
|
$insert['icon'] = date('Ymd').DS.$cfile_name;
|
|
}
|
|
|
|
if(isset($data['file_sub'])&&$data['file_sub']!=''){
|
|
$cfile_name = substr($data['file_sub'],strripos($data['file_sub'],'/')+1);
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'articleSUB'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'articleSUB'.DS.date('Ymd'));
|
|
}
|
|
$co = @copy("http://api.tmrjournals.com/public/articleSUB/".$data['file_sub'],ROOT_PATH.'public'.DS.'articleSUB'.DS.date('Ymd').DS.$cfile_name);
|
|
$insert['file_sub'] = date('Ymd').DS.$cfile_name;
|
|
}
|
|
if(isset($data['file_sub2'])&&$data['file_sub2']!=''){
|
|
$cfile_name = substr($data['file_sub2'],strripos($data['file_sub2'],'/')+1);
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'articleSUB2'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'articleSUB2'.DS.date('Ymd'));
|
|
}
|
|
$co = @copy("http://api.tmrjournals.com/public/articleSUB2/".$data['file_sub2'],ROOT_PATH.'public'.DS.'articleSUB2'.DS.date('Ymd').DS.$cfile_name);
|
|
$insert['file_sub2'] = date('Ymd').DS.$cfile_name;
|
|
}
|
|
if(isset($data['file_cdf'])&&$data['file_cdf']!=''){
|
|
$cfile_name = substr($data['file_cdf'],strripos($data['file_cdf'],'/')+1);
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'articleCDF'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'articleCDF'.DS.date('Ymd'));
|
|
}
|
|
$co = @copy("http://api.tmrjournals.com/public/articleCDF/".$data['file_cdf'],ROOT_PATH.'public'.DS.'articleCDF'.DS.date('Ymd').DS.$cfile_name);
|
|
$insert['file_cdf'] = date('Ymd').DS.$cfile_name;
|
|
}
|
|
if(isset($data['endnote'])&&$data['endnote']!=''){
|
|
$cfile_name = substr($data['endnote'],strripos($data['endnote'],'/')+1);
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'endNote'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'endNote'.DS.date('Ymd'));
|
|
}
|
|
$co = @copy("http://api.tmrjournals.com/public/endNote/".$data['endnote'],ROOT_PATH.'public'.DS.'endNote'.DS.date('Ymd').DS.$cfile_name);
|
|
$insert['endnote'] = date('Ymd').DS.$cfile_name;
|
|
}
|
|
if(isset($data['bibtex'])&&$data['bibtex']!=''){
|
|
$cfile_name = substr($data['bibtex'],strripos($data['bibtex'],'/')+1);
|
|
if(!is_dir(ROOT_PATH.'public'.DS.'bibTex'.DS.date('Ymd'))){
|
|
mkdir(ROOT_PATH.'public'.DS.'bibTex'.DS.date('Ymd'));
|
|
}
|
|
$co = @copy("http://api.tmrjournals.com/public/bibTex/".$data['bibtex'],ROOT_PATH.'public'.DS.'bibTex'.DS.date('Ymd').DS.$cfile_name);
|
|
$insert['bibtex'] = date('Ymd').DS.$cfile_name;
|
|
}
|
|
$insert['doi'] = '10.53388/'.$data['doi'];
|
|
$insert['abstract'] = $data['abstract'];
|
|
$insert['pub_date'] = $data['pub_date'];
|
|
$insert['abbr'] = $data['abbr'];
|
|
$insert['keywords'] = $data['keywords'];
|
|
$insert['npp'] = $data['npp'];
|
|
$insert['file_pdf'] = date('Ymd').DS.$file_name;
|
|
$insert['is_public'] = 1;
|
|
$insert['ctime'] = time();
|
|
Db::startTrans();
|
|
$aid = $this->article_obj->insertGetId($insert);
|
|
|
|
//处理作者
|
|
try{
|
|
$authors = object_to_array(json_decode($data['authors']));
|
|
$organs = object_to_array(json_decode($data['organs']));
|
|
$organ_res = true;
|
|
foreach($organs as $v){
|
|
$ca_insert['article_id'] = $aid;
|
|
$ca_insert['organ_name'] = $v['organ_name'];
|
|
$organ_res = $this->article_organ_obj->insert($ca_insert);
|
|
}
|
|
$author_res = true;
|
|
$ato_res = true;
|
|
$ca_au_id = true;
|
|
foreach($authors as $v){
|
|
$insert_author['article_id'] = $aid;
|
|
$insert_author['author_name'] = $v['first_name'].' '.$v['last_name'];
|
|
$insert_author['first_name'] = $v['first_name'];
|
|
$insert_author['last_name'] = $v['last_name'];
|
|
$insert_author['author_country'] = $v['author_country'];
|
|
$insert_author['is_first'] = $v['is_first'];
|
|
$insert_author['is_report'] = $v['is_report'];
|
|
$insert_author['email'] = $v['email'];
|
|
$ca_au_id = $this->article_author_obj->insertGetId($insert_author);
|
|
$cache_organs = $v['organs'];
|
|
foreach($cache_organs as $val){
|
|
$c_organ = $this->article_organ_obj->where('article_id',$aid)->where('organ_name',$val['organ_name'])->find();
|
|
if($c_organ==null){
|
|
return jsonError('organ error!');
|
|
}
|
|
$insert_orm['article_id'] = $aid;
|
|
$insert_orm['article_author_id'] = $ca_au_id;
|
|
$insert_orm['article_organ_id'] = $c_organ['article_organ_id'];
|
|
$ato_res = $this->author_to_organ_obj->insert($insert_orm);
|
|
}
|
|
|
|
}}catch(Exception $e){
|
|
|
|
Db::rollback();
|
|
return jsonError($e->getMessage());
|
|
}
|
|
|
|
if($aid&&$organ_res&&$author_res&&$ato_res&&$ca_au_id){
|
|
Db::commit();
|
|
return jsonSuccess([]);
|
|
} else {
|
|
Db::rollback();
|
|
return jsonError('system error');
|
|
}
|
|
|
|
}
|
|
|
|
/**
|
|
* 获取online文章列表
|
|
*/
|
|
public function getOnlineArticleForSubmit(){
|
|
$data = $this->request->post();
|
|
$rule = new Validate([
|
|
'issn'=>'require'
|
|
]);
|
|
if(!$rule->check($data)){
|
|
return jsonError($rule->getError());
|
|
}
|
|
$journal_info = $this->journal_obj->where('issn',$data['issn'])->find();
|
|
$stages = $this->journal_stage_obj->where('is_publish',0)->where('journal_id',$journal_info['journal_id'])->where('state',0)->select();
|
|
foreach($stages as $k => $v){
|
|
$cache = $this->article_obj->where('journal_stage_id',$v['journal_stage_id'])->where('state',0)->select();
|
|
$stages[$k]['articles'] = $cache;
|
|
}
|
|
$re['stages'] = $stages;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
|
|
// public function authortest(){
|
|
// $str = "[{\"art_aut_id\":6474,\"article_id\":2065,\"firstname\":\"Tadele\",\"lastname\":\"Yadesa\",\"orcid\":\"https:\\/\\/orcid.org\\/ 0000-0001-5151-2610\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Pharmacy\",\"email\":\"maatiikoo4@gmail.com\",\"author_title\":\"Ph.D.\",\"country\":\"Uganda\",\"address\":\"Mbarara University of Science and Technology P.O.BOX 1410\",\"is_super\":1,\"is_report\":1,\"state\":0},{\"art_aut_id\":6475,\"article_id\":2065,\"firstname\":\"Oliver\",\"lastname\":\"Kushemererwa\",\"orcid\":\"\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Pharmacy\",\"email\":\"Kusholiver@gmail.com\",\"author_title\":\"Others\",\"country\":\"Uganda\",\"address\":\"\",\"is_super\":0,\"is_report\":0,\"state\":0},{\"art_aut_id\":6476,\"article_id\":2065,\"firstname\":\"Joshua\",\"lastname\":\"Kiptoo\",\"orcid\":\"\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Pharmacy\",\"email\":\"KIPTOOKWALIA@gmail.com\",\"author_title\":\"Others\",\"country\":\"Uganda\",\"address\":\"\",\"is_super\":0,\"is_report\":0,\"state\":0},{\"art_aut_id\":6477,\"article_id\":2065,\"firstname\":\"John\",\"lastname\":\"Isiiko\",\"orcid\":\"\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Pharmacy\",\"email\":\"isiikojohn@gmail.com\",\"author_title\":\"Others\",\"country\":\"Uganda\",\"address\":\"\",\"is_super\":0,\"is_report\":0,\"state\":0},{\"art_aut_id\":6478,\"article_id\":2065,\"firstname\":\"Bonny\",\"lastname\":\"Luzze\",\"orcid\":\"\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Pharmacy\",\"email\":\"tottojrlz@gmail.com\",\"author_title\":\"Others\",\"country\":\"Uganda\",\"address\":\"\",\"is_super\":0,\"is_report\":0,\"state\":0},{\"art_aut_id\":6479,\"article_id\":2065,\"firstname\":\"Jacinta\",\"lastname\":\"Ojia\",\"orcid\":\"\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Internal medicine\",\"email\":\"ambark21@yahoo.com\",\"author_title\":\"Others\",\"country\":\"Uganda\",\"address\":\"\",\"is_super\":0,\"is_report\":0,\"state\":0},{\"art_aut_id\":6480,\"article_id\":2065,\"firstname\":\"Mohamed\",\"lastname\":\"Abdirahman\",\"orcid\":\"\",\"company\":\"Mbarara University of Science and Technology\",\"department\":\"Internal medicine\",\"email\":\"dr.mma001838@gmail.com\",\"author_title\":\"Others\",\"country\":\"Uganda\",\"address\":\"\",\"is_super\":1,\"is_report\":0,\"state\":0}]";
|
|
// $authors = object_to_array(json_decode($str));
|
|
// $o = [];
|
|
// $orgs = [];
|
|
// foreach($authors as $k => $v){
|
|
// if(in_array($v['company'],$orgs)){
|
|
// continue;
|
|
// }
|
|
// $orgs[] = $v['company'];
|
|
// }
|
|
// foreach($orgs as $v){
|
|
// $insert['article_id'] = 8888;
|
|
// $insert['organ_name'] = $v;
|
|
// $ca_id = $this->article_organ_obj->insertGetId($insert);
|
|
// $o[$v] = $ca_id;
|
|
// }
|
|
// foreach($authors as $v){
|
|
// $insert_author['article_id'] = 8888;
|
|
// $insert_author['author_name'] = $v['firstname'].' '.$v['lastname'];
|
|
// $insert_author['first_name'] = $v['firstname'];
|
|
// $insert_author['last_name'] = $v['lastname'];
|
|
// $insert_author['author_country'] = $v['country'];
|
|
// $insert_author['is_first'] = $v['is_super'];
|
|
// $insert_author['is_report'] = $v['is_report'];
|
|
// $insert_author['email'] = $v['email'];
|
|
// $ca_au_id = $this->article_author_obj->insertGetId($insert_author);
|
|
// $insert_orm['article_id'] = 8888;
|
|
// $insert_orm['article_author_id'] = $ca_au_id;
|
|
// $insert_orm['article_organ_id'] = $o[$v['company']];
|
|
// $this->author_to_organ_obj->insert($insert_orm);
|
|
// }
|
|
// echo 'ok';
|
|
// }
|
|
|
|
|
|
|
|
|
|
/**
|
|
* @title 获取文章基本信息
|
|
* @description 获取文章基本信息
|
|
* @author wangjinleichang
|
|
* @url /master/Article/getArticleBase
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
*
|
|
* @return journal:期刊信息#
|
|
* @return articleInfo:文章详情@
|
|
* @articleInfo icon:图片
|
|
* @articleInfo tradition_tag:封皮标签
|
|
* @articleInfo tradition:封皮简介
|
|
* @articleInfo doi:doi
|
|
* @articleInfo abstract:简介
|
|
* @articleInfo keywords:关键字
|
|
* @articleInfo fund:fund
|
|
* @articleInfo file_html:html文件
|
|
* @articleInfo sort:权重
|
|
* @articleInfo pub_date:发表日期
|
|
*
|
|
* @return files:文件列表#
|
|
*/
|
|
public function getArticleBase() {
|
|
$data = $this->request->post();
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
|
|
$ltais = $this->article_ltai_obj->where('article_id', $article_info['article_id'])->where('state', 0)->column('content');
|
|
$article_info['ltai'] = implode(',', $ltais);
|
|
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
|
|
$list = scandir(ROOT_PATH . 'public/articleHTML/' . trim($journal_info['sx']));
|
|
$frag = [];
|
|
foreach ($list as $k => $v) {
|
|
if ($k > 1) {
|
|
$frag[] = ['val' => $v];
|
|
}
|
|
}
|
|
|
|
$re['journal'] = $journal_info;
|
|
$re['articleInfo'] = $article_info;
|
|
$re['files'] = $frag;
|
|
return jsonSuccess($re);
|
|
// return json(['code'=>0,'msg'=>'success','data'=>$article_info]);
|
|
}
|
|
|
|
public function getHtmlFiles() {
|
|
$data = $this->request->post();
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
|
|
$list = scandir(ROOT_PATH . 'public/articleHTML/' . $journal_info['sx']);
|
|
$frag = [];
|
|
foreach ($list as $k => $v) {
|
|
if ($k > 1) {
|
|
$frag[] = $v;
|
|
}
|
|
}
|
|
return jsonSuccess($data);
|
|
// $list = scandir(ROOT_PATH.'public/articleHTML/TMR');
|
|
// echo '<pre>';
|
|
// var_dump($list);
|
|
// echo '</pre>';
|
|
// die;
|
|
}
|
|
|
|
/**
|
|
* @title 编辑文章基本信息
|
|
* @description 编辑文章基本信息
|
|
* @author wangjinleichang
|
|
* @url /master/Article/editArticleBase
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
* @param name:title type:string require:1 desc:标题
|
|
* @param name:subtitle type:string require:0 desc:副标题
|
|
* @param name:rotation type:string require:0 desc:轮播图
|
|
* @param name:icon type:string require:1 desc:图片
|
|
* @param name:tradition_tag type:string require:1 desc:封皮标签
|
|
* @param name:tradition type:string require:1 desc:封皮简介
|
|
* @param name:mhoo type:string require:1 desc:Medical history of objective
|
|
* @param name:journal_stage_id type:int require:1 desc:期刊分期id
|
|
* @param name:journal_special_id type:int require:1 desc:客座期刊id
|
|
* @param name:doi type:string require:1 desc:doi
|
|
* @param name:abstract type:string require:1 desc:简介
|
|
* @param name:keywords type:string require:1 desc:关键字
|
|
* @param name:ltai type:string require:0 desc:标题斜体(demo1,demo2)
|
|
* @param name:npp type:strng require:1 desc:文章页码
|
|
* @param name:is_public type:int require:1 desc:0不显示1显示
|
|
* @param name:type type:string require:1 desc:类型
|
|
* @param name:cited type:int require:1 desc:引用数
|
|
* @param name:abbr type:string require:0 desc:作者简称
|
|
* @param name:sort type:int require:1 desc:权重
|
|
* @param name:other_state type:int require:1 desc:附加状态0默认1Being questioned被质疑2Withdrawal被撤回
|
|
* @param name:file_html type:string require:0 desc:html文件
|
|
* @param name:fund type:string require:1 desc:fund
|
|
* @param name:pub_date type:string require:1 desc:发表日期
|
|
*
|
|
*/
|
|
public function editArticleBase() {
|
|
$data = $this->request->post();
|
|
if (isset($data['ltai'])) {
|
|
$this->editArticleLtai($data['ltai'], $data['article_id']);
|
|
}
|
|
$updata['icon'] = $data['icon'];
|
|
$updata['title'] = trim($data['title']);
|
|
$updata['subtitle'] = isset($data['subtitle'])?trim($data['subtitle']):'';
|
|
$updata['rotation'] = isset($data['rotation'])?$data['rotation']:'';
|
|
$updata['journal_stage_id'] = $data['journal_stage_id'];
|
|
$updata['journal_special_id'] = $data['journal_special_id'];
|
|
$updata['tradition_tag'] = $data['tradition_tag'];
|
|
$updata['tradition'] = $data['tradition'];
|
|
$updata['mhoo'] = $data['mhoo'];
|
|
$updata['doi'] = $data['doi'];
|
|
$updata['abstract'] = $data['abstract'];
|
|
$updata['keywords'] = $data['keywords'];
|
|
// $updata['abs_num'] = $data['abs_num'];
|
|
// $updata['pdf_num'] = $data['pdf_num'];
|
|
// $updata['html_num'] = $data['html_num'];
|
|
$updata['npp'] = $data['npp'];
|
|
$updata['is_public'] = $data['is_public'];
|
|
$updata['type'] = $data['type'];
|
|
$updata['cited'] = $data['cited'];
|
|
$updata['abbr'] = $data['abbr'];
|
|
$updata['fund'] = $data['fund'];
|
|
$updata['other_state'] = $data['other_state'];
|
|
$updata['file_html'] = $data['file_html'];
|
|
$updata['sort'] = $data['sort'];
|
|
$updata['pub_date'] = $data['pub_date'];
|
|
$res = $this->article_obj->where('article_id', $data['article_id'])->update($updata);
|
|
// if($res){
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
// }else{
|
|
// return json(['code'=>1,'msg'=>'system error']);
|
|
// }
|
|
}
|
|
|
|
private function editArticleLtai($ltai, $article_id) {
|
|
$list = explode(',', $ltai);
|
|
$has = $this->article_ltai_obj->where('article_id', $article_id)->where('state', 0)->select();
|
|
foreach ($has as $val) {
|
|
if (in_array($val['content'], $list)) {
|
|
foreach ($list as $k => $v) {
|
|
if ($val['content'] == $v) {
|
|
unset($list[$k]);
|
|
}
|
|
}
|
|
} else {
|
|
//删除
|
|
$this->article_ltai_obj->where('article_ltai_id', $val['article_ltai_id'])->update(['state' => 1]);
|
|
}
|
|
}
|
|
//增加
|
|
foreach ($list as $value) {
|
|
$cache['article_id'] = $article_id;
|
|
$cache['content'] = $value;
|
|
$this->article_ltai_obj->insert($cache);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 编辑文章文件信息
|
|
* @description 编辑文章文件信息
|
|
* @author wangjinleichang
|
|
* @url /master/Article/editArticleFile
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
* @param name:filetype type:string require:1 desc:文件类型(PDF/HTML/SUB/SUB2/endNote/bibTex/CDF)
|
|
* @param name:fileURL type:string require:1 desc:文件地址
|
|
*
|
|
*/
|
|
public function editArticleFile() {
|
|
$data = $this->request->post();
|
|
if ($data['filetype'] == 'PDF') {
|
|
$updata['file_pdf'] = $data['fileURL'];
|
|
} elseif ($data['filetype'] == 'HTML') {
|
|
$updata['file_html'] = $data['fileURL'];
|
|
} elseif ($data['filetype'] == 'SUB') {
|
|
$updata['file_sub'] = $data['fileURL'];
|
|
} elseif ($data['filetype'] == 'SUB2') {
|
|
$updata['file_sub2'] = $data['fileURL'];
|
|
} elseif ($data['filetype'] == 'endNote') {
|
|
$updata['endnote'] = $data['fileURL'];
|
|
} elseif ($data['filetype'] == 'bibTex') {
|
|
$updata['bibtex'] = $data['fileURL'];
|
|
}elseif($data['filetype'] == 'CDF'){
|
|
$updata['file_cdf'] = $data['fileURL'];
|
|
}
|
|
$this->article_obj->where('article_id', $data['article_id'])->update($updata);
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章列表
|
|
* @description 获取文章列表
|
|
* @author wangjinleichang
|
|
* @url /master/Article/getArticleList
|
|
* @method POST
|
|
*
|
|
* @param name:journal_id type:int default:0 require:1 desc:主键
|
|
* @param name:journal_stage_id type:int default:0 require:1 desc:主键
|
|
* @param name:editor_id type:int require:1 desc:编辑id
|
|
* @param name:seach type:string require:0 desc:关键词
|
|
* @param name:pageIndex type:int require:1 desc:当前页码数
|
|
* @param name:pageSize type:int require:1 desc:单页数据条数
|
|
*
|
|
* @return count:总数据数
|
|
* @return articleList:array#
|
|
*/
|
|
public function getArticleList() {
|
|
$data = $this->request->post();
|
|
$where['j_article.state'] = 0;
|
|
if (intval($data['journal_id']) !== 0) {
|
|
$where['j_article.journal_id'] = $data['journal_id'];
|
|
} else {
|
|
$journals = [];
|
|
if(isset($data['editor_id'])&&$data['editor_id']!=''){
|
|
$journals = $this->journal_obj->where('editor_id', $data['editor_id'])->column('journal_id');
|
|
}else{
|
|
$journals = $this->journal_obj->where('state',0)->column('journal_id');
|
|
}
|
|
$where['j_article.journal_id'] = ['in', $journals];
|
|
}
|
|
if (intval($data['journal_stage_id']) !== 0) {
|
|
$where['j_article.journal_stage_id'] = $data['journal_stage_id'];
|
|
}
|
|
if (isset($data['seach']) && $data['seach'] != '') {
|
|
$where['j_article.title'] = ['like', '%' . $data['seach'] . '%'];
|
|
}
|
|
$limit_start = ($data['pageIndex'] - 1) * $data['pageSize'];
|
|
$article_list = $this->article_obj->field('j_article.*,j_journal_stage.*,j_journal.title journal_title')->join(array(['j_journal_stage', 'j_article.journal_stage_id = j_journal_stage.journal_stage_id', 'LEFT'], ['j_journal', 'j_journal.journal_id=j_article.journal_id', 'LEFT']))->where($where)->order(['j_article.sort desc', 'j_article.article_id'])->limit($limit_start, $data['pageSize'])->select();
|
|
foreach ($article_list as $k => $v) {
|
|
$caches = $this->article_ltai_obj->where('article_id', $v['article_id'])->where('state', 0)->column('content');
|
|
$cache_title = $v['title'];
|
|
foreach ($caches as $val) {
|
|
$cache_title = str_replace($val, '<i>' . $val . '</i>', $cache_title);
|
|
}
|
|
$article_list[$k]['title'] = $cache_title;
|
|
//获取药剂信息
|
|
$atm = $this->article_to_medicament_obj->where('article_id',$v['article_id'])->where('atm_state',0)->find();
|
|
if($atm){
|
|
$med_info = $this->medicament_obj->where('med_id',$atm['med_id'])->where('med_state',0)->find();
|
|
$article_list[$k]['med_title'] = $med_info['med_title'];
|
|
$article_list[$k]['med_ename'] = $med_info['med_ename'];
|
|
}else{
|
|
$article_list[$k]['med_title'] = '';
|
|
$article_list[$k]['med_ename'] = '';
|
|
}
|
|
}
|
|
$count = $this->article_obj->where($where)->count();
|
|
return json(['code' => 0, 'msg' => 'success', 'data' => ['count' => $count, 'articleList' => $article_list]]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章对应期刊话题
|
|
* @description 获取文章对应期刊话题
|
|
* @author wangjinlei
|
|
* @url /master/Article/getTopicByArticle
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:期刊id
|
|
*
|
|
* @return topics:array#
|
|
* @return nowtopic:array#
|
|
*/
|
|
public function getTopicByArticle() {
|
|
$data = $this->request->post();
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
$topic_res = $this->journal_topic_obj->where('journal_id', $article_info['journal_id'])->where('state', 0)->select();
|
|
$frag = [];
|
|
foreach ($topic_res as $v) {
|
|
if ($v['is_final'] == 1) {
|
|
$frag[] = $v;
|
|
}
|
|
}
|
|
foreach ($frag as $k => $val) {
|
|
$frag[$k]['tname'] = $this->getTname($val, $topic_res);
|
|
}
|
|
//获取初始话题
|
|
$now_list = $this->article_to_topic_obj->where('article_id', $data['article_id'])->where('state', 0)->select();
|
|
return json(['code' => 0, 'msg' => 'success', 'data' => ['nowtopic' => $now_list, 'topics' => $frag]]);
|
|
}
|
|
|
|
private function getTname($now, $arr) {
|
|
if ($now['parent_id'] == 0) {
|
|
return $now['title'];
|
|
} else {
|
|
$frag = '>' . $now['title'];
|
|
foreach ($arr as $v) {
|
|
if ($v['journal_topic_id'] == $now['parent_id']) {
|
|
$frag = $this->getTname($v, $arr) . $frag;
|
|
}
|
|
}
|
|
return $frag;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 增加文章话题
|
|
* @description 增加文章话题
|
|
* @author wangjinlei
|
|
* @url /master/Article/addTopicByArticle
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:期刊id
|
|
* @param name:topic_id type:int require:1 desc:话题id
|
|
*
|
|
*/
|
|
public function addTopicByArticle() {
|
|
$data = $this->request->post();
|
|
$insert['article_id'] = $data['article_id'];
|
|
$insert['topic_id'] = $data['topic_id'];
|
|
$res = $this->article_to_topic_obj->insert($insert);
|
|
$this->msg_subscript_topic($data['topic_id'], $data['article_id']);
|
|
$this->msg_subscribe_base_topic($data['topic_id'], $data['article_id']);
|
|
if ($res) {
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => 'system error']);
|
|
}
|
|
}
|
|
|
|
|
|
private function msg_subscribe_base_topic($topic_id,$article_id){
|
|
$article_info = $this->article_obj->where('article_id',$article_id)->find();
|
|
$topic_info = $this->journal_topic_obj->where('journal_topic_id',$topic_id)->find();
|
|
$base_topic_info = $this->base_topic_obj->where('title',$topic_info['title'])->find();
|
|
$journal_info = $this->journal_obj->where('journal_id',$article_info['journal_id'])->find();
|
|
if($base_topic_info==null){
|
|
return ;
|
|
}
|
|
$list = $this->subscribe_base_topic_obj->where('base_topic_id',$base_topic_info['base_topic_id'])->where('state',0)->select();
|
|
|
|
$title = 'These new articles included in TMRDE database are available online.';
|
|
$tt = 'Dear Researcher,<br>';
|
|
$tt .= 'It is our great honor to present you the articles included in TMRDE.The following new articles have just been included.<br>';
|
|
$tt .= '<a href="https://www.tmrjournals.com/article.html?J_num='.$article_info['journal_id'].'&a_id='.$article_id.'">'.$article_info['title'].'</a><br>';
|
|
foreach ($list as $v){
|
|
$tt1='';
|
|
$tt1 .= $tt;
|
|
$tt1 .= '<a href="http://journalapi.tmrjournals.com/public/index.php/api/Journal/UnsubscribeBaseTopic/snum/' . $v['subscribe_base_topic_id'] . '">Unsubscribe</a><br><br>';
|
|
$tt1 .= 'Email:'.$journal_info['email'].'<br>';
|
|
$tt1 .= 'Website:'.$journal_info['website'].'<br><br>';
|
|
$tt1 .= 'TMR Publishing Group Ltd.<br>';
|
|
$tt1 .= '11 Cockle Bay Rd, Cockle Bay, Auckland, New Zealand<br>';
|
|
$tt1 .= 'Tel: +64 02108293806.';
|
|
$maidata['email'] = $v['email'];
|
|
$maidata['title'] = $title;
|
|
$maidata['content'] = $tt1;
|
|
$maidata['tmail'] = 'publicrelations@tmrjournals.com';
|
|
$maidata['tpassword'] = 'pRWU999999';
|
|
Queue::push('app\api\job\mail@fire', $maidata, "mail");
|
|
}
|
|
|
|
}
|
|
|
|
private function msg_subscript_topic($topic_id, $article_id) {
|
|
$article_info = $this->article_obj->where('article_id', $article_id)->find();
|
|
$stage_info = $this->journal_stage_obj->where('journal_stage_id', $article_info['journal_stage_id'])->find();
|
|
$topic_info = $this->journal_topic_obj->where('journal_topic_id', $topic_id)->find();
|
|
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
|
|
$list = [];
|
|
if ($topic_info['level'] == 2) {
|
|
$list = $this->subscribe_topic_obj->where('topic_id', $topic_id)->where('state', 0)->select();
|
|
} else {
|
|
$list = $this->subscribe_topic_obj->where('topic_id', $topic_info['parent_id'])->where('state', 0)->select();
|
|
}
|
|
|
|
//组成文章信息
|
|
$tt1 = '<div style="background-color: #ededed;margin: 0;">
|
|
<div class="con_content" style="font-family: Arial;
|
|
width: 600px;
|
|
margin: 0 auto;
|
|
background-color: #fff;
|
|
padding: 30px 40px;
|
|
color: #1B3051;
|
|
font-size: 14px;
|
|
line-height: 20px;">
|
|
<div>
|
|
<img style="width: 80px;" src="data:image/png;base64,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UmVhZHlxyWU8AAADI2lUWHRYTUw6Y29tLmFkb2JlLnhtcAAAAAAAPD94cGFja2V0IGJlZ2luPSLvu78iIGlkPSJXNU0wTXBDZWhpSHpyZVN6TlRjemtjOWQiPz4gPHg6eG1wbWV0YSB4bWxuczp4PSJhZG9iZTpuczptZXRhLyIgeDp4bXB0az0iQWRvYmUgWE1QIENvcmUgNS42LWMxNDggNzkuMTY0MDM2LCAyMDE5LzA4LzEzLTAxOjA2OjU3ICAgICAgICAiPiA8cmRmOlJERiB4bWxuczpyZGY9Imh0dHA6Ly93d3cudzMub3JnLzE5OTkvMDIvMjItcmRmLXN5bnRheC1ucyMiPiA8cmRmOkRlc2NyaXB0aW9uIHJkZjphYm91dD0iIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtbG5zOnhtcE1NPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvbW0vIiB4bWxuczpzdFJlZj0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL3NUeXBlL1Jlc291cmNlUmVmIyIgeG1wOkNyZWF0b3JUb29sPSJBZG9iZSBQaG90b3Nob3AgMjEuMCAoV2luZG93cykiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6MDNBODgyQzU3MUM4MTFFQkE4MjRBNTM0MTVGNUZGNzMiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6MDNBODgyQzY3MUM4MTFFQkE4MjRBNTM0MTVGNUZGNzMiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDowM0E4ODJDMzcxQzgxMUVCQTgyNEE1MzQxNUY1RkY3MyIgc3RSZWY6ZG9jdW1lbnRJRD0ieG1wLmRpZDowM0E4ODJDNDcxQzgxMUVCQTgyNEE1MzQxNUY1RkY3MyIvPiA8L3JkZjpEZXNjcmlwdGlvbj4gPC9yZGY6UkRGPiA8L3g6eG1wbWV0YT4gPD94cGFja2V0IGVuZD0iciI/PpvMdRIAAEVaSURBVHja7F0HgFxF+f9mXtt2JVfSAwmkUDVIMwYFAghKr6IgIF1QUAQLqKAiAupfgvReLFQBQXonFCGUACmQ3sv13dv2ysz/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" alt="">
|
|
</div><br><br>';
|
|
$tt1 .= $journal_info['title'] . '<br><br>';
|
|
$tt1 .= 'The following new articles have just been published in Topic "' . $topic_info['title'] . '" of ' . $journal_info['title'] . '<br><br>';
|
|
$tt1 .= $article_info['type'] . '<br>';
|
|
$tt1 .= '<a href="https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $article_info['article_id'] . '">' . $article_info['title'] . '</a><br>';
|
|
$tt1 .= $this->getAuthor($article_info) . '<br>';
|
|
$tt1 .= $journal_info['title'] . ' ' . $stage_info['stage_year'] . ' ' . $stage_info['stage_vol'] . "(" . $stage_info['stage_no'] . "). https://doi.org/" . $article_info['doi'] . '<br>';
|
|
$tt1 .= '<a href="https://www.tmrjournals.com/public/articlePDF/' . $article_info['file_pdf'] . '">Download pdf</a><br><br><br>';
|
|
|
|
$tt2 = 'Email: ' . $journal_info['email'] . '<br>';
|
|
$tt2 .= 'Website: https://www.tmrjournals.com/' . $journal_info['usx'] . '<br>';
|
|
$tt2 .= 'TMR Publishing Group Ltd.<br>';
|
|
$tt2 .= '11 Cockle Bay Rd, Cockle Bay, Auckland, New Zealand<br>';
|
|
$tt2 .= 'Tel: +64 02108293806.';
|
|
$tt2 .= '</div>
|
|
</div>';
|
|
|
|
foreach ($list as $v) {
|
|
$cache = $tt1 . '<a href="http://journalapi.tmrjournals.com/public/index.php/api/Journal/UnsubscribeTopic/snum/' . $v['subscribe_topic_id'] . '">Unsubscribe</a><br><br>' . $tt2;
|
|
$maidata['email'] = $v['email'];
|
|
$maidata['title'] = $journal_info['title'];
|
|
$maidata['content'] = $cache;
|
|
$maidata['tmail'] = 'publicrelations@tmrjournals.com';
|
|
$maidata['tpassword'] = 'pRWU999999';
|
|
Queue::push('app\api\job\mail@fire', $maidata, "mail");
|
|
}
|
|
}
|
|
|
|
private function getAuthor($article) {
|
|
$where['article_id'] = $article['article_id'];
|
|
$where['state'] = 0;
|
|
$list = $this->article_author_obj->where($where)->select();
|
|
$frag = '';
|
|
foreach ($list as $k => $v) {
|
|
$frag = $frag == '' ? '' . $v['author_name'] : $frag . ', ' . $v['author_name'];
|
|
}
|
|
return $frag;
|
|
}
|
|
|
|
/**
|
|
* @title 删除文章话题
|
|
* @description 删除文章话题
|
|
* @author wangjinlei
|
|
* @url /master/Article/delTopic
|
|
* @method POST
|
|
*
|
|
* @param name:article_to_topic_id type:int require:1 desc:主键id
|
|
*
|
|
*/
|
|
public function delTopic() {
|
|
$data = $this->request->post();
|
|
$res = $this->article_to_topic_obj->where('article_to_topic_id', $data['article_to_topic_id'])->update(['state' => 1]);
|
|
if ($res) {
|
|
return json(['code' => 0, 'msg' => 'success']);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => 'system error']);
|
|
}
|
|
}
|
|
|
|
// public function mycc() {
|
|
// $list = $this->article_author_obj->where('article_author_id', '>', 5126)->select();
|
|
// foreach ($list as $v) {
|
|
// $ca = explode(' ', $v['author_name']);
|
|
// $caf = '';
|
|
// $cal = '';
|
|
// if (isset($ca[0])) {
|
|
// $caf = str_replace('-', '', $ca[0]);
|
|
// }
|
|
// if (isset($ca[1])) {
|
|
// $cal = $ca[1];
|
|
// }
|
|
// $this->article_author_obj->where('article_author_id', $v['article_author_id'])->update(['first_name' => $caf, 'last_name' => $cal]);
|
|
// }
|
|
// echo 'over';
|
|
// }
|
|
|
|
/**
|
|
* @title 图片上传
|
|
* @description 图片上传
|
|
* @author wangjinlei
|
|
* @url /master/Article/up_article_file
|
|
* @method POST
|
|
*
|
|
* @param name:name type:string require:1 default:articleicon desc:文件域名称
|
|
*
|
|
* @return upurl:图片地址
|
|
*/
|
|
public function up_article_file() {
|
|
$file = request()->file('articleicon');
|
|
if ($file) {
|
|
$info = $file->move(ROOT_PATH . 'public' . DS . 'articleicon');
|
|
if ($info) {
|
|
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => $file->getError()]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 轮播图上传
|
|
* @description 轮播图上传
|
|
* @author wangjinlei
|
|
* @url /master/Article/up_rotation_file
|
|
* @method POST
|
|
*
|
|
* @param name:name type:string require:1 default:rotation desc:文件域名称
|
|
*
|
|
* @return upurl:图片地址
|
|
*/
|
|
public function up_rotation_file(){
|
|
$file = request()->file('rotation');
|
|
if ($file) {
|
|
$info = $file->move(ROOT_PATH . 'public' . DS . 'rotation');
|
|
if ($info) {
|
|
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => $file->getError()]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title cite图片上传
|
|
* @description cite图片上传
|
|
* @author wangjinlei
|
|
* @url /master/Article/up_cite_file
|
|
* @method POST
|
|
*
|
|
* @param name:name type:string require:1 default:articleCite desc:文件域名称
|
|
*
|
|
* @return upurl:图片地址
|
|
*/
|
|
public function up_cite_file() {
|
|
$file = request()->file('articleCite');
|
|
if ($file) {
|
|
$info = $file->move(ROOT_PATH . 'public' . DS . 'articleCite');
|
|
if ($info) {
|
|
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => $file->getError()]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title CDF文件上传
|
|
* @description CDF文件上传
|
|
* @author wangjinlei
|
|
* @url /master/Article/up_cdf_file
|
|
* @method POST
|
|
*
|
|
* @param name:name type:string require:1 default:articleCDF desc:文件域名称
|
|
*
|
|
* @return upurl:图片地址
|
|
*/
|
|
public function up_cdf_file(){
|
|
$file = request()->file('articleCDF');
|
|
if ($file) {
|
|
$info = $file->move(ROOT_PATH . 'public' . DS . 'articleCDF');
|
|
if ($info) {
|
|
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => $file->getError()]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title imgCome文件上传
|
|
* @description imgCome文件上传
|
|
* @author wangjinlei
|
|
* @url /master/Article/up_imgCome_file
|
|
* @method POST
|
|
*
|
|
* @param name:name type:string require:1 default:imgCome desc:文件域名称
|
|
*
|
|
* @return upurl:图片地址
|
|
*/
|
|
public function up_imgCome_file(){
|
|
$file = request()->file('imgCome');
|
|
if ($file) {
|
|
$info = $file->move(ROOT_PATH . 'public' . DS . 'imgCome');
|
|
if ($info) {
|
|
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => $file->getError()]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 文章文件上传
|
|
* @description 文章文件上传
|
|
* @author wangjinlei
|
|
* @url /master/Article/article_file
|
|
* @method GET
|
|
*
|
|
* @param name:name type:string require:1 desc:文件域名称(articlePDF/articleHTML/articleSUB/articleSUB2/bibTex/endNote/articleCDF)
|
|
* @param name:type type:string require:1 desc:pathinfo(articlePDF/articleHTML/articleSUB/articleSUB2/bibTex/endNote/articleCDF)
|
|
*
|
|
* @return upurl:图片地址
|
|
*/
|
|
public function article_file($type) {
|
|
$file = request()->file($type);
|
|
if ($file) {
|
|
$info = $file->move(ROOT_PATH . 'public' . DS . $type);
|
|
if ($info) {
|
|
return json(['code' => 0, 'msg' => 'success', 'upurl' => str_replace("\\", "/", $info->getSaveName())]);
|
|
} else {
|
|
return json(['code' => 1, 'msg' => $file->getError()]);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* @title 获取城市列表
|
|
* @description 获取城市列表
|
|
* @author wangjinlei
|
|
* @url /master/Article/getCountrys
|
|
* @method POST
|
|
*
|
|
* @return countrys:array#
|
|
*/
|
|
public function getCountrys() {
|
|
$res = $this->country_obj->order('en_name')->select();
|
|
return json(['code' => 0, 'msg' => 'success', 'data' => ['countrys' => $res]]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取客座话题
|
|
* @description 获取客座话题
|
|
* @author wangjinlei
|
|
* @url /master/Article/getJournalSpecials
|
|
* @method POST
|
|
*
|
|
* @param name:journal_id type:int require:1 desc:期刊id
|
|
*
|
|
* @return specials:客座期刊array#
|
|
*/
|
|
public function getJournalSpecials() {
|
|
$data = $this->request->post();
|
|
$list = $this->journal_special_obj->where('journal_id', $data['journal_id'])->where('state', 2)->select();
|
|
|
|
$re['specials'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 添加文章引用申请
|
|
* @description 添加文章引用申请
|
|
* @author wangjinlei
|
|
* @url /master/Article/addArticleCite
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
* @param name:journal_id type:int require:1 desc:期刊id
|
|
* @param name:img type:string require:1 desc:地址
|
|
* @param name:journal_name type:string require:1 desc:期刊名
|
|
* @param name:article_name type:string require:1 desc:文章名
|
|
* @param name:factor type:string require:1 desc:影响因子
|
|
* @param name:adate type:string require:1 desc:引用时间
|
|
*
|
|
* @return specials:客座期刊array#
|
|
*/
|
|
public function addArticleCite() {
|
|
$data = $this->request->post();
|
|
$insert['article_id'] = $data['article_id'];
|
|
$insert['journal_id'] = $data['journal_id'];
|
|
$insert['img'] = $data['img'];
|
|
$insert['journal_name'] = $data['journal_name'];
|
|
$insert['article_name'] = $data['article_name'];
|
|
$insert['factor'] = $data['factor'];
|
|
$insert['date'] = $data['adate'];
|
|
$insert['ctime'] = time();
|
|
$this->article_cite_obj->insert($insert);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章引用申请列表(编辑)
|
|
* @description 获取文章引用申请列表
|
|
* @author wangjinlei
|
|
* @url /master/Article/getArticleCites
|
|
* @method POST
|
|
*
|
|
* @param name:admin_id type:int require:1 desc:管理员id
|
|
*
|
|
* @return cites:信息array#
|
|
*/
|
|
public function getArticleCites() {
|
|
$data = $this->request->post();
|
|
$journals = $this->journal_obj->where('editor_id', $data['admin_id'])->where('state', 0)->column('journal_id');
|
|
$list = $this->article_cite_obj
|
|
->field('j_article_cite.*,j_journal.title journal_title')
|
|
->join('j_journal', 'j_journal.journal_id = j_article_cite.journal_id', 'left')
|
|
->where('j_article_cite.journal_id', 'in', $journals)
|
|
->order('j_article_cite.state asc,j_article_cite.article_cite_id asc')
|
|
->select();
|
|
|
|
$re['cites'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章引用列表(编辑)
|
|
* @description 获取文章引用列表
|
|
* @author wangjinlei
|
|
* @url /master/Article/getCitesByArticle
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
*
|
|
* @return cites:信息array#
|
|
* @return article:文章信息#
|
|
*/
|
|
public function getCitesByArticle() {
|
|
$data = $this->request->post();
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
$list = $this->article_cite_obj->where('article_id', $data['article_id'])->order('state asc,article_cite_id asc')->select();
|
|
|
|
$re['article'] = $article_info;
|
|
$re['cites'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章引用申请列表(管理员)
|
|
* @description 获取文章引用申请列表(管理员)
|
|
* @author wangjinlei
|
|
* @url /master/Article/getAllArticleCites
|
|
* @method POST
|
|
*
|
|
* @param name:state type:int require:1 desc:状态-1,0,1,2
|
|
* @param name:pageIndex type:int require:1 desc:当前页码数
|
|
* @param name:pageSize type:int require:1 desc:单页数据条数
|
|
*
|
|
* @return count:总数
|
|
* @return cites:信息array#
|
|
*/
|
|
public function getAllArticleCites() {
|
|
$data = $this->request->post();
|
|
$where = [];
|
|
if ($data['state'] >= 0) {
|
|
$where['j_article_cite.state'] = $data['state'];
|
|
}
|
|
$limit_start = ($data['pageIndex'] - 1) * $data['pageSize'];
|
|
$list = $this->article_cite_obj
|
|
->field('j_article_cite.*,j_journal.title journal_title')
|
|
->join('j_journal', 'j_journal.journal_id = j_article_cite.journal_id', 'left')
|
|
->where($where)
|
|
->order('j_article_cite.state asc,j_article_cite.article_cite_id asc')
|
|
->limit($limit_start, $data['pageSize'])
|
|
->select();
|
|
$count = $this->article_cite_obj->where($where)->count();
|
|
|
|
$re['count'] = $count;
|
|
$re['cites'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 获取文章引用详情
|
|
* @description 获取文章引用详情
|
|
* @author wangjinlei
|
|
* @url /master/Article/getCiteDetail
|
|
* @method POST
|
|
*
|
|
* @param name:article_cite_id type:int require:1 desc:主键
|
|
*
|
|
* @return cite:信息#
|
|
*/
|
|
public function getCiteDetail() {
|
|
$data = $this->request->post();
|
|
$cite_info = $this->article_cite_obj->where('article_cite_id', $data['article_cite_id'])->find();
|
|
|
|
$re['cite'] = $cite_info;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 审核文章引用
|
|
* @description 审核文章引用
|
|
* @author wangjinlei
|
|
* @url /master/Article/changeCiteState
|
|
* @method POST
|
|
*
|
|
* @param name:article_cite_id type:int require:1 desc:主键
|
|
* @param name:state type:int require:1 desc:状态1通过2驳回
|
|
*/
|
|
public function changeCiteState() {
|
|
$data = $this->request->post();
|
|
$this->article_cite_obj->where('article_cite_id', $data['article_cite_id'])->update(['state' => $data['state'], 'atime' => time()]);
|
|
if ($data['state'] == 1) {
|
|
$info = $this->article_cite_obj->where('article_cite_id', $data['article_cite_id'])->find();
|
|
$this->article_obj->where('article_id', $info['article_id'])->setInc('cited');
|
|
}
|
|
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取期刊引用
|
|
* @description 获取期刊引用
|
|
* @author wangjinlei
|
|
* @url /master/Article/getJournalCites
|
|
* @method POST
|
|
*
|
|
* @param name:issn type:string require:1 desc:issn号
|
|
*/
|
|
public function getJournalCites() {
|
|
$data = $this->request->post();
|
|
$journal_info = $this->journal_obj->where('issn', $data['issn'])->find();
|
|
$c_time = strtotime("-1 month", strtotime(date('Y-m') . '-26 00:00:00'));
|
|
$c_time1 = strtotime(date('Y-m' . '-25 23:59:59'));
|
|
$where['journal_id'] = $journal_info['journal_id'];
|
|
$where['atime'] = array(['>', $c_time], ['<=', $c_time1]);
|
|
$where['state'] = 1;
|
|
$list = $this->article_cite_obj->where($where)->select();
|
|
$re['cites'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 推送crossref
|
|
* @description 推送crossref
|
|
* @author wangjinlei
|
|
* @url /master/Article/pushCrossref
|
|
* @method POST
|
|
*
|
|
* @param name:doi_num type:string require:1 desc:doi号
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
*/
|
|
public function pushCrossref() {
|
|
$data = $this->request->post();
|
|
|
|
$has = $this->article_obj->where('doi', '10.53388/' . $data['doi_num'])->find();
|
|
if ($has) {
|
|
return jsonError('doi号重复');
|
|
}
|
|
if (strstr($data['doi_num'], '/') !== false) {
|
|
return jsonError('格式错误');
|
|
}
|
|
$author = $this->article_author_obj->where('article_id', $data['article_id'])->where('state', 0)->find();
|
|
if ($author == null) {
|
|
return jsonError('请先上传作者');
|
|
}
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
if ($article_info['npp'] == '') {
|
|
return jsonError('请先上传页码');
|
|
}
|
|
$url = 'https://doi.crossref.org/servlet/deposit';
|
|
$file = ROOT_PATH . 'public' . DS . 'xml' . DS . $data['article_id'] . '.xml';
|
|
$this->crossRef($data);
|
|
|
|
//存储
|
|
$this->article_obj->where('article_id', $data['article_id'])->update(['doi' => '10.53388/' . $data['doi_num']]);
|
|
|
|
//发送请求
|
|
$par['login_id'] = 'books@tmrjournals.com/tmrp';
|
|
$par['login_passwd'] = '849192806pnX';
|
|
$par['fname'] = new \CURLFile($file);
|
|
|
|
$this->myPost($url, $par);
|
|
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
private function myPost($url, $param = array()) {
|
|
// if (!is_array($param)) {
|
|
// throw new Exception("参数必须为array");
|
|
// }
|
|
$httph = curl_init($url);
|
|
curl_setopt($httph, CURLOPT_RETURNTRANSFER, 1);
|
|
curl_setopt($httph, CURLOPT_USERAGENT, "Mozilla/4.0 (compatible; MSIE 6.0; Windows NT 5.0)");
|
|
curl_setopt($httph, CURLOPT_POST, 1); //设置为POST方式
|
|
curl_setopt($httph, CURLOPT_POSTFIELDS, $param);
|
|
|
|
curl_exec($httph);
|
|
curl_close($httph);
|
|
// echo '<pre>';
|
|
// var_dump($rst);
|
|
// echo '</pre>';
|
|
// echo '<pre>';
|
|
// var_dump($err);
|
|
// echo '</pre>';
|
|
// die;
|
|
// die;
|
|
}
|
|
|
|
public function met() {
|
|
$s = '11';
|
|
$arr = explode('-', $s);
|
|
echo $arr[0];
|
|
}
|
|
|
|
public function crossRef($data) {
|
|
$xml = '';
|
|
//create xml 头
|
|
$xml .= '<?xml version="1.0" encoding="UTF-8"?>' . PHP_EOL;
|
|
$xml .= '<doi_batch version="4.3.7" xmlns="http://www.crossref.org/schema/4.3.7" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.crossref.org/schema/4.3.7
|
|
http://www.crossref.org/schemas/crossref4.3.7.xsd">' . PHP_EOL . PHP_EOL;
|
|
$xml .= '<head>' . PHP_EOL;
|
|
$xml .= '<doi_batch_id>' . date('Ymd') . '</doi_batch_id>' . PHP_EOL;
|
|
$xml .= '<timestamp>' . date('YmdHis') . '</timestamp>' . PHP_EOL;
|
|
$xml .= '<depositor>' . PHP_EOL;
|
|
$xml .= '<depositor_name>tmr@tmrjournals.com</depositor_name>' . PHP_EOL;
|
|
$xml .= '<email_address>tmr@tmrjournals.com</email_address>' . PHP_EOL;
|
|
$xml .= '</depositor>' . PHP_EOL;
|
|
$xml .= '<registrant>TMR</registrant>' . PHP_EOL;
|
|
$xml .= '</head>' . PHP_EOL;
|
|
|
|
//组装主体信息部分
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
|
|
$stage_info = $this->journal_stage_obj->where('journal_stage_id', $article_info['journal_stage_id'])->find();
|
|
$xml .= '<body>' . PHP_EOL;
|
|
$xml .= '<journal>' . PHP_EOL;
|
|
$xml .= '<journal_metadata language="en">' . PHP_EOL;
|
|
$xml .= '<full_title>' . str_replace("&", "and", $journal_info['title']) . '</full_title>' . PHP_EOL;
|
|
$xml .= '<abbrev_title>' . str_replace('&', 'and', $journal_info['jabbr']) . '</abbrev_title>' . PHP_EOL;
|
|
$xml .= '<issn media_type="print">' . $journal_info['issn'] . '</issn>' . PHP_EOL;
|
|
$xml .= '<coden>' . $journal_info['usx'] . '</coden>' . PHP_EOL;
|
|
$xml .= '</journal_metadata>' . PHP_EOL;
|
|
$xml .= '<journal_issue>' . PHP_EOL;
|
|
$xml .= '<publication_date media_type="print">' . PHP_EOL;
|
|
$xml .= '<year>' . $stage_info['stage_year'] . '</year>' . PHP_EOL;
|
|
$xml .= '</publication_date>' . PHP_EOL;
|
|
$xml .= '<journal_volume>' . PHP_EOL;
|
|
$xml .= '<volume>' . $stage_info['stage_vol'] . '</volume>' . PHP_EOL;
|
|
$xml .= '</journal_volume>' . PHP_EOL;
|
|
$xml .= '<issue>' . $stage_info['stage_no'] . '</issue>' . PHP_EOL;
|
|
$xml .= '</journal_issue>' . PHP_EOL;
|
|
$xml .= '<journal_article publication_type="full_text">' . PHP_EOL;
|
|
$xml .= '<titles>' . PHP_EOL;
|
|
$xml .= '<title>' . str_replace("&", "and", $article_info['title']) . '</title>' . PHP_EOL;
|
|
$xml .= '</titles>' . PHP_EOL;
|
|
$xml .= '<contributors>' . PHP_EOL;
|
|
$authors = $this->article_author_obj->where('article_id', $data['article_id'])->where('state', 0)->select();
|
|
foreach ($authors as $v) {
|
|
if ($v['is_first'] == 1) {
|
|
$xml .= '<person_name sequence="first" contributor_role="author">' . PHP_EOL;
|
|
} else {
|
|
$xml .= '<person_name sequence="additional" contributor_role="author">' . PHP_EOL;
|
|
}
|
|
$xml .= '<given_name>' . $v['first_name'] . '</given_name>' . PHP_EOL;
|
|
$xml .= '<surname>' . ($v['last_name']==''?$v['first_name']:$v['last_name']) . '</surname>' . PHP_EOL;
|
|
$xml .= '</person_name>' . PHP_EOL;
|
|
}
|
|
$xml .= '</contributors>' . PHP_EOL;
|
|
$xml .= '<publication_date media_type="print">' . PHP_EOL;
|
|
$xml .= '<year>' . $stage_info['stage_year'] . '</year>' . PHP_EOL;
|
|
$xml .= '</publication_date>' . PHP_EOL;
|
|
$xml .= '<pages>' . PHP_EOL;
|
|
$ca = explode('-', $article_info['npp']);
|
|
$xml .= '<first_page>' . $ca[0] . '</first_page>' . PHP_EOL;
|
|
$xml .= '</pages>' . PHP_EOL;
|
|
$xml .= '<publisher_item>' . PHP_EOL;
|
|
$xml .= '<identifier id_type="pii">' . trim($data['doi_num']) . '</identifier>' . PHP_EOL;
|
|
$xml .= '</publisher_item>' . PHP_EOL;
|
|
$xml .= '<doi_data>' . PHP_EOL;
|
|
$xml .= '<doi>10.53388/' . trim($data['doi_num']) . '</doi>' . PHP_EOL;
|
|
$xml .= '<resource><![CDATA[https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $article_info['article_id'] . ']]></resource>' . PHP_EOL;
|
|
$xml .= '</doi_data>' . PHP_EOL;
|
|
$xml .= '</journal_article>' . PHP_EOL;
|
|
$xml .= '</journal>' . PHP_EOL;
|
|
$xml .= '</body>' . PHP_EOL;
|
|
$xml .= '</doi_batch>' . PHP_EOL;
|
|
$txt = ROOT_PATH . 'public' . DS . 'xml' . DS . $article_info['article_id'] . '.xml';
|
|
file_put_contents($txt, $xml);
|
|
}
|
|
|
|
private function changDOI() {
|
|
$list = $this->article_obj->where('journal_id', 14)->where('state', 0)->select();
|
|
foreach ($list as $art) {
|
|
$ca_doi = explode('/', $art['doi']);
|
|
if (!isset($ca_doi[1])) {
|
|
continue;
|
|
}
|
|
$doi = '10.53388/' . $ca_doi[1];
|
|
$this->article_obj->where('article_id',$art['article_id'])->update(['doi'=>$doi]);
|
|
}
|
|
}
|
|
|
|
/**
|
|
* 生成xml文件
|
|
*/
|
|
private function makeXML() {
|
|
$xml = '';
|
|
//create xml 头
|
|
$xml .= '<?xml version="1.0" encoding="UTF-8"?>' . PHP_EOL;
|
|
$xml .= '<doi_batch version="4.3.7" xmlns="http://www.crossref.org/schema/4.3.7" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://www.crossref.org/schema/4.3.7
|
|
http://www.crossref.org/schemas/crossref4.3.7.xsd">' . PHP_EOL . PHP_EOL;
|
|
$xml .= '<head>' . PHP_EOL;
|
|
$xml .= '<doi_batch_id>' . date('Ymd') . '</doi_batch_id>' . PHP_EOL;
|
|
$xml .= '<timestamp>' . date('YmdHis') . '</timestamp>' . PHP_EOL;
|
|
$xml .= '<depositor>' . PHP_EOL;
|
|
$xml .= '<depositor_name>tmr@tmrjournals.com</depositor_name>' . PHP_EOL;
|
|
$xml .= '<email_address>tmr@tmrjournals.com</email_address>' . PHP_EOL;
|
|
$xml .= '</depositor>' . PHP_EOL;
|
|
$xml .= '<registrant>TMR</registrant>' . PHP_EOL;
|
|
$xml .= '</head>' . PHP_EOL;
|
|
$xml .= '<body>' . PHP_EOL;
|
|
//组装主体信息部分
|
|
|
|
$journal_info = $this->journal_obj->where('journal_id', 14)->find();
|
|
|
|
// $article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
$stage_list = $this->journal_stage_obj->where('journal_id', 14)->where('state', 0)->select();
|
|
foreach ($stage_list as $stage) {
|
|
$xml .= '<journal>' . PHP_EOL;
|
|
$xml .= '<journal_metadata language="en">' . PHP_EOL;
|
|
$xml .= '<full_title>' . $journal_info['title'] . '</full_title>' . PHP_EOL;
|
|
$xml .= '<abbrev_title>' . $journal_info['jabbr'] . '</abbrev_title>' . PHP_EOL;
|
|
$xml .= '<issn media_type="print">' . $journal_info['issn'] . '</issn>' . PHP_EOL;
|
|
$xml .= '<coden>' . $journal_info['usx'] . '</coden>' . PHP_EOL;
|
|
$xml .= '</journal_metadata>' . PHP_EOL;
|
|
$xml .= '<journal_issue>' . PHP_EOL;
|
|
$xml .= '<publication_date media_type="print">' . PHP_EOL;
|
|
$xml .= '<year>' . $stage['stage_year'] . '</year>' . PHP_EOL;
|
|
$xml .= '</publication_date>' . PHP_EOL;
|
|
$xml .= '<journal_volume>' . PHP_EOL;
|
|
$xml .= '<volume>' . $stage['stage_vol'] . '</volume>' . PHP_EOL;
|
|
$xml .= '</journal_volume>' . PHP_EOL;
|
|
$xml .= '<issue>' . $stage['stage_no'] . '</issue>' . PHP_EOL;
|
|
$xml .= '</journal_issue>' . PHP_EOL;
|
|
|
|
$art_list = $this->article_obj->where('journal_stage_id', $stage['journal_stage_id'])->where('state', 0)->select();
|
|
foreach ($art_list as $art) {
|
|
|
|
$ca_doi = explode('/', $art['doi']);
|
|
if (!isset($ca_doi[1])) {
|
|
continue;
|
|
}
|
|
$doi = '10.53388/' . $ca_doi[1];
|
|
|
|
$xml .= '<journal_article publication_type="full_text">' . PHP_EOL;
|
|
$xml .= '<titles>' . PHP_EOL;
|
|
$xml .= '<title>' . $art['title'] . '</title>' . PHP_EOL;
|
|
$xml .= '</titles>' . PHP_EOL;
|
|
$xml .= '<contributors>' . PHP_EOL;
|
|
$authors = $this->article_author_obj->where('article_id', $art['article_id'])->where('state', 0)->select();
|
|
foreach ($authors as $v) {
|
|
if ($v['is_first'] == 1) {
|
|
$xml .= '<person_name sequence="first" contributor_role="author">' . PHP_EOL;
|
|
} else {
|
|
$xml .= '<person_name sequence="additional" contributor_role="author">' . PHP_EOL;
|
|
}
|
|
$xml .= '<given_name>' . $v['first_name'] . '</given_name>' . PHP_EOL;
|
|
$xml .= '<surname>' . ($v['last_name']==''?$v['first_name']:$v['last_name']) . '</surname>' . PHP_EOL;
|
|
$xml .= '</person_name>' . PHP_EOL;
|
|
}
|
|
$xml .= '</contributors>' . PHP_EOL;
|
|
$xml .= '<publication_date media_type="print">' . PHP_EOL;
|
|
$xml .= '<year>' . $stage['stage_year'] . '</year>' . PHP_EOL;
|
|
$xml .= '</publication_date>' . PHP_EOL;
|
|
$xml .= '<pages>' . PHP_EOL;
|
|
$ca = explode('-', $art['npp']);
|
|
$xml .= '<first_page>' . $ca[0] . '</first_page>' . PHP_EOL;
|
|
$xml .= '</pages>' . PHP_EOL;
|
|
$xml .= '<publisher_item>' . PHP_EOL;
|
|
$xml .= '<identifier id_type="pii">' . $doi . '</identifier>' . PHP_EOL;
|
|
$xml .= '</publisher_item>' . PHP_EOL;
|
|
$xml .= '<doi_data>' . PHP_EOL;
|
|
$xml .= '<doi>' . $doi . '</doi>' . PHP_EOL;
|
|
$xml .= '<resource><![CDATA[https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $art['article_id'] . ']]></resource>' . PHP_EOL;
|
|
$xml .= '</doi_data>' . PHP_EOL;
|
|
$xml .= '</journal_article>' . PHP_EOL;
|
|
}
|
|
$xml .= '</journal>' . PHP_EOL;
|
|
}
|
|
$xml .= '</body>' . PHP_EOL;
|
|
$xml .= '</doi_batch>' . PHP_EOL;
|
|
$txt = ROOT_PATH . 'public' . DS . 'xml' . DS . 'all_1.xml';
|
|
file_put_contents($txt, $xml);
|
|
}
|
|
|
|
/**
|
|
* @title 增加相关文章
|
|
* @description 增加相关文章
|
|
* @author wangjinlei
|
|
* @url /master/Article/addRelatedArticle
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
* @param name:add_article_id type:int require:1 desc:增加的文章id
|
|
*/
|
|
public function addRelatedArticle(){
|
|
$data = $this->request->post();
|
|
$rule = new Validate([
|
|
'article_id'=>'require',
|
|
'add_article_id'=>'require'
|
|
]);
|
|
if(!$rule->check($data)){
|
|
return jsonError($rule->getError());
|
|
}
|
|
$article_info = $this->article_obj->where('article_id',$data['article_id'])->find();
|
|
$frag = [];
|
|
if($article_info['related']==""){
|
|
$frag[] = $data['add_article_id'];
|
|
}else{
|
|
if(in_array($data['add_article_id'], object_to_array(json_decode($article_info['related'])))){
|
|
return jsonError("重复添加!!");
|
|
}
|
|
$frag = array_merge(object_to_array(json_decode($article_info['related'])),[$data['add_article_id']]);
|
|
}
|
|
$this->article_obj->where("article_id",$data['article_id'])->update(['related'=> json_encode($frag)]);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 删除相关文章
|
|
* @description 删除相关文章
|
|
* @author wangjinlei
|
|
* @url /master/Article/delRelatedArticle
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
* @param name:del_article_id type:int require:1 desc:增加的文章id
|
|
*/
|
|
public function delRelatedArticle(){
|
|
$data = $this->request->post();
|
|
$article_info = $this->article_obj->where("article_id",$data['article_id'])->find();
|
|
$frag = object_to_array(json_decode($article_info['related']));
|
|
foreach ($frag as $k => $v){
|
|
if($v==$data['del_article_id']){
|
|
unset($frag[$k]);
|
|
}
|
|
}
|
|
$this->article_obj->where("article_id",$data['article_id'])->update(['related'=> json_encode($frag)]);
|
|
return jsonSuccess([]);
|
|
}
|
|
|
|
/**
|
|
* @title 获取相关文章
|
|
* @description 获取相关文章
|
|
* @author wangjinlei
|
|
* @url /master/Article/getRelatedArticles
|
|
* @method POST
|
|
*
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
*
|
|
* @return articles:文章列表#
|
|
*/
|
|
public function getRelatedArticles(){
|
|
$data = $this->request->post();
|
|
$article_info = $this->article_obj->where("article_id",$data['article_id'])->find();
|
|
$list = $this->article_obj
|
|
->field("j_article.*,j_journal.title journal_title")
|
|
->join('j_journal','j_journal.journal_id = j_article.journal_id','left')
|
|
->where("j_article.article_id","in", object_to_array(json_decode($article_info['related'])))
|
|
->select();
|
|
$re['articles'] = $list;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 获取期刊全部文章按分期划分
|
|
* @description 获取期刊全部文章按分期划分
|
|
* @author wangjinlei
|
|
* @url /master/Article/getArticlesByStages
|
|
* @method POST
|
|
*
|
|
* @param name:journal_id type:int require:1 desc:期刊id
|
|
*
|
|
* @return stages:文章列表#
|
|
*/
|
|
public function getArticlesByStages(){
|
|
$data = $this->request->post();
|
|
//获取期刊分期
|
|
$stage = $this->journal_stage_obj->where('journal_id',$data['journal_id'])->where("state",0)->order('stage_vol desc,stage_no')->select();
|
|
foreach ($stage as $k => $v){
|
|
$stage[$k]['articles'] = $this->article_obj->where('journal_stage_id',$v['journal_stage_id'])->where('state',0)->select();
|
|
}
|
|
$re['stages'] = $stage;
|
|
return jsonSuccess($re);
|
|
}
|
|
|
|
/**
|
|
* @title 注册doi
|
|
* @description 注册doi
|
|
* @author wangjinlei
|
|
* @url /master/Article/agentDOI
|
|
* @method POST
|
|
*
|
|
* @param name:doi type:string require:1 desc:doi号
|
|
* @param name:article_id type:int require:1 desc:文章id
|
|
*/
|
|
public function agentDOI() {
|
|
$data = $this->request->post();
|
|
// $data['doi'] = '10.12032/TMR20210301222';
|
|
// $data['article_id'] = 1333;
|
|
|
|
|
|
$xml = '';
|
|
//create xml 头
|
|
$xml .= '<?xml version="1.0" encoding="UTF-8"?>' . PHP_EOL;
|
|
$xml .= '<doi_batch version="1.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="D:\jboss-4.0.3SP1\wanfang\jboss-4.0.3SP1\server\default\deploy\WanFang.war\check.xsd">' . PHP_EOL . PHP_EOL;
|
|
$xml .= '<head>' . PHP_EOL;
|
|
$xml .= '<doi_batch_id>' . date('Ymd') . '</doi_batch_id>' . PHP_EOL;
|
|
$xml .= '<timestamp>' . date('YmdHis') . '</timestamp>' . PHP_EOL;
|
|
$xml .= '<depositor>' . PHP_EOL;
|
|
$xml .= '<name>TMR2015@163.com</name>' . PHP_EOL;
|
|
$xml .= '<email_address>TMR2015@163.com</email_address>' . PHP_EOL;
|
|
$xml .= '</depositor>' . PHP_EOL;
|
|
$xml .= '<registrant>传统医学研究(英文版)</registrant>' . PHP_EOL;
|
|
$xml .= '</head>' . PHP_EOL;
|
|
|
|
//组装主体信息部分
|
|
$article_info = $this->article_obj->where('article_id', $data['article_id'])->find();
|
|
$journal_info = $this->journal_obj->where('journal_id', $article_info['journal_id'])->find();
|
|
$stage_info = $this->journal_stage_obj->where('journal_stage_id', $article_info['journal_stage_id'])->find();
|
|
$xml .= '<body>' . PHP_EOL;
|
|
$xml .= '<journal>' . PHP_EOL;
|
|
$xml .= '<journal_metadata>' . PHP_EOL;
|
|
$xml .= '<journal_id>' . $journal_info['usx'] . '</journal_id>' . PHP_EOL;
|
|
$xml .= '<full_title>' . $journal_info['title'] . '</full_title>' . PHP_EOL;
|
|
$xml .= '<issn media_type="print">' . $journal_info['issn'] . '</issn>' . PHP_EOL;
|
|
$xml .= '<cn media_type="print"></cn>' . PHP_EOL;
|
|
$xml .= '</journal_metadata>' . PHP_EOL;
|
|
$xml .= '<journal_issue>' . PHP_EOL;
|
|
$xml .= '<publication_date media_type="print">' . PHP_EOL;
|
|
$xml .= '<year>' . $stage_info['stage_year'] . '</year>' . PHP_EOL;
|
|
$xml .= '<month/>' . PHP_EOL;
|
|
$xml .= '<day/>' . PHP_EOL;
|
|
$xml .= '</publication_date>' . PHP_EOL;
|
|
$xml .= '<journal_volume>' . PHP_EOL;
|
|
$xml .= '<volume>' . $stage_info['stage_vol'] . '</volume>' . PHP_EOL;
|
|
$xml .= '</journal_volume>' . PHP_EOL;
|
|
$xml .= '<issue>' . $stage_info['stage_no'] . '</issue>' . PHP_EOL;
|
|
$xml .= '</journal_issue>' . PHP_EOL;
|
|
$xml .= '<journal_article>' . PHP_EOL;
|
|
$xml .= '<titles>' . PHP_EOL;
|
|
$xml .= '<title>' . $article_info['title'] . '</title>' . PHP_EOL;
|
|
$xml .= '<subtitle></subtitle>' . PHP_EOL;
|
|
$xml .= '</titles>' . PHP_EOL;
|
|
$xml .= '<contributors>' . PHP_EOL;
|
|
$xml .= '<contributors>' . PHP_EOL;
|
|
$authors = $this->article_author_obj->where('article_id', $data['article_id'])->where('state', 0)->select();
|
|
$address = '';
|
|
$author = '';
|
|
foreach ($authors as $v) {
|
|
if ($v['is_first'] == 1) {
|
|
$ca = $this->author_to_organ_obj->where('article_author_id', $v['article_author_id'])->where('article_id', $data['article_id'])->find();
|
|
$ca_organ = $this->article_organ_obj->where('article_organ_id', $ca['article_organ_id'])->find();
|
|
$address = $ca_organ['organ_name'];
|
|
}
|
|
$author .= $v['author_name'] . ',';
|
|
}
|
|
$xml .= '<person_name sequence="first" contributor_role="author">' . substr($author, -1) . '</person_name>' . PHP_EOL;
|
|
$xml .= '<organization sequence="first" contributor_role="author">' . $address . '</organization>' . PHP_EOL;
|
|
$xml .= '</contributors>' . PHP_EOL;
|
|
$xml .= '<keywords></keywords>' . PHP_EOL;
|
|
$xml .= '<keywords>' . str_replace(',', ' ', $article_info['keywords']) . '</keywords>' . PHP_EOL;
|
|
$xml .= '<abstract></abstract>' . PHP_EOL;
|
|
$xml .= '<abstract>' . str_replace('Abstract', '', strip_tags(str_replace(" ", "", htmlspecialchars_decode($article_info['abstract'])))) . '</abstract>' . PHP_EOL;
|
|
$xml .= '<doi_data>' . PHP_EOL;
|
|
$xml .= '<doi>' . $article_info['doi'] . '</doi>' . PHP_EOL;
|
|
$xml .= '<resource><![CDATA[https://www.tmrjournals.com/article.html?J_num=' . $journal_info['journal_id'] . '&a_id=' . $article_info['article_id'] . ']]></resource>' . PHP_EOL;
|
|
$xml .= '</doi_data>' . PHP_EOL;
|
|
$xml .= '<pages>' . PHP_EOL;
|
|
$start = '';
|
|
$end = '';
|
|
if (stripos($article_info['npp'], '-') > 0) {
|
|
$ca_list = explode('-', $article_info['npp']);
|
|
$start = $ca_list[0];
|
|
$end = $ca_list[1];
|
|
} else {
|
|
$start = $article_info['npp'];
|
|
}
|
|
$xml .= '<first_page>' . $start . '</first_page>' . PHP_EOL;
|
|
$xml .= '<last_page>' . $end . '</last_page>' . PHP_EOL;
|
|
$xml .= '</pages>' . PHP_EOL;
|
|
$xml .= '</journal_article>' . PHP_EOL;
|
|
$txt = ROOT_PATH . 'public' . DS . 'xml' . DS . $article_info['article_id'] . '.xml';
|
|
file_put_contents($txt, $xml);
|
|
}
|
|
|
|
// public function upXML() {
|
|
// vendor("chinadoi.UPXML2");
|
|
// $up_obj = new \UpXml;
|
|
// $xmlfile = ROOT_PATH . 'public' . DS . 'xml' . DS . '1333.xml';
|
|
// $result = $up_obj->upload($xmlfile);
|
|
// echo '<pre>';
|
|
// var_dump($result);
|
|
// echo '</pre>';
|
|
// die;
|
|
// }
|
|
}
|