- Install nvm to manage node versions.
Install brew from brew.sh
brew install nvm
brew install nasm
brew install yasm
brew install pkg-config
brew install cmake
nvm install 18
npm i -g yarn
cd release/app
yarn install
yarn add ../native/recorder # Triggers build for the platform
cd ../..
yarn install
yarn start
If the C++ code is modified and new prebuilt binaries are needed follow the instructions in the native README.
After C++ code is modified, do the following to test it:
Edit native/recorder/package.json and bump the version. This will trigger a local build instead of downloading a prebuild release from github (because it won't find one).
cd release/app
yarn add ../../native/recorder ## Refresh the C++ code in node_modules and build it
cd ../..
yarn start
Once you are ready to commit the new C++ code, follow the instructions in the native README to upload to github.
- Edit release/app/package.json and adjust version info
- Execute
yarn macbuild && yarn winbuild
- Look in release/ for the dmg and exe files
- Copy the dmg and exe to a Releases set on github
For production builds an 'extraFiles' section copies the ndi library into the build. For dev builds, a copy:ndi script is used to copy it into the folder used by dev builds under node_modules. This is added to postinstall script execution.
"copy:ndi": "cp native/recorder/lib/libndi.dylib 'node_modules/electron/dist/Electron.app/Contents/Frameworks/Electron Framework.framework/Versions/A/Libraries'",
For "mac" section:
"extraFiles": [
{
"from": "native/recorder/lib",
"to": "Frameworks",
"filter": [
"libndi.dylib"
]
}
]
For "win" section:
"target": [
"nsis"
],
"extraFiles": [
{
"from": "native/recorder/lib/Processing.NDI.Lib.x64.dll",
"to": "Processing.NDI.Lib.x64.dll"
}
]
Add firebase render filter in configs/webpack.config.renderer.dev.dll.ts:
renderer: Object.keys(dependencies || {}).filter((it) => it !== 'firebase'),
See stackoverflow for issue it resolves.
Add md file suffix as a raw-loader to the module.config section of webpack.config.renderer.*.ts:
{
test: /\.md$/,
use: 'raw-loader',
}
Remove svg section and add to images in webpack.config.renderer.*.ts:
{
test: /\.(png|svg|jpg|jpeg|gif)$/i,
type: 'asset/resource',
}
In package.json add svg to the "moduleNameMapper" suffix list along with png:
"moduleNameMapper": {
"\\.(jpg|jpeg|svg|png|gif|eot|otf|webp|svg|ttf|woff|woff2|mp4|webm|wav|mp3|m4a|aac|oga)$": "<rootDir>/.erb/mocks/fileMock.js",
"\\.(css|less|sass|scss)$": "identity-obj-proxy"
},
In order to install apps downloaded outside the app store without diving into security exception settings, apps must be signed and notarized. This process takes several minutes as the binary must be uploaded to Apple to get notarized. To disable notariztion during development, set "notarize" : "false"
in the build.mac section of package.json
Requirements for signing:
- A 'Developer ID Application' signing identity certificate as well as it's associated private key to be in the keychain.
- Signing credentials with app specific password stored in the keychain.
You can verify you have a valid signing identity with command below. It should list a key such as "Developer ID Application: Entazza LLC (P87Q63DNL4)".
security find-identity -v -p codesigning
Once you have obtained an app specific password from your developer account, store it into the keychain with this command:
xcrun notarytool store-credentials "crewtimer-app-signing" --apple-id "[email protected]" --team-id P87Q63DNL4 --password app-specific-passord-hash
Signing is configured by setting the env variable APPLE_KEYCHAIN_PROFILE to the name of the profile in the keychain that has the credentials. See macPackager.js and notarize for other options.
If notarization fails, add console.log info to macPackager.js.
Note: As of 12/2024 the notarize.js script in .erb/scripts is not utilized.