Skip to content

Commit

Permalink
Change addOther to add, validate that we don't overwrite named proper…
Browse files Browse the repository at this point in the history
…ties
  • Loading branch information
Daniel DeGroff committed Jan 11, 2019
1 parent 3dae241 commit 8818e50
Show file tree
Hide file tree
Showing 3 changed files with 59 additions and 9 deletions.
7 changes: 2 additions & 5 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -148,7 +148,6 @@ assertEquals(jwt.subject, "f1e33ab3-027f-47c5-bb07-8dd8ab37a2d3");

```java
JSONWebKey jwk = JSONWebKey.build(publicKey);

String json = jwk.toJSON();
```

Expand All @@ -165,7 +164,6 @@ String json = jwk.toJSON();

```java
JSONWebKey jwk = JSONWebKey.build(privateKey);

String json = jwk.toJSON();
```

Expand All @@ -188,9 +186,8 @@ String json = jwk.toJSON();

```java
JSONWebKey jwk = JSONWebKey.build(privateKey)
.addOther("boom", "goes the dynamite")
.addOther("more", "cowbell");

.add("boom", "goes the dynamite")
.add("more", "cowbell");
String json = jwk.toJSON();
```

Expand Down
32 changes: 30 additions & 2 deletions src/main/java/io/fusionauth/jwks/domain/JSONWebKey.java
Original file line number Diff line number Diff line change
Expand Up @@ -21,6 +21,7 @@
import com.fasterxml.jackson.annotation.JsonIgnore;
import com.fasterxml.jackson.annotation.JsonProperty;
import io.fusionauth.jwks.JSONWebKeyBuilder;
import io.fusionauth.jwks.JSONWebKeyBuilderException;
import io.fusionauth.jwt.domain.Algorithm;
import io.fusionauth.jwt.domain.Buildable;
import io.fusionauth.jwt.domain.KeyType;
Expand Down Expand Up @@ -203,8 +204,35 @@ public static JSONWebKey build(PublicKey publicKey) {
}

@JsonIgnore
public JSONWebKey addOther(String key, Object value) {
other.put(key, value);
public JSONWebKey add(String key, Object value) {
if (key == null || value == null) {
return this;
}

switch (key) {
case "alg":
case "crv":
case "d":
case "dp":
case "dq":
case "e":
case "kid":
case "kty":
case "n":
case "p":
case "q":
case "qi":
case "use":
case "x":
case "x5c":
case "x5t":
case "x5t_256":
case "y":
throw new JSONWebKeyBuilderException("You can not add a named property. Use the field for [" + key + "] instead.", new IllegalArgumentException());
default:
other.put(key, value);
}

return this;
}

Expand Down
29 changes: 27 additions & 2 deletions src/test/java/io/fusionauth/jwks/JSONWebKeyBuilderTest.java
Original file line number Diff line number Diff line change
Expand Up @@ -27,11 +27,36 @@
import java.security.interfaces.ECPublicKey;
import java.security.interfaces.RSAPrivateKey;
import java.security.interfaces.RSAPublicKey;
import java.util.Arrays;

/**
* @author Daniel DeGroff
*/
public class JSONWebKeyBuilderTest extends BaseTest {
@Test
public void add_named_properties() {
Arrays.asList(
"alg",
"crv",
"d",
"dp",
"dq",
"e",
"kid",
"kty",
"n",
"p",
"q",
"qi",
"use",
"x",
"x5c",
"x5t",
"x5t_256",
"y"
).forEach(key -> expectException(JSONWebKeyBuilderException.class, () -> new JSONWebKey().add(key, "Nunya, Business")));
}

@Test
public void ec_private() throws Exception {
// EC 256 Private key - PKCS#8 encapsulated already
Expand Down Expand Up @@ -63,8 +88,8 @@ public void extra_properties() throws Exception {
// EC 256 Public key
ECPublicKey ecPublic_p256 = PEM.decode(Paths.get("src/test/resources/ec_public_key_p_256.pem")).getPublicKey();
assertJSONEquals(JSONWebKey.build(ecPublic_p256)
.addOther("more", "cowbell")
.addOther("boom", "goes the dynamite"), "src/test/resources/jwk/extra_properties.json");
.add("more", "cowbell")
.add("boom", "goes the dynamite"), "src/test/resources/jwk/extra_properties.json");
}

@Test
Expand Down

0 comments on commit 8818e50

Please sign in to comment.