From c7959f1f6df222f5aa15a95f7644d52a7f889a2c Mon Sep 17 00:00:00 2001 From: Victor Yves Crispim Date: Thu, 14 Sep 2023 14:31:04 -0300 Subject: [PATCH] feat: build single node binary --- cmd/cartesi-node/full.go | 52 ++++++++++++++++++++++++++++++++++ cmd/cartesi-node/main.go | 14 +++++++++ cmd/cartesi-node/no-backend.go | 14 +++++++++ cmd/cartesi-node/reader.go | 14 +++++++++ cmd/cartesi-node/root.go | 18 ++++++++++++ cmd/cartesi-node/validator.go | 14 +++++++++ go.mod | 10 +++++++ go.sum | 10 +++++++ 8 files changed, 146 insertions(+) create mode 100644 cmd/cartesi-node/full.go create mode 100644 cmd/cartesi-node/main.go create mode 100644 cmd/cartesi-node/no-backend.go create mode 100644 cmd/cartesi-node/reader.go create mode 100644 cmd/cartesi-node/root.go create mode 100644 cmd/cartesi-node/validator.go create mode 100644 go.mod create mode 100644 go.sum diff --git a/cmd/cartesi-node/full.go b/cmd/cartesi-node/full.go new file mode 100644 index 000000000..8a18a41c3 --- /dev/null +++ b/cmd/cartesi-node/full.go @@ -0,0 +1,52 @@ +// (c) Cartesi and individual authors (see AUTHORS) +// SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +package main + +import ( + "io" + "log" + "os" + "os/exec" + + "github.com/spf13/cobra" +) + +var full = &cobra.Command{ + Use: "full", + Short: "Starts the node in full mode with reader and validator capabilities", + Run: runFullNode, +} + +func runFullNode(cmd *cobra.Command, args []string) { + proc := exec.Command("cartesi-rollups-graphql-server") + + stdoutPipe, err := proc.StdoutPipe() + if err != nil { + log.Fatal("Error creating stdout pipe:", err) + } + + stderrPipe, err := proc.StderrPipe() + if err != nil { + log.Fatal("Error creating stderr pipe:", err) + } + + if err := proc.Start(); err != nil { + log.Fatal("Error starting sub-process:", err) + } + + // Create goroutines to display the sub-process's stdout and stderr. + go func() { + io.Copy(os.Stdout, stdoutPipe) + }() + + go func() { + io.Copy(os.Stderr, stderrPipe) + }() + + if err := proc.Wait(); err != nil { + log.Fatal("Error waiting for sub-process:", err) + } + + log.Println("Sub-process finished") +} diff --git a/cmd/cartesi-node/main.go b/cmd/cartesi-node/main.go new file mode 100644 index 000000000..efc06fe53 --- /dev/null +++ b/cmd/cartesi-node/main.go @@ -0,0 +1,14 @@ +// (c) Cartesi and individual authors (see AUTHORS) +// SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +package main + +import ( + "os" +) + +func main() { + if err := rootCmd.Execute(); err != nil { + os.Exit(1) + } +} diff --git a/cmd/cartesi-node/no-backend.go b/cmd/cartesi-node/no-backend.go new file mode 100644 index 000000000..ffb000f47 --- /dev/null +++ b/cmd/cartesi-node/no-backend.go @@ -0,0 +1,14 @@ +// (c) Cartesi and individual authors (see AUTHORS) +// SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +package main + +import "github.com/spf13/cobra" + +var noBackend = &cobra.Command{ + Use: "no-backend", + Short: "Starts the node in no-backend mode", + Run: func(cmd *cobra.Command, args []string) { + println("TODO") + }, +} diff --git a/cmd/cartesi-node/reader.go b/cmd/cartesi-node/reader.go new file mode 100644 index 000000000..52df50e46 --- /dev/null +++ b/cmd/cartesi-node/reader.go @@ -0,0 +1,14 @@ +// (c) Cartesi and individual authors (see AUTHORS) +// SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +package main + +import "github.com/spf13/cobra" + +var reader = &cobra.Command{ + Use: "reader", + Short: "Starts the node in reader mode", + Run: func(cmd *cobra.Command, args []string) { + println("TODO") + }, +} diff --git a/cmd/cartesi-node/root.go b/cmd/cartesi-node/root.go new file mode 100644 index 000000000..c7ea9d345 --- /dev/null +++ b/cmd/cartesi-node/root.go @@ -0,0 +1,18 @@ +// (c) Cartesi and individual authors (see AUTHORS) +// SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +package main + +import "github.com/spf13/cobra" + +var rootCmd = &cobra.Command{ + Use: "cartesi-node [reader|validator|full|no-backend]", + Run: func(cmd *cobra.Command, args []string) { cmd.Usage() }, +} + +func init() { + rootCmd.AddCommand(reader) + rootCmd.AddCommand(validator) + rootCmd.AddCommand(full) + rootCmd.AddCommand(noBackend) +} diff --git a/cmd/cartesi-node/validator.go b/cmd/cartesi-node/validator.go new file mode 100644 index 000000000..87f7ae18a --- /dev/null +++ b/cmd/cartesi-node/validator.go @@ -0,0 +1,14 @@ +// (c) Cartesi and individual authors (see AUTHORS) +// SPDX-License-Identifier: Apache-2.0 (see LICENSE) + +package main + +import "github.com/spf13/cobra" + +var validator = &cobra.Command{ + Use: "validator", + Short: "Starts the node in validator mode", + Run: func(cmd *cobra.Command, args []string) { + println("TODO") + }, +} diff --git a/go.mod b/go.mod new file mode 100644 index 000000000..0761ea0de --- /dev/null +++ b/go.mod @@ -0,0 +1,10 @@ +module github.com/cartesi/rollups-node + +go 1.21.1 + +require github.com/spf13/cobra v1.7.0 + +require ( + github.com/inconshreveable/mousetrap v1.1.0 // indirect + github.com/spf13/pflag v1.0.5 // indirect +) diff --git a/go.sum b/go.sum new file mode 100644 index 000000000..f3366a91a --- /dev/null +++ b/go.sum @@ -0,0 +1,10 @@ +github.com/cpuguy83/go-md2man/v2 v2.0.2/go.mod h1:tgQtvFlXSQOSOSIRvRPT7W67SCa46tRHOmNcaadrF8o= +github.com/inconshreveable/mousetrap v1.1.0 h1:wN+x4NVGpMsO7ErUn/mUI3vEoE6Jt13X2s0bqwp9tc8= +github.com/inconshreveable/mousetrap v1.1.0/go.mod h1:vpF70FUmC8bwa3OWnCshd2FqLfsEA9PFc4w1p2J65bw= +github.com/russross/blackfriday/v2 v2.1.0/go.mod h1:+Rmxgy9KzJVeS9/2gXHxylqXiyQDYRxCVz55jmeOWTM= +github.com/spf13/cobra v1.7.0 h1:hyqWnYt1ZQShIddO5kBpj3vu05/++x6tJ6dg8EC572I= +github.com/spf13/cobra v1.7.0/go.mod h1:uLxZILRyS/50WlhOIKD7W6V5bgeIt+4sICxh6uRMrb0= +github.com/spf13/pflag v1.0.5 h1:iy+VFUOCP1a+8yFto/drg2CJ5u0yRoB7fZw3DKv/JXA= +github.com/spf13/pflag v1.0.5/go.mod h1:McXfInJRrz4CZXVZOBLb0bTZqETkiAhM9Iw0y3An2Bg= +gopkg.in/check.v1 v0.0.0-20161208181325-20d25e280405/go.mod h1:Co6ibVJAznAaIkqp8huTwlJQCZ016jof/cbN4VW5Yz0= +gopkg.in/yaml.v3 v3.0.1/go.mod h1:K4uyk7z7BCEPqu6E+C64Yfv1cQ7kz7rIZviUmN+EgEM=