123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146 |
- <?php
- namespace Laravel\Sanctum;
- use Mockery;
- class Sanctum
- {
- /**
- * The personal access client model class name.
- *
- * @var string
- */
- public static $personalAccessTokenModel = 'Laravel\\Sanctum\\PersonalAccessToken';
- /**
- * A callback that can get the token from the request.
- *
- * @var callable|null
- */
- public static $accessTokenRetrievalCallback;
- /**
- * A callback that can add to the validation of the access token.
- *
- * @var callable|null
- */
- public static $accessTokenAuthenticationCallback;
- /**
- * Indicates if Sanctum's migrations will be run.
- *
- * @var bool
- */
- public static $runsMigrations = true;
- /**
- * Get the current application URL from the "APP_URL" environment variable - with port.
- *
- * @return string
- */
- public static function currentApplicationUrlWithPort()
- {
- $appUrl = config('app.url');
- return $appUrl ? ','.parse_url($appUrl, PHP_URL_HOST).(parse_url($appUrl, PHP_URL_PORT) ? ':'.parse_url($appUrl, PHP_URL_PORT) : '') : '';
- }
- /**
- * Set the current user for the application with the given abilities.
- *
- * @param \Illuminate\Contracts\Auth\Authenticatable|\Laravel\Sanctum\HasApiTokens $user
- * @param array $abilities
- * @param string $guard
- * @return \Illuminate\Contracts\Auth\Authenticatable
- */
- public static function actingAs($user, $abilities = [], $guard = 'sanctum')
- {
- $token = Mockery::mock(self::personalAccessTokenModel())->shouldIgnoreMissing(false);
- if (in_array('*', $abilities)) {
- $token->shouldReceive('can')->withAnyArgs()->andReturn(true);
- } else {
- foreach ($abilities as $ability) {
- $token->shouldReceive('can')->with($ability)->andReturn(true);
- }
- }
- $user->withAccessToken($token);
- if (isset($user->wasRecentlyCreated) && $user->wasRecentlyCreated) {
- $user->wasRecentlyCreated = false;
- }
- app('auth')->guard($guard)->setUser($user);
- app('auth')->shouldUse($guard);
- return $user;
- }
- /**
- * Set the personal access token model name.
- *
- * @param string $model
- * @return void
- */
- public static function usePersonalAccessTokenModel($model)
- {
- static::$personalAccessTokenModel = $model;
- }
- /**
- * Specify a callback that should be used to fetch the access token from the request.
- *
- * @param callable $callback
- * @return void
- */
- public static function getAccessTokenFromRequestUsing(callable $callback)
- {
- static::$accessTokenRetrievalCallback = $callback;
- }
- /**
- * Specify a callback that should be used to authenticate access tokens.
- *
- * @param callable $callback
- * @return void
- */
- public static function authenticateAccessTokensUsing(callable $callback)
- {
- static::$accessTokenAuthenticationCallback = $callback;
- }
- /**
- * Determine if Sanctum's migrations should be run.
- *
- * @return bool
- */
- public static function shouldRunMigrations()
- {
- return static::$runsMigrations;
- }
- /**
- * Configure Sanctum to not register its migrations.
- *
- * @return static
- */
- public static function ignoreMigrations()
- {
- static::$runsMigrations = false;
- return new static;
- }
- /**
- * Get the token model class name.
- *
- * @return string
- */
- public static function personalAccessTokenModel()
- {
- return static::$personalAccessTokenModel;
- }
- }
|