From 2ed731f66cccdf0a38fbfda33ada8025ad186920 Mon Sep 17 00:00:00 2001 From: Vitaly Takmazov Date: Thu, 4 Oct 2018 14:40:24 +0300 Subject: ActivityPub: handle http error when getting Person context --- .../main/java/com/juick/server/ActivityPubManager.java | 8 ++++---- .../main/java/com/juick/server/SignatureManager.java | 17 ++++++++++++----- 2 files changed, 16 insertions(+), 9 deletions(-) (limited to 'juick-server/src/main/java/com/juick/server') diff --git a/juick-server/src/main/java/com/juick/server/ActivityPubManager.java b/juick-server/src/main/java/com/juick/server/ActivityPubManager.java index e0bbdb85..cbe7f623 100644 --- a/juick-server/src/main/java/com/juick/server/ActivityPubManager.java +++ b/juick-server/src/main/java/com/juick/server/ActivityPubManager.java @@ -53,8 +53,8 @@ public class ActivityPubManager implements ActivityListener, NotificationListene User followedUser = socialService.getUserByAccountUri(acct); if (!followedUser.isAnonymous()) { // automatically accept follower requests - Person me = (Person) signatureManager.getContext(URI.create(acct)); - Person follower = (Person) signatureManager.getContext(URI.create(followEvent.getRequest().getActor())); + Person me = (Person) signatureManager.getContext(URI.create(acct)).get(); + Person follower = (Person) signatureManager.getContext(URI.create(followEvent.getRequest().getActor())).get(); Accept accept = new Accept(); accept.setActor(me.getId()); accept.setObject(followEvent.getRequest()); @@ -85,9 +85,9 @@ public class ActivityPubManager implements ActivityListener, NotificationListene User user = msg.getUser(); String userUri = personUri(user); Note note = makeNote(msg); - Person me = (Person) signatureManager.getContext(URI.create(userUri)); + Person me = (Person) signatureManager.getContext(URI.create(userUri)).get(); socialService.getFollowers(user).forEach(acct -> { - Person follower = (Person) signatureManager.getContext(URI.create(acct)); + Person follower = (Person) signatureManager.getContext(URI.create(acct)).get(); Create create = new Create(); create.setId(note.getId()); create.setActor(me.getId()); diff --git a/juick-server/src/main/java/com/juick/server/SignatureManager.java b/juick-server/src/main/java/com/juick/server/SignatureManager.java index 0c5ea512..98ccc24d 100644 --- a/juick-server/src/main/java/com/juick/server/SignatureManager.java +++ b/juick-server/src/main/java/com/juick/server/SignatureManager.java @@ -8,6 +8,7 @@ import org.springframework.http.HttpEntity; import org.springframework.http.HttpHeaders; import org.springframework.http.ResponseEntity; import org.springframework.stereotype.Component; +import org.springframework.web.client.HttpClientErrorException; import org.springframework.web.client.RestTemplate; import org.springframework.web.util.UriComponentsBuilder; import org.tomitribe.auth.signatures.Signature; @@ -25,6 +26,7 @@ import java.time.ZoneId; import java.time.format.DateTimeFormatter; import java.util.HashMap; import java.util.Map; +import java.util.Optional; @Component public class SignatureManager { @@ -55,9 +57,9 @@ public class SignatureManager { logger.info("accepted follower: {}", response.getStatusCodeValue()); } public boolean verifySignature(String signatureString, URI actor, String method, String path, Map headers) { - Context context = getContext(actor); - if (context instanceof Person) { - Person person = (Person) context; + Optional context = getContext(actor); + if (context.isPresent() && context.get() instanceof Person) { + Person person = (Person) context.get(); Key key = KeystoreManager.publicKeyOf(person); Verifier verifier = new Verifier(key, Signature.fromString(signatureString)); try { @@ -72,7 +74,12 @@ public class SignatureManager { logger.info("person not found"); return false; } - public Context getContext(URI contextUri) { - return new RestTemplate().getForEntity(contextUri, Context.class).getBody(); + Optional getContext(URI contextUri) { + try { + return Optional.of(new RestTemplate().getForEntity(contextUri, Context.class).getBody()); + } catch (HttpClientErrorException e) { + logger.warn("Cannot identify {}", contextUri); + } + return Optional.empty(); } } -- cgit v1.2.3