forked from zetane/ZetaForge
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdeploy_app.py
172 lines (144 loc) · 6.09 KB
/
deploy_app.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
"""
THIS IS A SCRIPT THAT EASES UP DEPLOYMENT PROCESS.
IT BASICALLY, HAS THREE STEPS
1) BUILD SERVER2
2) WRAP IT WITHIN FRONTEND
3) BUILD FRONTEND(WHICH ALSO HAS SERVER2)
"""
import subprocess
import shutil
import os
import threading
import json
import argparse
import boto3
def get_download_file(client_version, system, arch):
bucket_key = "ZetaForge-" + client_version
if system == 'Windows':
bucket_key += '-windows-x64'
bucket_key += ".tar.gz"
return bucket_key
elif system == 'Linux':
bucket_key += '-linux'
if arch == 'x86_64' or arch == 'x86-64':
bucket_key += '-x64'
else:
bucket_key += '-arm64'
bucket_key += ".tar.gz"
return bucket_key
else:
bucket_key += '-darwin'
if arch == 'x86_64' or arch == 'x86-64':
bucket_key += '-x64'
else:
bucket_key += '-arm64'
bucket_key += ".tar.gz"
return bucket_key
def upload_to_s3(file_path, object_key):
s3_client = boto3.client('s3')
bucket_name = 'forge-executables-test'
try:
with open(file_path, 'rb') as file:
s3_client.upload_fileobj(file, bucket_name, object_key)
print(f"File {file_path} uploaded to S3 bucket {bucket_name} as {object_key}")
except Exception as e:
print(f"Error uploading file to S3: {str(e)}")
def get_package_version():
# Specify the path to the package.json file
package_json_path = os.path.join(os.path.dirname(__file__), 'frontend', 'package.json')
try:
# Read the contents of package.json
with open(package_json_path, 'r') as file:
package_data = json.load(file)
# Extract the version from the package data
version = package_data.get('version')
if version:
return version
else:
raise ValueError("Version not found in package.json")
except FileNotFoundError:
raise FileNotFoundError("package.json not found")
except json.JSONDecodeError:
raise ValueError("Invalid JSON format in package.json")
def main():
parser = argparse.ArgumentParser(description="Description of your script")
parser.add_argument("--arch", nargs="+", default=['amd64', 'arm64'], help="Specify architecture (options: arm64, amd64)")
parser.add_argument("--platform", nargs="+", default=['darwin', 'linux', 'windows'], help="Specify platform. If not specified, it builts for every platform (options: darwin, linux, windows)")
args = parser.parse_args()
os_list = args.platform
version = get_package_version()
frontend = os.path.join("frontend", "server2")
os.makedirs(frontend, exist_ok=True)
res = subprocess.run('npm install', cwd="frontend", stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)
for os_ in os_list:
print(f"Compiling {version} for {os_}..")
for goarch in args.arch:
if goarch == 'arm64' and (os_ == 'windows'):
continue
compile_app(version, os_, goarch)
upload_file = get_download_file(version, os_, goarch)
upload_to_s3(os.path.join('frontend', 'release', version, upload_file), upload_file)
def compile_app(version, goos, goarch):
print(f"Compiling {goarch}..")
frontend = os.path.join("frontend", "server2")
shutil.rmtree(frontend)
os.makedirs(frontend, exist_ok=True)
try:
arch = goarch
if goos == 'windows':
arch = 'amd64'
cc = 'zig cc -target x86_64-windows-gnu'
s = subprocess.run(["env", f"GOOS={goos}", f"GOARCH={arch}", "CGO_ENABLED=1", f"CC={cc}", "go", "build"], capture_output=True, text=True)
if s.returncode != 0:
raise Exception(f"Failed to build go server: {s.stderr}")
print(s)
elif goos == 'linux':
if arch == 'amd64':
cc = 'zig cc -target x86_64-linux-gnu'
else:
cc = "zig cc -target aarch64-linux-gnu"
s = subprocess.run(["env", f"GOOS={goos}", f"GOARCH={arch}", "CGO_ENABLED=1", f"CC={cc}", "go", "build", "-trimpath", "-ldflags", "-extldflags -static"], capture_output=True, text=True)
if s.returncode != 0:
raise Exception(f"Failed to build go server: {s.stderr}")
print(s)
else:
s = subprocess.run(["env", f"GOOS={goos}", f"GOARCH={arch}", "CGO_ENABLED=1", "go", "build"], capture_output=True, text=True)
if s.returncode != 0:
raise Exception(f"Failed to build go server: {s.stderr}")
print(s)
except Exception as err:
print("ERROR WHILE BUILDING GO")
print(err)
raise Exception("Error")
server = "server"
filename = 's2-' + version
if goos == "windows":
filename += '.exe'
server += ".exe"
else:
filename += f'-{goarch}'
dest = os.path.join(frontend, filename)
print(f"Compiled go server {server}, moving to {dest}")
os.rename(server, dest)
print("Copying entrypoint.py..")
shutil.copyfile("entrypoint.py", os.path.join("frontend", "server2", "entrypoint.py"))
print(f'Building client: {goos}-{goarch}')
if goos == 'windows':
res = subprocess.Popen(["npm" , "run", f"build:{goos}"], cwd="frontend", stdout=subprocess.PIPE, stderr=subprocess.PIPE)
else:
res = subprocess.Popen(["npm" , "run", f"build:{goos}-{goarch}"], cwd="frontend", stdout=subprocess.PIPE, stderr=subprocess.PIPE)
def read_output(process, name):
for line in process.stdout:
print(f"{name}: {line.decode('utf-8')}", end='')
def read_error(process, name):
for line in process.stderr:
print(f"{name} (stderr): {line.decode('utf-8')}", end='')
# Create threads to read the outputs concurrently
npm_stdout_thread = threading.Thread(target=read_output, args=(res, '[npm build]'))
npm_stderr_thread = threading.Thread(target=read_error, args=(res, '[npm build]'))
npm_stdout_thread.start()
npm_stderr_thread.start()
npm_stdout_thread.join()
npm_stderr_thread.join()
if __name__ == '__main__':
main()