GOOD SHELL MAS BOY
Server: Apache/2.4.52 (Ubuntu)
System: Linux vmi1836763.contaboserver.net 5.15.0-130-generic #140-Ubuntu SMP Wed Dec 18 17:59:53 UTC 2024 x86_64
User: www-data (33)
PHP: 8.4.10
Disabled: NONE
Upload Files
File: /var/www/admin.fixgini.com/vendor/cloudinary/transformation-builder-sdk/src/Utils/StringUtils.php
<?php
/**
 * This file is part of the Cloudinary PHP package.
 *
 * (c) Cloudinary
 *
 * For the full copyright and license information, please view the LICENSE
 * file that was distributed with this source code.
 */

namespace Cloudinary;

/**
 * Class StringUtils
 *
 * @internal
 */
class StringUtils
{
    const MAX_STRING_LENGTH = 255;

    /**
     * Converts camelCase to snake_case.
     *
     * @param string $input     The input string.
     * @param string $separator Optional custom separator.
     *
     * @return string
     */
    public static function camelCaseToSnakeCase($input, $separator = '_')
    {
        return strtolower(preg_replace('/(?<!^)[A-Z]/', $separator . '$0', $input));
    }

    /**
     * Converts snake_case to camelCase.
     *
     * @param string $input     The input string.
     * @param string $separator Optional custom separator.
     *
     * @return string
     */
    public static function snakeCaseToCamelCase($input, $separator = '_')
    {
        return lcfirst(str_replace($separator, '', ucwords($input, $separator)));
    }

    /**
     * Creates acronym from input string.
     *
     * Example: my_input_string -> mis; color_space -> cs;
     *
     * @param string $input      The input string.
     * @param array  $exclusions The list of words to omit from acronym. Useful for internal names.
     * @param string $delimiter  The delimiter between words.
     *
     * @return string
     */
    public static function toAcronym($input, $exclusions = [], $delimiter = '_')
    {
        $acronym = '';

        foreach (ArrayUtils::safeFilter(ArrayUtils::blacklist(explode($delimiter, $input), $exclusions)) as $word) {
            $acronym .= $word[0];
        }

        return $acronym;
    }

    /**
     * Determines whether $haystack starts with $needle.
     *
     * @param string $haystack The string to search in.
     * @param string $needle   The string to search for.
     *
     * @return bool
     */
    public static function startsWith($haystack, $needle)
    {
        if (empty($haystack)) {
            return false;
        }

        return strpos($haystack, $needle) === 0;
    }

    /**
     * Determines whether $haystack ends with $needle.
     *
     * @param string $haystack The string to search in.
     * @param string $needle   The string to search for.
     *
     * @return bool
     */
    public static function endsWith($haystack, $needle)
    {
        $length = strlen($needle);
        if ($length === 0) {
            return true;
        }

        return (substr($haystack, -$length) === $needle);
    }

    /**
     * Ensures that the string is wrapped with specified character(s).
     *
     * @param string $string The input string.
     * @param string $char   The wrapping character(s).
     *
     * @return string
     */
    public static function ensureWrappedWith($string, $char)
    {
        if (! self::startsWith($string, $char)) {
            $string = $char . $string;
        }

        if (! self::endsWith($string, $char)) {
            $string .= $char;
        }

        return $string;
    }

    /**
     * Determines whether $haystack contains $needle.
     *
     * @param string $haystack The string to search in.
     * @param string $needle   The string to search for.
     *
     * @return bool
     */
    public static function contains($haystack, $needle)
    {
        if (empty($haystack)) {
            return false;
        }

        return strpos($haystack, $needle) !== false;
    }

    /**
     * Truncates prefix from the string.
     *
     * @param string $string The input string.
     * @param string $prefix Prefix to truncate.
     *
     * @return string The resulting string.
     */
    public static function truncatePrefix($string, $prefix)
    {
        if (self::startsWith($string, $prefix)) {
            return substr($string, strlen($prefix));
        }

        return $string;
    }

    /**
     * Removes characters from the middle of the string to ensure it is no more than $maxLength characters long.
     *
     * Removed characters are replaced with $glue, which is by default '...'.
     *
     * This method will give priority to the right-hand side of the string when data is truncated.
     *
     * @param string $string    The input string.
     * @param int    $maxLength Maximum string length.
     * @param string $glue
     *
     * @return string
     */
    public static function truncateMiddle($string, $maxLength = self::MAX_STRING_LENGTH, $glue = '...')
    {
        // Early exit if no truncation necessary
        if (strlen($string) <= $maxLength) {
            return $string;
        }

        $numRightChars = ceil($maxLength / 2);

        $numLeftChars = floor($maxLength / 2);
        $glue         = substr($glue, 0, $numLeftChars); // Pathological case, when glue is longer than a half
        $numLeftChars -= strlen($glue);

        return sprintf('%s%s%s', substr($string, 0, $numLeftChars), $glue, substr($string, 0 - $numRightChars));
    }

    /**
     * Ensures that string starts with prefix.
     *
     * @param string $string The string to search in.
     * @param string $prefix The string to search for.
     *
     * @return string
     */
    public static function ensureStartsWith($string, $prefix)
    {
        if (! self::startsWith($string, $prefix)) {
            return $prefix . $string;
        }

        return $string;
    }

    /**
     * Based on http://stackoverflow.com/a/1734255/526985
     *
     * @param string $str The input string.
     *
     * @return string Resulting string.
     */
    public static function smartEscape($str)
    {
        $revert = ['%3A' => ':', '%2F' => '/'];

        return strtr(rawurlencode($str), $revert);
    }

    /**
     * URL-encodes dot (.) character
     *
     * @param string $string The input string
     *
     * @return string|string[]|null
     */
    public static function encodeDot($string)
    {
        return str_replace('.', '%2E', $string);
    }

    /**
     * Escapes characters.
     *
     * @param string       $string      The input string.
     * @param string|array $unsafeChars The list of the characters to escape.
     *
     * @return string|string[]|null
     */
    public static function escapeUnsafeChars($string, $unsafeChars)
    {
        if (empty($unsafeChars)) {
            return $string;
        }

        if (is_array($unsafeChars)) {
            $unsafeChars = implode($unsafeChars);
        }

        return preg_replace('/([' . preg_quote($unsafeChars, '/') . '])/', '\\\$1', $string);
    }

    /**
     * Encodes data with URL safe base64.
     *
     * @see https://tools.ietf.org/html/rfc4648#section-5
     *
     * @param mixed $data The data to encode.
     *
     * @return string The encoded data, as a string.
     *
     * @internal
     */
    public static function base64UrlEncode($data)
    {
        return strtr(base64_encode($data), '+/', '-_');
    }

    /**
     * Wrapper around parse_str, returns query parameters.
     *
     * @param string $query The query string.
     *
     * @return array Query parameters.
     *
     * @see parse_str
     */
    public static function parseQueryString($query)
    {
        $params = [];
        if (! empty($query)) {
            parse_str($query, $params);
        }

        return $params;
    }
}