MyCrypto Beta RC (VISIT MyCryptoHQ/mycrypto.com for the current site)
Just looking to download? Grab our latest release
This codebase targets Node 8.9.4 (LTS). After yarn install
ing all dependencies (You may be required to install additional system dependencies, see Windows Installation), due to some node modules relying on them) you can run various commands depending on what you want to do:
# run app in dev mode in browser, rebuild on file changes
yarn run dev
# run app in dev mode in electron, rebuild on file changes
yarn run dev:electron
# builds the production server app
yarn run build
# builds the downloadable version of the site
yarn run build:downloadable
# builds the electron apps
yarn run build:electron
# builds only one OS's electron app
yarn run build:electron:(osx|linux|windows)
All of these builds are output to a folder in dist/
.
# run unit tests with Jest
yarn run test
# run integration tests with Jest
yarn run test:int
Some parts of the site, such as the Ledger wallet, require an HTTPS environment to work. To develop on HTTPS, do the following:
- Create your own SSL Certificate (Heroku has a nice guide here)
- Move the
.key
and.crt
files intowebpack_config/server.*
- Run the following command:
npm run dev:https
EthereumJS-Util previously contained a bug that would incorrectly derive addresses from private keys with a 1/128 probability of occurring. A summary of this issue can be found here.
As a reactionary measure, the address derivation checker was created.
To test for correct address derivation, the address derivation checker uses multiple sources of address derivation (EthereumJS and PyEthereum) to ensure that multiple official implementations derive the same address for any given private key.
- Docker installed/available
- dternyak/eth-priv-to-addr pulled from DockerHub
- Install docker (on macOS, Docker for Mac is suggested)
docker pull dternyak/eth-priv-to-addr
The derivation checker utility runs as part of the integration test suite.
yarn run test:int
│
├── common
│ ├── actions - Application actions
│ ├── api - Services and XHR utils
│ ├── assets - Images, fonts, etc.
│ ├── components - Components according to "Redux philosophy"
│ ├── config - Various config data and hard-coded json
│ ├── containers - Containers according to "Redux philosophy"
│ ├── libs - Framework-agnostic libraries and business logic
│ ├── reducers - Redux reducers
│ ├── sagas - Redux sagas
│ ├── sass - SCSS styles, variables, mixins
│ ├── selectors - Redux selectors
│ ├── translations - Language JSON dictionaries
│ ├── typescript - Typescript definition files
│ ├── utils - Common use utility functions
│ ├── BalanceSidebar.tsx - Entry point for app
│ ├── index.html - Html template file for html-webpack-plugin
│ ├── Root.tsx - Root component for React
│ └── store.ts - Redux reducer combiner and middleware injector
├── electron-app - Code for the native electron app
├── jest_config - Jest testing configuration
├── spec - Jest unit tests, mirror's common's structure
├── static - Files that don't get compiled, just moved to build
└── webpack_config - Webpack configuration
More information is available on the Wiki Pages
-
Ensure the following software is installed:
- Git for Windows
- Latest versions of Node.js and npm (click here for update instructions)
- Python 2.7.3
- Visual Studio (any version, Community is free) - windows-build-tools are NOT sufficient (although worth installing if the npm install still doesn't succeed)
-
npm install
-
npm update
Cross browser testing and debugging provided by the very lovely team at BrowserStack.