示例:catfish鲶鱼cms文章 (CatfishDemoSkycaiji)

  更新日期:2019-07-18 22:48
实现catfish鲶鱼cms文章入库功能,您可参考该代码开发更多catfish应用,使用时需在数据绑定》CMS路径结尾加上@catfish

插件代码

<?php
/**
 * 示例:catfish文章
 * 您可参考代码自行开发catfish的更多功能
 * 您可以使用 thinkphp5的函数
 */
namespace plugin\release\cms;
class CatfishDemoSkycaiji extends BaseCms{
	public $siteurl;//cms站点网址
	public function cms_db_catfish($cmsPath){
		$dbFile=realpath($cmsPath.'/application/database.php');
		$cmsDb=array();
		if(file_exists($dbFile)){
			$dbFile=include $dbFile;
			if(is_array($dbFile)){
				$cmsDb['db_host']=$dbFile['hostname'];
				$cmsDb['db_user']=$dbFile['username'];
				$cmsDb['db_pwd']=$dbFile['password'];
				$cmsDb['db_charset']=$dbFile['charset'];
				$cmsDb['db_port']=$dbFile['hostport'];
				$cmsDb['db_name']=$dbFile['database'];
				$cmsDb['db_prefix']=$dbFile['prefix'];
			}
		}
		return $cmsDb;
	}
	/*初始化扩展*/
	public function init_extend(){
		$siteUrl=$this->db()->table('__OPTIONS__')->where("option_name='domain'")->find();
		$this->siteurl=rtrim($siteUrl['option_value'],'\/\\').'/';
	}
	//参数
	public $_params = array (
		'author' => array (
			'name' => '作者账号',
			'require' => 1,
			'tag' => 'select',
			'option' => 'function:param_option_author',
		),
		'category' => array (
			'name' => '分类',
			'require' => 1,
			'tag' => 'select',
			'option' => 'function:param_option_category',
		),
		'title' => array (
			'name' => '文章标题',
			'require' => 1,
			'tag' => 'select',
			'option' => 'function:param_option_fields',
		),
		'content' => array (
			'name' => '文章内容',
			'require' => 1,
			'tag' => 'select',
			'option' => 'function:param_option_fields',
		),
	);

	/*
	 * 导入数据
	* 必须以数组形式返回:
	* id(必填)表示入库返回的自增id或状态
	* target(可选)记录入库的数据位置(发布的网址等)
	* desc(可选)记录入库的数据位置附加信息
	* error(可选)记录入库失败的错误信息
	* 入库的信息可在“已采集数据”中查看
	* return array('id'=>0,'target'=>'','desc'=>'','error'=>'');
	*/
	public function runImport($params){
		$newPost=array(
			'post_author'=>$params['author'],
			'post_keywords'=>'',
			'post_source'=>'',
	        'post_date'=>date("Y-m-d H:i:s",time()),
	        'post_content'=>$params['content'],
	        'post_title'=>$params['title'],
	        'post_excerpt'=>mb_substr(strip_tags($params['content']),0,100),
	        'post_status'=>1,
	        'comment_status'=>1,
	        'post_modified'=>date("Y-m-d H:i:s",time()),
			'post_comment'=>'',
	        'parent_id'=>0,
	        'post_type'=>0,
			'comment_count'=>0,
			'thumbnail'=>'',
			'post_hits'=>0,
			'post_like'=>0,
			'istop'=>0,
			'recommended'=>0,
			'status'=>1
		);
		
		$postId=$this->db()->table('__POSTS__')->insert($newPost,false,true);//添加文章并返回id
		if($postId>0){
			$this->db()->table('__TERM_RELATIONSHIPS__')->insert(array('object_id'=>$postId,'term_id'=>$params['category']),true);
			
			$target=$this->siteurl.'article/'.$postId.'.html';
			return array('id'=>$postId,'target'=>$target);
		}else{
			return array('id'=>0,'error'=>'文章入库失败');
		}
	}
	/*
	 * 参数选项:作者
	 * 必须返回键值对形式的数组
	 */
	public function param_option_author(){
		$usersDb=$this->db()->table('__USERS__')->where('user_type','in',array(1,3))->select();
		$userList=array();
		foreach ($usersDb as $user){
			$userList[$user['id']]=$user['user_login'];
		}
		return $userList;
	}
	
	/*
	 * 参数选项:分类
	 * 必须返回键值对形式的数组
	 */
	public function param_option_category(){
		$catsDb=$this->db()->table('__TERMS__')->select();//文章分类
		$catList=array();
		foreach ($catsDb as $cat){
			$catList[$cat['id']]=$cat['term_name'];
		}
		return $catList;
	}
}
?>