File: /www/wwwroot//mw.umchkw.com/application/admin/model/MediaFile.php
<?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 MediaFile extends Model
{
//初始化
protected function initialize()
{
// 需要调用`Model`的`initialize`方法
parent::initialize();
}
/**
* 删除单条视频文章的所有视频
* @author 小虎哥 by 2018-4-3
*/
public function delVideoFile($aid = array())
{
if (!is_array($aid)) {
$aid = array($aid);
}
$file_url_list = Db::name('media_file')->where(['aid'=>['IN', $aid]])->column('file_url');
$result = Db::name('media_file')->where(['aid'=>['IN', $aid]])->delete();
if ($result !== false) {
Db::name('media_log')->where(['aid'=>['IN', $aid]])->delete();
foreach ($file_url_list as $key => $val) {
$file_url_tmp = preg_replace('#^(/[/\w]+)?(/uploads/media/)#i', '.$2', $val);
if (!is_http_url($val) && file_exists($file_url_tmp)) {
@unlink($file_url_tmp);
}
}
}
\think\Cache::clear('media_file');
return $result;
}
/**
* 获取指定下载文章的所有文件
* @author 小虎哥 by 2018-4-3
*/
public function getMediaFile($aid, $field = '*')
{
if (!is_dir('./weapp/Videogroup/')) {
$result = Db::name('media_file')->field($field)
->where('aid', $aid)
->order('sort_order asc,file_id asc')
->select();
} else { // 安装了视频章节分组插件
$videogroupLogic = new \weapp\Videogroup\logic\VideogroupLogic;
$weappData = $videogroupLogic->getWeappData();
if (!empty($weappData['is_open'])) { // 开启
$result = Db::name('media_file')->alias('a')
->field('a.*, b.group_id as video_group_id,c.sort_order as c_sort,c.group_name')
->join('weapp_videogroup_file b', 'a.file_id = b.file_id', 'LEFT')
->join('weapp_videogroup c', 'c.aid = a.aid and c.group_id = b.group_id', 'LEFT')
->where('a.aid', $aid)
->order('c_sort asc,a.sort_order asc,a.file_id asc')
->select();
if (!empty($result)){
foreach ($result as $k => $v){
if (empty($v['video_group_id'])){
$result[] = $v;
unset($result[$k]);
}else{
break;
}
}
$result = array_merge($result);
}
} else { // 关闭
$result = Db::name('media_file')->field($field)
->where('aid', $aid)
->order('sort_order asc,file_id asc')
->select();
}
}
return $result;
}
/**
* 保存视频文章的视频
* @author 小虎哥 by 2018-4-3
*/
public function savefile($aid, $video_files = [], $opt = 'add')
{
if (!empty($video_files)) {
if ('add' == $opt) {
$redata = self::saveAll($video_files);
// 视频章节分组插件
if (is_dir('./weapp/Videogroup/')) {
$videogroupfiles = [];
foreach ($redata as $k1 => $v1) {
$video_group_id = $v1->getData('video_group_id');
$videogroupfiles[] = [
'file_id' => $v1->getData('file_id'),
'aid' => $v1->getData('aid'),
'group_id' => intval($video_group_id),
'add_time' => getTime(),
'update_time' => getTime(),
];
}
if (!empty($videogroupfiles)) {
Db::name('weapp_videogroup_file')->insertAll($videogroupfiles);
}
}
} else if ('edit' == $opt) {
$videogroupfiles = [];
$file_ids = [];
$insert = [];
foreach ($video_files as $k =>$v){
if (!empty($v['file_id'])){
$file_ids[] = $v['file_id'];
}else{
unset($v['file_id']);
$insert[] = $v;
unset($video_files[$k]);
}
}
$file_url_list = Db::name('media_file')->where('aid',$aid)->column('file_url');
Db::name('media_file')->where('aid',$aid)->where('file_id','not in',$file_ids)->delete();
// 更新
$update = self::saveAll($video_files);
foreach ($update as $k1 => $v1) {
$video_group_id = $v1->getData('video_group_id');
$videogroupfiles[] = [
'file_id' => $v1->getData('file_id'),
'aid' => $v1->getData('aid'),
'group_id' => intval($video_group_id),
'add_time' => getTime(),
'update_time' => getTime(),
];
}
//插入
$insert = self::saveAll($insert);
if (!empty($update) || !empty($insert)) {
foreach ($insert as $k1 => $v1) {
$video_group_id = $v1->getData('video_group_id');
$videogroupfiles[] = [
'file_id' => $v1->getData('file_id'),
'aid' => $v1->getData('aid'),
'group_id' => intval($video_group_id),
'add_time' => getTime(),
'update_time' => getTime(),
];
}
\think\Cache::clear('media_file');
foreach ($video_files as $k => $v) {
$index_key = array_search($v['file_url'], $file_url_list);
if (false !== $index_key && 0 <= $index_key) {
unset($file_url_list[$index_key]);
}
}
try {
foreach ($file_url_list as $key => $val) {
$file_url_tmp = preg_replace('#^(/[/\w]+)?(/uploads/media/)#i', '.$2', $val);
if (!is_http_url($val) && file_exists($file_url_tmp)) {
@unlink($file_url_tmp);
}
}
} catch (\Exception $e) {}
}
// 视频章节分组插件
if (is_dir('./weapp/Videogroup/')) {
Db::name('weapp_videogroup_file')->where('aid',$aid)->delete();
if (!empty($videogroupfiles)) {
Db::name('weapp_videogroup_file')->insertAll($videogroupfiles);
}
}
}
}else{
if ('edit' == $opt) {
Db::name('media_file')->where('aid',$aid)->delete();
// 视频章节分组插件
if (is_dir('./weapp/Videogroup/')) {
Db::name('weapp_videogroup_file')->where('aid',$aid)->delete();
}
}
}
}
}