MyCrypto is an open-source, client-side tool for generating ether wallets, handling ERC-20 tokens, and interacting with the blockchain more easily. https://mycrypto.com
Go to file
William O'Beirne 5542791af8 Electron Alpha Prep (#1665)
* Adjust update flow to not auto update, not publish in CI

* Revert "Adjust update flow to not auto update, not publish in CI"

This reverts commit 74fb382ce8d8cd9e227703ccfa8d6310bffd9dda.

* First pass at new app version modal

* Added app alpha notice that either warns you about alpha, or blocks the whole app.

* Improve newer version detection, add unit tests

* Remove native auto update behavior

* Notice once per session

* copy changes per PR review
2018-04-24 22:29:34 -05:00
.github Contributor Guidelines (#1054) 2018-02-11 20:59:06 -06:00
common Electron Alpha Prep (#1665) 2018-04-24 22:29:34 -05:00
electron-app Electron Alpha Prep (#1665) 2018-04-24 22:29:34 -05:00
jenkins add jenkins config for mac signing (#1664) 2018-04-24 17:55:01 -05:00
jest_config Fix jest tests (#1534) 2018-04-16 17:23:03 -05:00
scripts Create script to update tokens list from ethereum-lists/tokens (#1247) 2018-04-13 12:02:00 -05:00
shared/types ETC commonwealth node (#1518) 2018-04-15 11:45:36 -05:00
spec Electron Alpha Prep (#1665) 2018-04-24 22:29:34 -05:00
static MyEtherWallet -> MyCrypto (#977) 2018-02-06 22:28:28 -06:00
webpack_config Electron Redesign (#1505) 2018-04-16 18:30:58 -05:00
.drawbridgerc Add .drawbridgerc file (#1540) 2018-04-16 20:58:27 -05:00
.editorconfig Fix editor config (#1458) 2018-04-05 21:08:46 -05:00
.gitignore Mnemonic Redesign (#1501) 2018-04-12 23:50:36 -05:00
.npmrc Update dependencies to enable Greenkeeper 🌴 (#344) 2017-11-07 15:59:27 -08:00
.nvmrc Update Readme, bump nvmrc (#954) 2018-01-29 12:24:20 -06:00
.prettierignore Translation Updates (#1323) 2018-03-21 22:50:25 -05:00
.prettierrc Ensure CI fails on non-prettier compliant PRs (#693) 2018-01-01 17:51:18 -06:00
.travis.yml Add coverage reporting with coveralls (#1459) 2018-04-05 20:51:48 -05:00
LICENSE MyEtherWallet -> MyCrypto (#977) 2018-02-06 22:28:28 -06:00
README.md Prep Launch of Release Candidate 1.0.0 (#1538) 2018-04-16 20:32:17 -05:00
package.json Electron Alpha Prep (#1665) 2018-04-24 22:29:34 -05:00
tsconfig.json Create script to update tokens list from ethereum-lists/tokens (#1247) 2018-04-13 12:02:00 -05:00
tslint.json MEW-01-005 Web - Remove all HTTP links (#978) 2018-02-01 16:51:14 -06:00
yarn.lock RC Bugfixes (#1644) 2018-04-23 18:35:24 -05:00

README.md

MyCrypto Beta RC (VISIT MyCryptoHQ/mycrypto.com for the current site)
Just looking to download? Grab our latest release

Greenkeeper badge Coverage Status

Running the App

This codebase targets Node 8.9.4 (LTS). After npm installing all dependencies (You may be required to install additional system dependencies, due to some node modules relying on them) you can run various commands depending on what you want to do:

Development

# run app in dev mode in browser, rebuild on file changes
npm run dev
# run app in dev mode in electron, rebuild on file changes
npm run dev:electron

Build Releases

# builds the production server app
npm run build
# builds the downloadable version of the site
npm run build:downloadable
# builds the electron apps
npm run build:electron

# builds only one OS's electron app
npm run build:electron:(osx|linux|windows)

All of these builds are output to a folder in dist/.

Unit Tests:

# run unit tests with Jest
npm run test

Integration Tests:

# run integration tests with Jest
npm run test:int

Dev (HTTPS):

Some parts of the site, such as the Ledger wallet, require an HTTPS environment to work. To develop on HTTPS, do the following:

  1. Create your own SSL Certificate (Heroku has a nice guide here)
  2. Move the .key and .crt files into webpack_config/server.*
  3. Run the following command:
npm run dev:https

Address Derivation Checker:

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.

The derivation checker utility assumes that you have:
  1. Docker installed/available
  2. dternyak/eth-priv-to-addr pulled from DockerHub
Docker setup instructions:
  1. Install docker (on macOS, Docker for Mac is suggested)
  2. docker pull dternyak/eth-priv-to-addr
Run Derivation Checker

The derivation checker utility runs as part of the integration test suite.

npm run test:int

Folder structure:

│
├── 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
│   ├── index.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

Thanks & Support

Cross browser testing and debugging provided by the very lovely team at BrowserStack.