Skip to content

Commit

Permalink
fix(oxauth): client secret printed on logs (#1880)
Browse files Browse the repository at this point in the history
  • Loading branch information
yuriyz authored Nov 22, 2023
1 parent 6ee8d28 commit d15735f
Show file tree
Hide file tree
Showing 4 changed files with 41 additions and 2 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -52,6 +52,8 @@
import java.util.Arrays;
import java.util.Date;

import static org.gluu.oxauth.util.ServerUtil.prepareForLogs;

/**
* Provides interface for token REST web services
*
Expand Down Expand Up @@ -124,7 +126,7 @@ public Response requestAccessToken(String grantType, String code,
log.debug(
"Attempting to request access token: grantType = {}, code = {}, redirectUri = {}, username = {}, refreshToken = {}, " +
"clientId = {}, ExtraParams = {}, isSecure = {}, codeVerifier = {}, ticket = {}",
grantType, code, redirectUri, username, refreshToken, clientId, request.getParameterMap(),
grantType, code, redirectUri, username, refreshToken, clientId, prepareForLogs(request.getParameterMap()),
sec.isSecure(), codeVerifier, ticket);

boolean isUma = StringUtils.isNotBlank(ticket);
Expand Down
14 changes: 13 additions & 1 deletion Server/src/main/java/org/gluu/oxauth/util/ServerUtil.java
Original file line number Diff line number Diff line change
Expand Up @@ -52,11 +52,23 @@

public class ServerUtil {

private final static Logger log = LoggerFactory.getLogger(ServerUtil.class);
private static final Logger log = LoggerFactory.getLogger(ServerUtil.class);

private ServerUtil() {
}

public static Map<String, String[]> prepareForLogs(Map<String, String[]> parameters) {
if (parameters == null || parameters.isEmpty()) {
return new HashMap<>();
}

Map<String, String[]> result = new HashMap<>(parameters);
if (result.containsKey("client_secret")) {
result.put("client_secret", new String[] {"*****"});
}
return result;
}

public static JSONObject getJwks(Client client) {
return Strings.isNullOrEmpty(client.getJwks())
? JwtUtil.getJSONWebKeys(client.getJwksUri())
Expand Down
24 changes: 24 additions & 0 deletions Server/src/test/java/org/gluu/oxauth/util/ServerUtilTest.java
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
package org.gluu.oxauth.util;

import org.testng.annotations.Test;

import java.util.HashMap;
import java.util.Map;

import static org.junit.Assert.assertEquals;

/**
* @author Yuriy Z
*/
public class ServerUtilTest {

@Test
public void prepareForLogs_whenCalled_shouldNotHaveClearTextClientPassword() {
Map<String, String[]> parameters = new HashMap<>();
parameters.put("client_secret", new String[] {"124"});

final Map<String, String[]> result = ServerUtil.prepareForLogs(parameters);

assertEquals("*****", result.get("client_secret")[0]);
}
}
1 change: 1 addition & 0 deletions Server/src/test/resources/testng.xml
Original file line number Diff line number Diff line change
Expand Up @@ -14,6 +14,7 @@
<class name="org.gluu.oxauth.model.CIBAGrantTest" />
<class name="org.gluu.oxauth.authorize.ws.rs.AuthorizeRestWebServiceValidatorTest" />
<class name="org.gluu.oxauth.session.ws.rs.EndSessionRestWebServiceImplTest" />
<class name="org.gluu.oxauth.util.ServerUtilTest" />
</classes>
</test>

Expand Down

0 comments on commit d15735f

Please sign in to comment.