mirror of
https://github.com/Lastorder-DC/rhymix.git
synced 2026-01-22 04:39:55 +09:00
- 2022년 3월 개발팀 결정사항 적용 - 모듈 등 서드파티 자료 개발시 composer를 사용하면 상위 경로에 있는 코어의 composer.json을 수정하고, 코어의 vendor 디렉토리를 건드리는 것이 기본값임 - 이를 방지하기 위해 코어의 composer.json과 vendor를 common 디렉토리 안으로 이동하여, 모듈 경로에서 상위 폴더로 인식하지 않도록 함
110 lines
2.8 KiB
PHP
110 lines
2.8 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Takes the contents of blockquote when in strict and reformats for validation.
|
|
*/
|
|
class HTMLPurifier_ChildDef_StrictBlockquote extends HTMLPurifier_ChildDef_Required
|
|
{
|
|
/**
|
|
* @type array
|
|
*/
|
|
protected $real_elements;
|
|
|
|
/**
|
|
* @type array
|
|
*/
|
|
protected $fake_elements;
|
|
|
|
/**
|
|
* @type bool
|
|
*/
|
|
public $allow_empty = true;
|
|
|
|
/**
|
|
* @type string
|
|
*/
|
|
public $type = 'strictblockquote';
|
|
|
|
/**
|
|
* @type bool
|
|
*/
|
|
protected $init = false;
|
|
|
|
/**
|
|
* @param HTMLPurifier_Config $config
|
|
* @return array
|
|
* @note We don't want MakeWellFormed to auto-close inline elements since
|
|
* they might be allowed.
|
|
*/
|
|
public function getAllowedElements($config)
|
|
{
|
|
$this->init($config);
|
|
return $this->fake_elements;
|
|
}
|
|
|
|
/**
|
|
* @param array $children
|
|
* @param HTMLPurifier_Config $config
|
|
* @param HTMLPurifier_Context $context
|
|
* @return array
|
|
*/
|
|
public function validateChildren($children, $config, $context)
|
|
{
|
|
$this->init($config);
|
|
|
|
// trick the parent class into thinking it allows more
|
|
$this->elements = $this->fake_elements;
|
|
$result = parent::validateChildren($children, $config, $context);
|
|
$this->elements = $this->real_elements;
|
|
|
|
if ($result === false) {
|
|
return array();
|
|
}
|
|
if ($result === true) {
|
|
$result = $children;
|
|
}
|
|
|
|
$def = $config->getHTMLDefinition();
|
|
$block_wrap_name = $def->info_block_wrapper;
|
|
$block_wrap = false;
|
|
$ret = array();
|
|
|
|
foreach ($result as $node) {
|
|
if ($block_wrap === false) {
|
|
if (($node instanceof HTMLPurifier_Node_Text && !$node->is_whitespace) ||
|
|
($node instanceof HTMLPurifier_Node_Element && !isset($this->elements[$node->name]))) {
|
|
$block_wrap = new HTMLPurifier_Node_Element($def->info_block_wrapper);
|
|
$ret[] = $block_wrap;
|
|
}
|
|
} else {
|
|
if ($node instanceof HTMLPurifier_Node_Element && isset($this->elements[$node->name])) {
|
|
$block_wrap = false;
|
|
|
|
}
|
|
}
|
|
if ($block_wrap) {
|
|
$block_wrap->children[] = $node;
|
|
} else {
|
|
$ret[] = $node;
|
|
}
|
|
}
|
|
return $ret;
|
|
}
|
|
|
|
/**
|
|
* @param HTMLPurifier_Config $config
|
|
*/
|
|
private function init($config)
|
|
{
|
|
if (!$this->init) {
|
|
$def = $config->getHTMLDefinition();
|
|
// allow all inline elements
|
|
$this->real_elements = $this->elements;
|
|
$this->fake_elements = $def->info_content_sets['Flow'];
|
|
$this->fake_elements['#PCDATA'] = true;
|
|
$this->init = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
// vim: et sw=4 sts=4
|