Words typo in codes fixed.

This commit is contained in:
Naoki Kosaka 2021-06-20 17:26:15 +09:00
parent 4dd69d0dac
commit f05921420f
20 changed files with 85 additions and 85 deletions

View File

@ -26,11 +26,11 @@ func decodeActivity(request *http.Request) (*models.Activity, *models.Actor, []b
} }
KeyID := verifier.KeyId() KeyID := verifier.KeyId()
keyOwnerActor := new(models.Actor) keyOwnerActor := new(models.Actor)
err = keyOwnerActor.RetrieveRemoteActor(KeyID, fmt.Sprintf("%s (golang net/http; Activity-Relay %s; %s)", globalConfig.ServerServicename(), version, globalConfig.ServerHostname().Host), actorCache) err = keyOwnerActor.RetrieveRemoteActor(KeyID, fmt.Sprintf("%s (golang net/http; Activity-Relay %s; %s)", globalConfig.ServerServiceName(), version, globalConfig.ServerHostname().Host), actorCache)
if err != nil { if err != nil {
return nil, nil, nil, err return nil, nil, nil, err
} }
PubKey, err := models.ReadPublicKeyRSAfromString(keyOwnerActor.PublicKey.PublicKeyPem) PubKey, err := models.ReadPublicKeyRSAFromString(keyOwnerActor.PublicKey.PublicKeyPem)
if PubKey == nil { if PubKey == nil {
return nil, nil, nil, errors.New("Failed parse PublicKey from string") return nil, nil, nil, errors.New("Failed parse PublicKey from string")
} }
@ -47,9 +47,9 @@ func decodeActivity(request *http.Request) (*models.Activity, *models.Actor, []b
hash := sha256.New() hash := sha256.New()
hash.Write(body) hash.Write(body)
b := hash.Sum(nil) b := hash.Sum(nil)
calcurateDigest := "SHA-256=" + base64.StdEncoding.EncodeToString(b) calculatedDigest := "SHA-256=" + base64.StdEncoding.EncodeToString(b)
if givenDigest != calcurateDigest { if givenDigest != calculatedDigest {
return nil, nil, nil, errors.New("Digest header is mismatch") return nil, nil, nil, errors.New("Digest header is mismatch")
} }
@ -61,7 +61,7 @@ func decodeActivity(request *http.Request) (*models.Activity, *models.Actor, []b
} }
var remoteActor models.Actor var remoteActor models.Actor
err = remoteActor.RetrieveRemoteActor(activity.Actor, fmt.Sprintf("%s (golang net/http; Activity-Relay %s; %s)", globalConfig.ServerServicename(), version, globalConfig.ServerHostname().Host), actorCache) err = remoteActor.RetrieveRemoteActor(activity.Actor, fmt.Sprintf("%s (golang net/http; Activity-Relay %s; %s)", globalConfig.ServerServiceName(), version, globalConfig.ServerHostname().Host), actorCache)
if err != nil { if err != nil {
return nil, nil, nil, err return nil, nil, nil, err
} }

View File

@ -20,13 +20,13 @@ func handleWebfinger(writer http.ResponseWriter, request *http.Request) {
} else { } else {
request := resource[0] request := resource[0]
if request == WebfingerResource.Subject { if request == WebfingerResource.Subject {
wfresource, err := json.Marshal(&WebfingerResource) webfingerResource, err := json.Marshal(&WebfingerResource)
if err != nil { if err != nil {
panic(err) panic(err)
} }
writer.Header().Add("Content-Type", "application/json") writer.Header().Add("Content-Type", "application/json")
writer.WriteHeader(200) writer.WriteHeader(200)
writer.Write(wfresource) writer.Write(webfingerResource)
} else { } else {
writer.WriteHeader(404) writer.WriteHeader(404)
writer.Write(nil) writer.Write(nil)
@ -39,13 +39,13 @@ func handleNodeinfoLink(writer http.ResponseWriter, request *http.Request) {
writer.WriteHeader(400) writer.WriteHeader(400)
writer.Write(nil) writer.Write(nil)
} else { } else {
linksresource, err := json.Marshal(&Nodeinfo.NodeinfoLinks) linksResource, err := json.Marshal(&Nodeinfo.NodeinfoLinks)
if err != nil { if err != nil {
panic(err) panic(err)
} }
writer.Header().Add("Content-Type", "application/json") writer.Header().Add("Content-Type", "application/json")
writer.WriteHeader(200) writer.WriteHeader(200)
writer.Write(linksresource) writer.Write(linksResource)
} }
} }
@ -58,13 +58,13 @@ func handleNodeinfo(writer http.ResponseWriter, request *http.Request) {
Nodeinfo.Nodeinfo.Usage.Users.Total = userCount Nodeinfo.Nodeinfo.Usage.Users.Total = userCount
Nodeinfo.Nodeinfo.Usage.Users.ActiveMonth = userCount Nodeinfo.Nodeinfo.Usage.Users.ActiveMonth = userCount
Nodeinfo.Nodeinfo.Usage.Users.ActiveHalfyear = userCount Nodeinfo.Nodeinfo.Usage.Users.ActiveHalfyear = userCount
linksresource, err := json.Marshal(&Nodeinfo.Nodeinfo) linksResource, err := json.Marshal(&Nodeinfo.Nodeinfo)
if err != nil { if err != nil {
panic(err) panic(err)
} }
writer.Header().Add("Content-Type", "application/json") writer.Header().Add("Content-Type", "application/json")
writer.WriteHeader(200) writer.WriteHeader(200)
writer.Write(linksresource) writer.Write(linksResource)
} }
} }
@ -132,9 +132,9 @@ func pushRelayJob(sourceInbox string, body []byte) {
} }
} }
func pushRegistorJob(inboxURL string, body []byte) { func pushRegisterJob(inboxURL string, body []byte) {
job := &tasks.Signature{ job := &tasks.Signature{
Name: "registor", Name: "register",
RetryCount: 2, RetryCount: 2,
Args: []tasks.Arg{ Args: []tasks.Arg{
{ {
@ -181,13 +181,13 @@ func suitableFollow(activity *models.Activity, actor *models.Actor) bool {
func relayAcceptable(activity *models.Activity, actor *models.Actor) error { func relayAcceptable(activity *models.Activity, actor *models.Actor) error {
if !contains(activity.To, "https://www.w3.org/ns/activitystreams#Public") && !contains(activity.Cc, "https://www.w3.org/ns/activitystreams#Public") { if !contains(activity.To, "https://www.w3.org/ns/activitystreams#Public") && !contains(activity.Cc, "https://www.w3.org/ns/activitystreams#Public") {
return errors.New("Activity should contain https://www.w3.org/ns/activitystreams#Public as receiver") return errors.New("activity should contain https://www.w3.org/ns/activitystreams#Public as receiver")
} }
domain, _ := url.Parse(activity.Actor) domain, _ := url.Parse(activity.Actor)
if contains(relayState.Subscriptions, domain.Host) { if contains(relayState.Subscriptions, domain.Host) {
return nil return nil
} }
return errors.New("To use the relay service, Subscribe me in advance") return errors.New("to use the relay service, Subscribe me in advance")
} }
func suitableRelay(activity *models.Activity, actor *models.Actor) bool { func suitableRelay(activity *models.Activity, actor *models.Actor) bool {
@ -216,7 +216,7 @@ func handleInbox(writer http.ResponseWriter, request *http.Request, activityDeco
if err != nil { if err != nil {
resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Reject") resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Reject")
jsonData, _ := json.Marshal(&resp) jsonData, _ := json.Marshal(&resp)
go pushRegistorJob(actor.Inbox, jsonData) go pushRegisterJob(actor.Inbox, jsonData)
fmt.Println("Reject Follow Request : ", err.Error(), activity.Actor) fmt.Println("Reject Follow Request : ", err.Error(), activity.Actor)
writer.WriteHeader(202) writer.WriteHeader(202)
@ -235,7 +235,7 @@ func handleInbox(writer http.ResponseWriter, request *http.Request, activityDeco
} else { } else {
resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Accept") resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Accept")
jsonData, _ := json.Marshal(&resp) jsonData, _ := json.Marshal(&resp)
go pushRegistorJob(actor.Inbox, jsonData) go pushRegisterJob(actor.Inbox, jsonData)
relayState.AddSubscription(models.Subscription{ relayState.AddSubscription(models.Subscription{
Domain: domain.Host, Domain: domain.Host,
InboxURL: actor.Endpoints.SharedInbox, InboxURL: actor.Endpoints.SharedInbox,
@ -247,7 +247,7 @@ func handleInbox(writer http.ResponseWriter, request *http.Request, activityDeco
} else { } else {
resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Reject") resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Reject")
jsonData, _ := json.Marshal(&resp) jsonData, _ := json.Marshal(&resp)
go pushRegistorJob(actor.Inbox, jsonData) go pushRegisterJob(actor.Inbox, jsonData)
fmt.Println("Reject Follow Request : ", activity.Actor) fmt.Println("Reject Follow Request : ", activity.Actor)
} }

View File

@ -42,13 +42,13 @@ func TestHandleWebfingerGet(t *testing.T) {
defer r.Body.Close() defer r.Body.Close()
data, _ := ioutil.ReadAll(r.Body) data, _ := ioutil.ReadAll(r.Body)
var wfresource models.WebfingerResource var webfingerResource models.WebfingerResource
err = json.Unmarshal(data, &wfresource) err = json.Unmarshal(data, &webfingerResource)
if err != nil { if err != nil {
t.Fatalf("WebfingerResource response is not valid.") t.Fatalf("WebfingerResource response is not valid.")
} }
domain, _ := url.Parse(wfresource.Links[0].Href) domain, _ := url.Parse(webfingerResource.Links[0].Href)
if domain.Host != globalConfig.ServerHostname().Host { if domain.Host != globalConfig.ServerHostname().Host {
t.Fatalf("WebfingerResource's Host not valid.") t.Fatalf("WebfingerResource's Host not valid.")
} }
@ -305,7 +305,7 @@ func mockActivity(req string) models.Activity {
json.Unmarshal(body, &activity) json.Unmarshal(body, &activity)
return activity return activity
default: default:
panic("No assined request.") panic("No assigned request.")
} }
} }
@ -330,7 +330,7 @@ func mockActor(req string) models.Actor {
json.Unmarshal(body, &actor) json.Unmarshal(body, &actor)
return actor return actor
default: default:
panic("No assined request.") panic("No assigned request.")
} }
} }
@ -642,7 +642,7 @@ func TestHandleInboxValidCreate(t *testing.T) {
relayState.RedisClient.Del("relay:subscription:example.org").Result() relayState.RedisClient.Del("relay:subscription:example.org").Result()
} }
func TestHandleInboxlimitedCreate(t *testing.T) { func TestHandleInboxLimitedCreate(t *testing.T) {
activity := mockActivity("Create") activity := mockActivity("Create")
actor := mockActor("Person") actor := mockActor("Person")
domain, _ := url.Parse(activity.Actor) domain, _ := url.Parse(activity.Actor)

View File

@ -20,13 +20,13 @@ func configCmdInit() *cobra.Command {
var config = &cobra.Command{ var config = &cobra.Command{
Use: "config", Use: "config",
Short: "Manage configuration for relay", Short: "Manage configuration for relay",
Long: "Enable/disable relay costomize and import/export relay database.", Long: "Enable/disable relay customize and import/export relay database.",
} }
var configList = &cobra.Command{ var configList = &cobra.Command{
Use: "list", Use: "list",
Short: "List all relay configration", Short: "List all relay configuration",
Long: "List all relay configration.", Long: "List all relay configuration.",
Run: func(cmd *cobra.Command, args []string) { Run: func(cmd *cobra.Command, args []string) {
initProxy(listConfig, cmd, args) initProxy(listConfig, cmd, args)
}, },
@ -57,8 +57,8 @@ func configCmdInit() *cobra.Command {
var configEnable = &cobra.Command{ var configEnable = &cobra.Command{
Use: "enable", Use: "enable",
Short: "Enable/disable relay configration", Short: "Enable/disable relay configuration",
Long: `Enable or disable relay configration. Long: `Enable or disable relay configuration.
- service-block - service-block
Blocking feature for service-type actor. Blocking feature for service-type actor.
- manually-accept - manually-accept
@ -70,7 +70,7 @@ func configCmdInit() *cobra.Command {
return initProxyE(configEnable, cmd, args) return initProxyE(configEnable, cmd, args)
}, },
} }
configEnable.Flags().BoolP("disable", "d", false, "Disable configration instead of Enable") configEnable.Flags().BoolP("disable", "d", false, "Disable configuration instead of Enable")
config.AddCommand(configEnable) config.AddCommand(configEnable)
return config return config
@ -168,6 +168,6 @@ func importConfig(cmd *cobra.Command, args []string) {
ActivityID: Subscription.ActivityID, ActivityID: Subscription.ActivityID,
ActorID: Subscription.ActorID, ActorID: Subscription.ActorID,
}) })
cmd.Println("Regist [" + Subscription.Domain + "] as subscriber") cmd.Println("Register [" + Subscription.Domain + "] as subscriber")
} }
} }

View File

@ -73,7 +73,7 @@ func TestInvalidConfig(t *testing.T) {
app := configCmdInit() app := configCmdInit()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"enable", "hoge"}) app.SetArgs([]string{"enable", "hoge"})
app.Execute() app.Execute()
@ -89,7 +89,7 @@ func TestListConfig(t *testing.T) {
app := configCmdInit() app := configCmdInit()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"list"}) app.SetArgs([]string{"list"})
app.Execute() app.Execute()
@ -118,7 +118,7 @@ func TestExportConfig(t *testing.T) {
app := configCmdInit() app := configCmdInit()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"export"}) app.SetArgs([]string{"export"})
app.Execute() app.Execute()
@ -127,7 +127,7 @@ func TestExportConfig(t *testing.T) {
if err != nil { if err != nil {
t.Fatalf("Test resource fetch error.") t.Fatalf("Test resource fetch error.")
} }
jsonData, err := ioutil.ReadAll(file) jsonData, _ := ioutil.ReadAll(file)
output := buffer.String() output := buffer.String()
if strings.Split(output, "\n")[0] != string(jsonData) { if strings.Split(output, "\n")[0] != string(jsonData) {
t.Fatalf("Invalid Response.") t.Fatalf("Invalid Response.")
@ -144,7 +144,7 @@ func TestImportConfig(t *testing.T) {
relayState.Load() relayState.Load()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"export"}) app.SetArgs([]string{"export"})
app.Execute() app.Execute()
@ -153,7 +153,7 @@ func TestImportConfig(t *testing.T) {
if err != nil { if err != nil {
t.Fatalf("Test resource fetch error.") t.Fatalf("Test resource fetch error.")
} }
jsonData, err := ioutil.ReadAll(file) jsonData, _ := ioutil.ReadAll(file)
output := buffer.String() output := buffer.String()
if strings.Split(output, "\n")[0] != string(jsonData) { if strings.Split(output, "\n")[0] != string(jsonData) {
t.Fatalf("Invalid Response.") t.Fatalf("Invalid Response.")

View File

@ -64,7 +64,7 @@ func createUnfollowRequestResponse(subscription models.Subscription) error {
resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Reject") resp := activity.GenerateResponse(globalConfig.ServerHostname(), "Reject")
jsonData, _ := json.Marshal(&resp) jsonData, _ := json.Marshal(&resp)
pushRegistorJob(subscription.InboxURL, jsonData) pushRegisterJob(subscription.InboxURL, jsonData)
return nil return nil
} }

View File

@ -17,7 +17,7 @@ func TestListDomainSubscriber(t *testing.T) {
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app = domainCmdInit() app = domainCmdInit()
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"list"}) app.SetArgs([]string{"list"})
app.Execute() app.Execute()
@ -43,7 +43,7 @@ func TestListDomainLimited(t *testing.T) {
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app = domainCmdInit() app = domainCmdInit()
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"list", "-t", "limited"}) app.SetArgs([]string{"list", "-t", "limited"})
app.Execute() app.Execute()
@ -69,7 +69,7 @@ func TestListDomainBlocked(t *testing.T) {
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app = domainCmdInit() app = domainCmdInit()
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"list", "-t", "blocked"}) app.SetArgs([]string{"list", "-t", "blocked"})
app.Execute() app.Execute()
@ -187,7 +187,7 @@ func TestSetDomainInvalid(t *testing.T) {
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app = domainCmdInit() app = domainCmdInit()
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"set", "-t", "hoge", "hoge.example.jp"}) app.SetArgs([]string{"set", "-t", "hoge", "hoge.example.jp"})
app.Execute() app.Execute()
@ -234,7 +234,7 @@ func TestInvalidUnfollowDomain(t *testing.T) {
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app = domainCmdInit() app = domainCmdInit()
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"unfollow", "unknown.tld"}) app.SetArgs([]string{"unfollow", "unknown.tld"})
app.Execute() app.Execute()

View File

@ -64,9 +64,9 @@ func followCmdInit() *cobra.Command {
return follow return follow
} }
func pushRegistorJob(inboxURL string, body []byte) { func pushRegisterJob(inboxURL string, body []byte) {
job := &tasks.Signature{ job := &tasks.Signature{
Name: "registor", Name: "register",
RetryCount: 25, RetryCount: 25,
Args: []tasks.Arg{ Args: []tasks.Arg{
{ {
@ -105,7 +105,7 @@ func createFollowRequestResponse(domain string, response string) error {
if err != nil { if err != nil {
return err return err
} }
pushRegistorJob(data["inbox_url"], jsonData) pushRegisterJob(data["inbox_url"], jsonData)
relayState.RedisClient.Del("relay:pending:" + domain) relayState.RedisClient.Del("relay:pending:" + domain)
if response == "Accept" { if response == "Accept" {
relayState.AddSubscription(models.Subscription{ relayState.AddSubscription(models.Subscription{
@ -133,7 +133,7 @@ func createUpdateActorActivity(subscription models.Subscription) error {
if err != nil { if err != nil {
return err return err
} }
pushRegistorJob(subscription.InboxURL, jsonData) pushRegisterJob(subscription.InboxURL, jsonData)
return nil return nil
} }

View File

@ -12,7 +12,7 @@ func TestListFollows(t *testing.T) {
app := followCmdInit() app := followCmdInit()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
relayState.RedisClient.HMSet("relay:pending:example.com", map[string]interface{}{ relayState.RedisClient.HMSet("relay:pending:example.com", map[string]interface{}{
"inbox_url": "https://example.com/inbox", "inbox_url": "https://example.com/inbox",
@ -95,7 +95,7 @@ func TestInvalidFollow(t *testing.T) {
app := followCmdInit() app := followCmdInit()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"accept", "unknown.tld"}) app.SetArgs([]string{"accept", "unknown.tld"})
app.Execute() app.Execute()
@ -112,7 +112,7 @@ func TestInvalidRejectFollow(t *testing.T) {
app := followCmdInit() app := followCmdInit()
buffer := new(bytes.Buffer) buffer := new(bytes.Buffer)
app.SetOutput(buffer) app.SetOut(buffer)
app.SetArgs([]string{"reject", "unknown.tld"}) app.SetArgs([]string{"reject", "unknown.tld"})
app.Execute() app.Execute()

View File

@ -32,13 +32,13 @@ func relayActivity(args ...string) error {
err := sendActivity(inboxURL, Actor.ID, []byte(body), globalConfig.ActorKey()) err := sendActivity(inboxURL, Actor.ID, []byte(body), globalConfig.ActorKey())
if err != nil { if err != nil {
domain, _ := url.Parse(inboxURL) domain, _ := url.Parse(inboxURL)
eval_script := "local change = redis.call('HSETNX',KEYS[1], 'last_error', ARGV[1]); if change == 1 then redis.call('EXPIRE', KEYS[1], ARGV[2]) end;" evalScript := "local change = redis.call('HSETNX',KEYS[1], 'last_error', ARGV[1]); if change == 1 then redis.call('EXPIRE', KEYS[1], ARGV[2]) end;"
redisClient.Eval(eval_script, []string{"relay:statistics:" + domain.Host}, err.Error(), 60).Result() redisClient.Eval(evalScript, []string{"relay:statistics:" + domain.Host}, err.Error(), 60).Result()
} }
return err return err
} }
func registorActivity(args ...string) error { func registerActivity(args ...string) error {
inboxURL := args[0] inboxURL := args[0]
body := args[1] body := args[1]
err := sendActivity(inboxURL, Actor.ID, []byte(body), globalConfig.ActorKey()) err := sendActivity(inboxURL, Actor.ID, []byte(body), globalConfig.ActorKey())
@ -55,7 +55,7 @@ func Entrypoint(g *models.RelayConfig, v string) error {
return err return err
} }
err = machineryServer.RegisterTask("registor", registorActivity) err = machineryServer.RegisterTask("register", registerActivity)
if err != nil { if err != nil {
return err return err
} }

View File

@ -56,7 +56,7 @@ func TestRelayActivity(t *testing.T) {
err := relayActivity(s.URL, "data") err := relayActivity(s.URL, "data")
if err != nil { if err != nil {
t.Fatal("Failed - Data transfar not collect") t.Fatal("Failed - Data transfer not collect")
} }
} }
@ -95,7 +95,7 @@ func TestRelayActivityResp500(t *testing.T) {
} }
} }
func TestRegistorActivity(t *testing.T) { func TestRegisterActivity(t *testing.T) {
s := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { s := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
data, _ := ioutil.ReadAll(r.Body) data, _ := ioutil.ReadAll(r.Body)
if string(data) != "data" || r.Header.Get("Content-Type") != "application/activity+json" { if string(data) != "data" || r.Header.Get("Content-Type") != "application/activity+json" {
@ -108,32 +108,32 @@ func TestRegistorActivity(t *testing.T) {
})) }))
defer s.Close() defer s.Close()
err := registorActivity(s.URL, "data") err := registerActivity(s.URL, "data")
if err != nil { if err != nil {
t.Fatal("Failed - Data transfar not collect") t.Fatal("Failed - Data transfer not collect")
} }
} }
func TestRegistorActivityNoHost(t *testing.T) { func TestRegisterActivityNoHost(t *testing.T) {
s := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { s := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
})) }))
defer s.Close() defer s.Close()
err := registorActivity("http://nohost.example.jp", "data") err := registerActivity("http://nohost.example.jp", "data")
if err == nil { if err == nil {
t.Fatal("Failed - Error not reported.") t.Fatal("Failed - Error not reported.")
} }
} }
func TestRegistorActivityResp500(t *testing.T) { func TestRegisterActivityResp500(t *testing.T) {
s := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) { s := httptest.NewServer(http.HandlerFunc(func(w http.ResponseWriter, r *http.Request) {
w.WriteHeader(500) w.WriteHeader(500)
w.Write(nil) w.Write(nil)
})) }))
defer s.Close() defer s.Close()
err := registorActivity(s.URL, "data") err := registerActivity(s.URL, "data")
if err == nil { if err == nil {
t.Fatal("Failed - Error not reported.") t.Fatal("Failed - Error not reported.")
} }

View File

@ -4,7 +4,7 @@ package deliver
type NullLogger struct { type NullLogger struct {
} }
// NewNullLogger : Create Nulllogger // NewNullLogger : Create NullLogger
func NewNullLogger() *NullLogger { func NewNullLogger() *NullLogger {
var newNullLogger NullLogger var newNullLogger NullLogger
return &newNullLogger return &newNullLogger

View File

@ -35,7 +35,7 @@ func appendSignature(request *http.Request, body *[]byte, KeyID string, publicKe
func sendActivity(inboxURL string, KeyID string, body []byte, publicKey *rsa.PrivateKey) error { func sendActivity(inboxURL string, KeyID string, body []byte, publicKey *rsa.PrivateKey) error {
req, _ := http.NewRequest("POST", inboxURL, bytes.NewBuffer(body)) req, _ := http.NewRequest("POST", inboxURL, bytes.NewBuffer(body))
req.Header.Set("Content-Type", "application/activity+json") req.Header.Set("Content-Type", "application/activity+json")
req.Header.Set("User-Agent", fmt.Sprintf("%s (golang net/http; Activity-Relay %s; %s)", globalConfig.ServerServicename(), version, globalConfig.ServerHostname().Host)) req.Header.Set("User-Agent", fmt.Sprintf("%s (golang net/http; Activity-Relay %s; %s)", globalConfig.ServerServiceName(), version, globalConfig.ServerHostname().Host))
req.Header.Set("Date", httpdate.Time2Str(time.Now())) req.Header.Set("Date", httpdate.Time2Str(time.Now()))
appendSignature(req, &body, KeyID, publicKey) appendSignature(req, &body, KeyID, publicKey)
resp, err := httpClient.Do(req) resp, err := httpClient.Do(req)

View File

@ -94,8 +94,8 @@ func (relayConfig *RelayConfig) ServerHostname() *url.URL {
return relayConfig.domain return relayConfig.domain
} }
// ServerHostname is API Server's servername definition. // ServerServiceName is API Server's servername definition.
func (relayConfig *RelayConfig) ServerServicename() string { func (relayConfig *RelayConfig) ServerServiceName() string {
return relayConfig.serviceName return relayConfig.serviceName
} }
@ -109,7 +109,7 @@ func (relayConfig *RelayConfig) ActorKey() *rsa.PrivateKey {
return relayConfig.actorKey return relayConfig.actorKey
} }
// CreateRedisClient is create new redis client from RelayConfig. // RedisClient is return redis client from RelayConfig.
func (relayConfig *RelayConfig) RedisClient() *redis.Client { func (relayConfig *RelayConfig) RedisClient() *redis.Client {
return relayConfig.redisClient return relayConfig.redisClient
} }

View File

@ -81,15 +81,15 @@ func TestRelayConfig_ServerHostname(t *testing.T) {
} }
func TestRelayConfig_DumpWelcomeMessage(t *testing.T) { func TestRelayConfig_DumpWelcomeMessage(t *testing.T) {
relayconfig := createRelayConfig(t) relayConfig := createRelayConfig(t)
w := relayconfig.DumpWelcomeMessage("Testing", "") w := relayConfig.DumpWelcomeMessage("Testing", "")
informations := map[string]string{ informations := map[string]string{
"module NAME": "Testing", "module NAME": "Testing",
"RELAY NANE": relayconfig.serviceName, "RELAY NANE": relayConfig.serviceName,
"RELAY DOMAIN": relayconfig.domain.Host, "RELAY DOMAIN": relayConfig.domain.Host,
"REDIS URL": relayconfig.redisURL, "REDIS URL": relayConfig.redisURL,
"BIND ADDRESS": relayconfig.serverBind, "BIND ADDRESS": relayConfig.serverBind,
} }
for key, information := range informations { for key, information := range informations {

View File

@ -45,8 +45,8 @@ type Actor struct {
Image *Image `json:"image,omitempty"` Image *Image `json:"image,omitempty"`
} }
// GenerateSelfKey : Generate relay Actor from Publickey. // GenerateSelfKey : Generate relay Actor from PublicKey.
func (actor *Actor) GenerateSelfKey(hostname *url.URL, publickey *rsa.PublicKey) { func (actor *Actor) GenerateSelfKey(hostname *url.URL, publicKey *rsa.PublicKey) {
actor.Context = []string{"https://www.w3.org/ns/activitystreams", "https://w3id.org/security/v1"} actor.Context = []string{"https://www.w3.org/ns/activitystreams", "https://w3id.org/security/v1"}
actor.ID = hostname.String() + "/actor" actor.ID = hostname.String() + "/actor"
actor.Type = "Service" actor.Type = "Service"
@ -55,7 +55,7 @@ func (actor *Actor) GenerateSelfKey(hostname *url.URL, publickey *rsa.PublicKey)
actor.PublicKey = PublicKey{ actor.PublicKey = PublicKey{
hostname.String() + "/actor#main-key", hostname.String() + "/actor#main-key",
hostname.String() + "/actor", hostname.String() + "/actor",
generatePublicKeyPEMString(publickey), generatePublicKeyPEMString(publicKey),
} }
} }
@ -195,9 +195,9 @@ func (activity *Activity) NestedActivity() (*Activity, error) {
}, nil }, nil
} }
} }
return nil, errors.New("Can't assart type") return nil, errors.New("can't assert type")
} }
return nil, errors.New("Can't assart id") return nil, errors.New("can't assert id")
} }
// ActivityObject : ActivityPub Activity. // ActivityObject : ActivityPub Activity.
@ -235,7 +235,7 @@ type WebfingerResource struct {
func (resource *WebfingerResource) GenerateFromActor(hostname *url.URL, actor *Actor) { func (resource *WebfingerResource) GenerateFromActor(hostname *url.URL, actor *Actor) {
resource.Subject = "acct:" + actor.PreferredUsername + "@" + hostname.Host resource.Subject = "acct:" + actor.PreferredUsername + "@" + hostname.Host
resource.Links = []WebfingerLink{ resource.Links = []WebfingerLink{
WebfingerLink{ {
"self", "self",
"application/activity+json", "application/activity+json",
actor.ID, actor.ID,
@ -303,7 +303,7 @@ type NodeinfoMetadata struct {
// GenerateFromActor : Generate Webfinger resource from Actor. // GenerateFromActor : Generate Webfinger resource from Actor.
func (resource *NodeinfoResources) GenerateFromActor(hostname *url.URL, actor *Actor, serverVersion string) { func (resource *NodeinfoResources) GenerateFromActor(hostname *url.URL, actor *Actor, serverVersion string) {
resource.NodeinfoLinks.Links = []NodeinfoLink{ resource.NodeinfoLinks.Links = []NodeinfoLink{
NodeinfoLink{ {
"http://nodeinfo.diaspora.software/ns/schema/2.1", "http://nodeinfo.diaspora.software/ns/schema/2.1",
"https://" + hostname.Host + "/nodeinfo/2.1", "https://" + hostname.Host + "/nodeinfo/2.1",
}, },

View File

@ -92,7 +92,7 @@ func (config *RelayState) Load() {
config.Subscriptions = subscriptions config.Subscriptions = subscriptions
} }
// SetConfig : Set relay configration // SetConfig : Set relay configuration
func (config *RelayState) SetConfig(key Config, value bool) { func (config *RelayState) SetConfig(key Config, value bool) {
strValue := 0 strValue := 0
if value { if value {

View File

@ -167,7 +167,7 @@ func TestLimitedDomain(t *testing.T) {
} }
} }
func TestLoadCompatiSubscription(t *testing.T) { func TestLoadCompatibleSubscription(t *testing.T) {
relayState.RedisClient.FlushAll().Result() relayState.RedisClient.FlushAll().Result()
relayState.AddSubscription(Subscription{ relayState.AddSubscription(Subscription{

View File

@ -12,7 +12,7 @@ import (
"github.com/go-redis/redis" "github.com/go-redis/redis"
) )
func ReadPublicKeyRSAfromString(pemString string) (*rsa.PublicKey, error) { func ReadPublicKeyRSAFromString(pemString string) (*rsa.PublicKey, error) {
pemByte := []byte(pemString) pemByte := []byte(pemString)
decoded, _ := pem.Decode(pemByte) decoded, _ := pem.Decode(pemByte)
defer func() { defer func() {

View File

@ -60,7 +60,7 @@ JOB_CONCURRENCY: 50
### Environment Variable ### Environment Variable
This is **Optional** : When `config.yml` not exists, use environment variable. This is **Optional** : When `config.yaml` not exists, use environment variable.
- ACTOR_PEM - ACTOR_PEM
- REDIS_URL - REDIS_URL
@ -81,7 +81,7 @@ Thank you for your support.
### Monthly Donation ### Monthly Donation
**[My Doner List](https://relay.toot.yukimochi.jp#patreon-list)** **[My Donner List](https://relay.toot.yukimochi.jp#patreon-list)**
#### Donation Platform #### Donation Platform
- [Patreon](https://www.patreon.com/yukimochi) - [Patreon](https://www.patreon.com/yukimochi)