From c4bb553217efa9841c3d80e7c5f65bcb59ae0e7d Mon Sep 17 00:00:00 2001 From: Michael Demetriou Date: Fri, 11 Oct 2019 10:08:24 +0300 Subject: [PATCH] If the remote actor does not have a sharedInbox then return their inbox so implementations do not need to care whethere there is a sharedInbox or not --- remoteActor.go | 24 +++++++++++++++++++----- 1 file changed, 19 insertions(+), 5 deletions(-) diff --git a/remoteActor.go b/remoteActor.go index a87ba23..2b5e82e 100644 --- a/remoteActor.go +++ b/remoteActor.go @@ -1,13 +1,20 @@ package activityserve import ( - "bytes" - "encoding/json" "fmt" "io/ioutil" - "net/http" "github.com/gologme/log" + + // "github.com/go-fed/activity/pub" + // "github.com/go-fed/httpsig" + + "net/http" + // "net/url" + + "encoding/json" + + "bytes" ) // RemoteActor is a type that holds an actor @@ -31,8 +38,12 @@ func NewRemoteActor(iri string) (RemoteActor, error) { outbox := info["outbox"].(string) inbox := info["inbox"].(string) - endpoints := info["endpoints"].(map[string]interface{}) - sharedInbox := endpoints["sharedInbox"].(string) + var endpoints map[string]interface{} + var sharedInbox string + if info["endpoints"] != nil { + endpoints = info["endpoints"].(map[string]interface{}) + sharedInbox = endpoints["sharedInbox"].(string) + } return RemoteActor{ iri: iri, @@ -95,5 +106,8 @@ func (ra RemoteActor) GetInbox() string { // GetSharedInbox returns the inbox url of the actor func (ra RemoteActor) GetSharedInbox() string { + if ra.sharedInbox == "" { + return ra.inbox + } return ra.sharedInbox }