diff options
| author | 2024-01-09 10:41:32 +0100 | |
|---|---|---|
| committer | 2024-01-09 10:41:32 +0100 | |
| commit | 7cce1a7cc65c34906a730a6470369e257e044e04 (patch) | |
| tree | 6c0cc2605fbcf699e1aaf5906f588ddffb661511 | |
| parent | [feature] Log pubKeyID for http-signed requests (#2501) (diff) | |
| download | gotosocial-7cce1a7cc65c34906a730a6470369e257e044e04.tar.xz | |
[bugfix] Outdent placeholder from `<aside>` when returning unknown media attachments (#2485)
* [bugfix] Outdent placeholder from `<aside>`
* visually separate placeholder note from body
* fix test
| -rw-r--r-- | internal/typeutils/internaltofrontend_test.go | 2 | ||||
| -rw-r--r-- | internal/typeutils/util.go | 39 | 
2 files changed, 19 insertions, 22 deletions
diff --git a/internal/typeutils/internaltofrontend_test.go b/internal/typeutils/internaltofrontend_test.go index 68b075310..a6fd03755 100644 --- a/internal/typeutils/internaltofrontend_test.go +++ b/internal/typeutils/internaltofrontend_test.go @@ -466,7 +466,7 @@ func (suite *InternalToFrontendTestSuite) TestStatusToFrontendUnknownAttachments    "muted": false,    "bookmarked": false,    "pinned": false, -  "content": "\u003cp\u003ehi \u003cspan class=\"h-card\"\u003e\u003ca href=\"http://localhost:8080/@admin\" class=\"u-url mention\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"\u003e@\u003cspan\u003eadmin\u003c/span\u003e\u003c/a\u003e\u003c/span\u003e here's some media for ya\u003c/p\u003e\u003caside\u003e\u003cp\u003eNote from localhost:8080: 2 attachments in this status could not be downloaded. Treat the following external links with care:\u003cul\u003e\u003cli\u003e\u003ca href=\"http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE7ZGJYTSYMXF927GF9353KR.svg\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"\u003e01HE7ZGJYTSYMXF927GF9353KR.svg\u003c/a\u003e [SVG line art of a sloth, public domain]\u003c/li\u003e\u003cli\u003e\u003ca href=\"http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE892Y8ZS68TQCNPX7J888P3.mp3\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"\u003e01HE892Y8ZS68TQCNPX7J888P3.mp3\u003c/a\u003e [Jolly salsa song, public domain.]\u003c/li\u003e\u003c/ul\u003e\u003c/p\u003e\u003c/aside\u003e", +  "content": "\u003cp\u003ehi \u003cspan class=\"h-card\"\u003e\u003ca href=\"http://localhost:8080/@admin\" class=\"u-url mention\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"\u003e@\u003cspan\u003eadmin\u003c/span\u003e\u003c/a\u003e\u003c/span\u003e here's some media for ya\u003c/p\u003e\u003chr\u003e\u003cp\u003e\u003ci lang=\"en\"\u003eℹ️ Note from localhost:8080: 2 attachments in this status could not be downloaded. Treat the following external links with care:\u003c/i\u003e\u003c/p\u003e\u003cul\u003e\u003cli\u003e\u003ca href=\"http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE7ZGJYTSYMXF927GF9353KR.svg\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"\u003e01HE7ZGJYTSYMXF927GF9353KR.svg\u003c/a\u003e [SVG line art of a sloth, public domain]\u003c/li\u003e\u003cli\u003e\u003ca href=\"http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE892Y8ZS68TQCNPX7J888P3.mp3\" rel=\"nofollow noreferrer noopener\" target=\"_blank\"\u003e01HE892Y8ZS68TQCNPX7J888P3.mp3\u003c/a\u003e [Jolly salsa song, public domain.]\u003c/li\u003e\u003c/ul\u003e",    "reblog": null,    "account": {      "id": "01FHMQX3GAABWSM0S2VZEC2SWC", diff --git a/internal/typeutils/util.go b/internal/typeutils/util.go index 176b887b3..0b7516d3a 100644 --- a/internal/typeutils/util.go +++ b/internal/typeutils/util.go @@ -93,24 +93,22 @@ func misskeyReportInlineURLs(content string) []*url.URL {  }  // placeholdUnknownAttachments separates any attachments with type `unknown` -// out of the given slice, and returns an `<aside>` tag containing links to +// out of the given slice, and returns a piece of text containing links to  // those attachments, as well as the slice of remaining "known" attachments.  // If there are no unknown-type attachments in the provided slice, an empty  // string and the original slice will be returned.  // -// If an aside is created, it will be run through the sanitizer before being -// returned, to ensure that malicious links don't cause issues. +// Returned text will be run through the sanitizer before being returned, to +// ensure that malicious links don't cause issues.  //  // Example:  // -//	<aside> -//	   <p>Note from your.instance.com: 2 attachments in this status could not be downloaded. Treat the following external links with care: -//	      <ul> -//	         <li><a href="http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE7ZGJYTSYMXF927GF9353KR.svg" rel="nofollow noreferrer noopener" target="_blank">01HE7ZGJYTSYMXF927GF9353KR.svg</a> [SVG line art of a sloth, public domain]</li> -//	         <li><a href="http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE892Y8ZS68TQCNPX7J888P3.mp3" rel="nofollow noreferrer noopener" target="_blank">01HE892Y8ZS68TQCNPX7J888P3.mp3</a> [Jolly salsa song, public domain.]</li> -//	      </ul> -//	   </p> -//	</aside> +//	<hr> +//	<p><i lang="en">ℹ️ Note from your.instance.com: 2 attachments in this status could not be downloaded. Treat the following external links with care:</i></p> +//	<ul> +//	   <li><a href="http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE7ZGJYTSYMXF927GF9353KR.svg" rel="nofollow noreferrer noopener" target="_blank">01HE7ZGJYTSYMXF927GF9353KR.svg</a> [SVG line art of a sloth, public domain]</li> +//	   <li><a href="http://example.org/fileserver/01HE7Y659ZWZ02JM4AWYJZ176Q/attachment/original/01HE892Y8ZS68TQCNPX7J888P3.mp3" rel="nofollow noreferrer noopener" target="_blank">01HE892Y8ZS68TQCNPX7J888P3.mp3</a> [Jolly salsa song, public domain.]</li> +//	</ul>  func placeholdUnknownAttachments(arr []*apimodel.Attachment) (string, []*apimodel.Attachment) {  	// Extract unknown-type attachments into a separate  	// slice, deleting them from arr in the process. @@ -146,11 +144,12 @@ func placeholdUnknownAttachments(arr []*apimodel.Attachment) (string, []*apimode  		links = "links"  	} -	var aside strings.Builder -	aside.WriteString(`<aside>`) -	aside.WriteString(`<p>`) -	aside.WriteString(`Note from ` + config.GetHost() + `: ` + attachments + ` in this status could not be downloaded. Treat the following external ` + links + ` with care:`) -	aside.WriteString(`<ul>`) +	var note strings.Builder +	note.WriteString(`<hr>`) +	note.WriteString(`<p><i lang="en">`) +	note.WriteString(`ℹ️ Note from ` + config.GetHost() + `: ` + attachments + ` in this status could not be downloaded. Treat the following external ` + links + ` with care:`) +	note.WriteString(`</i></p>`) +	note.WriteString(`<ul>`)  	for _, a := range unknowns {  		var (  			remoteURL = *a.RemoteURL @@ -160,13 +159,11 @@ func placeholdUnknownAttachments(arr []*apimodel.Attachment) (string, []*apimode  		if d := a.Description; d != nil && *d != "" {  			entry += ` [` + *d + `]`  		} -		aside.WriteString(`<li>` + entry + `</li>`) +		note.WriteString(`<li>` + entry + `</li>`)  	} -	aside.WriteString(`</ul>`) -	aside.WriteString(`</p>`) -	aside.WriteString(`</aside>`) +	note.WriteString(`</ul>`) -	return text.SanitizeToHTML(aside.String()), arr +	return text.SanitizeToHTML(note.String()), arr  }  // ContentToContentLanguage tries to  | 
