doesn't work '/\f/' ); $replace = array( '\\\\\\', '\\"', '\\$', '\\t', '\\r', '\\n', // '\\b', '\\f', ); $string = preg_replace($special, $replace, $string); return '"' . $string . '"'; } public static function renderDictionaryKey($key) { if (preg_match('/^[a-z_]+[a-z0-9_]*$/i', $key)) { return static::escapeIfReserved($key); } else { return static::renderString($key); } } // Requires an array public static function renderArray($array) { $data = array(); foreach ($array as $entry) { if ($entry instanceof IcingaConfigRenderer) { $data[] = $entry; } else { $data[] = self::renderString($entry); } } return static::renderEscapedArray($data); } public static function renderEscapedArray($array) { $str = '[ ' . implode(', ', $array) . ' ]'; if (strlen($str) < 60) { return $str; } // Prefix for toConfigString? return "[\n " . implode(",\n ", $array) . "\n]"; } public static function renderDictionary($dictionary) { $vals = array(); foreach ($dictionary as $key => $value) { $vals[$key] = rtrim( self::renderKeyValue( self::renderDictionaryKey($key), $value ) ); } if (empty($vals)) { return '{}'; } ksort($vals, SORT_STRING); // Prefix for toConfigString? return "{\n" . implode("\n", $vals) . "\n}"; } public static function renderExpression($string) { return "{{\n " . $string . "\n}}"; } public static function alreadyRendered($string) { return new IcingaConfigRendered($string); } public static function isReserved($string) { return in_array($string, self::$reservedWords, true); } public static function escapeIfReserved($string) { if (self::isReserved($string)) { return '@' . $string; } else { return $string; } } public static function isValidInterval($interval) { if (ctype_digit($interval)) { return true; } $parts = preg_split('/\s+/', $interval, -1, PREG_SPLIT_NO_EMPTY); foreach ($parts as $part) { if (! preg_match('/^(\d+)([dhms]?)$/', $part)) { return false; } } return true; } public static function parseInterval($interval) { if ($interval === null || $interval === '') { return null; } if (ctype_digit($interval)) { return (int) $interval; } $parts = preg_split('/\s+/', $interval, -1, PREG_SPLIT_NO_EMPTY); $value = 0; foreach ($parts as $part) { if (! preg_match('/^(\d+)([dhms]?)$/', $part, $m)) { throw new ProgrammingError( '"%s" is not a valid time (duration) definition', $interval ); } switch ($m[2]) { case 'd': $value += $m[1] * 86400; break; case 'h': $value += $m[1] * 3600; break; case 'm': $value += $m[1] * 60; break; default: $value += (int) $m[1]; } } return $value; } public static function renderInterval($interval) { // TODO: compat only, do this at munge time. All db fields should be int $seconds = self::parseInterval($interval); if ($seconds === 0) { return '0s'; } $steps = array( 'd' => 86400, 'h' => 3600, 'm' => 60, ); foreach ($steps as $unit => $duration) { if ($seconds % $duration === 0) { return (int) floor($seconds / $duration) . $unit; } } return $seconds . 's'; } public static function stringHasMacro($string) { return preg_match('/(?