You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

api_activitypub_person_test.go 3.3KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113
  1. // Copyright 2022 The Gitea Authors. All rights reserved.
  2. // SPDX-License-Identifier: MIT
  3. package integration
  4. import (
  5. "context"
  6. "fmt"
  7. "net/http"
  8. "net/http/httptest"
  9. "net/url"
  10. "testing"
  11. "code.gitea.io/gitea/models/db"
  12. user_model "code.gitea.io/gitea/models/user"
  13. "code.gitea.io/gitea/modules/activitypub"
  14. "code.gitea.io/gitea/modules/setting"
  15. "code.gitea.io/gitea/routers"
  16. ap "github.com/go-ap/activitypub"
  17. "github.com/stretchr/testify/assert"
  18. )
  19. func TestActivityPubPerson(t *testing.T) {
  20. setting.Federation.Enabled = true
  21. testWebRoutes = routers.NormalRoutes()
  22. defer func() {
  23. setting.Federation.Enabled = false
  24. testWebRoutes = routers.NormalRoutes()
  25. }()
  26. onGiteaRun(t, func(*testing.T, *url.URL) {
  27. userID := 2
  28. username := "user2"
  29. req := NewRequestf(t, "GET", fmt.Sprintf("/api/v1/activitypub/user-id/%v", userID))
  30. resp := MakeRequest(t, req, http.StatusOK)
  31. body := resp.Body.Bytes()
  32. assert.Contains(t, string(body), "@context")
  33. var person ap.Person
  34. err := person.UnmarshalJSON(body)
  35. assert.NoError(t, err)
  36. assert.Equal(t, ap.PersonType, person.Type)
  37. assert.Equal(t, username, person.PreferredUsername.String())
  38. keyID := person.GetID().String()
  39. assert.Regexp(t, fmt.Sprintf("activitypub/user-id/%v$", userID), keyID)
  40. assert.Regexp(t, fmt.Sprintf("activitypub/user-id/%v/outbox$", userID), person.Outbox.GetID().String())
  41. assert.Regexp(t, fmt.Sprintf("activitypub/user-id/%v/inbox$", userID), person.Inbox.GetID().String())
  42. pubKey := person.PublicKey
  43. assert.NotNil(t, pubKey)
  44. publicKeyID := keyID + "#main-key"
  45. assert.Equal(t, pubKey.ID.String(), publicKeyID)
  46. pubKeyPem := pubKey.PublicKeyPem
  47. assert.NotNil(t, pubKeyPem)
  48. assert.Regexp(t, "^-----BEGIN PUBLIC KEY-----", pubKeyPem)
  49. })
  50. }
  51. func TestActivityPubMissingPerson(t *testing.T) {
  52. setting.Federation.Enabled = true
  53. testWebRoutes = routers.NormalRoutes()
  54. defer func() {
  55. setting.Federation.Enabled = false
  56. testWebRoutes = routers.NormalRoutes()
  57. }()
  58. onGiteaRun(t, func(*testing.T, *url.URL) {
  59. req := NewRequestf(t, "GET", "/api/v1/activitypub/user-id/999999999")
  60. resp := MakeRequest(t, req, http.StatusNotFound)
  61. assert.Contains(t, resp.Body.String(), "user does not exist")
  62. })
  63. }
  64. func TestActivityPubPersonInbox(t *testing.T) {
  65. setting.Federation.Enabled = true
  66. testWebRoutes = routers.NormalRoutes()
  67. defer func() {
  68. setting.Federation.Enabled = false
  69. testWebRoutes = routers.NormalRoutes()
  70. }()
  71. srv := httptest.NewServer(testWebRoutes)
  72. defer srv.Close()
  73. onGiteaRun(t, func(*testing.T, *url.URL) {
  74. appURL := setting.AppURL
  75. setting.AppURL = srv.URL + "/"
  76. defer func() {
  77. setting.Database.LogSQL = false
  78. setting.AppURL = appURL
  79. }()
  80. username1 := "user1"
  81. ctx := context.Background()
  82. user1, err := user_model.GetUserByName(ctx, username1)
  83. assert.NoError(t, err)
  84. user1url := fmt.Sprintf("%s/api/v1/activitypub/user-id/1#main-key", srv.URL)
  85. c, err := activitypub.NewClient(db.DefaultContext, user1, user1url)
  86. assert.NoError(t, err)
  87. user2inboxurl := fmt.Sprintf("%s/api/v1/activitypub/user-id/2/inbox", srv.URL)
  88. // Signed request succeeds
  89. resp, err := c.Post([]byte{}, user2inboxurl)
  90. assert.NoError(t, err)
  91. assert.Equal(t, http.StatusNoContent, resp.StatusCode)
  92. // Unsigned request fails
  93. req := NewRequest(t, "POST", user2inboxurl)
  94. MakeRequest(t, req, http.StatusInternalServerError)
  95. })
  96. }