Fix janky hashtag detection. Closes #1686
This commit is contained in:
parent
bb3bbc0eaf
commit
bd14b70679
@ -112,21 +112,19 @@ func SendPublicMessage(textContent string) error {
|
|||||||
|
|
||||||
tagProp := streams.NewActivityStreamsTagProperty()
|
tagProp := streams.NewActivityStreamsTagProperty()
|
||||||
|
|
||||||
// Iterate through the post text and find #Hashtags.
|
hashtagStrings := utils.GetHashtagsFromText(originalContent)
|
||||||
words := strings.Split(originalContent, " ")
|
|
||||||
for _, word := range words {
|
for _, hashtag := range hashtagStrings {
|
||||||
if strings.HasPrefix(word, "#") {
|
tagWithoutHashtag := strings.TrimPrefix(hashtag, "#")
|
||||||
tagWithoutHashtag := strings.TrimPrefix(word, "#")
|
|
||||||
|
|
||||||
// Replace the instances of the tag with a link to the tag page.
|
// Replace the instances of the tag with a link to the tag page.
|
||||||
tagHTML := getHashtagLinkHTMLFromTagString(tagWithoutHashtag)
|
tagHTML := getHashtagLinkHTMLFromTagString(tagWithoutHashtag)
|
||||||
textContent = strings.ReplaceAll(textContent, word, tagHTML)
|
textContent = strings.ReplaceAll(textContent, hashtag, tagHTML)
|
||||||
|
|
||||||
// Create Hashtag object for the tag.
|
// Create Hashtag object for the tag.
|
||||||
hashtag := apmodels.MakeHashtag(tagWithoutHashtag)
|
hashtag := apmodels.MakeHashtag(tagWithoutHashtag)
|
||||||
tagProp.AppendTootHashtag(hashtag)
|
tagProp.AppendTootHashtag(hashtag)
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
activity, _, note, noteID := createBaseOutboundMessage(textContent)
|
activity, _, note, noteID := createBaseOutboundMessage(textContent)
|
||||||
note.SetActivityStreamsTag(tagProp)
|
note.SetActivityStreamsTag(tagProp)
|
||||||
|
@ -10,6 +10,7 @@ import (
|
|||||||
"os/exec"
|
"os/exec"
|
||||||
"path"
|
"path"
|
||||||
"path/filepath"
|
"path/filepath"
|
||||||
|
"regexp"
|
||||||
"strings"
|
"strings"
|
||||||
|
|
||||||
"github.com/mssola/user_agent"
|
"github.com/mssola/user_agent"
|
||||||
@ -321,10 +322,15 @@ func GetHostnameFromURL(u url.URL) string {
|
|||||||
// GetHostnameFromURLString will return the hostname component from a URL object.
|
// GetHostnameFromURLString will return the hostname component from a URL object.
|
||||||
func GetHostnameFromURLString(s string) string {
|
func GetHostnameFromURLString(s string) string {
|
||||||
u, err := url.Parse(s)
|
u, err := url.Parse(s)
|
||||||
|
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return ""
|
return ""
|
||||||
}
|
}
|
||||||
|
|
||||||
return u.Host
|
return u.Host
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// GetHashtagsFromText returns all the #Hashtags from a string.
|
||||||
|
func GetHashtagsFromText(text string) []string {
|
||||||
|
re := regexp.MustCompile(`#[a-zA-Z0-9_]+`)
|
||||||
|
return re.FindAllString(text, -1)
|
||||||
|
}
|
||||||
|
@ -1,6 +1,8 @@
|
|||||||
package utils
|
package utils
|
||||||
|
|
||||||
import "testing"
|
import (
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
func TestUserAgent(t *testing.T) {
|
func TestUserAgent(t *testing.T) {
|
||||||
testAgents := []string{
|
testAgents := []string{
|
||||||
@ -16,3 +18,15 @@ func TestUserAgent(t *testing.T) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func TestGetHashtagsFromText(t *testing.T) {
|
||||||
|
text := `Some text with a #hashtag goes here.\n\n
|
||||||
|
Another #secondhashtag, goes here.\n\n
|
||||||
|
#thirdhashtag`
|
||||||
|
|
||||||
|
hashtags := GetHashtagsFromText(text)
|
||||||
|
|
||||||
|
if hashtags[0] != "#hashtag" || hashtags[1] != "#secondhashtag" || hashtags[2] != "#thirdhashtag" {
|
||||||
|
t.Error("Incorrect hashtags fetched from text.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user