mirror of
https://github.com/shlinkio/shlink.git
synced 2025-01-07 06:34:05 -06:00
Explicitly imported global functions in UrlShortener
This commit is contained in:
parent
459f807e67
commit
e1222de05b
@ -18,6 +18,11 @@ use Shlinkio\Shlink\Core\Exception\NonUniqueSlugException;
|
|||||||
use Shlinkio\Shlink\Core\Exception\RuntimeException;
|
use Shlinkio\Shlink\Core\Exception\RuntimeException;
|
||||||
use Shlinkio\Shlink\Core\Repository\ShortUrlRepository;
|
use Shlinkio\Shlink\Core\Repository\ShortUrlRepository;
|
||||||
use Shlinkio\Shlink\Core\Util\TagManagerTrait;
|
use Shlinkio\Shlink\Core\Util\TagManagerTrait;
|
||||||
|
use Throwable;
|
||||||
|
use function floor;
|
||||||
|
use function fmod;
|
||||||
|
use function preg_match;
|
||||||
|
use function strlen;
|
||||||
|
|
||||||
class UrlShortener implements UrlShortenerInterface
|
class UrlShortener implements UrlShortenerInterface
|
||||||
{
|
{
|
||||||
@ -101,7 +106,7 @@ class UrlShortener implements UrlShortenerInterface
|
|||||||
|
|
||||||
$this->em->commit();
|
$this->em->commit();
|
||||||
return $shortUrl;
|
return $shortUrl;
|
||||||
} catch (\Throwable $e) {
|
} catch (Throwable $e) {
|
||||||
if ($this->em->getConnection()->isTransactionActive()) {
|
if ($this->em->getConnection()->isTransactionActive()) {
|
||||||
$this->em->rollback();
|
$this->em->rollback();
|
||||||
$this->em->close();
|
$this->em->close();
|
||||||
@ -137,13 +142,13 @@ class UrlShortener implements UrlShortenerInterface
|
|||||||
private function convertAutoincrementIdToShortCode(float $id): string
|
private function convertAutoincrementIdToShortCode(float $id): string
|
||||||
{
|
{
|
||||||
$id += self::ID_INCREMENT; // Increment the Id so that the generated shortcode is not too short
|
$id += self::ID_INCREMENT; // Increment the Id so that the generated shortcode is not too short
|
||||||
$length = \strlen($this->chars);
|
$length = strlen($this->chars);
|
||||||
$code = '';
|
$code = '';
|
||||||
|
|
||||||
while ($id > 0) {
|
while ($id > 0) {
|
||||||
// Determine the value of the next higher character in the short code and prepend it
|
// Determine the value of the next higher character in the short code and prepend it
|
||||||
$code = $this->chars[(int) \fmod($id, $length)] . $code;
|
$code = $this->chars[(int) fmod($id, $length)] . $code;
|
||||||
$id = \floor($id / $length);
|
$id = floor($id / $length);
|
||||||
}
|
}
|
||||||
|
|
||||||
return $this->chars[(int) $id] . $code;
|
return $this->chars[(int) $id] . $code;
|
||||||
@ -174,7 +179,7 @@ class UrlShortener implements UrlShortenerInterface
|
|||||||
public function shortCodeToUrl(string $shortCode): ShortUrl
|
public function shortCodeToUrl(string $shortCode): ShortUrl
|
||||||
{
|
{
|
||||||
// Validate short code format
|
// Validate short code format
|
||||||
if (! \preg_match('|[' . $this->chars . ']+|', $shortCode)) {
|
if (! preg_match('|[' . $this->chars . ']+|', $shortCode)) {
|
||||||
throw InvalidShortCodeException::fromCharset($shortCode, $this->chars);
|
throw InvalidShortCodeException::fromCharset($shortCode, $this->chars);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user