Better-sqlite3 issue

My project is using RedwoodJS version 8.5.0, node version 22.11.0
I was trying to install date-fns-tz using this command

yarn workspace web add date-fns-tz

I get this error:

YN0000: · Yarn 4.5.1
➤ YN0000: ┌ Resolution step
➤ YN0000: └ Completed
➤ YN0000: ┌ Post-resolution validation
➤ YN0086: │ Some peer dependencies are incorrectly met by dependencies; run yarn explain peer-requirements for details.
➤ YN0000: └ Completed
➤ YN0000: ┌ Fetch step
➤ YN0000: └ Completed in 0s 649ms
➤ YN0000: ┌ Link step
➤ YN0007: │ better-sqlite3@npm:8.6.0 must be built because it never has been before or the last one failed
➤ YN0009: │ better-sqlite3@npm:8.6.0 couldn't be built successfully (exit code 1, logs can be found here: /private/var/folders/kz/sy0k3fv16g5d4hgcvcc1xp7w0000gn/T/xfs-a9a7fb2c/build.log)
➤ YN0000: └ Completed in 17s 119ms
➤ YN0000: · Failed with errors in 17s 986ms

I’ve tried to install better-sqlite3. I assume I should install it in the web workspace so I used this command.

yarn workspace web add better-sqlite3

Here is the info from yarn rw info

System:
    OS: macOS 14.6.1
    Shell: 5.9 - /bin/zsh
  Binaries:
    Node: 22.11.0 - /private/var/folders/kz/sy0k3fv16g5d4hgcvcc1xp7w0000gn/T/xfs-b607e323/node
    Yarn: 4.5.1 - /private/var/folders/kz/sy0k3fv16g5d4hgcvcc1xp7w0000gn/T/xfs-b607e323/yarn
  Databases:
    SQLite: 3.43.2 - /usr/bin/sqlite3
  Browsers:
    Chrome: 133.0.6943.99
    Edge: 124.0.2478.97
    Safari: 17.6
  npmPackages:
    @redwoodjs/auth-dbauth-setup: 8.5.0 => 8.5.0 
    @redwoodjs/cli-storybook-vite: 8.5.0 => 8.5.0 
    @redwoodjs/core: 8.5.0 => 8.5.0 
    @redwoodjs/project-config: 8.5.0 => 8.5.0 
    @redwoodjs/studio: 12.0.0 => 12.0.0 
  redwood.toml:
    [web]
      title = "Test App"
      port = 8910
      apiUrl = "/.redwood/functions" # You can customize graphql and dbauth urls individually too: see https://redwoodjs.com/docs/app-configuration-redwood-toml#api-paths
      includeEnvironmentVariables = [
        # Add any ENV vars that should be available to the web side to this array
        # See https://redwoodjs.com/docs/environment-variables#web
      ]
    [api]
      port = 8911
    [browser]
      open = true
    [notifications]
      versionUpdates = ["latest"]

Error Log from the install attempt on better-sqlite3

# This file contains the result of Yarn building a package (better-sqlite3@npm:8.6.0)
# Script name: install

prebuild-install warn install No prebuilt binaries found (target=22.11.0 runtime=node arch=arm64 libc= platform=darwin)
gyp info it worked if it ends with ok
gyp info using node-gyp@11.0.0
gyp info using node@22.11.0 | darwin | arm64
gyp info find Python using Python version 3.13.2 found at "/usr/local/opt/python@3.13/bin/python3.13"

gyp info spawn /usr/local/opt/python@3.13/bin/python3.13
gyp info spawn args [
gyp info spawn args '/Users/me/Dropbox/projects/testapp/node_modules/node-gyp/gyp/gyp_main.py',
gyp info spawn args 'binding.gyp',
gyp info spawn args '-f',
gyp info spawn args 'make',
gyp info spawn args '-I',
gyp info spawn args '/Users/me/Dropbox/projects/testapp/node_modules/@redwoodjs/studio/node_modules/better-sqlite3/build/config.gypi',
gyp info spawn args '-I',
gyp info spawn args '/Users/me/Dropbox/projects/testapp/node_modules/node-gyp/addon.gypi',
gyp info spawn args '-I',
gyp info spawn args '/Users/me/Library/Caches/node-gyp/22.11.0/include/node/common.gypi',
gyp info spawn args '-Dlibrary=shared_library',
gyp info spawn args '-Dvisibility=default',
gyp info spawn args '-Dnode_root_dir=/Users/me/Library/Caches/node-gyp/22.11.0',
gyp info spawn args '-Dnode_gyp_dir=/Users/me/Dropbox/projects/testapp/node_modules/node-gyp',
gyp info spawn args '-Dnode_lib_file=/Users/me/Library/Caches/node-gyp/22.11.0/<(target_arch)/node.lib',
gyp info spawn args '-Dmodule_root_dir=/Users/me/Dropbox/projects/testapp/node_modules/@redwoodjs/studio/node_modules/better-sqlite3',
gyp info spawn args '-Dnode_engine=v8',
gyp info spawn args '--depth=.',
gyp info spawn args '--no-parallel',
gyp info spawn args '--generator-output',
gyp info spawn args 'build',
gyp info spawn args '-Goutput_dir=.'
gyp info spawn args ]
gyp info spawn make
gyp info spawn args [ 'BUILDTYPE=Release', '-C', 'build' ]
  TOUCH ba23eeee118cd63e16015df367567cb043fed872.intermediate
  ACTION deps_sqlite3_gyp_locate_sqlite3_target_copy_builtin_sqlite3 ba23eeee118cd63e16015df367567cb043fed872.intermediate
  TOUCH Release/obj.target/deps/locate_sqlite3.stamp
  CC(target) Release/obj.target/sqlite3/gen/sqlite3/sqlite3.o
  LIBTOOL-STATIC Release/sqlite3.a
  CXX(target) Release/obj.target/better_sqlite3/src/better_sqlite3.o
./src/util/macros.lzz:150:35: error: no matching member function for call to 'SetAccessor'
  150 |         recv->InstanceTemplate()->SetAccessor(
      |         ~~~~~~~~~~~~~~~~~~~~~~~~~~^~~~~~~~~~~
/Users/me/Library/Caches/node-gyp/22.11.0/include/node/v8-template.h:1049:8: note: candidate function not viable: no known conversion from 'v8::AccessControl' to 'PropertyAttribute' for 5th argument
 1049 |   void SetAccessor(
      |        ^
 1050 |       Local<String> name, AccessorGetterCallback getter,
 1051 |       AccessorSetterCallback setter = nullptr,
 1052 |       Local<Value> data = Local<Value>(), PropertyAttribute attribute = None,
      |                                           ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
/Users/me/Library/Caches/node-gyp/22.11.0/include/node/v8-template.h:1055:8: note: candidate function not viable: no known conversion from 'v8::AccessorGetterCallback' (aka 'void (*)(Local<String>, const PropertyCallbackInfo<Value> &)') to 'AccessorNameGetterCallback' (aka 'void (*)(Local<Name>, const PropertyCallbackInfo<Value> &)') for 2nd argument
 1055 |   void SetAccessor(
      |        ^
 1056 |       Local<Name> name, AccessorNameGetterCallback getter,
      |                         ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
./src/objects/database.lzz:180:21: warning: variable 'status' set but not used [-Wunused-but-set-variable]
  180 |                 int status = sqlite3_db_config(db_handle, SQLITE_DBCONFIG_ENABLE_LOAD_EXTENSION, 1, NULL);
      |                     ^
1 warning and 1 error generated.
make: *** [Release/obj.target/better_sqlite3/src/better_sqlite3.o] Error 1
rm ba23eeee118cd63e16015df367567cb043fed872.intermediate
gyp ERR! build error 
gyp ERR! stack Error: `make` failed with exit code: 2
gyp ERR! stack at ChildProcess.<anonymous> (/Users/me/Dropbox/projects/testapp/node_modules/node-gyp/lib/build.js:216:23)
gyp ERR! System Darwin 23.6.0
gyp ERR! command "/Users/me/.nvm/versions/node/v22.11.0/bin/node" "/Users/me/Dropbox/projects/testapp/node_modules/node-gyp/bin/node-gyp.js" "rebuild" "--release"
gyp ERR! cwd /Users/me/Dropbox/projects/testapp/node_modules/@redwoodjs/studio/node_modules/better-sqlite3
gyp ERR! node -v v22.11.0
gyp ERR! node-gyp -v v11.0.0
gyp ERR! not ok 

I figured out what was causing the problem. I was using Node 22.11.0. I changed to Node v20.18.2, deleted all the node_modules and did a yarn install. Problem went away. I guess I missed where you need to use a node vers 20.x