make-mac.mk 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. CC=clang
  2. CXX=clang++
  3. TOPDIR=$(shell pwd)
  4. INCLUDES=-I$(shell pwd)/rustybits/target -isystem $(TOPDIR)/ext -I$(TOPDIR)/ext/prometheus-cpp-lite-1.0/core/include -I$(TOPDIR)/ext-prometheus-cpp-lite-1.0/3rdparty/http-client-lite/include -I$(TOPDIR)/ext/prometheus-cpp-lite-1.0/simpleapi/include
  5. DEFS=
  6. LIBS=
  7. ARCH_FLAGS=-arch x86_64 -arch arm64
  8. CODESIGN=echo
  9. PRODUCTSIGN=echo
  10. CODESIGN_APP_CERT=
  11. CODESIGN_INSTALLER_CERT=
  12. NOTARIZE=echo
  13. NOTARIZE_APPLE_ID=null
  14. NOTARIZE_TEAM_ID=null
  15. ZT_BUILD_PLATFORM=3
  16. ZT_BUILD_ARCHITECTURE=2
  17. ZT_VERSION_MAJOR=$(shell cat version.h | grep -F VERSION_MAJOR | cut -d ' ' -f 3)
  18. ZT_VERSION_MINOR=$(shell cat version.h | grep -F VERSION_MINOR | cut -d ' ' -f 3)
  19. ZT_VERSION_REV=$(shell cat version.h | grep -F VERSION_REVISION | cut -d ' ' -f 3)
  20. ZT_VERSION_BUILD=$(shell cat version.h | grep -F VERSION_BUILD | cut -d ' ' -f 3)
  21. # for central controller builds
  22. TIMESTAMP=$(shell date +"%Y%m%d%H%M")
  23. DEFS+=-DZT_BUILD_PLATFORM=$(ZT_BUILD_PLATFORM) -DZT_BUILD_ARCHITECTURE=$(ZT_BUILD_ARCHITECTURE)
  24. include objects.mk
  25. ONE_OBJS+=osdep/MacEthernetTap.o osdep/MacKextEthernetTap.o osdep/MacDNSHelper.o ext/http-parser/http_parser.o
  26. LIBS+=-framework CoreServices -framework SystemConfiguration -framework CoreFoundation -framework Security
  27. ifeq ($(ZT_CONTROLLER),1)
  28. ZT_NONFREE=1
  29. endif
  30. ifeq ($(ZT_NONFREE),1)
  31. include objects-nonfree.mk
  32. ONE_OBJS+=$(CONTROLLER_OBJS)
  33. override DEFS += -DZT_NONFREE_CONTROLLER
  34. endif
  35. ifeq ($(ZT_OFFICIAL_RELEASE),1)
  36. ZT_USE_MINIUPNPC=1
  37. CODESIGN=codesign
  38. PRODUCTSIGN=productsign
  39. CODESIGN_APP_CERT="Developer ID Application: ZeroTier, Inc (8ZD9JUCZ4V)"
  40. CODESIGN_INSTALLER_CERT="Developer ID Installer: ZeroTier, Inc (8ZD9JUCZ4V)"
  41. NOTARIZE=xcrun notarytool
  42. NOTARIZE_APPLE_ID="[email protected]"
  43. NOTARIZE_TEAM_ID="8ZD9JUCZ4V"
  44. endif
  45. # Use fast ASM Salsa20/12 for x64 processors
  46. override DEFS+=-DZT_USE_X64_ASM_SALSA2012
  47. CORE_OBJS+=ext/x64-salsa2012-asm/salsa2012.o
  48. CXXFLAGS=$(CFLAGS) -std=c++17 -stdlib=libc++
  49. # Build miniupnpc and nat-pmp as included libraries -- extra defs are required for these sources
  50. override DEFS+=-DMACOSX -DZT_SSO_SUPPORTED -DZT_USE_MINIUPNPC -DMINIUPNP_STATICLIB -D_DARWIN_C_SOURCE -DMINIUPNPC_SET_SOCKET_TIMEOUT -DMINIUPNPC_GET_SRC_ADDR -D_BSD_SOURCE -D_DEFAULT_SOURCE -DOS_STRING=\"Darwin/15.0.0\" -DMINIUPNPC_VERSION_STRING=\"2.0\" -DUPNP_VERSION_STRING=\"UPnP/1.1\" -DENABLE_STRNATPMPERR
  51. ONE_OBJS+=ext/libnatpmp/natpmp.o ext/libnatpmp/getgateway.o ext/miniupnpc/connecthostport.o ext/miniupnpc/igd_desc_parse.o ext/miniupnpc/minisoap.o ext/miniupnpc/minissdpc.o ext/miniupnpc/miniupnpc.o ext/miniupnpc/miniwget.o ext/miniupnpc/minixml.o ext/miniupnpc/portlistingparse.o ext/miniupnpc/receivedata.o ext/miniupnpc/upnpcommands.o ext/miniupnpc/upnpdev.o ext/miniupnpc/upnperrors.o ext/miniupnpc/upnpreplyparse.o osdep/PortMapper.o
  52. ifeq ($(ZT_CONTROLLER),1)
  53. MACOS_VERSION_MIN=10.15
  54. override CXXFLAGS=$(CFLAGS) -std=c++17 -stdlib=libc++
  55. LIBS+=-L/opt/homebrew/lib -L/usr/local/opt/libpqxx/lib -L/usr/local/opt/libpq/lib -L/usr/local/opt/openssl/lib/ -lpqxx -lpq -lssl -lcrypto -lgssapi_krb5 ext/redis-plus-plus-1.1.1/install/macos/lib/libredis++.a ext/hiredis-0.14.1/lib/macos/libhiredis.a rustybits/target/libsmeeclient.a
  56. override DEFS+=-DZT_CONTROLLER_USE_LIBPQ -DZT_CONTROLLER_USE_REDIS -DZT_CONTROLLER
  57. INCLUDES+=-I/opt/homebrew/include -I/opt/homebrew/opt/libpq/include -I/usr/local/opt/libpq/include -I/usr/local/opt/libpqxx/include -Iext/hiredis-0.14.1/include/ -Iext/redis-plus-plus-1.1.1/install/macos/include/sw/ -Irustybits/target/
  58. else
  59. MACOS_VERSION_MIN=10.13
  60. endif
  61. # Build with address sanitization library for advanced debugging (clang)
  62. ifeq ($(ZT_SANITIZE),1)
  63. override DEFS+=-fsanitize=address -DASAN_OPTIONS=symbolize=1
  64. endif
  65. ifeq ($(ZT_DEBUG_TRACE),1)
  66. override DEFS+=-DZT_DEBUG_TRACE
  67. endif
  68. # Debug mode -- dump trace output, build binary with -g
  69. ifeq ($(ZT_DEBUG),1)
  70. ZT_TRACE=1
  71. ARCH_FLAGS=
  72. CFLAGS+=-Wall -g $(INCLUDES) $(DEFS) $(ARCH_FLAGS)
  73. STRIP=echo
  74. EXTRA_CARGO_FLAGS=
  75. RUST_VARIANT=debug
  76. # The following line enables optimization for the crypto code, since
  77. # C25519 in particular is almost UNUSABLE in heavy testing without it.
  78. node/Salsa20.o node/SHA512.o node/C25519.o node/Poly1305.o: CFLAGS = -Wall -O2 -g $(INCLUDES) $(DEFS)
  79. else
  80. CFLAGS?=-O3 -fstack-protector-strong
  81. CFLAGS+=$(ARCH_FLAGS) -Wall -flto -fPIE -mmacosx-version-min=$(MACOS_VERSION_MIN) -DNDEBUG -Wno-unused-private-field $(INCLUDES) $(DEFS)
  82. STRIP=strip
  83. EXTRA_CARGO_FLAGS=--release
  84. RUST_VARIANT=release
  85. endif
  86. ifeq ($(ZT_TRACE),1)
  87. override DEFS+=-DZT_TRACE
  88. endif
  89. ifeq ($(ZT_DEBUG),1)
  90. override DEFS+=-DZT_DEBUG
  91. endif
  92. ifeq ($(ZT_VAULT_SUPPORT),1)
  93. override DEFS+=-DZT_VAULT_SUPPORT=1
  94. LIBS+=-lcurl
  95. endif
  96. OTEL_VERSION=1.21.0
  97. ifeq (${ZT_OTEL},1)
  98. OTEL_INSTALL_DIR=ext/opentelemetry-cpp-${OTEL_VERSION}/localinstall
  99. override DEFS+=-DZT_OTEL
  100. INCLUDES+=-I${OTEL_INSTALL_DIR}/include
  101. LIBS+=-L${OTEL_INSTALL_DIR}/lib -lopentelemetry_exporter_in_memory_metric -lopentelemetry_exporter_in_memory -lopentelemetry_exporter_ostream_logs -lopentelemetry_exporter_ostream_metrics -lopentelemetry_exporter_ostream_span -lopentelemetry_trace -lopentelemetry_common -lopentelemetry_resources -lopentelemetry_logs -lopentelemetry_metrics -lopentelemetry_version
  102. else
  103. OTEL_INSTALL_DIR=ext/opentelemetry-cpp-api-only
  104. INCLUDES+=-I${OTEL_INSTALL_DIR}/include
  105. endif
  106. all: one
  107. ext/x64-salsa2012-asm/salsa2012.o:
  108. as -arch x86_64 -mmacosx-version-min=$(MACOS_VERSION_MIN) -o ext/x64-salsa2012-asm/salsa2012.o ext/x64-salsa2012-asm/salsa2012.s
  109. mac-agent: FORCE
  110. $(CC) -O3 $(ARCH_FLAGS) -mmacosx-version-min=$(MACOS_VERSION_MIN) -o MacEthernetTapAgent osdep/MacEthernetTapAgent.c
  111. $(CODESIGN) -f --options=runtime -s $(CODESIGN_APP_CERT) MacEthernetTapAgent
  112. osdep/MacDNSHelper.o: osdep/MacDNSHelper.mm
  113. $(CXX) $(CXXFLAGS) -c osdep/MacDNSHelper.mm -o osdep/MacDNSHelper.o
  114. ifeq ($(ZT_CONTROLLER),1)
  115. one: otel zeroidc smeeclient $(CORE_OBJS) $(ONE_OBJS) one.o mac-agent
  116. else
  117. one: otel zeroidc $(CORE_OBJS) $(ONE_OBJS) one.o mac-agent
  118. endif
  119. $(CXX) $(CXXFLAGS) -o zerotier-one $(CORE_OBJS) $(ONE_OBJS) one.o $(LIBS) rustybits/target/libzeroidc.a
  120. # $(STRIP) zerotier-one
  121. ln -sf zerotier-one zerotier-idtool
  122. ln -sf zerotier-one zerotier-cli
  123. $(CODESIGN) -f --options=runtime -s $(CODESIGN_APP_CERT) zerotier-one
  124. zerotier-one: one
  125. zeroidc: rustybits/target/libzeroidc.a
  126. ifeq ($(ZT_CONTROLLER),1)
  127. smeeclient: rustybits/target/libsmeeclient.a
  128. rustybits/target/libsmeeclient.a: FORCE
  129. cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p smeeclient --target=x86_64-apple-darwin $(EXTRA_CARGO_FLAGS)
  130. cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p smeeclient --target=aarch64-apple-darwin $(EXTRA_CARGO_FLAGS)
  131. cd rustybits && lipo -create target/x86_64-apple-darwin/$(RUST_VARIANT)/libsmeeclient.a target/aarch64-apple-darwin/$(RUST_VARIANT)/libsmeeclient.a -output target/libsmeeclient.a
  132. endif
  133. rustybits/target/libzeroidc.a: FORCE
  134. cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p zeroidc --target=x86_64-apple-darwin $(EXTRA_CARGO_FLAGS)
  135. cd rustybits && MACOSX_DEPLOYMENT_TARGET=$(MACOS_VERSION_MIN) cargo build -p zeroidc --target=aarch64-apple-darwin $(EXTRA_CARGO_FLAGS)
  136. cd rustybits && lipo -create target/x86_64-apple-darwin/$(RUST_VARIANT)/libzeroidc.a target/aarch64-apple-darwin/$(RUST_VARIANT)/libzeroidc.a -output target/libzeroidc.a
  137. central-controller:
  138. make ARCH_FLAGS="-arch x86_64" ZT_CONTROLLER=1 one
  139. zerotier-idtool: one
  140. zerotier-cli: one
  141. $(ONE_OBJS): zeroidc
  142. libzerotiercore.a: $(CORE_OBJS)
  143. ar rcs libzerotiercore.a $(CORE_OBJS)
  144. ranlib libzerotiercore.a
  145. core: libzerotiercore.a
  146. selftest: $(CORE_OBJS) $(ONE_OBJS) selftest.o
  147. $(CXX) $(CXXFLAGS) -o zerotier-selftest selftest.o $(CORE_OBJS) $(ONE_OBJS) $(LIBS) rustybits/target/libzeroidc.a
  148. $(STRIP) zerotier-selftest
  149. zerotier-selftest: selftest
  150. # Make compile_commands.json for clangd editor extensions. Probably works on Linux too.
  151. compile_commands: FORCE
  152. compiledb make ZT_DEBUG=1
  153. # Requires Packages: http://s.sudre.free.fr/Software/Packages/about.html
  154. mac-dist-pkg: FORCE
  155. packagesbuild "ext/installfiles/mac/ZeroTier One.pkgproj"
  156. rm -f "ZeroTier One Signed.pkg"
  157. $(PRODUCTSIGN) --sign $(CODESIGN_INSTALLER_CERT) "ZeroTier One.pkg" "ZeroTier One Signed.pkg"
  158. if [ -f "ZeroTier One Signed.pkg" ]; then mv -f "ZeroTier One Signed.pkg" "ZeroTier One.pkg"; fi
  159. #rm -f zt1_update_$(ZT_BUILD_PLATFORM)_$(ZT_BUILD_ARCHITECTURE)_*
  160. #cat ext/installfiles/mac-update/updater.tmpl.sh "ZeroTier One.pkg" >zt1_update_$(ZT_BUILD_PLATFORM)_$(ZT_BUILD_ARCHITECTURE)_$(ZT_VERSION_MAJOR).$(ZT_VERSION_MINOR).$(ZT_VERSION_REV)_$(ZT_VERSION_BUILD).exe
  161. $(NOTARIZE) submit --apple-id "[email protected]" --team-id "8ZD9JUCZ4V" --wait "ZeroTier One.pkg"
  162. echo '*** When Apple notifies that the app is notarized, run: xcrun stapler staple "ZeroTier One.pkg"'
  163. # For ZeroTier, Inc. to build official signed packages
  164. official: FORCE
  165. cd ../DesktopUI ; make ZT_OFFICIAL_RELEASE=1
  166. make clean
  167. make ZT_OFFICIAL_RELEASE=1 -j 8 one ZT_NONFREE=1
  168. make ZT_OFFICIAL_RELEASE=1 mac-dist-pkg
  169. _buildx:
  170. @echo "docker buildx create"
  171. # docker run --rm --privileged multiarch/qemu-user-static --reset -p yes
  172. docker run --privileged --rm tonistiigi/binfmt --install all
  173. @echo docker buildx create --name multiarch --driver docker-container --use
  174. @echo docker buildx inspect --bootstrap
  175. controller-builder: _buildx FORCE
  176. docker buildx build --platform linux/arm64,linux/amd64 --no-cache -t registry.zerotier.com/zerotier/ctlbuild:latest -f ext/central-controller-docker/Dockerfile.builder . --push
  177. controller-run: _buildx FORCE
  178. docker buildx build --platform linux/arm64,linux/amd64 --no-cache -t registry.zerotier.com/zerotier-central/ctlrun:latest -f ext/central-controller-docker/Dockerfile.run_base . --push
  179. central-controller-docker: _buildx FORCE
  180. docker buildx build --platform linux/arm64,linux/amd64 --no-cache -t registry.zerotier.com/zerotier-central/ztcentral-controller:${TIMESTAMP} -f ext/central-controller-docker/Dockerfile --build-arg git_branch=$(shell git name-rev --name-only HEAD) . --push
  181. @echo Image: registry.zerotier.com/zerotier-central/ztcentral-controller:${TIMESTAMP}
  182. centralv2-controller-docker: _buildx FORCE
  183. docker buildx build --platform linux/amd64,linux/arm64 --no-cache -t us-central1-docker.pkg.dev/zerotier-d648c7/central-v2/ztcentral-controller:${TIMESTAMP} -f ext/central-controller-docker/Dockerfile --build-arg git_branch=`git name-rev --name-only HEAD` . --push
  184. @echo Image: us-central1-docker.pkg.dev/zerotier-d648c7/central-v2/ztcentral-controller:${TIMESTAMP}
  185. docker-release: _buildx
  186. docker buildx build --platform linux/386,linux/amd64,linux/arm/v7,linux/arm64,linux/mips64le,linux/ppc64le,linux/s390x -t zerotier/zerotier:${RELEASE_DOCKER_TAG} -t zerotier/zerotier:latest --build-arg VERSION=${RELEASE_VERSION} -f Dockerfile.release . --push
  187. clean:
  188. rm -rf MacEthernetTapAgent *.dSYM build-* *.a *.pkg *.dmg *.o node/*.o nonfree/controller/*.o service/*.o osdep/*.o ext/http-parser/*.o $(CORE_OBJS) $(ONE_OBJS) zerotier-one zerotier-idtool zerotier-selftest zerotier-cli zerotier doc/node_modules zt1_update_$(ZT_BUILD_PLATFORM)_$(ZT_BUILD_ARCHITECTURE)_* rustybits/target/ ext/opentelemetry-cpp-${OTEL_VERSION}/localinstall ext/opentelemetry-cpp-${OTEL_VERSION}/build
  189. ifeq (${ZT_OTEL},1)
  190. otel:
  191. cd ext/opentelemetry-cpp-1.21.0 && mkdir -p localinstall && cmake -B build -S . -DCMAKE_BUILD_TYPE=Release -DCMAKE_INSTALL_PREFIX=$(shell pwd)/ext/opentelemetry-cpp-1.21.0/localinstall -DCMAKE_OSX_ARCHITECTURES="arm64;x86_64" -DCMAKE_OSX_DEPLOYMENT_TARGET=${MACOS_VERSION_MIN} -DBUILD_TESTING=OFF -DOPENTELEMETRY_INSTALL=ON -DWITH_BENCHMARK=OFF -DWITH_EXAMPLES=OFF -DWITH_FUNC_TESTS=OFF
  192. cd ext/opentelemetry-cpp-1.21.0/build && make install
  193. else
  194. otel:
  195. @echo "OpenTelemetry Exporter not enabled, skipping build."
  196. endif
  197. distclean: clean
  198. realclean: clean
  199. FORCE: