Skip to content

renat2985/toncoin_payment_sonoff

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🇷🇺 Русская версия документации здесь

Payment for Your Services via TonCoin

A convenient and fast way to implement paid services using the TonCoin cryptocurrency. The process is simple: You open any crypto wallet, scan the QR code (for example, it can be printed on a sheet with the required amount), transfer the specified amount, and as soon as the payment is received, the relay will activate and turn on your device for the time you set. This could be any device, from a kettle, coffee machine, or light bulb to powering electricity in a room or another location.

You can assemble the device yourself or ask to build it for you. To order a ready-made device, contact me via Telegram, Skype, Discord.

We have a similar project with a screen, check it out.

IMAGE ALT TEXT HERE

Key Features:

  1. Device Connection:

    • When first powered on, if the device can’t find the router or if you press the button on the ESP itself, it will create an access point named “TonCoin payments.”

    • Connect to this access point (no password needed) and open a browser, then enter http://192.168.4.1. Usually, after connecting to Wi-Fi, the Captive portal will automatically open and redirect you to the desired page.

    • Click "Configure WiFi" to proceed with the setup.

  2. Device Configuration:

    • Router and Password: Enter your Wi-Fi connection details.

    • Device Name: Specify a device name, e.g., "Buy coffee.". You can optionally add GPIO pins in this field. Example: Device_name:12,0,13, where Device_name is the name of the device, and 12,0,13 are the corresponding pin numbers for the relay, erase button, and LED (RELAY_PIN,BUTTON_PIN,LED_PIN).

    • Your Toncoin Wallet: Enter your wallet address to receive payments.

    • CoinMarketCap API: Is a service that allows you to get the current TonCoin price in fiat currency. For testing, you can use the default API, but if you plan to use the device on a regular basis, it is highly recommended to register on the CoinMarketCap website and get your own API. The free version allows up to 10,000 requests per month for price data. This is more than enough for 10 devices, but if our API is used by more devices, not everyone will be able to receive the actual price, and as a result, payments may fail.

    • Currency: Select the currency in which you want to receive payments (EUR, USD, RUB, BYN, BGN, GBP, etc.). This is necessary for automatic conversion to TonCoin based on the current exchange rate, updated hourly through coinmarketcap.com.

    • Service Currency Price: Specify the price in your selected currency that the customer should pay.

    • Payment Tolerance: In this field, specify the acceptable price deviation. Since the Ton price constantly fluctuates, you need to indicate a deviation range (as a single number) that you are willing to accept for payment.

    • Relay Work Time: Specify how long the relay should be activated in seconds. This can range from one second (for simulating a button press) to several minutes or hours.

  3. Reset Settings: To reset the device to its factory settings, follow these steps:

    1. Press the Sonoff button on the device.
    2. The device will reboot.
    3. After rebooting, a Wi-Fi access point named Crypto Sonoff will appear. The device is now ready for reconfiguration.

Please note, if the blue LED starts flashing, it is a signal that something went wrong. You might have entered your Toncoin wallet incorrectly. It could also indicate an incorrect CoinMarketCap API. If you are using the standard API (without changes), it may have exceeded the limit, and you might need to create your own CoinMarketCap API. The WiFi signal has disappeared. Another reason could be that the trial period of the software has expired.

Instructions for Self-Assembly:

For self-assembly you will need any of these devices: SONOFF OLD, SONOFF RF R2, SONOFF BASICR2, SONOFF Mini R1, SONOFF Mini R2, SONOFF S26, SONOFF S26R2.

  • A programmer, such as USB to TTL / PL230

  • A soldering iron and wires

We have added support for SONOFF devices based on the ESP32 (Dual R3, Mini R4, Basic R4, POW, THR316), but most of them have not yet undergone full testing. If you encounter any issues, please contact us, and we will do our best to assist you. On devices with ESP8266 (Mini R1, Mini R2, S26, S26R2), all GPIO (pins) remained unchanged, and no configuration is required. However, with ESP32, many GPIO pins have changed depending on the device model. We decided not to release separate firmware for each model as it would make maintenance more complicated. Therefore, you will need to manually configure the GPIO for your device. To do this, after the device name, add a colon (:) followed by the GPIO for the relay, then the GPIO for the reset button, and finally the GPIO for the LED. Below, you will find a list of devices and their corresponding GPIO settings. Simply copy the necessary configurations, and the device should work.

Dual R3:27,0,13
Mini R4:26,0,19
Mini R4M:4,9,19
Basic R4:4,9,6
POW 16a:13,0,18
POW 20a:4,0,18
POW Ring:21,0,13
THR316:21,0,15

Good luck! If you have any questions, don't hesitate to reach out.

Web installer (recommended)

For Advanced Users: Firmware Instructions via Programmer

  -  Module: Generic ESP8266 Module
  -  Flash Size: 1M
  -  CPU Frequency: 80Mhz
  -  Flash Mode: DOUT
  -  Flash Frequency: 40Mhz

  { "path": "./build/esp8266.esp8266.generic/toncoin_payment_sonoff.ino.bin", "offset": 0 }
  { "path": "./build/esp32.esp32.esp32*/toncoin_payment_sonoff.ino.bootloader.bin", "offset": 0 },
  { "path": "./build/esp32.esp32.esp32*/toncoin_payment_sonoff.ino.partitions.bin", "offset": 32768 },
  { "path": "./build/esp32.esp32.esp32*/boot_app0.bin", "offset": 57344 },
  { "path": "./build/esp32.esp32.esp32*/toncoin_payment_sonoff.ino.bin", "offset": 65536 }

ESP8266 NodeMCU Flasher

https://github.com/nodemcu/nodemcu-flasher Download Release: Win32 or Win64.

🔋 Donation

If you like this project, you can buy me a cup of coffee ☕