user = $this->createApiUser(); $this->key = $this->createApiKey($this->user); $this->withHeader('Accept', 'application/vnd.pterodactyl.v1+json'); $this->withHeader('Authorization', 'Bearer ' . $this->getApiKey()->identifier . decrypt($this->getApiKey()->token)); $this->withMiddleware('api..key:' . ApiKey::TYPE_APPLICATION); } public function getApiUser(): User { return $this->user; } public function getApiKey(): ApiKey { return $this->key; } /** * Creates a new default API key and refreshes the headers using it. */ protected function createNewDefaultApiKey(User $user, array $permissions = []): ApiKey { $this->key = $this->createApiKey($user, $permissions); $this->refreshHeaders($this->key); return $this->key; } /** * Refresh the authorization header for a request to use a different API key. */ protected function refreshHeaders(ApiKey $key) { $this->withHeader('Authorization', 'Bearer ' . $key->identifier . decrypt($key->token)); } /** * Create an administrative user. */ protected function createApiUser(): User { return User::factory()->create([ 'root_admin' => true, ]); } /** * Create a new application API key for a given user model. */ protected function createApiKey(User $user, array $permissions = []): ApiKey { return ApiKey::factory()->create(array_merge([ 'user_id' => $user->id, 'key_type' => ApiKey::TYPE_APPLICATION, 'r_servers' => AdminAcl::READ | AdminAcl::WRITE, 'r_nodes' => AdminAcl::READ | AdminAcl::WRITE, 'r_allocations' => AdminAcl::READ | AdminAcl::WRITE, 'r_users' => AdminAcl::READ | AdminAcl::WRITE, 'r_locations' => AdminAcl::READ | AdminAcl::WRITE, 'r_nests' => AdminAcl::READ | AdminAcl::WRITE, 'r_eggs' => AdminAcl::READ | AdminAcl::WRITE, 'r_database_hosts' => AdminAcl::READ | AdminAcl::WRITE, 'r_server_databases' => AdminAcl::READ | AdminAcl::WRITE, ], $permissions)); } /** * Return a transformer that can be used for testing purposes. */ protected function getTransformer(string $abstract): BaseTransformer { $request = Request::createFromGlobals(); $request->setUserResolver(function () { return $this->getApiKey()->user; }); $transformer = $abstract::fromRequest($request); Assert::assertInstanceOf(BaseTransformer::class, $transformer); Assert::assertNotInstanceOf(BaseClientTransformer::class, $transformer); return $transformer; } }