-
Notifications
You must be signed in to change notification settings - Fork 10
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Php/http_api #678
base: main
Are you sure you want to change the base?
Php/http_api #678
Conversation
Hey. I don't know what's better for you. I can also make a proposal PR if you like that more. I would rewrite the Authenticator stuff like that: enum Suit: string
{
case CLIENT_CREDENTIALS = 'client_credentials';
case PASSWORD = 'password';
}
interface IAuthenticatorOptions {
}
class ResourceOwnerPasswordGrantAuthenticatorOptions implements IAuthenticatorOptions {
public string $grandType = 'password';
public function __construct(public string $clientId, public string $username, public string $password) {}
}
class ClientCredentialsAuthenticatorOptions implements IAuthenticatorOptions {
public string $grandType = 'client_credentials';
public function __construct(public string $clientId, public string $clientSecret) {}
}
class someAuthenticator {
private function tokenRequestToForm(IAuthenticatorOptions $options): string
{
return match(true) {
$options instanceof ResourceOwnerPasswordGrantAuthenticatorOptions => http_build_query([
'client_id' => $options->clientId,
'username' => $options->username ?? throw new InvalidArgumentException(),
'password' => $options->password ?? throw new InvalidArgumentException(),
'grant_type' => $options->grandType
]),
$options instanceof ClientCredentialsAuthenticatorOptions => http_build_query([
'client_id' => $options->clientId,
'client_secret' => $options->clientSecret ?? throw new InvalidArgumentException(),
'grant_type' => $options->grandType,
])
};
}
} With that change you don't need the knowledge for what grandType does need what fields, because the classes are specific. |
This PR is allot of work. Thank you for tackling it! |
php/src/vaas/Authentication/ClientCredentialsGrantAuthenticator.php
Outdated
Show resolved
Hide resolved
php/src/vaas/Authentication/ResourceOwnerPasswordGrantAuthenticator.php
Outdated
Show resolved
Hide resolved
Since I find it to complicated to explain my proposal about the Authenticator stuff, I made a PR to your PR-Branch. |
Co-authored-by: Matthias Simonis <[email protected]>
The benefit is, that you don't have to do error prone validation of arbitrary in some options-class. The authenticators know the fields they need, so there is no need to validate that because you cannot construct an object without them.
* adds fromVaasOptions function for the forXXXOptions * removes the default() function as it is not used anywhere
…or_proposal Refators the Authenntication stuff
…posal refactors the forXXX-options
Update dependencies
e74ab83
to
ead1756
Compare
No description provided.