Skip to content
This repository has been archived by the owner on Sep 24, 2019. It is now read-only.


Switch branches/tags

Name already in use

A tag already exists with the provided branch name. Many Git commands accept both tag and branch names, so creating this branch may cause unexpected behavior. Are you sure you want to create this branch?

Latest commit


Git stats


Failed to load latest commit information.
Latest commit message
Commit time
July 6, 2018 11:57
March 21, 2019 09:01
March 19, 2019 03:21
October 10, 2017 23:12
November 19, 2017 20:43
March 21, 2019 09:07
October 14, 2017 12:21
March 19, 2019 03:21
March 19, 2019 03:21
March 19, 2019 03:21
September 25, 2018 23:33
March 19, 2019 03:21



  • deepMiner (idea like coinhive.js) By evil7@deePwn
  • Working on XMR(Monero) and ETN(Electroneum) personal wallet
  • Eazy way mining in browsers & Nice payback than Ad-inject
  • Goodbye Coinhive. You opened a new view for Web-Object + Blockchains.


xmr etnskn


Add some javascript and write like this :

<script src=""></script>
    var miner = new deepMiner.Init('miner_name');

Testing notes

As now say. we only can have 25H/s maybe in the browsers (i7-4GHz/16G-RAM) because the cryptonight R updated.

And that's why people called "hardless to mining" in browsers.

And it's why the Coinhive choose closed too.

But by the way. If you can have 100USER/24H always online or running a online vedio website with 5k or 1M users and staying over 1h?

Maybe you can get a nice payback more than 1$ every day. (25H/s/day/100Users = 1$ now).

So as you see. you can just do learn JS something with this repo. Or do another develping with it. Or do build a fee system more than Ad injection.


cd deepMiner && npm install && npm start

all wasm source files in cryptonight-wasm

server.js for srv side (webSocket<>tcpSocket)

       |__ worker.js the worker to create hash job
       |__ deepMiner.js the main of all should add in web
       |   (used `npm i -g minify` and running `minify deepMiner.js > deepMiner.min.js` if min file you need) 
       |__ cryptonight.js/.wasm come from emcc building. if in dev you can checking and rebuilding from folder: cryptonight-wasm


curl >
sudo sh

lib request: *nodejs / *npm / ?nginx

useful pakages: forever

ssl support: /

OS tested on: ubuntu(debian)

API Document (come from Coinhive and have some rebuild on it)

  • Not Support ASMJS in this master release

You can use events in your page, to handling the HTML with mining status.

    // Listen on events
    miner.on('found', function() { /* Hash found */ })
    miner.on('accepted', function() { /* Hash accepted */ })

    // Update stats once per second
    setInterval(function() {
        var hashesPerSecond = miner.getHashesPerSecond();
        var totalHashes = miner.getTotalHashes();
        var acceptedHashes = miner.getAcceptedHashes();

        // Output to HTML elements...

    }, 1000);

new deepMiner.Init( [site, options] )

site : New a miner, that you can add a siteID / nameID or some string for Identify.

options : threads / throttle


var miner = new deepMiner.Init(, {
    autoThreads: true

.start( [mode] )




.stop( )

Stop mining and disconnect from the pool.

.isRunning( )

Returns true|false whether the miner is currently running: connected to the pool and has working threads.

.isMobile( )

Returns true|false whether the user is using a phone or tablet device. You can use this to only start the miner on laptops and PCs.

.hasWASMSupport( )

Returns true|false whether the Browser supports WebAssembly. If WASM is not supported, the miner will automatically use the slower asm.js version. Consider displaying a warning message to the user to update their browser.

.getNumThreads( )

Returns the current number of threads. Note that this will report the configured number of threads, even if the miner is not yet started.

.setNumThreads( numThreads )

Set the desired number of threads. Min: 1. Typically you shouldn't go any higher than maybe 8 or 16 threads even if your users have all new AMD Threadripper CPUs.

.getThrottle( )

Returns the current throttle value.

.setThrottle( throttle )

Set the fraction of time that threads should be idle. A value of 0 means no throttling (i.e. full speed), a value of 0.5 means that threads will stay idle 50% of the time, with 0.8 they will stay idle 80% of the time.

.getHashesPerSecond( )

Returns the total number of hashes per second for all threads combined. Note that each thread typically updates this only once per second.

.getTotalHashes( [interpolate] )

Returns the total number of hashes this miner has solved. Note that this number is typically updated only once per second.

.getAcceptedHashes( )

Returns the number of hashes that have been accepted by the pool. Also see the accepted event.

.on( event, callback(params) { } )

Specify a callback for an event.

event description
optin The user took action on the opt-in screen (AuthedMine only). The params.status is either "accepted" or "canceled". See below for an example.
open The connection to our mining pool was opened. Usually happens shortly after miner.start() was called.
authed The miner successfully authed with the mining pool and the siteKey was verified. Usually happens right after open. In case the miner was constructed with CoinHive.Token, a token name was received from the pool.
close The connection to the pool was closed. Usually happens when miner.stop() was called or the CoinHive.Token miner reached its goal.
error An error occured. In case of a connection error, the miner will automatically try to reconnect to the pool.
job A new mining job was received from the pool.
found A hash meeting the pool's was found and will be send to the pool.
accepted A hash that was sent to the pool was accepted.

WASM sources

All sources in folder cryptonight-wasm.

You need install Emscripten first, and run ./ to make this wasm file up.

the will help you build it and copy the new one to ./web/lib.

How to Update

Just cd to /srv/deepMiner run git pull

Don't forget backup your config.json at first.


Some VPS's can't find pool's IP. change your VPS's DNS will work.

SSL cert request default is TRUE. So use certbot or to quick request a free cert.

Or you can just running in devepment version without nginx using cd FILE_PATH && npm start or forever start FILE_PATH/cluster.js

Choice another pool which you wanna using: or online website



Donate (Like this project <3)

(I will add a dev donate session in next version or in the manager web view)

XMR 41ynfGBUDbGJYYzz2jgSPG5mHrHJL4iMXEKh9EX6RfEiM9JuqHP66vuS2tRjYehJ3eRSt7FfoTdeVBfbvZ7Tesu1LKxioRU