From 121511f10da225819f00bab5263146e13da00823 Mon Sep 17 00:00:00 2001 From: Eric Meyer Date: Wed, 1 Nov 2017 09:40:04 -0500 Subject: [PATCH 1/2] Refactor existing code to use Godo --- .gitignore | 1 + Gododir/main.go | 35 +++++++++++++++++++++++++++++++++++ main.go | 25 ------------------------- 3 files changed, 36 insertions(+), 25 deletions(-) create mode 100644 Gododir/main.go delete mode 100644 main.go diff --git a/.gitignore b/.gitignore index e7405fee..8bfa0dbc 100644 --- a/.gitignore +++ b/.gitignore @@ -1,3 +1,4 @@ .idea +Gododir/godobin-* test_data_dir/ vendor/ diff --git a/Gododir/main.go b/Gododir/main.go new file mode 100644 index 00000000..21f35193 --- /dev/null +++ b/Gododir/main.go @@ -0,0 +1,35 @@ +package main + +import ( + "log" + + "github.com/8thlight/vulcanizedb/core" + "github.com/jmoiron/sqlx" + do "gopkg.in/godo.v2" +) + +func tasks(p *do.Project) { + + p.Task("run", nil, func(context *do.Context) { + ipcPath := context.Args.MayString("", "ipc-path", "i") + + port := "5432" + host := "localhost" + databaseName := "vulcanize" + + var blockchain core.Blockchain = core.NewGethBlockchain(ipcPath) + blockchain.RegisterObserver(core.BlockchainLoggingObserver{}) + pgConfig := "host=" + host + " port=" + port + " dbname=" + databaseName + " sslmode=disable" + db, err := sqlx.Connect("postgres", pgConfig) + if err != nil { + log.Fatalf("Error connecting to DB: %v\n", err) + } + blockchain.RegisterObserver(core.BlockchainDBObserver{Db: db}) + blockchain.SubscribeToEvents() + }) + +} + +func main() { + do.Godo(tasks) +} diff --git a/main.go b/main.go deleted file mode 100644 index 133480f3..00000000 --- a/main.go +++ /dev/null @@ -1,25 +0,0 @@ -package main - -import ( - "flag" - - "log" - - "github.com/8thlight/vulcanizedb/core" - "github.com/jmoiron/sqlx" -) - -func main() { - ipcPath := flag.String("ipcPath", "", "location geth.ipc") - flag.Parse() - - var blockchain core.Blockchain = core.NewGethBlockchain(*ipcPath) - blockchain.RegisterObserver(core.BlockchainLoggingObserver{}) - pgConfig := "host=localhost port=5432 dbname=vulcanize sslmode=disable" - db, err := sqlx.Connect("postgres", pgConfig) - if err != nil { - log.Fatalf("Error connecting to DB: %v\n", err) - } - blockchain.RegisterObserver(core.BlockchainDBObserver{Db: db}) - blockchain.SubscribeToEvents() -} From 102beb11e3e8f4c6edccec5af7c1d2c911316f97 Mon Sep 17 00:00:00 2001 From: Eric Meyer Date: Wed, 1 Nov 2017 10:17:01 -0500 Subject: [PATCH 2/2] Add the concept of multiple environments * Right now, the two environments are Public and Private * This was to reflect the two blockchains we run against --- .travis.yml | 4 +- Gododir/main.go | 69 +++++++++++++++++++++++------ README.md | 14 +++--- config/config.go | 5 +++ config/database.go | 13 ++++++ config/private.go | 11 +++++ config/public.go | 11 +++++ core/blockchain_db_observer_test.go | 19 +++----- scripts/create_migration | 2 +- scripts/dump_schema | 2 - scripts/migrate | 3 -- scripts/rollback | 3 -- 12 files changed, 113 insertions(+), 43 deletions(-) create mode 100644 config/config.go create mode 100644 config/database.go create mode 100644 config/private.go create mode 100644 config/public.go delete mode 100755 scripts/dump_schema delete mode 100755 scripts/migrate delete mode 100755 scripts/rollback diff --git a/.travis.yml b/.travis.yml index ac077457..25d19f0e 100644 --- a/.travis.yml +++ b/.travis.yml @@ -5,8 +5,8 @@ go: services: - postgresql before_script: - - createdb vulcanize - - psql vulcanize < migrations/schema.sql + - createdb vulcanize_private + - psql vulcanize_private < migrations/schema.sql script: - go test -v ./core/... notifications: diff --git a/Gododir/main.go b/Gododir/main.go index 21f35193..8254201f 100644 --- a/Gododir/main.go +++ b/Gododir/main.go @@ -3,29 +3,70 @@ package main import ( "log" + "fmt" + + cfg "github.com/8thlight/vulcanizedb/config" "github.com/8thlight/vulcanizedb/core" "github.com/jmoiron/sqlx" do "gopkg.in/godo.v2" ) +func parseIpcPath(context *do.Context) string { + ipcPath := context.Args.MayString("", "ipc-path", "i") + if ipcPath == "" { + log.Fatalln("--ipc-path required") + } + return ipcPath +} + +func startBlockchainListener(config cfg.Config, ipcPath string) { + port := config.Database.Port + host := config.Database.Hostname + databaseName := config.Database.Name + + var blockchain core.Blockchain = core.NewGethBlockchain(ipcPath) + blockchain.RegisterObserver(core.BlockchainLoggingObserver{}) + pgConfig := fmt.Sprintf("host=%s port=%d dbname=%s sslmode=disable", host, port, databaseName) + db, err := sqlx.Connect("postgres", pgConfig) + if err != nil { + log.Fatalf("Error connecting to DB: %v\n", err) + } + blockchain.RegisterObserver(core.BlockchainDBObserver{Db: db}) + blockchain.SubscribeToEvents() +} + func tasks(p *do.Project) { - p.Task("run", nil, func(context *do.Context) { - ipcPath := context.Args.MayString("", "ipc-path", "i") + p.Task("runPublic", nil, func(context *do.Context) { + startBlockchainListener(cfg.Public(), parseIpcPath(context)) + }) - port := "5432" - host := "localhost" - databaseName := "vulcanize" + p.Task("runPrivate", nil, func(context *do.Context) { + startBlockchainListener(cfg.Private(), parseIpcPath(context)) + }) - var blockchain core.Blockchain = core.NewGethBlockchain(ipcPath) - blockchain.RegisterObserver(core.BlockchainLoggingObserver{}) - pgConfig := "host=" + host + " port=" + port + " dbname=" + databaseName + " sslmode=disable" - db, err := sqlx.Connect("postgres", pgConfig) - if err != nil { - log.Fatalf("Error connecting to DB: %v\n", err) - } - blockchain.RegisterObserver(core.BlockchainDBObserver{Db: db}) - blockchain.SubscribeToEvents() + p.Task("migratePublic", nil, func(context *do.Context) { + connectString := cfg.DbConnectionString(cfg.Public().Database) + context.Bash(fmt.Sprintf("migrate -database '%s' -path ./migrations up", connectString)) + context.Bash(fmt.Sprintf("pg_dump -O -s %s > migrations/schema.sql", cfg.Public().Database.Name)) + }) + + p.Task("migratePrivate", nil, func(context *do.Context) { + connectString := cfg.DbConnectionString(cfg.Private().Database) + context.Bash(fmt.Sprintf("migrate -database '%s' -path ./migrations up", connectString)) + context.Bash(fmt.Sprintf("pg_dump -O -s %s > migrations/schema.sql", cfg.Private().Database.Name)) + }) + + p.Task("rollbackPublic", nil, func(context *do.Context) { + connectString := cfg.DbConnectionString(cfg.Public().Database) + context.Bash(fmt.Sprintf("migrate -database '%s' -path ./migrations down 1", connectString)) + context.Bash("pg_dump -O -s vulcanize_public > migrations/schema.sql") + }) + + p.Task("rollbackPrivate", nil, func(context *do.Context) { + connectString := cfg.DbConnectionString(cfg.Private().Database) + context.Bash(fmt.Sprintf("migrate -database '%s' -path ./migrations down 1", connectString)) + context.Bash("pg_dump -O -s vulcanize_private > migrations/schema.sql") }) } diff --git a/README.md b/README.md index 07549e74..ef98e797 100644 --- a/README.md +++ b/README.md @@ -9,6 +9,8 @@ - Go 1.9+ - https://github.com/golang/dep - `go get -u github.com/golang/dep/cmd/dep` + - https://github.com/go-godo/godo + - `go get -u gopkg.in/godo.v2/cmd/godo` - Postgres 10 ### Cloning the Repository @@ -22,15 +24,17 @@ 5. `cd $GOPATH/src/github.com/8thlight/vulcanizedb` 6. `dep ensure` -### Setting up the Development Database +### Setting up the Databases 1. Install Postgres 2. Create a superuser for yourself and make sure `psql --list` works without prompting for a password. 3. `go get -u -d github.com/mattes/migrate/cli github.com/lib/pq` 4. `go build -tags 'postgres' -o /usr/local/bin/migrate github.com/mattes/migrate/cli` -5. `createdb vulcanize` -6. `cd $GOPATH/src/github.com/8thlight/vulcanizedb` -7. `./scripts/migrate` +5. `createdb vulcanize_public` +6. `createdb vulcanize_private` +7. `cd $GOPATH/src/github.com/8thlight/vulcanizedb` +8. `godo migratePublic` +9. `godo migratePrivate` Adding a new migration: `./scripts/create_migration ` @@ -60,7 +64,7 @@ The default location for Ethereum is: 1. Start a blockchain. 2. In a separate terminal start listener (ipcDir location) - - `go run main.go --ipcPath /path/to/file.ipc` + - `godo runPublic -- --ipc-path /path/to/file.ipc` ## Running the Tests diff --git a/config/config.go b/config/config.go new file mode 100644 index 00000000..154c69df --- /dev/null +++ b/config/config.go @@ -0,0 +1,5 @@ +package config + +type Config struct { + Database Database +} diff --git a/config/database.go b/config/database.go new file mode 100644 index 00000000..7e82fb97 --- /dev/null +++ b/config/database.go @@ -0,0 +1,13 @@ +package config + +import "fmt" + +type Database struct { + Hostname string + Name string + Port int +} + +func DbConnectionString(dbConfig Database) string { + return fmt.Sprintf("postgresql://%s:%d/%s?sslmode=disable", dbConfig.Hostname, dbConfig.Port, dbConfig.Name) +} diff --git a/config/private.go b/config/private.go new file mode 100644 index 00000000..53027c5b --- /dev/null +++ b/config/private.go @@ -0,0 +1,11 @@ +package config + +func Private() Config { + return Config{ + Database: Database{ + Name: "vulcanize_private", + Hostname: "localhost", + Port: 5432, + }, + } +} diff --git a/config/public.go b/config/public.go new file mode 100644 index 00000000..420fd9a1 --- /dev/null +++ b/config/public.go @@ -0,0 +1,11 @@ +package config + +func Public() Config { + return Config{ + Database: Database{ + Name: "vulcanize_public", + Hostname: "localhost", + Port: 5432, + }, + } +} diff --git a/core/blockchain_db_observer_test.go b/core/blockchain_db_observer_test.go index 983554f8..d781606e 100644 --- a/core/blockchain_db_observer_test.go +++ b/core/blockchain_db_observer_test.go @@ -1,8 +1,7 @@ package core_test import ( - "fmt" - + "github.com/8thlight/vulcanizedb/config" "github.com/8thlight/vulcanizedb/core" "github.com/jmoiron/sqlx" _ "github.com/lib/pq" @@ -10,28 +9,22 @@ import ( . "github.com/onsi/gomega" ) -const ( - host = "localhost" - port = 5432 - user = "postgres" - password = "postgres" - dbname = "vulcanize" -) - var _ = Describe("Saving blocks to the database", func() { var db *sqlx.DB var err error - pgConfig := fmt.Sprintf( - "host=%s port=%d user=%s password=%s dbname=%s sslmode=disable", - host, port, user, password, dbname) BeforeEach(func() { + pgConfig := config.DbConnectionString(config.Private().Database) db, err = sqlx.Connect("postgres", pgConfig) db.MustExec("DELETE FROM transactions") db.MustExec("DELETE FROM blocks") }) + AfterEach(func() { + db.Close() + }) + It("implements the observer interface", func() { var observer core.BlockchainObserver = core.BlockchainDBObserver{Db: db} Expect(observer).NotTo(BeNil()) diff --git a/scripts/create_migration b/scripts/create_migration index 5a8d66a9..b51a0cae 100755 --- a/scripts/create_migration +++ b/scripts/create_migration @@ -2,7 +2,7 @@ if [ $# -eq 1 ] then - migrate -database postgresql://localhost:5432/postgres create -dir ./migrations -ext sql $1 + migrate create -dir ./migrations -ext sql $1 else echo "**An Error Occurred**" echo "Usage: ./scripts/create_migration " diff --git a/scripts/dump_schema b/scripts/dump_schema deleted file mode 100755 index aad61aaa..00000000 --- a/scripts/dump_schema +++ /dev/null @@ -1,2 +0,0 @@ -#!/bin/bash -pg_dump -O -s vulcanize > migrations/schema.sql diff --git a/scripts/migrate b/scripts/migrate deleted file mode 100755 index 34826ab0..00000000 --- a/scripts/migrate +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/bash -migrate -database 'postgresql://localhost:5432/vulcanize?sslmode=disable' -path ./migrations up -./scripts/dump_schema diff --git a/scripts/rollback b/scripts/rollback deleted file mode 100755 index 85b6656d..00000000 --- a/scripts/rollback +++ /dev/null @@ -1,3 +0,0 @@ -#!/bin/bash -migrate -database 'postgresql://localhost:5432/vulcanize?sslmode=disable' -path ./migrations down 1 -./scripts/dump_schema