Skip to content
This repository has been archived by the owner on Mar 9, 2022. It is now read-only.

Add config for downloading repo migrations #128

Merged
merged 5 commits into from
May 3, 2021
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions config.go
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,7 @@ type Config struct {
Pubsub PubsubConfig
Peering Peering
DNS DNS
Migration Migration

Provider Provider
Reprovider Reprovider
Expand Down
4 changes: 4 additions & 0 deletions init.go
Original file line number Diff line number Diff line change
Expand Up @@ -92,6 +92,10 @@ func InitWithIdentity(identity Identity) (*Config, error) {
DNS: DNS{
Resolvers: map[string]string{},
},
Migration: Migration{
DownloadSources: []string{},
Keep: "",
},
}

return conf, nil
Expand Down
17 changes: 17 additions & 0 deletions migration.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,17 @@
package config

const DefaultMigrationKeep = "cache"

var DefaultMigrationDownloadSources = []string{"HTTPS", "IPFS"}

// Migration configures how migrations are downloaded and if the downloads are
// added to IPFS locally
type Migration struct {
// Sources in order of preference, where "IPFS" means use IPFS and "HTTPS"
// means use default gateways. Any other values are interpreted as
// hostnames for custom gateways. Empty list means "use default sources".
Stebalien marked this conversation as resolved.
Show resolved Hide resolved
DownloadSources []string
Stebalien marked this conversation as resolved.
Show resolved Hide resolved
// Whether or not to keep the migration after downloading it.
// Options are "discard", "cache", "pin". Empty string for default.
Keep string
}
34 changes: 34 additions & 0 deletions migration_test.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,34 @@
package config

import (
"encoding/json"
"testing"
)

func TestMigrationDecode(t *testing.T) {
str := `
{
"DownloadSources": ["IPFS", "HTTP", "127.0.0.1"],
"Keep": "cache"
}
`

var cfg Migration
if err := json.Unmarshal([]byte(str), &cfg); err != nil {
t.Errorf("failed while unmarshalling migration struct: %s", err)
}

if len(cfg.DownloadSources) != 3 {
t.Fatal("wrong number of DownloadSources")
}
expect := []string{"IPFS", "HTTP", "127.0.0.1"}
for i := range expect {
if cfg.DownloadSources[i] != expect[i] {
t.Errorf("wrong DownloadSource at %d", i)
}
}

if cfg.Keep != "cache" {
t.Error("wrong value for Keep")
}
}