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); } /** * @return \Pterodactyl\Models\User */ public function getApiUser(): User { return $this->user; } /** * @return \Pterodactyl\Models\ApiKey */ public function getApiKey(): ApiKey { return $this->key; } /** * Creates a new default API key and refreshes the headers using it. * * @param \Pterodactyl\Models\User $user * @param array $permissions * @return \Pterodactyl\Models\ApiKey */ 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. * * @param \Pterodactyl\Models\ApiKey $key */ protected function refreshHeaders(ApiKey $key) { $this->withHeader('Authorization', 'Bearer ' . $key->identifier . decrypt($key->token)); } /** * Create an administrative user. * * @return \Pterodactyl\Models\User */ protected function createApiUser(): User { return User::factory()->create([ 'root_admin' => true, ]); } /** * Create a new application API key for a given user model. * * @param \Pterodactyl\Models\User $user * @param array $permissions * @return \Pterodactyl\Models\ApiKey */ 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. * * @param string $abstract * @return \Pterodactyl\Transformers\Api\Application\BaseTransformer */ protected function getTransformer(string $abstract): BaseTransformer { /** @var \Pterodactyl\Transformers\Api\Application\BaseTransformer $transformer */ $transformer = $this->app->make($abstract); $transformer->setKey($this->getApiKey()); Assert::assertInstanceOf(BaseTransformer::class, $transformer); Assert::assertNotInstanceOf(BaseClientTransformer::class, $transformer); return $transformer; } }