This project is a monorepo for various NPM packages scoped under @fastnear/
. It's a TypeScript project that is a full rewrite, creating a new JavaScript library for building on NEAR Protocol.
The API itself (ergonomics, how you use it) will be changing more liberally until the release is out of alpha.
This repo also contains wallet-related packages, which provides an alternate path to the established wallet selector. While functional, the wallet side of this monorepo has seen less attention.
At this early stage, the best place to begin understanding this library is:
It will load a demo. This section will be expanded with wonderfully simple commands you can run. All the final effort in delivering this was in code so far, and the demo.
Yarn is used in this repo, and it's likely not the yarn commonly installed. You must run:
yarn set version berry
yarn build
Will go through all the workspaces packages (see workspaces
key in package.json
) and build them for ECMAScript, CommonJS, and a Universal Module Definition. This is achieved using esbuild
.
Remember that esbuild and similar systems separate the TypeScript evaluation, strict or not, and so we cannot assume that a successful yarn build
means valid TypeScript.
yarn type-check
During development, this was helpful:
yarn type-check && yarn build
If the tsc
call (that does not emit artifacts) finds an error, it'll stop before building.
Will run a command and catch TypeScript problems that should be fixed.
This repo has a tsconfig.base.json
that is used in some packages during build. It currently has strict: true
but it can be helpful to turn it off during particularly rapid development. It won't (shouldn't) harm your project to turn off strict mode. This library will seek to adhere to strict mode, but that does not cascade into demanding this from end developers.
Each workspace package (NPM module) has an esbuild.config.mjs
file that's used to take the TypeScript files in the src
directory and compile them to:
The modern JavaScript module system, primarily used for browser and server environments, and the default for most new packages.
The older module system for NodeJS, ensuring backwards compatibility.
A universal module format that works in browsers (with or without a bundler) and in NodeJS, bridging the gap between different environments.
Universal Module Definition (UMD) is a versatile module format that aims to provide compatibility across different environments, including both browsers and server-side applications. Unlike purely browser-centric solutions like AMD or server-specific formats like CommonJS, UMD offers a unified approach. It checks the environment and adapts accordingly, making it suitable for various scenarios without requiring major adjustments. source
All workspace packages publish a new version regardless of whether the package was modified.
Each package's dist
folder is revisioned, so make sure to run build. Not intending to focus much on CI.
In the project root, open package.json
and change the version that should be reflected in all packages.
yarn constraints
The file yarn.config.cjs
defines a Yarn constraint that takes the root manifest and updates all the workspace package versions based on that.
After you bump the version run yarn build
again because the artifacts will be updated in the comments about the version.
OTP is required and can be input into the command:
yarn workspaces foreach --all -ptv run publish --access public --tolerate-republish --otp
I've only been testing with MyNEARWallet for a wallet. There may be obvious issues in the other ones, I don't know :)
Generally, the most progress has been on the API. Expect to find more unaddressed wallet issues than API ones. And feel free to lean in, knowing it's alpha and greenfield.
Put attention there, could have unaddressed issues
REPL is useful during development and is quite alpha.
Exports are coming from the utils
package in this monorepo. Want to acknowledge the hard work that went into this, and show gratitude for their willingness to have open source licenses.
npm: https://www.npmjs.com/package/base58-js
MIT License: https://github.com/pur3miish/base58-js/blob/9ae694c74f4556834ee7e88cd08ac686600eb7cf/LICENSE
npm: https://www.npmjs.com/package/borsh
MIT License: https://github.com/near/borsh-js/blob/63ad2a30f5d682e9bc8ae923446ff584f4b93f69/LICENSE-MIT.txt
Apache License: https://github.com/near/borsh-js/blob/63ad2a30f5d682e9bc8ae923446ff584f4b93f69/LICENSE-APACHE
npm: https://www.npmjs.com/package/@noble/curves
MIT License: https://github.com/paulmillr/noble-curves/blob/e9eef8b76434ba9bc24f71189b05433d7c685a02/LICENSE
Note: we are currently exporting sha256 from this library, but I believe the Web API Crypto and Crypto.Subtle have this ability and that library export won't be needed.