mirror of
https://github.com/superseriousbusiness/gotosocial.git
synced 2025-10-29 07:52:24 -05:00
[bugfix] Relax Mention parsing, allowing either href or name (#2320)
This commit is contained in:
parent
dd4b0241ea
commit
51d0a0bba5
6 changed files with 317 additions and 40 deletions
|
|
@ -32,7 +32,6 @@ import (
|
|||
"github.com/superseriousbusiness/gotosocial/internal/gtserror"
|
||||
"github.com/superseriousbusiness/gotosocial/internal/gtsmodel"
|
||||
"github.com/superseriousbusiness/gotosocial/internal/text"
|
||||
"github.com/superseriousbusiness/gotosocial/internal/util"
|
||||
)
|
||||
|
||||
// ExtractObjects will extract object vocab.Types from given implementing interface.
|
||||
|
|
@ -841,27 +840,27 @@ func ExtractMentions(i WithTag) ([]*gtsmodel.Mention, error) {
|
|||
|
||||
// ExtractMention extracts a minimal gtsmodel.Mention from a Mentionable.
|
||||
func ExtractMention(i Mentionable) (*gtsmodel.Mention, error) {
|
||||
// See if a name has been set in the
|
||||
// format `@someone@example.org`.
|
||||
nameString := ExtractName(i)
|
||||
if nameString == "" {
|
||||
return nil, gtserror.New("name prop empty")
|
||||
}
|
||||
|
||||
// Ensure namestring is valid so we
|
||||
// can handle it properly later on.
|
||||
if _, _, err := util.ExtractNamestringParts(nameString); err != nil {
|
||||
return nil, err
|
||||
}
|
||||
|
||||
// The href prop should be the AP URI
|
||||
// of the target account.
|
||||
// of the target account; it could also
|
||||
// be the URL, but we'll check this later.
|
||||
var href string
|
||||
hrefProp := i.GetActivityStreamsHref()
|
||||
if hrefProp == nil || !hrefProp.IsIRI() {
|
||||
return nil, gtserror.New("no href prop")
|
||||
if hrefProp != nil && hrefProp.IsIRI() {
|
||||
href = hrefProp.GetIRI().String()
|
||||
}
|
||||
|
||||
// One of nameString and hrefProp must be set.
|
||||
if nameString == "" && href == "" {
|
||||
return nil, gtserror.Newf("neither Name nor Href were set")
|
||||
}
|
||||
|
||||
return >smodel.Mention{
|
||||
NameString: nameString,
|
||||
TargetAccountURI: hrefProp.GetIRI().String(),
|
||||
TargetAccountURI: href,
|
||||
}, nil
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -21,14 +21,16 @@ import (
|
|||
"testing"
|
||||
|
||||
"github.com/stretchr/testify/suite"
|
||||
"github.com/superseriousbusiness/activity/streams"
|
||||
"github.com/superseriousbusiness/gotosocial/internal/ap"
|
||||
"github.com/superseriousbusiness/gotosocial/testrig"
|
||||
)
|
||||
|
||||
type ExtractMentionsTestSuite struct {
|
||||
APTestSuite
|
||||
}
|
||||
|
||||
func (suite *ExtractMentionsTestSuite) TestExtractMentions() {
|
||||
func (suite *ExtractMentionsTestSuite) TestExtractMentionsFromNote() {
|
||||
note := suite.noteWithMentions1
|
||||
|
||||
mentions, err := ap.ExtractMentions(note)
|
||||
|
|
@ -44,6 +46,101 @@ func (suite *ExtractMentionsTestSuite) TestExtractMentions() {
|
|||
suite.Equal("https://gts.superseriousbusiness.org/users/f0x", m2.TargetAccountURI)
|
||||
}
|
||||
|
||||
func (suite *ExtractMentionsTestSuite) TestExtractMentions() {
|
||||
newMention := func(nameString string, href string) ap.Mentionable {
|
||||
mention := streams.NewActivityStreamsMention()
|
||||
|
||||
if nameString != "" {
|
||||
nameProp := streams.NewActivityStreamsNameProperty()
|
||||
nameProp.AppendXMLSchemaString(nameString)
|
||||
mention.SetActivityStreamsName(nameProp)
|
||||
}
|
||||
|
||||
if href != "" {
|
||||
hrefProp := streams.NewActivityStreamsHrefProperty()
|
||||
hrefProp.SetIRI(testrig.URLMustParse(href))
|
||||
mention.SetActivityStreamsHref(hrefProp)
|
||||
}
|
||||
|
||||
return mention
|
||||
}
|
||||
|
||||
type test struct {
|
||||
nameString string
|
||||
href string
|
||||
expectedNameString string
|
||||
expectedHref string
|
||||
expectedErr string
|
||||
}
|
||||
|
||||
for i, t := range []test{
|
||||
{
|
||||
// Mention with both Name and Href set, should be fine.
|
||||
nameString: "@someone@example.org",
|
||||
href: "https://example.org/@someone",
|
||||
expectedNameString: "@someone@example.org",
|
||||
expectedHref: "https://example.org/@someone",
|
||||
expectedErr: "",
|
||||
},
|
||||
{
|
||||
// Mention with just Href set, should be fine.
|
||||
nameString: "",
|
||||
href: "https://example.org/@someone",
|
||||
expectedNameString: "",
|
||||
expectedHref: "https://example.org/@someone",
|
||||
expectedErr: "",
|
||||
},
|
||||
{
|
||||
// Mention with just Name set, should be fine.
|
||||
nameString: "@someone@example.org",
|
||||
href: "",
|
||||
expectedNameString: "@someone@example.org",
|
||||
expectedHref: "",
|
||||
expectedErr: "",
|
||||
},
|
||||
{
|
||||
// Mention with nothing set, not fine!
|
||||
nameString: "",
|
||||
href: "",
|
||||
expectedNameString: "",
|
||||
expectedHref: "",
|
||||
expectedErr: "ExtractMention: neither Name nor Href were set",
|
||||
},
|
||||
} {
|
||||
apMention := newMention(t.nameString, t.href)
|
||||
mention, err := ap.ExtractMention(apMention)
|
||||
|
||||
if err != nil {
|
||||
if errString := err.Error(); errString != t.expectedErr {
|
||||
suite.Fail("",
|
||||
"test %d expected error %s, got %s",
|
||||
i+1, t.expectedErr, errString,
|
||||
)
|
||||
}
|
||||
continue
|
||||
} else if t.expectedErr != "" {
|
||||
suite.Fail("",
|
||||
"test %d expected error %s, got no error",
|
||||
i+1, t.expectedErr,
|
||||
)
|
||||
}
|
||||
|
||||
if mention.NameString != t.expectedNameString {
|
||||
suite.Fail("",
|
||||
"test %d expected nameString %s, got %s",
|
||||
i+1, t.expectedNameString, mention.NameString,
|
||||
)
|
||||
}
|
||||
|
||||
if mention.TargetAccountURI != t.expectedHref {
|
||||
suite.Fail("",
|
||||
"test %d expected href %s, got %s",
|
||||
i+1, t.expectedHref, mention.TargetAccountURI,
|
||||
)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
func TestExtractMentionsTestSuite(t *testing.T) {
|
||||
suite.Run(t, &ExtractMentionsTestSuite{})
|
||||
}
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue