diff --git a/components/org.wso2.openbanking.cds.identity/src/main/java/org/wso2/openbanking/cds/identity/grant/type/handlers/CDSAuthorizationCodeGrantHandler.java b/components/org.wso2.openbanking.cds.identity/src/main/java/org/wso2/openbanking/cds/identity/grant/type/handlers/CDSAuthorizationCodeGrantHandler.java index a73920b2..ea9f387e 100644 --- a/components/org.wso2.openbanking.cds.identity/src/main/java/org/wso2/openbanking/cds/identity/grant/type/handlers/CDSAuthorizationCodeGrantHandler.java +++ b/components/org.wso2.openbanking.cds.identity/src/main/java/org/wso2/openbanking/cds/identity/grant/type/handlers/CDSAuthorizationCodeGrantHandler.java @@ -110,7 +110,7 @@ public void publishUserAccessTokenData(OAuth2AccessTokenRespDTO oAuth2AccessToke * @return */ @Override - public boolean issueRefreshToken() throws IdentityOAuth2Exception { + public OAuth2AccessTokenRespDTO issue(OAuthTokenReqMessageContext tokReqMsgCtx) throws IdentityOAuth2Exception { OAuthTokenReqMessageContext tokenReqMessageContext = getTokenMessageContext(); @@ -124,10 +124,21 @@ public boolean issueRefreshToken() throws IdentityOAuth2Exception { if (log.isDebugEnabled()) { log.debug("Refresh token validity period is set to: " + sharingDuration); } - // do not issue refresh token if sharing duration value equals to zero - if (sharingDuration == 0) { - return false; - } + + } + return super.issue(tokReqMsgCtx); + } + + @Override + public boolean issueRefreshToken() throws IdentityOAuth2Exception { + + OAuthTokenReqMessageContext tokenReqMessageContext = getTokenMessageContext(); + if (isRegulatory(tokenReqMessageContext)) { + long sharingDuration; + String[] scopes = tokenReqMessageContext.getScope(); + String consentId = CDSIdentityUtil.getConsentId(scopes); + sharingDuration = CDSIdentityUtil.getRefreshTokenValidityPeriod(consentId); + return sharingDuration != 0; } return true; }