*/ /** * Admin model class of the file module * @author NAVER (developers@xpressengine.com) */ class FileAdminModel extends File { /** * Initialization * @return void */ public function init() { } /** * Get all the attachments in order by time descending (for administrators) * *
* Search options: * - s_module_srl: int[] or int, search module_srl * - exclude_module_srl: int[] or int, exclude module_srl * - isvalid: Y or N * - direct_download: Y or N * - s_filename: string, like operation * - s_filesize_more: int, more operation, byte unit * - s_filesize_mega_more: int, more operation, mega unit * - s_filesize_less: int, less operation, byte unit * - s_filesize_mega_less: int, less operation, mega unit * - s_download_count: int, more operation * - s_regdate: string(YYYYMMDDHHMMSS), like prefix operation(STRING%) * - s_ipaddress: string, like prefix operation * - s_user_id: string * - s_user_name: string * - s_nick_name: string * - sort_index: string. default: files.file_srl * - page : int * - list_count: int. default: 20 * - page_count: int. default: 10 * * Result data: * - file_srl * - upload_target_srl * - upload_target_type * - sid * - module_srl * - member_srl * - download_count * - direct_download * - source_filename * - uploaded_filename * - file_size * - comment * - isvaild * - regdate * - ipaddress * ** * @param object $obj Search options * @param array $columnList Column list to get from DB * @return Object Object contains query result */ public function getFileList($obj, $columnList = array()) { $args = new stdClass(); $this->_makeSearchParam($obj, $args); // Set valid/invalid state if(isset($obj->isvalid) && in_array($obj->isvalid, ['Y', 'N'])) { $args->isvalid = $obj->isvalid; } // Set multimedia/common file if(isset($obj->direct_download) && in_array($obj->direct_download, ['Y', 'N'])) { $args->direct_download = $obj->direct_download; } // Set variables $args->sort_index = $obj->sort_index ?? null; $args->order_type = $obj->order_type ?? 'desc'; $args->page = isset($obj->page) ? ($obj->page ? $obj->page : 1) : 1; $args->list_count = isset($obj->list_count) ? ($obj->list_count? $obj->list_count : 20) : 20; $args->page_count = isset($obj->page_count) ? ($obj->page_count? $obj->page_count : 10) : 10; $args->s_module_srl = $obj->module_srl ?? null; $args->exclude_module_srl = $obj->exclude_module_srl ?? null; if(toBool($obj->exclude_secret ?? null)) { $args->document_status = array('PUBLIC'); $args->comment_is_secret = array('N'); $output = executeQueryArray('file.getFileListByTargetStatus', $args, $columnList); } else { $output = executeQueryArray('file.getFileList', $args, $columnList); } // Return if no result or an error occurs if(!$output->toBool() || !count($output->data)) { return $output; } foreach($output->data as $key => $file) { if(isset($_SESSION['file_management'][$file->file_srl]) && $_SESSION['file_management'][$file->file_srl]) { $file->isCarted = true; } else { $file->isCarted = false; } $file->download_url = FileModel::getDownloadUrl($file->file_srl, $file->sid, 0, $file->source_filename); $output->data[$key] = $file; } return $output; } /** * Return number of attachments which belongs to a specific document * *
* Result data: * +---------+-------+ * | isvalid | count | * +---------+-------+ * | Y | 00 | * +---------+-------+ * | N | 00 | * +---------+-------+ ** * @param object $obj Search options (not used...) * @return array */ public function getFilesCountByGroupValid($obj = '') { //$this->_makeSearchParam($obj, $args); $output = executeQueryArray('file.getFilesCountByGroupValid', $args); return $output->data; } /** * Return number of attachments which belongs to a specific date * * @param string $date Date string * @return int */ public function getFilesCountByDate($date = '') { $args = new stdClass(); if($date) { $args->regDate = date('Ymd', strtotime($date)); } $output = executeQuery('file.getFilesCount', $args); if(!$output->toBool()) { return 0; } return $output->data->count; } /** * Make search parameters from object(private) * * @param object $obj Original searach options * @param object $args Result searach options * @return void */ protected function _makeSearchParam(&$obj, &$args) { // Search options $search_target = isset($obj->search_target)? ($obj->search_target? $obj->search_target : trim(Context::get('search_target'))) : trim(Context::get('search_target') ?? ''); $search_keyword = isset($obj->search_keyword)? ($obj->search_keyword? $obj->search_keyword : trim(Context::get('search_keyword'))) : trim(Context::get('search_keyword') ?? ''); if($search_target && $search_keyword) { switch($search_target) { case 'filename' : $args->s_filename = $search_keyword; break; case 'filesize_more' : $args->s_filesize_more = (int)$search_keyword; break; case 'filesize_mega_more' : $args->s_filesize_more = (int)$search_keyword * 1024 * 1024; break; case 'filesize_less' : $args->s_filesize_less = (int)$search_keyword; break; case 'filesize_mega_less' : $args->s_filesize_less = (int)$search_keyword * 1024 * 1024; break; case 'download_count' : $args->s_download_count = (int)$search_keyword; break; case 'download_count_less' : $args->s_download_count_less = (int)$search_keyword; break; case 'regdate' : $args->s_regdate = $search_keyword; break; case 'ipaddress' : $args->s_ipaddress = $search_keyword; break; case 'user_id' : $args->s_user_id = $search_keyword; break; case 'user_name' : $args->s_user_name = $search_keyword; break; case 'nick_name' : $args->s_nick_name = $search_keyword; break; case 'isvalid' : $args->isvalid = $search_keyword; break; } } } } /* End of file file.admin.model.php */ /* Location: ./modules/file/file.admin.model.php */