Skip to content

Commit

Permalink
Merge pull request #2294 from acelaya-forks/feature/user-agent
Browse files Browse the repository at this point in the history
Migrate from mobiledetectlib to phpuseragentparser
  • Loading branch information
acelaya authored Nov 28, 2024
2 parents d121d4d + 6331fa3 commit 3f30af4
Show file tree
Hide file tree
Showing 2 changed files with 9 additions and 12 deletions.
2 changes: 1 addition & 1 deletion composer.json
Original file line number Diff line number Diff line change
Expand Up @@ -23,6 +23,7 @@
"doctrine/dbal": "^4.2",
"doctrine/migrations": "^3.8",
"doctrine/orm": "^3.3",
"donatj/phpuseragentparser": "^1.10",
"endroid/qr-code": "^6.0",
"friendsofphp/proxy-manager-lts": "^1.0",
"geoip2/geoip2": "^3.0",
Expand All @@ -39,7 +40,6 @@
"mezzio/mezzio-fastroute": "^3.12",
"mezzio/mezzio-problem-details": "^1.15",
"mlocati/ip-lib": "^1.18.1",
"mobiledetect/mobiledetectlib": "4.8.x-dev#920c549 as 4.9",
"pagerfanta/core": "^3.8",
"ramsey/uuid": "^4.7",
"shlinkio/doctrine-specification": "^2.1.1",
Expand Down
19 changes: 8 additions & 11 deletions module/Core/src/Model/DeviceType.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,8 @@

namespace Shlinkio\Shlink\Core\Model;

use Detection\MobileDetect;
use donatj\UserAgent\Platforms;
use donatj\UserAgent\UserAgentParser;

enum DeviceType: string
{
Expand All @@ -12,17 +13,13 @@ enum DeviceType: string

public static function matchFromUserAgent(string $userAgent): self|null
{
$detect = new MobileDetect();
$detect->setUserAgent($userAgent);
static $uaParser = new UserAgentParser();
$ua = $uaParser->parse($userAgent);

return match (true) {
// $detect->is('iOS') && $detect->isTablet() => self::IOS, // TODO To detect iPad only
// $detect->is('iOS') && ! $detect->isTablet() => self::IOS, // TODO To detect iPhone only
// $detect->is('androidOS') && $detect->isTablet() => self::ANDROID, // TODO To detect Android tablets
// $detect->is('androidOS') && ! $detect->isTablet() => self::ANDROID, // TODO To detect Android phones
$detect->is('iOS') => self::IOS, // Detects both iPhone and iPad
$detect->is('androidOS') => self::ANDROID, // Detects both android phones and android tablets
! $detect->isMobile() && ! $detect->isTablet() => self::DESKTOP,
return match ($ua->platform()) {
Platforms::IPHONE, Platforms::IPAD => self::IOS, // Detects both iPhone and iPad (except iPadOS 13+)
Platforms::ANDROID => self::ANDROID, // Detects both android phones and android tablets
Platforms::LINUX, Platforms::WINDOWS, Platforms::MACINTOSH, Platforms::CHROME_OS => self::DESKTOP,
default => null,
};
}
Expand Down

0 comments on commit 3f30af4

Please sign in to comment.