From 5efad50005484e4bcd56fd68a46040e3d89b0efe Mon Sep 17 00:00:00 2001 From: Julio Capote Date: Sun, 1 Jan 2023 20:37:51 -0500 Subject: clean up urls, scheme:host:port now configurable --- urls/urls.go | 40 +++++++++++++++------------------------- 1 file changed, 15 insertions(+), 25 deletions(-) (limited to 'urls') diff --git a/urls/urls.go b/urls/urls.go index 91e0b37..6a2025b 100644 --- a/urls/urls.go +++ b/urls/urls.go @@ -3,48 +3,38 @@ package urls import ( "fmt" "net/url" - "path" ) -func UrlInbox(name, domain string) (*url.URL, error) { - u, err := url.Parse(path.Join(domain, "actors", name, "inbox")) - u.Scheme = "https" +func linkTo(name, base string, path ...string) (*url.URL, error) { + u, err := url.JoinPath(base, path...) if err != nil { - return nil, fmt.Errorf("could not build inbox url: %w", err) + return nil, fmt.Errorf("could not build %s url: %w", name, err) } - return u, nil + uri, err := url.Parse(u) + if err != nil { + return nil, fmt.Errorf("could not parse %s url: %w", name, err) + } + return uri, err +} + +func UrlInbox(name, domain string) (*url.URL, error) { + return linkTo("inbox", domain, "actors", name, "inbox") } func UrlOutbox(name, domain string) (*url.URL, error) { - u, err := url.Parse(path.Join(domain, "actors", name, "outbox")) - u.Scheme = "https" - if err != nil { - return nil, fmt.Errorf("could not build outbox url: %w", err) - } - return u, nil + return linkTo("outbox", domain, "actors", name, "outbox") } func UrlActivity(name, domain, id string) (*url.URL, error) { - u, err := url.Parse(path.Join(domain, "actors", name, "activity", id)) - u.Scheme = "https" - if err != nil { - return nil, fmt.Errorf("could not build activity url: %w", err) - } - return u, nil + return linkTo("activity", domain, "actors", name, "activity", id) } func UrlNote(name, domain, id string) (*url.URL, error) { - u, err := url.Parse(path.Join(domain, "actors", name, "activity", id, "note")) - u.Scheme = "https" - if err != nil { - return nil, fmt.Errorf("could not build note url: %w", err) - } - return u, nil + return linkTo("note", domain, "actors", name, "activity", id, "note") } func UrlOutboxPage(name, domain string) (*url.URL, error) { u, err := UrlOutbox(name, domain) - u.Scheme = "https" if err != nil { return nil, fmt.Errorf("could not build outbox page url: %w", err) } -- cgit v1.2.3