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

Commit

Permalink
Merge pull request #128 from ipfs/feat/migration-config
Browse files Browse the repository at this point in the history
Add config for downloading repo migrations
  • Loading branch information
Stebalien committed May 3, 2021
2 parents 0a47425 + a2a309d commit 9a8ef0f
Show file tree
Hide file tree
Showing 4 changed files with 56 additions and 0 deletions.
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".
DownloadSources []string
// 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")
}
}

0 comments on commit 9a8ef0f

Please sign in to comment.