org.eclipse.microprofile.openapi.models.security.OAuthFlow Maven / Gradle / Ivy
Show all versions of microprofile-openapi-api Show documentation
/**
* Copyright (c) 2017 Contributors to the Eclipse Foundation
* Copyright 2017 SmartBear Software
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.eclipse.microprofile.openapi.models.security;
import org.eclipse.microprofile.openapi.models.Constructible;
import org.eclipse.microprofile.openapi.models.Extensible;
/**
* Configuration details for a supportde OAuthFlow
*
* @see OAuth Flow Object
*/
public interface OAuthFlow extends Constructible, Extensible {
/**
* The authorization URL to be used for this flow. This MUST be in the form of a URL. This is a REQUIRED property.
*
* This method returns the authorizationUrl property from OAuthFlow instance.
*
* @return String authorizationUrl
**/
String getAuthorizationUrl();
/**
* The authorization URL to be used for this flow. This MUST be in the form of a URL. This is a REQUIRED property.
*
* Applies to oauth2 ("implicit", "authorizationCode").
*
*
* This method sets the authorizationUrl property of an OAuthFlow instance to the given authorizationUrl argument.
*
* @param authorizationUrl the authorization URL used for this flow
*/
void setAuthorizationUrl(String authorizationUrl);
/**
* The authorization URL to be used for this flow. This MUST be in the form of a URL. This is a REQUIRED property.
*
* Applies to oauth2 ("implicit", "authorizationCode").
*
*
* This method sets the authorizationUrl property of OAuthFlow instance to the given authorizationUrl argument and returns the modified instance.
*
* @param authorizationUrl the authorization URL used for this flow
* @return OAuthFlow instance with the set authorizationUrl property
*/
default OAuthFlow authorizationUrl(String authorizationUrl) {
setAuthorizationUrl(authorizationUrl);
return this;
}
/**
* The token URL to be used for this flow. This MUST be in the form of a URL. This is a REQUIRED property.
*
* This method returns the tokenUrl property from OAuthFlow instance.
*
* @return String tokenUrl
**/
String getTokenUrl();
/**
* The token URL to be used for this flow. This MUST be in the form of a URL. This is a REQUIRED property.
*
* Applies to oauth2 ("password", "clientCredentials", "authorizationCode").
*
*
* This method sets the tokenUrl property of OAuthFlow instance to the given tokenUrl argument.
*
* @param tokenUrl the token URL to be used for this flow
*/
void setTokenUrl(String tokenUrl);
/**
* The token URL to be used for this flow. This MUST be in the form of a URL. This is a REQUIRED property.
*
* Applies to oauth2 ("password", "clientCredentials", "authorizationCode").
*
*
* This method sets the tokenUrl property of OAuthFlow instance to the given tokenUrl argument and returns the instance.
*
* @param tokenUrl the token URL to be used for this flow
* @return OAuthFlow instance with the set tokenUrl property
*/
default OAuthFlow tokenUrl(String tokenUrl) {
setTokenUrl(tokenUrl);
return this;
}
/**
* The URL to be used for obtaining refresh tokens. This MUST be in the form of a URL.
*
* This method returns the refreshUrl property from OAuthFlow instance.
*
* @return String refreshUrl
**/
String getRefreshUrl();
/**
* The URL to be used for obtaining refresh tokens. This MUST be in the form of a URL.
*
* Applies to oauth2.
*
*
* This method sets the refreshUrl property of OAuthFlow instance to the given refreshUrl argument.
*
* @param refreshUrl the URL to be used for obtaining refresh tokens
*/
void setRefreshUrl(String refreshUrl);
/**
* The URL to be used for obtaining refresh tokens. This MUST be in the form of a URL.
*
* Applies to oauth2.
*
*
* This method sets the refreshUrl property of OAuthFlow instance to the given refreshUrl argument and returns the modified instance.
*
* @param refreshUrl the URL to be used for obtaining refresh tokens
* @return OAuthFlow instance with the set refreshUrl property
*/
default OAuthFlow refreshUrl(String refreshUrl) {
setRefreshUrl(refreshUrl);
return this;
}
/**
* The available scopes for the OAuth2 security scheme. A map between the scope name and a short description for it. This is a REQUIRED property.
*
* This method returns the scopes property from OAuthFlow instance.
*
* @return Scopes scopes
**/
Scopes getScopes();
/**
* The available scopes for the OAuth2 security scheme. A map between the scope name and a short description for it. This is a REQUIRED property.
*
* Applies to oauth2.
*
*
* This method sets the scopes property of OAuthFlow instance to the given argument.
*
* @param scopes the available scopes for the OAuth2 security scheme
*/
void setScopes(Scopes scopes);
/**
* The available scopes for the OAuth2 security scheme. A map between the scope name and a short description for it. This is a REQUIRED property.
*
* Applies to oauth2.
*
*
* This method sets the scopes property of OAuthFlow instance to the given argument and returns the modified instance.
*
* @param scopes the available scopes for the OAuth2 security scheme
* @return OAuthFlow instance with the set scopes property
*/
default OAuthFlow scopes(Scopes scopes) {
setScopes(scopes);
return this;
}
}