forked from rotki/rotki
-
Notifications
You must be signed in to change notification settings - Fork 0
/
rotkehlchen.spec
145 lines (127 loc) · 4.79 KB
/
rotkehlchen.spec
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
# -*- mode: python -*-
from __future__ import print_function # isort:skip
import os
import platform
import sys
from pathlib import Path
from PyInstaller.utils.hooks import collect_submodules
from rotkehlchen.constants.misc import GLOBALDB_NAME
from rotkehlchen.exchanges.constants import SUPPORTED_EXCHANGES
from rotkehlchen.types import EVM_CHAINS_WITH_TRANSACTIONS, Location
from rotkehlchen.utils.misc import get_system_spec
"""
PyInstaller spec file to build single file or dir distributions
"""
# Set to false to produce an exploded single-dir
ONEFILE = int(os.environ.get('ONEFILE', True))
MACOS_IDENTITY = os.environ.get('IDENTITY', None)
def Entrypoint(dist, group, name, scripts=None, pathex=None, hiddenimports=None, hookspath=None, excludes=None, runtime_hooks=None, datas=None): # noqa: E501
scripts = scripts or []
pathex = pathex or []
# insert path of the egg at the verify front of the search path
pathex = [Path.cwd()] + pathex
# script name must not be a valid module name to avoid name clashes on import
script_path = os.path.join(workpath, name + '-script.py')
with open(script_path, 'w') as fh:
fh.write('import rotkehlchen.__main__\n')
fh.write('rotkehlchen.__main__.main()')
return Analysis(
[script_path] + scripts,
pathex=pathex,
hiddenimports=hiddenimports,
hookspath=hookspath,
excludes=excludes,
runtime_hooks=runtime_hooks,
datas=datas,
)
# We don't need Tk and friends
sys.modules['FixTk'] = None
if (platform_name := platform.system().lower()) == 'darwin':
platform_name = f"macos-{'arm64' if platform.machine() == 'arm64' else 'x64'}"
executable_name = 'rotki-core-{}-{}'.format(
get_system_spec()['rotkehlchen'],
platform_name,
)
hiddenimports = ['cytoolz.utils', 'cytoolz._signatures']
# Since the exchanges are loaded dynamically and some of them may not be detected
# by pyinstaller (https://github.com/rotki/rotki/issues/602) make sure they are
# all included as imports in the created executable
for exchange_name in SUPPORTED_EXCHANGES:
if exchange_name == Location.BINANCEUS:
continue
hiddenimports.append(f'rotkehlchen.exchanges.{exchange_name}')
for chain in EVM_CHAINS_WITH_TRANSACTIONS: # load modules from the evm chains
hiddenimports.extend(collect_submodules(f'rotkehlchen.chain.{chain.name.lower()}.modules'))
a = Entrypoint(
'rotkehlchen',
'console_scripts',
'rotkehlchen',
hookspath=['tools/pyinstaller_hooks'],
hiddenimports=hiddenimports,
datas=[
# This list should be kept in sync with setup.py (package_data)
('rotkehlchen/data/eth_abi.json', 'rotkehlchen/data'),
('rotkehlchen/data/eth_contracts.json', 'rotkehlchen/data'),
(f'rotkehlchen/data/{GLOBALDB_NAME}', 'rotkehlchen/data'),
('rotkehlchen/data/globaldb_v2_v3_assets.sql', 'rotkehlchen/data'),
('rotkehlchen/data/nodes.json', 'rotkehlchen/data'),
('rotkehlchen/data/nodes_as_of_1-26-1.json', 'rotkehlchen/data'),
('rotkehlchen/data/populate_asset_collections.sql', 'rotkehlchen/data'),
('rotkehlchen/data/populate_multiasset_mappings.sql', 'rotkehlchen/data'),
('rotkehlchen/data/populate_location_asset_mappings.sql', 'rotkehlchen/data'),
('rotkehlchen/data/populate_location_unsupported_assets.sql', 'rotkehlchen/data'),
# TODO
# We probably should have a better way to specify some data should be loaded
# by a module in pyinstaller. Should be loaded dynamically by rotki and not
# by pyinstaller if we want it to be truly modular
(
'rotkehlchen/chain/ethereum/modules/dxdaomesa/data/contracts.json',
'rotkehlchen/chain/ethereum/modules/dxdaomesa/data',
),
],
excludes=['FixTk', 'tcl', 'tk', '_tkinter', 'tkinter', 'Tkinter', 'debugimporter'],
)
pyz = PYZ(a.pure, a.zipped_data, cipher=None)
if ONEFILE:
exe = EXE(
pyz,
a.scripts,
a.binaries,
a.zipfiles,
a.datas,
name=executable_name,
debug=False,
strip=False,
upx=False,
runtime_tmpdir=None,
console=True,
)
else:
identity = None
entitlements = None
if MACOS_IDENTITY is not None:
identity = MACOS_IDENTITY
entitlements = 'packaging/entitlements.plist'
exe = EXE(
pyz,
a.scripts,
exclude_binaries=True,
name=executable_name,
debug=False,
strip=False,
upx=False,
console=True,
codesign_identity=identity,
entitlements_file=entitlements,
)
coll = COLLECT(
exe,
a.binaries,
a.zipfiles,
a.datas,
strip=False,
upx=False,
name='rotki-core',
codesign_identity=identity,
entitlements_file=entitlements,
)