123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208 |
- <?php
- /**
- * 易优CMS
- * ============================================================================
- * 版权所有 2016-2028 海口快推科技有限公司,并保留所有权利。
- * 网站地址: http://www.eyoucms.com
- * ----------------------------------------------------------------------------
- * 如果商业用途务必到官方购买正版授权, 以免引起不必要的法律纠纷.
- * ============================================================================
- * Author: 小虎哥 <1105415366@qq.com>
- * Date: 2018-4-3
- */
-
- namespace app\admin\model;
-
- use think\Db;
- use think\Model;
-
- /**
- * 视频
- */
- class Media extends Model
- {
- //初始化
- protected function initialize()
- {
- // 需要调用`Model`的`initialize`方法
- parent::initialize();
- }
-
- /**
- * 后置操作方法
- * 自定义的一个函数 用于数据保存后做的相应处理操作, 使用时手动调用
- * @param int $aid 产品id
- * @param array $post post数据
- * @param string $opt 操作
- */
- public function afterSave($aid, $post, $opt)
- {
- // 处理外贸链接
- if (is_dir('./weapp/Waimao/')) {
- $waimaoLogic = new \weapp\Waimao\logic\WaimaoLogic;
- $waimaoLogic->update_htmlfilename($aid, $post, $opt);
- }
-
- if ('add' == $opt) {
- // 视频章节分组插件
- if (is_dir('./weapp/Videogroup/')) {
- $Prefix = config('database.prefix');
- $isTable = Db::query("SHOW TABLES LIKE '{$Prefix}weapp_videogroup'");
- if (!empty($isTable)) {
- Db::name('weapp_videogroup')->where(['hash'=>$post['hash_1670831712']])->update(['aid'=>$aid,'update_time'=>getTime()]);
- }
- }
- }
-
- $video_files = [];
- $post['addonFieldExt']['total_video'] = 0;
- if (!empty($post['video'])) {
- $post['addonFieldExt']['total_video'] = count($post['video']);
- $post['addonFieldExt']['total_duration'] = 0;
- foreach ($post['video'] as $k => $v) {
- $v['file_url'] = trim($v['file_url']);
- if (empty($v['file_url'])){
- $post['addonFieldExt']['total_video'] -= 1;
- continue;
- }
- $post['addonFieldExt']['total_duration'] += $v['file_time'];
- $file_size = !empty($v['file_size']) ? $v['file_size'] : 0;
- $is_remote = 0;
- $file_ext = explode('.', $v['file_url']);
- $file_ext = preg_replace('/^(.*)\?(.*)$/i', '${1}', end($file_ext));
- $uhash = md5($v['file_url'].$file_size);
- if (is_http_url($v['file_url'])) {
- $is_remote = 1;
- $md5file = '';
- } else {
- if (preg_match('#^(/[\w]+)?(/uploads/media/)#i', $v['file_url'])) {
- $file_path_tmp = preg_replace('#^(/[\w]+)?(/uploads/media/)#i', '$2', $v['file_url']);
- } else {
- $file_path_tmp = preg_replace('#^('.$this->root_dir.')?(/)#i', '$2', $v['file_url']);
- }
- $md5file = md5_file('.'.$file_path_tmp);
- }
- $video_files[] = [
- 'aid' => $aid,
- 'file_id' => $v['file_id'],
- 'title' => $post['title'],
- 'file_url' => !empty($v['file_url']) ? $v['file_url'] : '',
- 'file_time' => !empty($v['file_time']) ? $v['file_time'] : 0,
- 'file_title' => !empty($v['file_title']) ? $v['file_title'] : '',
- 'file_ext' => $file_ext,
- 'file_size' => $file_size,
- 'file_mime' => !empty($v['file_mime']) ? $v['file_mime'] : '',
- 'sort_order' => !empty($v['sort_order']) ? $v['sort_order'] : '100',
- 'uhash' => $uhash,
- 'md5file' => $md5file,
- 'is_remote' => $is_remote,
- 'gratis' => !empty($v['gratis']) ? $v['gratis'] : 0,
- 'video_group_id' => !empty($v['video_group_id']) ? intval($v['video_group_id']) : 0,
- 'add_time' => getTime(),
- 'update_time' => getTime(),
- ];
- }
- }
-
- $post['aid'] = $aid;
- $addonFieldExt = !empty($post['addonFieldExt']) ? $post['addonFieldExt'] : array();
- model('Field')->dealChannelPostData($post['channel'], $post, $addonFieldExt);
-
- // ---------多视频
- model('MediaFile')->savefile($aid, $video_files, $opt);
-
- // --处理TAG标签
- model('Taglist')->savetags($aid, $post['typeid'], $post['tags'], $post['arcrank'], $opt);
-
- if ('edit' == $opt) {
- // 清空sql_cache_table数据缓存表 并 添加查询执行语句到mysql缓存表
- Db::name('sql_cache_table')->execute('TRUNCATE TABLE '.config('database.prefix').'sql_cache_table');
- model('SqlCacheTable')->InsertSqlCacheTable(true);
- } else {
- // 处理mysql缓存表数据
- if (isset($post['arcrank']) && -1 == $post['arcrank'] && -1 == $post['old_arcrank'] && !empty($post['users_id'])) {
- // 待审核
- model('SqlCacheTable')->UpdateDraftSqlCacheTable($post, $opt);
- } else if (isset($post['arcrank'])) {
- // 已审核
- $post['old_typeid'] = intval($post['attr']['typeid']);
- model('SqlCacheTable')->UpdateSqlCacheTable($post, $opt, 'media');
- }
- }
- }
-
- /**
- * 获取单条记录
- * @author wengxianhu by 2017-7-26
- */
- public function getInfo($aid, $field = null, $isshowbody = true)
- {
- $result = array();
- $field = !empty($field) ? $field : '*';
- $result = Db::name('archives')->field($field)
- ->where([
- 'aid' => $aid,
- 'lang' => get_admin_lang(),
- ])
- ->find();
- if ($isshowbody) {
- $tableName = Db::name('channeltype')->where('id','eq',$result['channel'])->getField('table');
- $result['addonFieldExt'] = Db::name($tableName.'_content')->where('aid',$aid)->find();
- }
-
- // 文章TAG标签
- if (!empty($result)) {
- $typeid = isset($result['typeid']) ? $result['typeid'] : 0;
- $tags = model('Taglist')->getListByAid($aid, $typeid);
- $result['tags'] = $tags['tag_arr'];
- $result['tag_id'] = $tags['tid_arr'];
- }
-
- return $result;
- }
-
- /**
- * 删除的后置操作方法
- * 自定义的一个函数 用于数据删除后做的相应处理操作, 使用时手动调用
- * @param int $aid
- */
- public function afterDel($aidArr = array())
- {
- if (is_string($aidArr)) {
- $aidArr = explode(',', $aidArr);
- }
- // 同时删除内容
- Db::name('media_content')->where(
- array(
- 'aid'=>array('IN', $aidArr)
- )
- )
- ->delete();
- // 同时删除软件
- $result = Db::name('media_file')->field('file_url')
- ->where(
- array(
- 'aid'=>array('IN', $aidArr)
- )
- )
- ->select();
- if (!empty($result)) {
- foreach ($result as $key => $val) {
- $file_url = preg_replace('#^(/[/\w\-]+)?(/public/upload/|/uploads/)#i', '$2', $val['file_url']);
- if (!is_http_url($file_url) && file_exists('.'.$file_url) && preg_match('#^(/uploads/|/public/upload/)(.*)/([^/]+)\.([a-z]+)$#i', $file_url)) {
- @unlink(realpath('.'.$file_url));
- }
- }
- $r = Db::name('media_file')->where(
- array(
- 'aid'=>array('IN', $aidArr)
- )
- )->delete();
- if ($r !== false) {
- Db::name('media_log')->where(array('aid'=>array('IN', $aidArr)))->delete();
- }
- }
- // 同时删除TAG标签
- model('Taglist')->delByAids($aidArr);
- }
- }
|