Merge pull request #4469 from halseth/mobile-global-config

mobile+make: restore mobile compilation
This commit is contained in:
Johan T. Halseth 2020-07-17 09:55:35 +02:00 committed by GitHub
commit 9d147c55d7
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 47 additions and 13 deletions

@ -44,6 +44,8 @@ jobs:
- make lint workers=1 - make lint workers=1
- make btcd - make btcd
- make release sys=windows-amd64 - make release sys=windows-amd64
- make mobile-rpc
- go build --tags="mobile" ./mobile
- stage: Test - stage: Test
script: make travis-cover script: make travis-cover
name: Unit Cover name: Unit Cover

@ -6,6 +6,8 @@ BTCD_PKG := github.com/btcsuite/btcd
GOVERALLS_PKG := github.com/mattn/goveralls GOVERALLS_PKG := github.com/mattn/goveralls
LINT_PKG := github.com/golangci/golangci-lint/cmd/golangci-lint LINT_PKG := github.com/golangci/golangci-lint/cmd/golangci-lint
GOACC_PKG := github.com/ory/go-acc GOACC_PKG := github.com/ory/go-acc
FALAFEL_PKG := github.com/lightninglabs/falafel
GOIMPORTS_PKG := golang.org/x/tools/cmd/goimports
GO_BIN := ${GOPATH}/bin GO_BIN := ${GOPATH}/bin
BTCD_BIN := $(GO_BIN)/btcd BTCD_BIN := $(GO_BIN)/btcd
@ -32,6 +34,7 @@ BTCD_COMMIT := $(shell cat go.mod | \
LINT_COMMIT := v1.18.0 LINT_COMMIT := v1.18.0
GOACC_COMMIT := ddc355013f90fea78d83d3a6c71f1d37ac07ecd5 GOACC_COMMIT := ddc355013f90fea78d83d3a6c71f1d37ac07ecd5
FALAFEL_COMMIT := v0.7.1
DEPGET := cd /tmp && GO111MODULE=on go get -v DEPGET := cd /tmp && GO111MODULE=on go get -v
GOBUILD := GO111MODULE=on go build -v GOBUILD := GO111MODULE=on go build -v
@ -107,6 +110,14 @@ btcd:
@$(call print, "Installing btcd.") @$(call print, "Installing btcd.")
$(DEPGET) $(BTCD_PKG)@$(BTCD_COMMIT) $(DEPGET) $(BTCD_PKG)@$(BTCD_COMMIT)
falafel:
@$(call print, "Installing falafel.")
$(DEPGET) $(FALAFEL_PKG)@$(FALAFEL_COMMIT)
goimports:
@$(call print, "Installing goimports.")
$(DEPGET) $(GOIMPORTS_PKG)
# ============ # ============
# INSTALLATION # INSTALLATION
# ============ # ============
@ -213,9 +224,9 @@ rpc-check: rpc
for rpc in $$(find lnrpc/ -name "*.proto" | $(XARGS) awk '/ rpc /{print $$2}'); do if ! grep -q $$rpc lnrpc/rest-annotations.yaml; then echo "RPC $$rpc not added to lnrpc/rest-annotations.yaml"; exit 1; fi; done for rpc in $$(find lnrpc/ -name "*.proto" | $(XARGS) awk '/ rpc /{print $$2}'); do if ! grep -q $$rpc lnrpc/rest-annotations.yaml; then echo "RPC $$rpc not added to lnrpc/rest-annotations.yaml"; exit 1; fi; done
if test -n "$$(git describe --dirty | grep dirty)"; then echo "Protos not properly formatted or not compiled with v3.4.0"; git status; git diff; exit 1; fi if test -n "$$(git describe --dirty | grep dirty)"; then echo "Protos not properly formatted or not compiled with v3.4.0"; git status; git diff; exit 1; fi
mobile-rpc: mobile-rpc: falafel goimports
@$(call print, "Creating mobile RPC from protos.") @$(call print, "Creating mobile RPC from protos.")
cd ./mobile; ./gen_bindings.sh cd ./mobile; ./gen_bindings.sh $(FALAFEL_COMMIT)
vendor: vendor:
@$(call print, "Re-creating vendor directory.") @$(call print, "Re-creating vendor directory.")
@ -224,12 +235,12 @@ vendor:
ios: vendor mobile-rpc ios: vendor mobile-rpc
@$(call print, "Building iOS framework ($(IOS_BUILD)).") @$(call print, "Building iOS framework ($(IOS_BUILD)).")
mkdir -p $(IOS_BUILD_DIR) mkdir -p $(IOS_BUILD_DIR)
$(GOMOBILE_BIN) bind -target=ios -tags="ios $(DEV_TAGS) autopilotrpc experimental" $(LDFLAGS) -v -o $(IOS_BUILD) $(MOBILE_PKG) $(GOMOBILE_BIN) bind -target=ios -tags="mobile $(DEV_TAGS) autopilotrpc experimental" $(LDFLAGS) -v -o $(IOS_BUILD) $(MOBILE_PKG)
android: vendor mobile-rpc android: vendor mobile-rpc
@$(call print, "Building Android library ($(ANDROID_BUILD)).") @$(call print, "Building Android library ($(ANDROID_BUILD)).")
mkdir -p $(ANDROID_BUILD_DIR) mkdir -p $(ANDROID_BUILD_DIR)
$(GOMOBILE_BIN) bind -target=android -tags="android $(DEV_TAGS) autopilotrpc experimental" $(LDFLAGS) -v -o $(ANDROID_BUILD) $(MOBILE_PKG) $(GOMOBILE_BIN) bind -target=android -tags="mobile $(DEV_TAGS) autopilotrpc experimental" $(LDFLAGS) -v -o $(ANDROID_BUILD) $(MOBILE_PKG)
mobile: ios android mobile: ios android
@ -252,6 +263,7 @@ clean:
unit \ unit \
unit-cover \ unit-cover \
unit-race \ unit-race \
falafel \
goveralls \ goveralls \
travis-race \ travis-race \
travis-cover \ travis-cover \

@ -1,4 +1,4 @@
// +build ios android // +build mobile
package lndmobile package lndmobile
@ -9,6 +9,7 @@ import (
flags "github.com/jessevdk/go-flags" flags "github.com/jessevdk/go-flags"
"github.com/lightningnetwork/lnd" "github.com/lightningnetwork/lnd"
"github.com/lightningnetwork/lnd/signal"
) )
// Start starts lnd in a new goroutine. // Start starts lnd in a new goroutine.
@ -40,10 +41,21 @@ func Start(extraArgs string, unlockerReady, rpcReady Callback) {
splitArgs = append(splitArgs, "--"+a) splitArgs = append(splitArgs, "--"+a)
} }
// Add the extra arguments to os.Args, as that will be parsed during // Add the extra arguments to os.Args, as that will be parsed in
// startup. // LoadConfig below.
os.Args = append(os.Args, splitArgs...) os.Args = append(os.Args, splitArgs...)
// Load the configuration, and parse the extra arguments as command
// line options. This function will also set up logging properly.
loadedConfig, err := lnd.LoadConfig()
if err != nil {
_, _ = fmt.Fprintln(os.Stderr, err)
os.Exit(1)
}
// Hook interceptor for os signals.
signal.Intercept()
// Set up channels that will be notified when the RPC servers are ready // Set up channels that will be notified when the RPC servers are ready
// to accept calls. // to accept calls.
var ( var (
@ -67,7 +79,9 @@ func Start(extraArgs string, unlockerReady, rpcReady Callback) {
// Call the "real" main in a nested manner so the defers will properly // Call the "real" main in a nested manner so the defers will properly
// be executed in the case of a graceful shutdown. // be executed in the case of a graceful shutdown.
go func() { go func() {
if err := lnd.Main(cfg); err != nil { if err := lnd.Main(
loadedConfig, cfg, signal.ShutdownChannel(),
); err != nil {
if e, ok := err.(*flags.Error); ok && if e, ok := err.(*flags.Error); ok &&
e.Type == flags.ErrHelp { e.Type == flags.ErrHelp {
} else { } else {
@ -84,7 +98,7 @@ func Start(extraArgs string, unlockerReady, rpcReady Callback) {
// We must set the TLS certificates in order to properly // We must set the TLS certificates in order to properly
// authenticate with the wallet unlocker service. // authenticate with the wallet unlocker service.
auth, err := lnd.WalletUnlockerAuthOptions() auth, err := lnd.WalletUnlockerAuthOptions(loadedConfig)
if err != nil { if err != nil {
unlockerReady.OnError(err) unlockerReady.OnError(err)
return return
@ -102,7 +116,7 @@ func Start(extraArgs string, unlockerReady, rpcReady Callback) {
// Now that the RPC server is ready, we can get the needed // Now that the RPC server is ready, we can get the needed
// authentication options, and add them to the global dial // authentication options, and add them to the global dial
// options. // options.
auth, err := lnd.AdminAuthOptions() auth, err := lnd.AdminAuthOptions(loadedConfig)
if err != nil { if err != nil {
rpcReady.OnError(err) rpcReady.OnError(err)
return return

@ -3,11 +3,17 @@
mkdir -p build mkdir -p build
# Check falafel version. # Check falafel version.
falafelVersion="0.7" falafelVersion=$1
if [ -z $falafelVersion ]
then
echo "falafel version not set"
exit 1
fi
falafel=$(which falafel) falafel=$(which falafel)
if [ $falafel ] if [ $falafel ]
then then
version=$($falafel -v) version="v$($falafel -v)"
if [ $version != $falafelVersion ] if [ $version != $falafelVersion ]
then then
echo "falafel version $falafelVersion required" echo "falafel version $falafelVersion required"
@ -45,7 +51,7 @@ protoc -I/usr/local/include -I. \
# If prefix=1 is specified, prefix the generated methods with subserver name. # If prefix=1 is specified, prefix the generated methods with subserver name.
# This must be enabled to support subservers with name conflicts. # This must be enabled to support subservers with name conflicts.
use_prefix="0" use_prefix="0"
if [[ $prefix = "1" ]] if [ "$prefix" = "1" ]
then then
echo "Prefixing methods with subserver name" echo "Prefixing methods with subserver name"
use_prefix="1" use_prefix="1"