-
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 SDK: Use VaaS HTTP API #678
base: main
Are you sure you want to change the base?
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! |
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.
Since I find it to complicated to explain my proposal about the Authenticator stuff, I made a PR to your PR-Branch. |
I also created a PR for my comments on the ForXXX Options. |
…or_proposal Refators the Authenntication stuff
* adds fromVaasOptions function for the forXXXOptions * removes the default() function as it is not used anywhere
…posal refactors the forXXX-options
No description provided.