Find this useful? Enter your email to receive occasional updates for securing PHP code.

Signing you up...

Thank you for signing up!

PHP Decode

<?php trait HomepageFunctions { public function homepageCheckKeyPermissions($key, $permi..

Decoded Output download

<?php

trait HomepageFunctions
{
	public function homepageCheckKeyPermissions($key, $permissions)
	{
		if (array_key_exists($key, $permissions)) {
			return $permissions[$key];
		} elseif ($key == 'all') {
			return $permissions;
		} else {
			return [];
		}
	}
	
	public function getHomepageSettingsList()
	{
		$methods = get_class_methods($this);
		$searchTerm = 'SettingsArray';
		return array_filter($methods, function ($k) use ($searchTerm) {
			return stripos($k, $searchTerm) !== false;
		}, 0);
	}
	
	public function getHomepageSettingsCombined()
	{
		$list = $this->getHomepageSettingsList();
		$combined = [];
		foreach ($list as $item) {
			$combined[] = $this->$item(true);
		}
		return $combined;
	}
	
	public function homepageItemPermissions($settings = false, $api = false)
	{
		if (!$settings) {
			if ($api) {
				$this->setAPIResponse('error', 'No settings were supplied', 422);
			}
			return false;
		}
		foreach ($settings as $type => $setting) {
			$settingsType = gettype($setting);
			switch ($type) {
				case 'enabled':
					if ($settingsType == 'string') {
						if (!$this->config[$setting]) {
							if ($api) {
								$this->setAPIResponse('error', $setting . ' module is not enabled', 409);
							}
							return false;
						}
					} else {
						foreach ($setting as $item) {
							if (!$this->config[$item]) {
								if ($api) {
									$this->setAPIResponse('error', $item . ' module is not enabled', 409);
								}
								return false;
							}
						}
					}
					break;
				case 'auth':
					if ($settingsType == 'string') {
						if (!$this->qualifyRequest($this->config[$setting])) {
							if ($api) {
								$this->setAPIResponse('error', 'User not approved to view this homepage item', 401);
							}
							return false;
						}
					} else {
						foreach ($setting as $item) {
							if (!$this->qualifyRequest($this->config[$item])) {
								if ($api) {
									$this->setAPIResponse('error', 'User not approved to view this homepage item', 401);
								}
								return false;
							}
						}
					}
					break;
				case 'not_empty':
					if ($settingsType == 'string') {
						if (empty($this->config[$setting])) {
							if ($api) {
								$this->setAPIResponse('error', $setting . ' was not supplied', 422);
							}
							return false;
						}
					} else {
						foreach ($setting as $item) {
							if (empty($this->config[$item])) {
								if ($api) {
									$this->setAPIResponse('error', $item . ' was not supplied', 422);
								}
								return false;
							}
						}
					}
					break;
				default:
					//return false;
			}
		}
		return true;
	}
} ?>

Did this file decode correctly?

Original Code

<?php

trait HomepageFunctions
{
	public function homepageCheckKeyPermissions($key, $permissions)
	{
		if (array_key_exists($key, $permissions)) {
			return $permissions[$key];
		} elseif ($key == 'all') {
			return $permissions;
		} else {
			return [];
		}
	}
	
	public function getHomepageSettingsList()
	{
		$methods = get_class_methods($this);
		$searchTerm = 'SettingsArray';
		return array_filter($methods, function ($k) use ($searchTerm) {
			return stripos($k, $searchTerm) !== false;
		}, 0);
	}
	
	public function getHomepageSettingsCombined()
	{
		$list = $this->getHomepageSettingsList();
		$combined = [];
		foreach ($list as $item) {
			$combined[] = $this->$item(true);
		}
		return $combined;
	}
	
	public function homepageItemPermissions($settings = false, $api = false)
	{
		if (!$settings) {
			if ($api) {
				$this->setAPIResponse('error', 'No settings were supplied', 422);
			}
			return false;
		}
		foreach ($settings as $type => $setting) {
			$settingsType = gettype($setting);
			switch ($type) {
				case 'enabled':
					if ($settingsType == 'string') {
						if (!$this->config[$setting]) {
							if ($api) {
								$this->setAPIResponse('error', $setting . ' module is not enabled', 409);
							}
							return false;
						}
					} else {
						foreach ($setting as $item) {
							if (!$this->config[$item]) {
								if ($api) {
									$this->setAPIResponse('error', $item . ' module is not enabled', 409);
								}
								return false;
							}
						}
					}
					break;
				case 'auth':
					if ($settingsType == 'string') {
						if (!$this->qualifyRequest($this->config[$setting])) {
							if ($api) {
								$this->setAPIResponse('error', 'User not approved to view this homepage item', 401);
							}
							return false;
						}
					} else {
						foreach ($setting as $item) {
							if (!$this->qualifyRequest($this->config[$item])) {
								if ($api) {
									$this->setAPIResponse('error', 'User not approved to view this homepage item', 401);
								}
								return false;
							}
						}
					}
					break;
				case 'not_empty':
					if ($settingsType == 'string') {
						if (empty($this->config[$setting])) {
							if ($api) {
								$this->setAPIResponse('error', $setting . ' was not supplied', 422);
							}
							return false;
						}
					} else {
						foreach ($setting as $item) {
							if (empty($this->config[$item])) {
								if ($api) {
									$this->setAPIResponse('error', $item . ' was not supplied', 422);
								}
								return false;
							}
						}
					}
					break;
				default:
					//return false;
			}
		}
		return true;
	}
}

Function Calls

None

Variables

None

Stats

MD5 069f71fa4074f807fe95b164d6bd93d7
Eval Count 0
Decode Time 120 ms