mirror of
https://git.wownero.com/wownero/wownero.git
synced 2024-08-15 01:03:23 +00:00
commit
3162f5bcd6
2 changed files with 73 additions and 200 deletions
|
@ -1,9 +1,9 @@
|
||||||
Monero daemon internationalization
|
Wownero daemon internationalization
|
||||||
==================================
|
==================================
|
||||||
|
|
||||||
The Monero command line tools can be translated in various languages. If you wish to contribute and need help/support, contact the [Monero Localization Workgroup on Taiga](https://taiga.getmonero.org/project/erciccione-monero-localization/) or come chat on `#monero-translations` (Freenode/IRC, riot/matrix, MatterMost)
|
The Wownero command line tools can be translated in various languages. If you wish to contribute and need help/support, come chat on `#wownero` (Freenode/IRC)
|
||||||
|
|
||||||
In order to use the same translation workflow as the [Monero Core GUI](https://github.com/monero-project/monero-core), they use Qt Linguist translation files. However, to avoid the dependencies on Qt this normally implies, they use a custom loader to read those files at runtime.
|
In order to use the same translation workflow as the [Wownero GUI](https://github.com/wownero/wownero-gui), they use Qt Linguist translation files. However, to avoid the dependencies on Qt this normally implies, they use a custom loader to read those files at runtime.
|
||||||
|
|
||||||
### Tools for translators
|
### Tools for translators
|
||||||
|
|
||||||
|
@ -19,11 +19,11 @@ To update ts files after changing source code:
|
||||||
|
|
||||||
To add a new language, eg Spanish (ISO code es):
|
To add a new language, eg Spanish (ISO code es):
|
||||||
|
|
||||||
cp translations/monero.ts translations/monero_es.ts
|
cp translations/wownero.ts translations/wownero_es.ts
|
||||||
|
|
||||||
To edit translations for Spanish:
|
To edit translations for Spanish:
|
||||||
|
|
||||||
linguist translations/monero_es.ts
|
linguist translations/wownero_es.ts
|
||||||
|
|
||||||
To build translations after modifying them:
|
To build translations after modifying them:
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ To build translations after modifying them:
|
||||||
|
|
||||||
To test a translation:
|
To test a translation:
|
||||||
|
|
||||||
LANG=es ./build/release/bin/monero-wallet-cli
|
LANG=es ./build/release/bin/wownero-wallet-cli
|
||||||
|
|
||||||
To add new translatable strings in the source code:
|
To add new translatable strings in the source code:
|
||||||
|
|
||||||
|
|
261
README.md
261
README.md
|
@ -3,80 +3,73 @@
|
||||||
Copyright (c) 2014-2018 The Monero Project.
|
Copyright (c) 2014-2018 The Monero Project.
|
||||||
Portions Copyright (c) 2012-2013 The Cryptonote developers.
|
Portions Copyright (c) 2012-2013 The Cryptonote developers.
|
||||||
|
|
||||||
## Development resources
|
## Resources
|
||||||
|
|
||||||
- Web: [getmonero.org](https://getmonero.org)
|
- Web: [wownero.org](http://wownero.org)
|
||||||
- Forum: [forum.getmonero.org](https://forum.getmonero.org)
|
- Twitter: [@w0wn3r0](https://twitter.com/w0wn3r0)
|
||||||
- Mail: [dev@getmonero.org](mailto:dev@getmonero.org)
|
- Discord: [discord.gg/sQt74ep](https://discord.gg/sQt74ep)
|
||||||
- GitHub: [https://github.com/monero-project/monero](https://github.com/monero-project/monero)
|
- Reddit: [/r/wownero](https://www.reddit.com/r/wownero)
|
||||||
- IRC: [#monero-dev on Freenode](http://webchat.freenode.net/?randomnick=1&channels=%23monero-dev&prompt=1&uio=d4)
|
- Mail: [wownero@protonmail.com](mailto:wownero@protonmail.com)
|
||||||
|
- GitHub: [https://github.com/wownero/wownero](https://github.com/wownero/wownero)
|
||||||
|
- IRC: [#wownero on Freenode](https://kiwiirc.com/client/irc.freenode.net/?nick=suchchatter|?#wownero)
|
||||||
|
|
||||||
## Vulnerability response
|
## Vulnerability response
|
||||||
|
|
||||||
- Our [Vulnerability Response Process](https://github.com/monero-project/meta/blob/master/VULNERABILITY_RESPONSE_PROCESS.md) encourages responsible disclosure
|
- TODO
|
||||||
- We are also available via [HackerOne](https://hackerone.com/monero)
|
|
||||||
|
|
||||||
## Build
|
## Build
|
||||||
|
|
||||||
| Operating System | Processor | Status |
|
| Operating System | Processor | Status |
|
||||||
| --------------------- | -------- |--------|
|
| --------------------- | -------- |--------|
|
||||||
| Ubuntu 16.04 | i686 | [![Ubuntu 16.04 i686](https://build.getmonero.org/png?builder=monero-static-ubuntu-i686)](https://build.getmonero.org/builders/monero-static-ubuntu-i686)
|
| Ubuntu 16.04 | i686 | TODO
|
||||||
| Ubuntu 16.04 | amd64 | [![Ubuntu 16.04 amd64](https://build.getmonero.org/png?builder=monero-static-ubuntu-amd64)](https://build.getmonero.org/builders/monero-static-ubuntu-amd64)
|
| Ubuntu 16.04 | amd64 | TODO
|
||||||
| Ubuntu 16.04 | armv7 | [![Ubuntu 16.04 armv7](https://build.getmonero.org/png?builder=monero-static-ubuntu-arm7)](https://build.getmonero.org/builders/monero-static-ubuntu-arm7)
|
| Ubuntu 16.04 | armv7 | TODO
|
||||||
| Debian Stable | armv8 | [![Debian armv8](https://build.getmonero.org/png?builder=monero-static-debian-armv8)](https://build.getmonero.org/builders/monero-static-debian-armv8)
|
| Debian Stable | armv8 | TODO
|
||||||
| OSX 10.10 | amd64 | [![OSX 10.10 amd64](https://build.getmonero.org/png?builder=monero-static-osx-10.10)](https://build.getmonero.org/builders/monero-static-osx-10.10)
|
| OSX 10.10 | amd64 | TODO
|
||||||
| OSX 10.11 | amd64 | [![OSX 10.11 amd64](https://build.getmonero.org/png?builder=monero-static-osx-10.11)](https://build.getmonero.org/builders/monero-static-osx-10.11)
|
| OSX 10.11 | amd64 | TODO
|
||||||
| OSX 10.12 | amd64 | [![OSX 10.12 amd64](https://build.getmonero.org/png?builder=monero-static-osx-10.12)](https://build.getmonero.org/builders/monero-static-osx-10.12)
|
| OSX 10.12 | amd64 | TODO
|
||||||
| FreeBSD 11 | amd64 | [![FreeBSD 11 amd64](https://build.getmonero.org/png?builder=monero-static-freebsd64)](https://build.getmonero.org/builders/monero-static-freebsd64)
|
| FreeBSD 11 | amd64 | TODO
|
||||||
| DragonFly BSD 4.6 | amd64 | [![DragonFly BSD amd64](https://build.getmonero.org/png?builder=monero-static-dragonflybsd-amd64)](https://build.getmonero.org/builders/monero-static-dragonflybsd-amd64)
|
| DragonFly BSD 4.6 | amd64 | TODO
|
||||||
| Windows (MSYS2/MinGW) | i686 | [![Windows (MSYS2/MinGW) i686](https://build.getmonero.org/png?builder=monero-static-win32)](https://build.getmonero.org/builders/monero-static-win32)
|
| Windows (MSYS2/MinGW) | i686 | TODO
|
||||||
| Windows (MSYS2/MinGW) | amd64 | [![Windows (MSYS2/MinGW) amd64](https://build.getmonero.org/png?builder=monero-static-win64)](https://build.getmonero.org/builders/monero-static-win64)
|
| Windows (MSYS2/MinGW) | amd64 | TODO
|
||||||
|
|
||||||
## Coverage
|
## Coverage
|
||||||
|
|
||||||
| Type | Status |
|
| Type | Status |
|
||||||
|-----------|--------|
|
|-----------|--------|
|
||||||
| Coverity | [![Coverity Status](https://scan.coverity.com/projects/9657/badge.svg)](https://scan.coverity.com/projects/9657/)
|
|
||||||
| Coveralls | [![Coveralls Status](https://coveralls.io/repos/github/monero-project/monero/badge.svg?branch=master)](https://coveralls.io/github/monero-project/monero?branch=master)
|
|
||||||
| License | [![License](https://img.shields.io/badge/license-BSD3-blue.svg)](https://opensource.org/licenses/BSD-3-Clause)
|
| License | [![License](https://img.shields.io/badge/license-BSD3-blue.svg)](https://opensource.org/licenses/BSD-3-Clause)
|
||||||
|
|
||||||
## Introduction
|
## Introduction
|
||||||
|
|
||||||
Monero is a private, secure, untraceable, decentralised digital currency. You are your bank, you control your funds, and nobody can trace your transfers unless you allow them to do so.
|
Wownero is a fork of the private cryptocurrenty Monero with two major changes: A capped emmision that disallows infinite coin creation 10x the coin for 10x the W0W; Wownero is a fairly launched coin with no premine. It's not a fork of another blockchain. With its own genesis block there is no degradation of privacy due to ring signatures using different participants for the same tx outputs on opposing forks.
|
||||||
|
|
||||||
**Privacy:** Monero uses a cryptographically sound system to allow you to send and receive funds without your transactions being easily revealed on the blockchain (the ledger of transactions that everyone has). This ensures that your purchases, receipts, and all transfers remain absolutely private by default.
|
**Privacy:** Wownero uses a cryptographically sound system to allow you to send and receive funds without your transactions being easily revealed on the blockchain (the ledger of transactions that everyone has). This ensures that your purchases, receipts, and all transfers remain absolutely private by default.
|
||||||
|
|
||||||
**Security:** Using the power of a distributed peer-to-peer consensus network, every transaction on the network is cryptographically secured. Individual wallets have a 25 word mnemonic seed that is only displayed once, and can be written down to backup the wallet. Wallet files are encrypted with a passphrase to ensure they are useless if stolen.
|
**Security:** Using the power of a distributed peer-to-peer consensus network, every transaction on the network is cryptographically secured. Individual wallets have a 25 word mnemonic seed that is only displayed once, and can be written down to backup the wallet. Wallet files are encrypted with a passphrase to ensure they are useless if stolen.
|
||||||
|
|
||||||
**Untraceability:** By taking advantage of ring signatures, a special property of a certain type of cryptography, Monero is able to ensure that transactions are not only untraceable, but have an optional measure of ambiguity that ensures that transactions cannot easily be tied back to an individual user or computer.
|
**Untraceability:** By taking advantage of ring signatures, a special property of a certain type of cryptography, Wownero is able to ensure that transactions are not only untraceable, but have an optional measure of ambiguity that ensures that transactions cannot easily be tied back to an individual user or computer.
|
||||||
|
|
||||||
## About this project
|
## About this project
|
||||||
|
|
||||||
This is the core implementation of Monero. It is open source and completely free to use without restrictions, except for those specified in the license agreement below. There are no restrictions on anyone creating an alternative implementation of Monero that uses the protocol and network in a compatible manner.
|
This is the core implementation of Wownero. It is open source and completely free to use without restrictions, except for those specified in the license agreement below. There are no restrictions on anyone creating an alternative implementation of Wownero that uses the protocol and network in a compatible manner.
|
||||||
|
|
||||||
As with many development projects, the repository on Github is considered to be the "staging" area for the latest changes. Before changes are merged into that branch on the main repository, they are tested by individual developers in their own branches, submitted as a pull request, and then subsequently tested by contributors who focus on testing and code reviews. That having been said, the repository should be carefully considered before using it in a production environment, unless there is a patch in the repository for a particular show-stopping issue you are experiencing. It is generally a better idea to use a tagged release for stability.
|
As with many development projects, the repository on Github is considered to be the "staging" area for the latest changes. Before changes are merged into that branch on the main repository, they are tested by individual developers in their own branches, submitted as a pull request, and then subsequently tested by contributors who focus on testing and code reviews. That having been said, the repository should be carefully considered before using it in a production environment, unless there is a patch in the repository for a particular show-stopping issue you are experiencing. It is generally a better idea to use a tagged release for stability.
|
||||||
|
|
||||||
**Anyone is welcome to contribute to Monero's codebase!** If you have a fix or code change, feel free to submit it as a pull request directly to the "master" branch. In cases where the change is relatively small or does not affect other parts of the codebase it may be merged in immediately by any one of the collaborators. On the other hand, if the change is particularly large or complex, it is expected that it will be discussed at length either well in advance of the pull request being submitted, or even directly on the pull request.
|
**Anyone is welcome to contribute to Wownero's codebase!** If you have a fix or code change, feel free to submit it as a pull request directly to the "master" branch. In cases where the change is relatively small or does not affect other parts of the codebase it may be merged in immediately by any one of the collaborators. On the other hand, if the change is particularly large or complex, it is expected that it will be discussed at length either well in advance of the pull request being submitted, or even directly on the pull request.
|
||||||
|
|
||||||
## Supporting the project
|
## Supporting the project
|
||||||
|
|
||||||
Monero is a 100% community-sponsored endeavor. If you want to join our efforts, the easiest thing you can do is support the project financially. Both Monero and Bitcoin donations can be made to **donate.getmonero.org** if using a client that supports the [OpenAlias](https://openalias.org) standard. Alternatively you can send XMR to the Monero donation address via the `donate` command (type `help` in the command-line wallet for details).
|
Wownero is a 100% community-sponsored endeavor. If you want to join our efforts, the easiest thing you can do is support the project financially.
|
||||||
|
|
||||||
|
The Wownero donation address (mostly reserved for hookers and blow) is: `Wo3MWeKwtA918DU4c69hVSNgejdWFCRCuWjShRY66mJkU2Hv58eygJWDJS1MNa2Ge5M1WjUkGHuLqHkweDxwZZU42d16v94mP`
|
||||||
|
|
||||||
The Monero donation address is: `44AFFq5kSiGBoZ4NMDwYtN18obc8AemS33DBLWs3H7otXft3XjrpDtQGv7SqSsaBYBb98uNbr2VBBEt7f2wfn3RVGQBEP3A` (viewkey: `f359631075708155cc3d92a32b75a7d02a5dcf27756707b47a2b31b21c389501`)
|
The Monero donation address is: `44AFFq5kSiGBoZ4NMDwYtN18obc8AemS33DBLWs3H7otXft3XjrpDtQGv7SqSsaBYBb98uNbr2VBBEt7f2wfn3RVGQBEP3A` (viewkey: `f359631075708155cc3d92a32b75a7d02a5dcf27756707b47a2b31b21c389501`)
|
||||||
|
|
||||||
The Bitcoin donation address is: `1KTexdemPdxSBcG55heUuTjDRYqbC5ZL8H`
|
The Monero Bitcoin donation address is: `1KTexdemPdxSBcG55heUuTjDRYqbC5ZL8H`
|
||||||
|
|
||||||
Core development funding and/or some supporting services are also graciously provided by sponsors:
|
Core development funding and/or some supporting services are also graciously provided by sponsors:
|
||||||
|
|
||||||
[<img width="80" src="https://static.getmonero.org/images/sponsors/mymonero.png"/>](https://mymonero.com)
|
<img width="100" src="https://botw-pd.s3.amazonaws.com/styles/logo-thumbnail/s3/0024/1083/brand.gif"/><img width="100" src="https://blogvecindad.com/imagenes/2007/02/brawndo.jpg"/><img width="100" src="https://www.subscribepro.com/wp-content/uploads/2016/04/logo-depend-250x130.png"/>
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/kitware.png?1"/>](http://kitware.com)
|
|
||||||
[<img width="100" src="https://static.getmonero.org/images/sponsors/dome9.png"/>](http://dome9.com)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/araxis.png"/>](http://araxis.com)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/jetbrains.png"/>](http://www.jetbrains.com/)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/navicat.png"/>](http://www.navicat.com/)
|
|
||||||
[<img width="150" src="https://static.getmonero.org/images/sponsors/symas.png"/>](http://www.symas.com/)
|
|
||||||
|
|
||||||
There are also several mining pools that kindly donate a portion of their fees, [a list of them can be found on our Bitcointalk post](https://bitcointalk.org/index.php?topic=583449.0).
|
|
||||||
|
|
||||||
## License
|
## License
|
||||||
|
|
||||||
|
@ -88,13 +81,14 @@ If you want to help out, see [CONTRIBUTING](CONTRIBUTING.md) for a set of guidel
|
||||||
|
|
||||||
## Scheduled mandatory software upgrades
|
## Scheduled mandatory software upgrades
|
||||||
|
|
||||||
Monero uses a fixed-schedule mandatory software upgrade (hard fork) mechanism to implement new features. This means that users of Monero (end users and service providers) need to run current versions and upgrade their software on a regular schedule. Mandatory software upgrades occur during the months of March and September. The required software for these upgrades will be available prior to the scheduled date. Please check the repository prior to this date for the proper Monero software version. Below is the historical schedule and the projected schedule for the next upgrade.
|
Wownero uses a fixed-schedule mandatory software upgrade (hard fork) mechanism to implement new features. This means that users of Wownero (end users and service providers) need to run current versions and upgrade their software on a regular schedule.The required software for these upgrades will be available prior to the scheduled date. Please check the repository prior to this date for the proper Wownero software version. Below is the historical schedule and the projected schedule for the next upgrade.
|
||||||
Dates are provided in the format YYYY-MM-DD.
|
Dates are provided in the format YYYY-MM-DD.
|
||||||
|
|
||||||
|
|
||||||
| Software upgrade block height | Date | Fork version | Minimum Monero version | Recommended Monero version | Details |
|
| Software upgrade block height | Date | Fork version | Minimum Monero version | Recommended Monero version | Details |
|
||||||
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
| ------------------------------ | -----------| ----------------- | ---------------------- | -------------------------- | ---------------------------------------------------------------------------------- |
|
||||||
| 1 | 2018-04-01 | v7 | v0.1.0.0 | v0.1.0.0 | Cryptonight variant 1, ringsize >= 8, sorted inputs
|
| 1 | 2018-04-01 | v7 | v0.1.0.0 | v0.1.0.0 | Cryptonight variant 1, ringsize >= 8, sorted inputs
|
||||||
|
| X | 2018-04-XX | v8 | v0.2.0.0 | v0.2.0.0 | Bulletproofs, LWMA difficulty algorithm, ringsize >= 10
|
||||||
|
|
||||||
X's indicate that these details have not been determined as of commit date.
|
X's indicate that these details have not been determined as of commit date.
|
||||||
|
|
||||||
|
@ -102,50 +96,7 @@ X's indicate that these details have not been determined as of commit date.
|
||||||
|
|
||||||
Approximately three months prior to a scheduled mandatory software upgrade, a branch from Master will be created with the new release version tag. Pull requests that address bugs should then be made to both Master and the new release branch. Pull requests that require extensive review and testing (generally, optimizations and new features) should *not* be made to the release branch.
|
Approximately three months prior to a scheduled mandatory software upgrade, a branch from Master will be created with the new release version tag. Pull requests that address bugs should then be made to both Master and the new release branch. Pull requests that require extensive review and testing (generally, optimizations and new features) should *not* be made to the release branch.
|
||||||
|
|
||||||
## Installing Monero from a package
|
## Compiling Wownero from source
|
||||||
|
|
||||||
Packages are available for
|
|
||||||
|
|
||||||
* Ubuntu and [snap supported](https://snapcraft.io/docs/core/install) systems, via a community contributed build.
|
|
||||||
|
|
||||||
snap install monero --beta
|
|
||||||
|
|
||||||
Installing a snap is very quick. Snaps are secure. They are isolated with all of their dependencies. Snaps also auto update when a new version is released.
|
|
||||||
|
|
||||||
* Arch Linux (via [AUR](https://aur.archlinux.org/)):
|
|
||||||
- Stable release: [`monero`](https://aur.archlinux.org/packages/monero)
|
|
||||||
- Bleeding edge: [`monero-git`](https://aur.archlinux.org/packages/monero-git)
|
|
||||||
|
|
||||||
* Void Linux:
|
|
||||||
|
|
||||||
xbps-install -S monero
|
|
||||||
|
|
||||||
* GuixSD
|
|
||||||
|
|
||||||
guix package -i monero
|
|
||||||
|
|
||||||
* OS X via [Homebrew](http://brew.sh)
|
|
||||||
|
|
||||||
brew tap sammy007/cryptonight
|
|
||||||
brew install monero --build-from-source
|
|
||||||
|
|
||||||
* Docker
|
|
||||||
|
|
||||||
# Build using all available cores
|
|
||||||
docker build -t monero .
|
|
||||||
|
|
||||||
# or build using a specific number of cores (reduce RAM requirement)
|
|
||||||
docker build --build-arg NPROC=1 -t monero .
|
|
||||||
|
|
||||||
# either run in foreground
|
|
||||||
docker run -it -v /monero/chain:/root/.bitmonero -v /monero/wallet:/wallet -p 18080:18080 monero
|
|
||||||
|
|
||||||
# or in background
|
|
||||||
docker run -it -d -v /monero/chain:/root/.bitmonero -v /monero/wallet:/wallet -p 18080:18080 monero
|
|
||||||
|
|
||||||
Packaging for your favorite distribution would be a welcome contribution!
|
|
||||||
|
|
||||||
## Compiling Monero from source
|
|
||||||
|
|
||||||
### Dependencies
|
### Dependencies
|
||||||
|
|
||||||
|
@ -186,11 +137,11 @@ build the library binary manually. This can be done with the following command `
|
||||||
|
|
||||||
Clone recursively to pull-in needed submodule(s):
|
Clone recursively to pull-in needed submodule(s):
|
||||||
|
|
||||||
`$ git clone --recursive https://github.com/monero-project/monero`
|
`$ git clone --recursive https://github.com/wownero/wownero`
|
||||||
|
|
||||||
If you already have a repo cloned, initialize and update:
|
If you already have a repo cloned, initialize and update:
|
||||||
|
|
||||||
`$ cd monero && git submodule init && git submodule update`
|
`$ cd wownero && git submodule init && git submodule update`
|
||||||
|
|
||||||
### Build instructions
|
### Build instructions
|
||||||
|
|
||||||
|
@ -202,7 +153,7 @@ invokes cmake commands as needed.
|
||||||
* Install the dependencies
|
* Install the dependencies
|
||||||
* Change to the root of the source code directory and build:
|
* Change to the root of the source code directory and build:
|
||||||
|
|
||||||
cd monero
|
cd wownero
|
||||||
make
|
make
|
||||||
|
|
||||||
*Optional*: If your machine has several cores and enough memory, enable
|
*Optional*: If your machine has several cores and enough memory, enable
|
||||||
|
@ -215,9 +166,9 @@ invokes cmake commands as needed.
|
||||||
|
|
||||||
* The resulting executables can be found in `build/release/bin`
|
* The resulting executables can be found in `build/release/bin`
|
||||||
|
|
||||||
* Add `PATH="$PATH:$HOME/monero/build/release/bin"` to `.profile`
|
* Add `PATH="$PATH:$HOME/wownero/build/release/bin"` to `.profile`
|
||||||
|
|
||||||
* Run Monero with `monerod --detach`
|
* Run Monero with `wownerod --detach`
|
||||||
|
|
||||||
* **Optional**: build and run the test suite to verify the binaries:
|
* **Optional**: build and run the test suite to verify the binaries:
|
||||||
|
|
||||||
|
@ -237,73 +188,6 @@ invokes cmake commands as needed.
|
||||||
|
|
||||||
HAVE_DOT=YES doxygen Doxyfile
|
HAVE_DOT=YES doxygen Doxyfile
|
||||||
|
|
||||||
#### On the Raspberry Pi
|
|
||||||
|
|
||||||
Tested on a Raspberry Pi Zero with a clean install of minimal Raspbian Stretch (2017-09-07 or later) from https://www.raspberrypi.org/downloads/raspbian/. If you are using Raspian Jessie, [please see note in the following section](#note-for-raspbian-jessie-users).
|
|
||||||
|
|
||||||
* `apt-get update && apt-get upgrade` to install all of the latest software
|
|
||||||
|
|
||||||
* Install the dependencies for Monero from the 'Debian' column in the table above.
|
|
||||||
|
|
||||||
* Increase the system swap size:
|
|
||||||
```
|
|
||||||
sudo /etc/init.d/dphys-swapfile stop
|
|
||||||
sudo nano /etc/dphys-swapfile
|
|
||||||
CONF_SWAPSIZE=1024
|
|
||||||
sudo /etc/init.d/dphys-swapfile start
|
|
||||||
```
|
|
||||||
* Clone monero and checkout most recent release version:
|
|
||||||
```
|
|
||||||
git clone https://github.com/monero-project/monero.git
|
|
||||||
cd monero
|
|
||||||
git checkout tags/v0.11.1.0
|
|
||||||
```
|
|
||||||
* Build:
|
|
||||||
```
|
|
||||||
make release
|
|
||||||
```
|
|
||||||
* Wait 4-6 hours
|
|
||||||
|
|
||||||
* The resulting executables can be found in `build/release/bin`
|
|
||||||
|
|
||||||
* Add `PATH="$PATH:$HOME/monero/build/release/bin"` to `.profile`
|
|
||||||
|
|
||||||
* Run Monero with `monerod --detach`
|
|
||||||
|
|
||||||
* You may wish to reduce the size of the swap file after the build has finished, and delete the boost directory from your home directory
|
|
||||||
|
|
||||||
#### *Note for Raspbian Jessie users:*
|
|
||||||
|
|
||||||
If you are using the older Raspbian Jessie image, compiling Monero is a bit more complicated. The version of Boost available in the Debian Jessie repositories is too old to use with Monero, and thus you must compile a newer version yourself. The following explains the extra steps, and has been tested on a Raspberry Pi 2 with a clean install of minimal Raspbian Jessie.
|
|
||||||
|
|
||||||
* As before, `apt-get update && apt-get upgrade` to install all of the latest software, and increase the system swap size
|
|
||||||
|
|
||||||
```
|
|
||||||
sudo /etc/init.d/dphys-swapfile stop
|
|
||||||
sudo nano /etc/dphys-swapfile
|
|
||||||
CONF_SWAPSIZE=1024
|
|
||||||
sudo /etc/init.d/dphys-swapfile start
|
|
||||||
```
|
|
||||||
|
|
||||||
* Then, install the dependencies for Monero except `libunwind` and `libboost-all-dev`
|
|
||||||
|
|
||||||
* Install the latest version of boost (this may first require invoking `apt-get remove --purge libboost*` to remove a previous version if you're not using a clean install):
|
|
||||||
```
|
|
||||||
cd
|
|
||||||
wget https://sourceforge.net/projects/boost/files/boost/1.64.0/boost_1_64_0.tar.bz2
|
|
||||||
tar xvfo boost_1_64_0.tar.bz2
|
|
||||||
cd boost_1_64_0
|
|
||||||
./bootstrap.sh
|
|
||||||
sudo ./b2
|
|
||||||
```
|
|
||||||
* Wait ~8 hours
|
|
||||||
```
|
|
||||||
sudo ./bjam install
|
|
||||||
```
|
|
||||||
* Wait ~4 hours
|
|
||||||
|
|
||||||
* From here, follow the [general Raspberry Pi instructions](#on-the-raspberry-pi) from the "Clone monero and checkout most recent release version" step.
|
|
||||||
|
|
||||||
#### On Windows:
|
#### On Windows:
|
||||||
|
|
||||||
Binaries for Windows are built on Windows using the MinGW toolchain within
|
Binaries for Windows are built on Windows using the MinGW toolchain within
|
||||||
|
@ -355,9 +239,7 @@ application.
|
||||||
|
|
||||||
### On FreeBSD:
|
### On FreeBSD:
|
||||||
|
|
||||||
The project can be built from scratch by following instructions for Linux above. If you are running monero in a jail you need to add the flag: `allow.sysvipc=1` to your jail configuration, otherwise lmdb will throw the error message: `Failed to open lmdb environment: Function not implemented`.
|
The project can be built from scratch by following instructions for Linux above. If you are running wownero in a jail you need to add the flag: `allow.sysvipc=1` to your jail configuration, otherwise lmdb will throw the error message: `Failed to open lmdb environment: Function not implemented`.
|
||||||
|
|
||||||
We expect to add Monero into the ports tree in the near future, which will aid in managing installations using ports or packages.
|
|
||||||
|
|
||||||
### On OpenBSD:
|
### On OpenBSD:
|
||||||
|
|
||||||
|
@ -447,7 +329,7 @@ cmake ..
|
||||||
doas make install
|
doas make install
|
||||||
```
|
```
|
||||||
|
|
||||||
Build monero: `env DEVELOPER_LOCAL_TOOLS=1 BOOST_ROOT=/usr/local make release-static`
|
Build wownero: `env DEVELOPER_LOCAL_TOOLS=1 BOOST_ROOT=/usr/local make release-static`
|
||||||
|
|
||||||
### On Solaris:
|
### On Solaris:
|
||||||
|
|
||||||
|
@ -460,15 +342,6 @@ The default Solaris linker can't be used, you have to install GNU ld, then run c
|
||||||
|
|
||||||
Then you can run make as usual.
|
Then you can run make as usual.
|
||||||
|
|
||||||
### On Linux for Android (using docker):
|
|
||||||
|
|
||||||
# Build image (select android64.Dockerfile for aarch64)
|
|
||||||
cd utils/build_scripts/ && docker build -f android32.Dockerfile -t monero-android .
|
|
||||||
# Create container
|
|
||||||
docker create -it --name monero-android monero-android bash
|
|
||||||
# Get binaries
|
|
||||||
docker cp monero-android:/opt/android/monero/build/release/bin .
|
|
||||||
|
|
||||||
### Building portable statically linked binaries
|
### Building portable statically linked binaries
|
||||||
|
|
||||||
By default, in either dynamically or statically linked builds, binaries target the specific host processor on which the build happens and are not portable to other processors. Portable binaries can be built using the following targets:
|
By default, in either dynamically or statically linked builds, binaries target the specific host processor on which the build happens and are not portable to other processors. Portable binaries can be built using the following targets:
|
||||||
|
@ -481,15 +354,15 @@ By default, in either dynamically or statically linked builds, binaries target t
|
||||||
* ```make release-static-win64``` builds binaries on 64-bit Windows portable across 64-bit Windows systems
|
* ```make release-static-win64``` builds binaries on 64-bit Windows portable across 64-bit Windows systems
|
||||||
* ```make release-static-win32``` builds binaries on 64-bit or 32-bit Windows portable across 32-bit Windows systems
|
* ```make release-static-win32``` builds binaries on 64-bit or 32-bit Windows portable across 32-bit Windows systems
|
||||||
|
|
||||||
## Running monerod
|
## Running wownerod
|
||||||
|
|
||||||
The build places the binary in `bin/` sub-directory within the build directory
|
The build places the binary in `bin/` sub-directory within the build directory
|
||||||
from which cmake was invoked (repository root by default). To run in
|
from which cmake was invoked (repository root by default). To run in
|
||||||
foreground:
|
foreground:
|
||||||
|
|
||||||
./bin/monerod
|
./bin/wownerod
|
||||||
|
|
||||||
To list all available options, run `./bin/monerod --help`. Options can be
|
To list all available options, run `./bin/wownerod --help`. Options can be
|
||||||
specified either on the command line or in a configuration file passed by the
|
specified either on the command line or in a configuration file passed by the
|
||||||
`--config-file` argument. To specify an option in the configuration file, add
|
`--config-file` argument. To specify an option in the configuration file, add
|
||||||
a line with the syntax `argumentname=value`, where `argumentname` is the name
|
a line with the syntax `argumentname=value`, where `argumentname` is the name
|
||||||
|
@ -497,17 +370,17 @@ of the argument without the leading dashes, for example `log-level=1`.
|
||||||
|
|
||||||
To run in background:
|
To run in background:
|
||||||
|
|
||||||
./bin/monerod --log-file monerod.log --detach
|
./bin/wownerod --log-file wownerod.log --detach
|
||||||
|
|
||||||
To run as a systemd service, copy
|
To run as a systemd service, copy
|
||||||
[monerod.service](utils/systemd/monerod.service) to `/etc/systemd/system/` and
|
[wownerod.service](utils/systemd/wownerod.service) to `/etc/systemd/system/` and
|
||||||
[monerod.conf](utils/conf/monerod.conf) to `/etc/`. The [example
|
[wownerod.conf](utils/conf/wownerod.conf) to `/etc/`. The [example
|
||||||
service](utils/systemd/monerod.service) assumes that the user `monero` exists
|
service](utils/systemd/wownerod.service) assumes that the user `wownero` exists
|
||||||
and its home is the data directory specified in the [example
|
and its home is the data directory specified in the [example
|
||||||
config](utils/conf/monerod.conf).
|
config](utils/conf/wownerod.conf).
|
||||||
|
|
||||||
If you're on Mac, you may need to add the `--max-concurrency 1` option to
|
If you're on Mac, you may need to add the `--max-concurrency 1` option to
|
||||||
monero-wallet-cli, and possibly monerod, if you get crashes refreshing.
|
wownero-wallet-cli, and possibly wownerod, if you get crashes refreshing.
|
||||||
|
|
||||||
## Internationalization
|
## Internationalization
|
||||||
|
|
||||||
|
@ -515,29 +388,29 @@ See [README.i18n.md](README.i18n.md).
|
||||||
|
|
||||||
## Using Tor
|
## Using Tor
|
||||||
|
|
||||||
While Monero isn't made to integrate with Tor, it can be used wrapped with torsocks, by
|
While Wownero isn't made to integrate with Tor, it can be used wrapped with torsocks, by
|
||||||
setting the following configuration parameters and environment variables:
|
setting the following configuration parameters and environment variables:
|
||||||
|
|
||||||
* `--p2p-bind-ip 127.0.0.1` on the command line or `p2p-bind-ip=127.0.0.1` in
|
* `--p2p-bind-ip 127.0.0.1` on the command line or `p2p-bind-ip=127.0.0.1` in
|
||||||
monerod.conf to disable listening for connections on external interfaces.
|
wownerod.conf to disable listening for connections on external interfaces.
|
||||||
* `--no-igd` on the command line or `no-igd=1` in monerod.conf to disable IGD
|
* `--no-igd` on the command line or `no-igd=1` in wownerod.conf to disable IGD
|
||||||
(UPnP port forwarding negotiation), which is pointless with Tor.
|
(UPnP port forwarding negotiation), which is pointless with Tor.
|
||||||
* `DNS_PUBLIC=tcp` or `DNS_PUBLIC=tcp://x.x.x.x` where x.x.x.x is the IP of the
|
* `DNS_PUBLIC=tcp` or `DNS_PUBLIC=tcp://x.x.x.x` where x.x.x.x is the IP of the
|
||||||
desired DNS server, for DNS requests to go over TCP, so that they are routed
|
desired DNS server, for DNS requests to go over TCP, so that they are routed
|
||||||
through Tor. When IP is not specified, monerod uses the default list of
|
through Tor. When IP is not specified, wownerod uses the default list of
|
||||||
servers defined in [src/common/dns_utils.cpp](src/common/dns_utils.cpp).
|
servers defined in [src/common/dns_utils.cpp](src/common/dns_utils.cpp).
|
||||||
* `TORSOCKS_ALLOW_INBOUND=1` to tell torsocks to allow monerod to bind to interfaces
|
* `TORSOCKS_ALLOW_INBOUND=1` to tell torsocks to allow wownerod to bind to interfaces
|
||||||
to accept connections from the wallet. On some Linux systems, torsocks
|
to accept connections from the wallet. On some Linux systems, torsocks
|
||||||
allows binding to localhost by default, so setting this variable is only
|
allows binding to localhost by default, so setting this variable is only
|
||||||
necessary to allow binding to local LAN/VPN interfaces to allow wallets to
|
necessary to allow binding to local LAN/VPN interfaces to allow wallets to
|
||||||
connect from remote hosts. On other systems, it may be needed for local wallets
|
connect from remote hosts. On other systems, it may be needed for local wallets
|
||||||
as well.
|
as well.
|
||||||
* Do NOT pass `--detach` when running through torsocks with systemd, (see
|
* Do NOT pass `--detach` when running through torsocks with systemd, (see
|
||||||
[utils/systemd/monerod.service](utils/systemd/monerod.service) for details).
|
[utils/systemd/wownerod.service](utils/systemd/wownerod.service) for details).
|
||||||
|
|
||||||
Example command line to start monerod through Tor:
|
Example command line to start wownerod through Tor:
|
||||||
|
|
||||||
DNS_PUBLIC=tcp torsocks monerod --p2p-bind-ip 127.0.0.1 --no-igd
|
DNS_PUBLIC=tcp torsocks wownerod --p2p-bind-ip 127.0.0.1 --no-igd
|
||||||
|
|
||||||
### Using Tor on Tails
|
### Using Tor on Tails
|
||||||
|
|
||||||
|
@ -545,13 +418,13 @@ TAILS ships with a very restrictive set of firewall rules. Therefore, you need
|
||||||
to add a rule to allow this connection too, in addition to telling torsocks to
|
to add a rule to allow this connection too, in addition to telling torsocks to
|
||||||
allow inbound connections. Full example:
|
allow inbound connections. Full example:
|
||||||
|
|
||||||
sudo iptables -I OUTPUT 2 -p tcp -d 127.0.0.1 -m tcp --dport 18081 -j ACCEPT
|
sudo iptables -I OUTPUT 2 -p tcp -d 127.0.0.1 -m tcp --dport 34568 -j ACCEPT
|
||||||
DNS_PUBLIC=tcp torsocks ./monerod --p2p-bind-ip 127.0.0.1 --no-igd --rpc-bind-ip 127.0.0.1 \
|
DNS_PUBLIC=tcp torsocks ./wownerod --p2p-bind-ip 127.0.0.1 --no-igd --rpc-bind-ip 127.0.0.1 \
|
||||||
--data-dir /home/amnesia/Persistent/your/directory/to/the/blockchain
|
--data-dir /home/amnesia/Persistent/your/directory/to/the/blockchain
|
||||||
|
|
||||||
## Debugging
|
## Debugging
|
||||||
|
|
||||||
This section contains general instructions for debugging failed installs or problems encountered with Monero. First ensure you are running the latest version built from the Github repo.
|
This section contains general instructions for debugging failed installs or problems encountered with Wownero. First ensure you are running the latest version built from the Github repo.
|
||||||
|
|
||||||
### Obtaining stack traces and core dumps on Unix systems
|
### Obtaining stack traces and core dumps on Unix systems
|
||||||
|
|
||||||
|
@ -564,7 +437,7 @@ Run the build.
|
||||||
Once it stalls, enter the following command:
|
Once it stalls, enter the following command:
|
||||||
|
|
||||||
```
|
```
|
||||||
gdb /path/to/monerod `pidof monerod`
|
gdb /path/to/wownerod `pidof wownerod`
|
||||||
```
|
```
|
||||||
|
|
||||||
Type `thread apply all bt` within gdb in order to obtain the stack trace
|
Type `thread apply all bt` within gdb in order to obtain the stack trace
|
||||||
|
@ -577,17 +450,17 @@ Enter `echo core | sudo tee /proc/sys/kernel/core_pattern` to stop cores from be
|
||||||
|
|
||||||
Run the build.
|
Run the build.
|
||||||
|
|
||||||
When it terminates with an output along the lines of "Segmentation fault (core dumped)", there should be a core dump file in the same directory as monerod. It may be named just `core`, or `core.xxxx` with numbers appended.
|
When it terminates with an output along the lines of "Segmentation fault (core dumped)", there should be a core dump file in the same directory as wownerod. It may be named just `core`, or `core.xxxx` with numbers appended.
|
||||||
|
|
||||||
You can now analyse this core dump with `gdb` as follows:
|
You can now analyse this core dump with `gdb` as follows:
|
||||||
|
|
||||||
`gdb /path/to/monerod /path/to/dumpfile`
|
`gdb /path/to/wownerod /path/to/dumpfile`
|
||||||
|
|
||||||
Print the stack trace with `bt`
|
Print the stack trace with `bt`
|
||||||
|
|
||||||
* To run monero within gdb:
|
* To run wownero within gdb:
|
||||||
|
|
||||||
Type `gdb /path/to/monerod`
|
Type `gdb /path/to/wownerod`
|
||||||
|
|
||||||
Pass command-line options with `--args` followed by the relevant arguments
|
Pass command-line options with `--args` followed by the relevant arguments
|
||||||
|
|
||||||
|
@ -597,7 +470,7 @@ Type `run` to run monerod
|
||||||
|
|
||||||
We use the tool `valgrind` for this.
|
We use the tool `valgrind` for this.
|
||||||
|
|
||||||
Run with `valgrind /path/to/monerod`. It will be slow.
|
Run with `valgrind /path/to/wownerod`. It will be slow.
|
||||||
|
|
||||||
### LMDB
|
### LMDB
|
||||||
|
|
||||||
|
@ -605,7 +478,7 @@ Instructions for debugging suspected blockchain corruption as per @HYC
|
||||||
|
|
||||||
There is an `mdb_stat` command in the LMDB source that can print statistics about the database but it's not routinely built. This can be built with the following command:
|
There is an `mdb_stat` command in the LMDB source that can print statistics about the database but it's not routinely built. This can be built with the following command:
|
||||||
|
|
||||||
`cd ~/monero/external/db_drivers/liblmdb && make`
|
`cd ~/wownero/external/db_drivers/liblmdb && make`
|
||||||
|
|
||||||
The output of `mdb_stat -ea <path to blockchain dir>` will indicate inconsistencies in the blocks, block_heights and block_info table.
|
The output of `mdb_stat -ea <path to blockchain dir>` will indicate inconsistencies in the blocks, block_heights and block_info table.
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue