add functions to rpc.proto, start lnshell

This commit is contained in:
Tadge Dryja 2015-12-30 22:58:15 -04:00 committed by Olaoluwa Osuntokun
parent 6647bdd2b8
commit 8a50faaf47
5 changed files with 180 additions and 6 deletions

1
.gitignore vendored

@ -31,5 +31,6 @@ cmd/cmd
**.hex **.hex
cmd/lncli/lncli cmd/lncli/lncli
cmd/lnshell/lnshell
test_wal/* test_wal/*

@ -6,14 +6,24 @@ import (
"log" "log"
"os" "os"
"strings" "strings"
"time"
"github.com/codegangsta/cli" "github.com/codegangsta/cli"
"google.golang.org/grpc" "google.golang.org/grpc"
"li.lan/labs/plasma/lnrpc"
) )
func shell(z *cli.Context) { func shell(z *cli.Context) {
fmt.Printf("LN shell v0.0FTW\n") fmt.Printf("LN shell v0.0FTW\n")
// opts := []grpc.DialOption{grpc.WithInsecure()}
// conn, err := grpc.Dial("localhost:10000", opts...)
// if err != nil {
// log.Fatal(err)
// }
// state, err := conn.State()
// if err != nil {
// log.Fatal(err)
// }
// fmt.Printf("connection state: %s\n", state.String())
for { for {
reader := bufio.NewReaderSize(os.Stdin, 4000) reader := bufio.NewReaderSize(os.Stdin, 4000)
fmt.Printf("->") fmt.Printf("->")
@ -47,7 +57,6 @@ func Shellparse(cmdslice []string) error {
// Help() // Help()
// return nil // return nil
// } // }
// if cmd == "pbx" { // if cmd == "pbx" {
// err = PbxConnect(args) // err = PbxConnect(args)
// if err != nil { // if err != nil {
@ -121,15 +130,20 @@ func RpcConnect(args []string) error {
return err return err
} }
fmt.Printf("connection state: %s\n", state.String()) fmt.Printf("connection state: %s\n", state.String())
time.Sleep(time.Second * 2)
lnClient := lnrpc.NewLightningClient(conn) // lnClient := lnrpc.NewLightningClient(conn)
// lnClient.NewAddress(nil, nil, nil) // crashes // lnClient.NewAddress(nil, nil, nil) // crashes
state, err = conn.State()
if err != nil {
return err
}
fmt.Printf("connection state: %s\n", state.String())
err = conn.Close() err = conn.Close()
if err != nil { if err != nil {
return err return err
} }
return nil return nil
} }

63
cmd/lnshell/commands.go Normal file

@ -0,0 +1,63 @@
package main
import (
"fmt"
"time"
"google.golang.org/grpc"
)
// connects via grpc to the ln node. default (hardcoded?) local:10K
func RpcConnect(args []string) error {
// client := getClient(ctx)
opts := []grpc.DialOption{grpc.WithInsecure()}
conn, err := grpc.Dial("localhost:10000", opts...)
if err != nil {
return err
}
state, err := conn.State()
if err != nil {
return err
}
fmt.Printf("connection state: %s\n", state.String())
time.Sleep(time.Second * 2)
// lnClient := lnrpc.NewLightningClient(conn)
// lnClient.NewAddress(nil, nil, nil) // crashes
state, err = conn.State()
if err != nil {
return err
}
fmt.Printf("connection state: %s\n", state.String())
err = conn.Close()
if err != nil {
return err
}
return nil
}
func LnConnect(args []string) error {
fmt.Printf("lnconnect, %d args\n", len(args))
return nil
}
// LnListen listens on the default port for incoming connections
func LnListen(args []string) error {
fmt.Printf("will start TCP port listener\n")
return nil
}
// For testing. Syntax: lnhi hello world
func LnChat(args []string) error {
var chat string
for _, s := range args {
chat += s + " "
}
// msg := append([]byte{lnwire.MSGID_TEXTCHAT}, []byte(chat)...)
fmt.Printf("will send text message: %s\n", chat)
return nil
}

@ -0,0 +1,74 @@
package main
import (
"bufio"
"fmt"
"log"
"os"
"strings"
)
func main() {
fmt.Printf("LNShell v0.0. \n")
fmt.Printf("Connects to LN daemon, default on 127.0.0.1:10000.\n")
shellPrompt()
return
}
func shellPrompt() {
for {
reader := bufio.NewReaderSize(os.Stdin, 4000)
fmt.Printf("->")
msg, err := reader.ReadString('\n')
if err != nil {
log.Fatal(err)
}
cmdslice := strings.Fields(msg)
if len(cmdslice) < 1 {
continue
}
fmt.Printf("entered command: %s\n", msg)
err = Shellparse(cmdslice)
if err != nil {
log.Fatal(err)
}
}
}
func Shellparse(cmdslice []string) error {
var err error
var args []string
cmd := cmdslice[0]
if len(cmdslice) > 1 {
args = cmdslice[1:]
}
if cmd == "exit" || cmd == "quit" {
return fmt.Errorf("User exit")
}
if cmd == "lnhi" {
err = LnChat(args)
if err != nil {
fmt.Printf("LN chat error: %s\n", err)
}
return nil
}
if cmd == "lnc" {
err = LnConnect(args)
if err != nil {
fmt.Printf("LN connect error: %s\n", err)
}
return nil
}
if cmd == "rpc" {
err = RpcConnect(args)
if err != nil {
fmt.Printf("RPC connect error: %s\n", err)
}
return nil
}
fmt.Printf("Command not recognized.\n")
return nil
}

@ -5,6 +5,9 @@ package lnrpc;
service Lightning { service Lightning {
rpc SendMany(SendManyRequest) returns (SendManyResponse); rpc SendMany(SendManyRequest) returns (SendManyResponse);
rpc NewAddress(NewAddressRequest) returns (NewAddressResponse); rpc NewAddress(NewAddressRequest) returns (NewAddressResponse);
rpc TCPListen(TCPListenRequest) returns (TCPListenResponse);
rpc LNConnect(LNConnectRequest) returns (LnConnectResponse);
rpc LNChat(LnChatRequest) returns (LnChatResponse);
} }
message SendManyRequest { message SendManyRequest {
@ -19,3 +22,22 @@ message NewAddressRequest {}
message NewAddressResponse { message NewAddressResponse {
string address = 1; string address = 1;
} }
message TCPListenRequest{
string hostport = 1;
}
message TCPListenResponse{}
message LNConnectRequest{
string idAtHost = 1;
}
message LnChatResponse{
bytes lnID = 1;
}
message LnChatRequest{
bytes destID = 1;
string msg = 2;
}
message LnChatResponse{}