HEX
Server: nginx/1.22.1
System: Linux VM-16-9-centos 3.10.0-1160.99.1.el7.x86_64 #1 SMP Wed Sep 13 14:19:20 UTC 2023 x86_64
User: www (1001)
PHP: 7.3.31
Disabled: passthru,exec,system,putenv,chroot,chgrp,chown,shell_exec,popen,proc_open,pcntl_exec,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,imap_open,apache_setenv
Upload Files
File: /www/wwwroot/oa.sanjiangapp.com/app/sys/block/model.php
<?php
/**
 * The model file of block module of ZDOO.
 *
 * @copyright   Copyright 2009-2018 青岛易软天创网络科技有限公司(QingDao Nature Easy Soft Network Technology Co,LTD, www.cnezsoft.com)
 * @license     ZPL (http://zpl.pub/page/zplv12.html)
 * @author      Yidong Wang <yidong@cnezsoft.com>
 * @package     block
 * @version     $Id$
 * @link        http://www.zdoo.com
 */
class blockModel extends model
{
    /**
     * Save params
     *
     * @param  int    $id
     * @param  string $type
     * @param  string $appName
     * @access public
     * @return void
     */
    public function save($id = 0, $type = 'system', $appName = 'sys')
    {
        $data = fixer::input('post')
            ->add('account', $this->app->user->account)
            ->add('id', $id)
            ->add('app', $appName)
            ->add('hidden', 0)
            ->stripTags('html', $this->config->allowedTags)
            ->setIF($type != 'system', 'block', $type)
            ->setDefault('grid', '4')
            ->setDefault('source', $appName)
            ->setDefault('params', array())
            ->get();

        $block = $this->dao->select('*')->from(TABLE_BLOCK)->where('`id`')->eq($data->id)->fetch();

        if($block)
        {
            $data->height = $block->height;
            $data->order  = $block->order;
        }
        else
        {
            $data->order = $this->getLastKey($appName) + 1;
        }

        if($type != 'system') $data->source = '';
        if($type == 'html')
        {
            $data = $this->loadModel('file')->processImgURL($data, 'html', $this->post->uid);
            $data->params['html'] = $data->html;
            unset($data->html);
        }
        $data->params = helper::jsonEncode($data->params);

        $this->dao->replace(TABLE_BLOCK)->data($data, 'uid')->exec();
    }

    /**
     * Get content for entry block.
     *
     * @param  object    $block
     * @access public
     * @return string
     */
    public function getEntry($block = null)
    {
        if(empty($block)) return false;
        $entry = $this->loadModel('entry')->getByCode($block->source);

        if(empty($block->params)) $block->params = new stdclass();

        $block->params->account = $this->app->user->account;
        $block->params->uid     = $this->app->user->id;
        $block->params->grid    = $block->grid;
        $params = base64_encode(json_encode($block->params));

        $query['mode']    = 'getblockdata';
        $query['blockid'] = $block->block;
        $query['hash']    = $entry->key;
        $query['entry']   = $entry->id;
        $query['app']     = 'sys';
        $query['lang']    = str_replace('-', '_', $this->app->getClientLang());
        $query['sso']     = base64_encode(commonModel::getSysURL() . helper::createLink('entry', 'visit', "entry=$entry->id"));
        $query['user']    = $this->app->user->account;
        if(isset($params)) $query['param'] = $params;

        $query     = http_build_query($query);
        $parsedUrl = parse_url($entry->block);
        $parsedUrl['query'] = empty($parsedUrl['query']) ? $query : $parsedUrl['query'] . "&" . $query;

        $link = '';
        if(!isset($parsedUrl['scheme']))
        {
            $link  = commonModel::getSysURL() . $parsedUrl['path'];
            $link .= '?' . $parsedUrl['query'];
        }
        else
        {
            $link .= $parsedUrl['scheme'] . '://' . $parsedUrl['host'];
            if(isset($parsedUrl['port'])) $link .= ':' . $parsedUrl['port'];
            if(isset($parsedUrl['path'])) $link .= $parsedUrl['path'];
            $link .= '?' . $parsedUrl['query'];
        }

        /* Send login request. */
        $loginObj = "<div class='block-entry-login hidden' data-url=" . helper::createLink('sys.entry', 'visit', "entryID={$entry->id}")  . "></div>";
        return $loginObj . str_replace('panel-body', '', commonModel::http($link));
    }

    /**
     * Get content when type is rss
     *
     * @param  object    $block
     * @access public
     * @return string
     */
    public function getRss($block = null)
    {
        if(empty($block)) return false;
        $http = $this->app->loadClass('http');

        $xml = $http->get(htmlspecialchars_decode($block->params->link));

        $xpc = xml_parser_create();
        xml_parse_into_struct($xpc, $xml, $values);
        xml_parser_free($xpc);

        $channelTags = array();
        $itemTags    = array();
        $inItem      = false;
        foreach($values as $value)
        {
            $tag = strtolower($value['tag']);
            if($value['tag'] == 'ITEM' and $value['type'] == 'open')  $inItem = true;
            if($value['tag'] == 'ITEM' and $value['type'] == 'close') $inItem = false;

            /* The level of text node is 3 in channel. */
            if(!$inItem and $value['type'] == 'complete' and $value['level'] == 3) $channelTags[$tag] = isset($value['value']) ? $value['value'] : '';
            /* The level of text node is 4 in item. */
            if($inItem  and $value['type'] == 'complete' and $value['level'] == 4) $itemTags[$tag][]  = isset($value['value']) ? $value['value'] : '';
        }

        $maxNum = $block->params->num == 0 ? count(current($itemTags)) : $block->params->num;
        $html   = "<div class='list-group'>";
        for($i = 0; $i < $maxNum; $i++)
        {
            $title = '';
            foreach(array_keys($itemTags) as $tag)
            {
                if($tag == 'title')
                {
                    $title = $itemTags[$tag][$i];
                }
                elseif($tag == 'pubdate')
                {
                    $time = date('n-j H:s',strtotime($itemTags[$tag][$i]));
                    $html .= "<a class='list-group-item' target='_blank' href='{$itemTags['link'][$i]}'><small class='text-muted pull-right'>{$time}</small><h5 class='list-group-item-heading small text-ellipsis'>{$title}</h5></a>";
                }
            }
        }

        return $html . '</div>';
    }

    /**
     * Get block by ID.
     *
     * @param  int    $id
     * @access public
     * @return object
     */
    public function getByID($id = 0)
    {
        $block = $this->dao->select('*')->from(TABLE_BLOCK)
            ->where('id')->eq($id)
            ->fetch();
        if(empty($block)) return false;

        $block->params = json_decode($block->params);
        if(empty($block->params)) $block->params = new stdclass();
        if($block->block == 'html') $block->params = $this->loadModel('file')->replaceImgURL($block->params, 'html');
        return $block;
    }

    /**
     * Get last key.
     *
     * @param  string $appName
     * @access public
     * @return int
     */
    public function getLastKey($appName = 'sys')
    {
        $index = $this->dao->select('`order`')->from(TABLE_BLOCK)
            ->where('app')->eq($appName)
            ->andWhere('account')->eq($this->app->user->account)
            ->orderBy('order desc')
            ->limit(1)
            ->fetch('order');
        return $index ? $index : 0;
    }

    /**
     * Get block list for account.
     *
     * @param  string $appName
     * @access public
     * @return void
     */
    public function getBlockList($appName = 'sys')
    {
        $blocks = $this->dao->select('*')->from(TABLE_BLOCK)->where('account')->eq($this->app->user->account)
            ->andWhere('app')->eq($appName)
            ->andWhere('hidden')->eq(0)
            ->orderBy('`order`')
            ->fetchAll('order');

        foreach($blocks as $key => $block)
        {
            $block->fixedSize = $this->checkBlockFixedSize($block);

            $openBlocks = $this->app->clientDevice == 'mobile' ? 'html,allEntries,dynamic' : 'html,allEntries,dynamic,attend';
            if(strpos($openBlocks, $block->block) !== false) continue;

            $entry = $this->loadModel('entry')->getByCode($block->source);
            if($entry && !$entry->buildin) continue;

            $module = $block->block;
            $method = 'browse';

            if(strpos('blog, project', $block->block) !== false) $method = 'index';
            if($block->block == 'attend') $method = 'personal';
            if($block->block == 'thread')
            {
                $module = 'forum';
                $method = 'board';
            }

            if(strpos(',baseFacts,funds,chart,report,', ",{$block->block},") !== false) $module = 'trade';
            if($block->block == 'report') $method = 'report';

            if(isset($this->config->mainMenu->alias[$module]))
            {
                if(!commonModel::hasPriv($module, $method) && !commonModel::hasPriv($this->config->mainMenu->alias[$module], $method)) unset($blocks[$key]);
            }
            else
            {
                if(!commonModel::hasPriv($module, $method)) unset($blocks[$key]);
            }
        }
        return $blocks;
    }

    /**
     * Get hidden blocks
     *
     * @access public
     * @return array
     */
    public function getHiddenBlocks()
    {
        return $this->dao->select('*')->from(TABLE_BLOCK)->where('account')->eq($this->app->user->account)
            ->andWhere('app')->eq('sys')
            ->andWhere('hidden')->eq(1)
            ->orderBy('`order`')
            ->fetchAll('order');
    }

    /**
     * Init block when account use first.
     *
     * @param  string    $appName
     * @access public
     * @return bool
     */
    public function initBlock($appName = 'sys')
    {
        $this->app->loadLang('block', 'sys');
        $blocks  = $this->lang->block->default[$appName];
        $account = $this->app->user->account;

        /* Mark this app has init. */
        $this->loadModel('setting')->setItem("$account.$appName.common.blockInited", true);
        foreach($blocks as $index => $block)
        {
            $block['order']   = $index;
            $block['app']     = $appName;
            $block['account'] = $account;
            $block['params']  = isset($block['params']) ? helper::jsonEncode($block['params']) : '';
            if(!isset($block['source'])) $block['source'] = $appName;

            $this->dao->replace(TABLE_BLOCK)->data($block)->exec();
        }

        return !dao::isError();
    }

    /**
     * Check block is long block or not.
     *
     * @param  int    $block
     * @access public
     * @return void
     */
    public function isLongBlock($block)
    {
        if(empty($block)) return true;
        $fixedSize = $this->checkBlockFixedSize($block);
        if($fixedSize == 'long')  return true;
        if($fixedSize == 'short') return false;
        return $block->grid >= 6;
    }

    /**
     * Check block is fixed long or short
     * @return string 'long', 'short' or ''
     */
    public function checkBlockFixedSize($block)
    {
        if(empty($block)) return false;
        if(strpos($this->config->block->fixedLongBlocks, $block->block) !== false) return 'long';
        if(strpos($this->config->block->fixedShortBlocks, $block->block) !== false) return 'short';
        return '';
    }
}