Words typo in codes fixed.
This commit is contained in:
parent
4dd69d0dac
commit
f05921420f
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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)
|
||||||
|
@ -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")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -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.")
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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()
|
||||||
|
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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()
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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.")
|
||||||
}
|
}
|
||||||
|
@ -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
|
||||||
|
@ -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)
|
||||||
|
@ -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
|
||||||
}
|
}
|
||||||
|
@ -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 {
|
||||||
|
@ -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",
|
||||||
},
|
},
|
||||||
|
@ -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 {
|
||||||
|
@ -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{
|
||||||
|
@ -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() {
|
||||||
|
@ -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)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user