185 lines
5.2 KiB
PHP
185 lines
5.2 KiB
PHP
<?php
|
||
namespace MailPoet\Util;
|
||
use MailPoet\Config\Env;
|
||
|
||
class Helpers {
|
||
const DIVIDER = '***MailPoet***';
|
||
const LINK_TAG = 'link';
|
||
|
||
static function replaceLinkTags($text, $link, $target = '_blank') {
|
||
$text = str_replace(
|
||
'[' . self::LINK_TAG . ']',
|
||
sprintf('<a href="%s" target="%s">', $link, $target),
|
||
$text
|
||
);
|
||
$text = str_replace('[/' . self::LINK_TAG . ']', '</a>', $text);
|
||
return $text;
|
||
}
|
||
|
||
static function getMaxPostSize($bytes = false) {
|
||
$maxPostSize = ini_get('post_max_size');
|
||
if(!$bytes) return $maxPostSize;
|
||
switch(substr($maxPostSize, -1)) {
|
||
case 'M':
|
||
case 'm':
|
||
return (int)$maxPostSize * 1048576;
|
||
case 'K':
|
||
case 'k':
|
||
return (int)$maxPostSize * 1024;
|
||
case 'G':
|
||
case 'g':
|
||
return (int)$maxPostSize * 1073741824;
|
||
default:
|
||
return $maxPostSize;
|
||
}
|
||
}
|
||
|
||
static function flattenArray($array) {
|
||
if(!$array) return;
|
||
$flattened_array = array();
|
||
array_walk_recursive($array, function ($a) use (&$flattened_array) {
|
||
$flattened_array[] = $a;
|
||
});
|
||
return $flattened_array;
|
||
}
|
||
|
||
/*
|
||
* Using func_get_args() in order to check for proper number ofparameters and trigger errors exactly as the built-in array_column()
|
||
* does in PHP 5.5.
|
||
* @author Ben Ramsey (http://benramsey.com)
|
||
*/
|
||
static function arrayColumn($input = null, $columnKey = null, $indexKey = null) {
|
||
$argc = func_num_args();
|
||
$params = func_get_args();
|
||
if($argc < 2) {
|
||
trigger_error("array_column() expects at least 2 parameters, {$argc} given", E_USER_WARNING);
|
||
return null;
|
||
}
|
||
if(!is_array($params[0])) {
|
||
trigger_error(
|
||
'array_column() expects parameter 1 to be array, ' . gettype($params[0]) . ' given',
|
||
E_USER_WARNING
|
||
);
|
||
return null;
|
||
}
|
||
if(!is_int($params[1])
|
||
&& !is_float($params[1])
|
||
&& !is_string($params[1])
|
||
&& $params[1] !== null
|
||
&& !(is_object($params[1]) && method_exists($params[1], '__toString'))
|
||
) {
|
||
trigger_error('array_column(): The column key should be either a string or an integer', E_USER_WARNING);
|
||
return false;
|
||
}
|
||
if(isset($params[2])
|
||
&& !is_int($params[2])
|
||
&& !is_float($params[2])
|
||
&& !is_string($params[2])
|
||
&& !(is_object($params[2]) && method_exists($params[2], '__toString'))
|
||
) {
|
||
trigger_error('array_column(): The index key should be either a string or an integer', E_USER_WARNING);
|
||
return false;
|
||
}
|
||
$paramsInput = $params[0];
|
||
$paramsColumnKey = ($params[1] !== null) ? (string)$params[1] : null;
|
||
$paramsIndexKey = null;
|
||
if(isset($params[2])) {
|
||
if(is_float($params[2]) || is_int($params[2])) {
|
||
$paramsIndexKey = (int)$params[2];
|
||
} else {
|
||
$paramsIndexKey = (string)$params[2];
|
||
}
|
||
}
|
||
$resultArray = array();
|
||
foreach($paramsInput as $row) {
|
||
$key = $value = null;
|
||
$keySet = $valueSet = false;
|
||
if($paramsIndexKey !== null && array_key_exists($paramsIndexKey, $row)) {
|
||
$keySet = true;
|
||
$key = (string)$row[$paramsIndexKey];
|
||
}
|
||
if($paramsColumnKey === null) {
|
||
$valueSet = true;
|
||
$value = $row;
|
||
} elseif(is_array($row) && array_key_exists($paramsColumnKey, $row)) {
|
||
$valueSet = true;
|
||
$value = $row[$paramsColumnKey];
|
||
}
|
||
if($valueSet) {
|
||
if($keySet) {
|
||
$resultArray[$key] = $value;
|
||
} else {
|
||
$resultArray[] = $value;
|
||
}
|
||
}
|
||
}
|
||
return $resultArray;
|
||
}
|
||
|
||
static function underscoreToCamelCase($str, $capitalise_first_char = false) {
|
||
if($capitalise_first_char) {
|
||
$str[0] = strtoupper($str[0]);
|
||
}
|
||
$func = create_function('$c', 'return strtoupper($c[1]);');
|
||
return preg_replace_callback('/_([a-z])/', $func, $str);
|
||
}
|
||
|
||
static function camelCaseToUnderscore($str) {
|
||
$str[0] = strtolower($str[0]);
|
||
$func = create_function('$c', 'return "_" . strtolower($c[1]);');
|
||
return preg_replace_callback('/([A-Z])/', $func, $str);
|
||
}
|
||
|
||
static function joinObject($object = array()) {
|
||
return implode(self::DIVIDER, $object);
|
||
}
|
||
|
||
static function splitObject($object = array()) {
|
||
return explode(self::DIVIDER, $object);
|
||
}
|
||
|
||
/**
|
||
* Convert a timestamp to a Mysql datetime
|
||
*
|
||
* @param int $timestamp Timestamp
|
||
* @return string Datetime
|
||
*/
|
||
static public function mysqlDate($timestamp) {
|
||
return date('Y-m-d H:i:s', $timestamp);
|
||
}
|
||
|
||
|
||
/**
|
||
* Count the number of rows in a table
|
||
*
|
||
* @global object $wpdb
|
||
* @param string $table Table
|
||
* @param bool $withoutPrefix Table name without DB prefix
|
||
* @return int Number of rows found
|
||
*/
|
||
static public function rowsCount($table, $withoutPrefix=true) {
|
||
global $wpdb;
|
||
|
||
if($withoutPrefix) {
|
||
$table = $wpdb->prefix . $table;
|
||
}
|
||
$sql = "SELECT COUNT(*) FROM `$table`";
|
||
$count = $wpdb->get_var($sql);
|
||
|
||
return $count;
|
||
}
|
||
|
||
/**
|
||
* Load a SQL file
|
||
*
|
||
* @param string $filename Filename without extension
|
||
*/
|
||
static public function loadSQL($filename) {
|
||
$db = \ORM::getDb();
|
||
$full_filename = Env::$path . '/tests/_data/' . $filename . '.sql';
|
||
$sql = file_get_contents($full_filename);
|
||
$db->exec($sql);
|
||
}
|
||
|
||
}
|