This repository has been archived by the owner on Feb 1, 2024. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 263
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
automate creation of pre-compiled binary for ccxt-rest (#311)
* 1 - check for pkg installed, download and untar ccxt source code * 2 - split ccxt_bin_gen script from fs_bin_gen script * 3 - move to separate folders in ./scripts * 4 - run npm install before running pkg tool; copy dependency files to output directory * 5 - build script should check build result after installing web dependencies and generating static files * 6 - wrap underlying error when pkg check fails * 7 - check node version before generating ccxt binary * 8 - separate -g flag on build script to generate ccxt binary * 9 - remove /downloads from path of ccxt binary output * 10 - set silent registrations on kelpos and prettify ccxt_bin_gen log output * 11 - zip output of ccxt binary * 12 - check result of running ccxt_bin_gen in main build script * 13 - keep zipped output file in it's own folder and remove inner folder hierarchy * 14 - clean up directory that was zipped * 15 - remove fetch logic of ccxt binary from build script * update circle config to install yarn * 17 - install yarn after usinng correct version of node * 18 - command to use yarn in same shell * 19 - update command to use yarn and move setup of nvm and yarn to install_deps section * 20 - use nvm version 10.17 * 21 - move filesystem_vfsdata_dev to avoid package conflict * 22 - ReplaceAll is only available from go10.12 onwards
- Loading branch information
1 parent
6062a2d
commit b0d608f
Showing
9 changed files
with
295 additions
and
32 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,187 @@ | ||
package main | ||
|
||
import ( | ||
"flag" | ||
"fmt" | ||
"log" | ||
"path/filepath" | ||
"regexp" | ||
"strings" | ||
|
||
"github.com/pkg/errors" | ||
"github.com/stellar/kelp/support/kelpos" | ||
"github.com/stellar/kelp/support/networking" | ||
) | ||
|
||
const kelpPrefsDirectory = "build" | ||
const ccxtDownloadURL = "https://github.com/ccxt-rest/ccxt-rest/archive/v0.0.4.tar.gz" | ||
const ccxtDownloadFilename = "ccxt-rest_v0.0.4.tar.gz" | ||
const ccxtUntaredDirName = "ccxt-rest-0.0.4" | ||
const ccxtBinOutputDir = "bin" | ||
const nodeVersionMatchRegex = "v8.[0-9]+.[0-9]+" | ||
|
||
func main() { | ||
goosP := flag.String("goos", "", "GOOS for which to build") | ||
flag.Parse() | ||
goos := *goosP | ||
|
||
pkgos := "" | ||
if goos == "darwin" { | ||
pkgos = "macos" | ||
} else if goos == "linux" { | ||
pkgos = "linux" | ||
} else if goos == "windows" { | ||
pkgos = "win" | ||
} else { | ||
panic("unsupported goos flag: " + goos) | ||
} | ||
|
||
kos := kelpos.GetKelpOS() | ||
kos.SetSilentRegistrations() | ||
|
||
zipFoldername := fmt.Sprintf("ccxt-rest_%s-x64", goos) | ||
generateCcxtBinary(kos, pkgos, zipFoldername) | ||
} | ||
|
||
func checkNodeVersion(kos *kelpos.KelpOS) { | ||
fmt.Printf("checking node version ... ") | ||
|
||
version, e := kos.Blocking("node", "node -v") | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "ensure that the `pkg` tool is installed correctly. You can get it from here https://github.com/zeit/pkg or by running `npm install -g pkg`")) | ||
} | ||
|
||
match, e := regexp.Match(nodeVersionMatchRegex, version) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "could not match regex against node version")) | ||
} | ||
if !match { | ||
log.Fatal("node version will fail to compile a successful binary because of the requirements of ccxt-rest's dependencies, should use v8.x.x instead of " + string(version)) | ||
} | ||
|
||
fmt.Printf("valid\n") | ||
} | ||
|
||
func checkPkgTool(kos *kelpos.KelpOS) { | ||
fmt.Printf("checking for presence of `pkg` tool ... ") | ||
_, e := kos.Blocking("pkg", "pkg -v") | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "ensure that the `pkg` tool is installed correctly. You can get it from here https://github.com/zeit/pkg or by running `npm install -g pkg`")) | ||
} | ||
fmt.Printf("done\n") | ||
} | ||
|
||
func downloadCcxtSource(kos *kelpos.KelpOS, downloadDir string) { | ||
fmt.Printf("making directory where we can download ccxt file %s ... ", downloadDir) | ||
e := kos.Mkdir(downloadDir) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "could not make directory for downloadDir "+downloadDir)) | ||
} | ||
fmt.Printf("done\n") | ||
|
||
fmt.Printf("downloading file from URL %s ... ", ccxtDownloadURL) | ||
downloadFilePath := filepath.Join(downloadDir, ccxtDownloadFilename) | ||
e = networking.DownloadFile(ccxtDownloadURL, downloadFilePath) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "could not download ccxt tar.gz file")) | ||
} | ||
fmt.Printf("done\n") | ||
|
||
fmt.Printf("untaring file %s ... ", downloadFilePath) | ||
_, e = kos.Blocking("tar", fmt.Sprintf("tar xvf %s -C %s", downloadFilePath, downloadDir)) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "could not untar ccxt file")) | ||
} | ||
fmt.Printf("done\n") | ||
} | ||
|
||
func npmInstall(kos *kelpos.KelpOS, installDir string) { | ||
fmt.Printf("running npm install on directory %s ... ", installDir) | ||
npmCmd := fmt.Sprintf("cd %s && npm install && cd -", installDir) | ||
_, e := kos.Blocking("npm", npmCmd) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "failed to run npm install")) | ||
} | ||
fmt.Printf("done\n") | ||
} | ||
|
||
// pkg --targets node8-linux-x64 build/ccxt/ccxt-rest-0.0.4 | ||
func runPkgTool(kos *kelpos.KelpOS, sourceDir string, outDir string, pkgos string) { | ||
target := fmt.Sprintf("node8-%s-x64", pkgos) | ||
|
||
fmt.Printf("running pkg tool on source directory %s with output directory as %s on target platform %s ... ", sourceDir, outDir, target) | ||
pkgCommand := fmt.Sprintf("pkg --out-path %s --targets %s %s", outDir, target, sourceDir) | ||
outputBytes, e := kos.Blocking("pkg", pkgCommand) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "failed to run pkg tool")) | ||
} | ||
fmt.Printf("done\n") | ||
|
||
copyDependencyFiles(kos, outDir, string(outputBytes)) | ||
} | ||
|
||
func copyDependencyFiles(kos *kelpos.KelpOS, outDir string, pkgCmdOutput string) { | ||
fmt.Println() | ||
fmt.Printf("copying dependency files to the output directory %s ...\n", outDir) | ||
for _, line := range strings.Split(pkgCmdOutput, "\n") { | ||
if !strings.Contains(line, "node_modules") { | ||
continue | ||
} | ||
filename := strings.TrimSpace(strings.Replace(line, "(MISSING)", "", -1)) | ||
|
||
fmt.Printf(" copying file %s to the output directory %s ... ", filename, outDir) | ||
cpCmd := fmt.Sprintf("cp %s %s", filename, outDir) | ||
_, e := kos.Blocking("cp", cpCmd) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "failed to copy dependency file "+filename)) | ||
} | ||
fmt.Printf("done\n") | ||
} | ||
fmt.Printf("done\n") | ||
fmt.Println() | ||
} | ||
|
||
func mkDir(kos *kelpos.KelpOS, zipDir string) { | ||
fmt.Printf("making directory %s ... ", zipDir) | ||
e := kos.Mkdir(zipDir) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "unable to make directory "+zipDir)) | ||
} | ||
fmt.Printf("done\n") | ||
} | ||
|
||
func zipOutput(kos *kelpos.KelpOS, ccxtDir string, sourceDir string, zipFoldername string, zipOutDir string) { | ||
zipFilename := zipFoldername + ".zip" | ||
fmt.Printf("zipping directory %s as file %s ... ", filepath.Join(ccxtDir, ccxtBinOutputDir), zipFilename) | ||
zipCmd := fmt.Sprintf("cd %s && mv %s %s && zip -rq %s %s && cd - && mv %s %s", ccxtDir, ccxtBinOutputDir, zipFoldername, zipFilename, zipFoldername, filepath.Join(ccxtDir, zipFilename), zipOutDir) | ||
_, e := kos.Blocking("zip", zipCmd) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, "unable to zip folder with ccxt binary and dependencies")) | ||
} | ||
fmt.Printf("done\n") | ||
|
||
zipDirPath := filepath.Join(ccxtDir, zipFoldername) | ||
fmt.Printf("clean up zipped directory %s ... ", zipDirPath) | ||
cleanupCmd := fmt.Sprintf("rm %s/* && rmdir %s", zipDirPath, zipDirPath) | ||
_, e = kos.Blocking("zip", cleanupCmd) | ||
if e != nil { | ||
log.Fatal(errors.Wrap(e, fmt.Sprintf("unable to cleanup zip folder %s with ccxt binary and dependencies", zipDirPath))) | ||
} | ||
fmt.Printf("done\n") | ||
} | ||
|
||
func generateCcxtBinary(kos *kelpos.KelpOS, pkgos string, zipFoldername string) { | ||
checkNodeVersion(kos) | ||
checkPkgTool(kos) | ||
|
||
ccxtDir := filepath.Join(kelpPrefsDirectory, "ccxt") | ||
sourceDir := filepath.Join(ccxtDir, ccxtUntaredDirName) | ||
outDir := filepath.Join(ccxtDir, ccxtBinOutputDir) | ||
zipOutDir := filepath.Join(ccxtDir, "zipped") | ||
|
||
downloadCcxtSource(kos, ccxtDir) | ||
npmInstall(kos, sourceDir) | ||
runPkgTool(kos, sourceDir, outDir, pkgos) | ||
mkDir(kos, zipOutDir) | ||
zipOutput(kos, ccxtDir, outDir, zipFoldername, zipOutDir) | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
File renamed without changes.
Oops, something went wrong.