Skip to content

Latest commit

 

History

History
689 lines (432 loc) · 21.5 KB

readme.md

File metadata and controls

689 lines (432 loc) · 21.5 KB

The VKAX Whale Alert script is designed to monitor and generate a feed for large-value transactions on the VKAX blockchain. This script performs several key tasks:

Key Features:

  1. Fetch Latest Blocks:

    • It checks recent blocks on the VKAX blockchain to identify transactions. The script fetches block data using RPC calls to a VKAX node, looking at a specified number of recent blocks.
  2. Transaction Filtering:

    • The script filters transactions based on their value. Specifically, it looks for transactions where the amount exceeds a defined threshold (e.g., 1,000,000 VKAX). This helps identify "whale" transactions, which are typically large transactions that could indicate significant movements in the network.
  3. RSS Feed Generation:

    • Once it finds these large transactions, it formats them into an RSS feed. The feed contains details about each transaction, such as:
      • The transaction ID (TXID).
      • The transaction amount.
      • The timestamp of when the transaction occurred.
      • A link to the explorer for more details.
  4. Data Formatting for Alerts:

    • The output RSS feed is structured to provide concise data that can be easily consumed by users or integrated into other platforms. It includes a title, description, and a link to explore each transaction further.
  5. Automated Updates:

    • The script can be run on a regular basis (e.g., every few minutes or hours) to continuously monitor the blockchain for large transactions, ensuring the feed is always up to date.

Typical Use Cases:

  • Monitoring Big Moves: Track large transactions (whale movements) to identify significant shifts in the VKAX blockchain.
  • Automated Alerts: Users can subscribe to the RSS feed to get real-time notifications of large transactions, helping them stay informed.
  • Blockchain Analytics: Researchers, investors, or analysts interested in blockchain data can use the feed to track unusual or noteworthy transactions in the VKAX ecosystem.

In summary, the VKAX Whale Alert script helps automate the process of identifying and tracking large transactions on the VKAX blockchain, then outputs them in an easy-to-follow RSS format for easy monitoring or integration.

Here’s a detailed step-by-step guide to build VKAX from source on Ubuntu 22.04 and then install the script provided. This will help you set up everything from compiling VKAX to running the Python script.

Step 1: Install Dependencies

First, you need to install some essential dependencies for building VKAX on Ubuntu.

  1. Update your system and install necessary dependencies:

    Open a terminal and run the following commands:

    sudo apt update
    sudo apt upgrade -y
    sudo apt install -y build-essential libtool autotools-dev automake pkg-config libssl-dev libboost-all-dev libevent-dev bsdmainutils libzmq3-dev libdb-dev libdb++-dev libminiupnpc-dev libsodium-dev libnatpmp-dev libprotobuf-dev protobuf-compiler libqt5gui5 libqt5core5a libqt5dbus5 libqt5widgets5 qtbase5-dev qtchooser qtbase5-dev-tools libqt5webkit5-dev libprotobuf-dev libunbound-dev
  2. Install additional tools for Git and networking:

    sudo apt install -y git curl

Step 2: Clone the VKAX Repository

  1. Clone the VKAX source code from GitHub:

    Run the following command to clone the VKAX repository:

    git clone https://github.com/vkaxcore/vkax.git
  2. Navigate to the VKAX directory:

    cd vkax

Step 3: Build VKAX

  1. Run autogen to prepare the build system:

    ./autogen.sh
  2. Configure the build:

    Set up the build configuration by running the following command:

    ./configure
  3. Compile the VKAX code:

    Once configured, run make to compile VKAX:

    make
  4. Install VKAX:

    After building, install VKAX by running:

    sudo make install

Step 4: Set Up VKAX Core Daemon

  1. Create a directory for your VKAX data:

    mkdir ~/.vkaxcore
  2. Create a configuration file for VKAX:

    Create the vkax.conf file in the ~/.vkaxcore/ directory:

    nano ~/.vkaxcore/vkax.conf

    Add the following configuration (you can adjust the settings as needed):

    rpcuser=daemonrpcuser
    rpcpassword=daemonrpcpassword
    rpcport=11111
    rpcallowip=127.0.0.1
    daemon=1
    server=1
    

    Save the file by pressing Ctrl + O, then exit by pressing Ctrl + X.

  3. Start VKAX Daemon:

    Start the VKAX daemon with the following command:

    vkaxd

    This will run the VKAX daemon in the background and begin syncing the blockchain.

  4. Verify the VKAX Daemon is Running:

    To check if VKAX is running correctly, use:

    vkax-cli getinfo

    This should show information about your VKAX node.

Step 5: Install Python and Script Dependencies

  1. Install Python 3 and pip:

    Run the following command to install Python and pip:

    sudo apt install -y python3 python3-pip
  2. Install Requests and Other Python Libraries:

    Install the necessary Python libraries for your script:

    pip3 install requests

Certainly! Here is the updated Step 6 with instructions to download the script directly from GitHub instead of manually creating it:


Step 6: Set Up the Python Script

  1. Download the Python Script:

    Instead of manually copying the script, you can download it directly from the GitHub repository.

    Run the following command to download the vkax_rss_feed.py script:

    curl -o /home/ubuntu/vkax_rss_feed.py https://raw.githubusercontent.com/realsetvin/vkax-whale-alert/main/vkax_rss_feed.py

    This will download the script and save it as vkax_rss_feed.py in the /home/ubuntu/ directory.

  2. Install Requests and Other Python Libraries:

    If you haven’t already, install the necessary Python libraries for the script. In particular, you’ll need the requests module, which you can install with:

    pip3 install requests
  3. Run the Python Script:

    Now that the script is downloaded, you can run it with:

    python3 /home/ubuntu/vkax_rss_feed.py

    The script will start fetching transactions from the VKAX blockchain and create an RSS feed with transactions over the 1,000,000 VKAX threshold.


Step 7: Automate the Script (Optional)

To run the script automatically on a regular basis, you can use cron jobs.

  1. Edit crontab:

    Open the crontab editor:

    crontab -e
  2. Add a cron job to run the script every hour (or adjust as needed):

    Add the following line to run the script every hour:

    0 * * * * /usr/bin/python3 /home/ubuntu/create_rss_feed.py

    This will execute the script every hour. Save and close the crontab (Ctrl + O, then Ctrl + X).

Step 8: Monitoring and Debugging

  1. Check Logs:

    To see the output of the Python script and debug any issues, check the generated log files or output.

    For example, you can check if the script is producing any errors in the system log:

    tail -f /var/log/syslog
  2. Verify VKAX Daemon:

    You can monitor the progress of your VKAX node by checking its status:

    vkax-cli getblockcount

    To broadcast the RSS feed from your Ubuntu 22 AMD VPS, you will need to set up a web server to serve the RSS file. This guide will show you how to set up Nginx (a popular and efficient web server) to serve your RSS feed file. After that, you will be able to broadcast the RSS feed on your server, accessible via a URL.

Step-by-Step Instructions to Broadcast RSS Feed on Ubuntu 22 VPS


Step 1: Update Your VPS

Before setting up the web server, make sure your system is up-to-date.

  1. Log in to your VPS via SSH:

    ssh ubuntu@your-vps-ip
  2. Update the package list and upgrade your system:

    sudo apt update && sudo apt upgrade -y

Step 2: Install Nginx

Nginx is a powerful web server that will serve your RSS feed.

  1. Install Nginx:

    sudo apt install nginx -y
  2. After installation, start and enable Nginx to run automatically on boot:

    sudo systemctl start nginx
    sudo systemctl enable nginx
  3. Check if Nginx is running by opening your server's IP address in a web browser:

    http://your-vps-ip

    You should see the default Nginx landing page.


Step 3: Create a Directory for the RSS Feed

Now, create a directory to store the RSS feed file.

  1. Create a directory in /var/www/html (the default web root for Nginx):

    sudo mkdir /var/www/html/rss
  2. If you haven't already, copy or download the RSS feed file into this directory. For example, if your RSS feed file is vkax_high_value_transactions.xml, run:

    sudo cp /home/ubuntu/vkax_high_value_transactions.xml /var/www/html/rss/
  3. Set the appropriate permissions to make sure Nginx can access the file:

    sudo chown -R www-data:www-data /var/www/html/rss
    sudo chmod -R 755 /var/www/html/rss

Step 4: Configure Nginx to Serve the RSS Feed

Now, configure Nginx to serve your RSS feed file from the server.

  1. Open the Nginx configuration file in a text editor:

    sudo nano /etc/nginx/sites-available/default
  2. Modify the configuration to add a new location block to serve your RSS feed:

    Inside the server block, add this configuration to serve the RSS feed:

    server {
        listen 80 default_server;
        listen [::]:80 default_server;
    
        root /var/www/html;
        index index.html index.htm index.nginx-debian.html;
    
        server_name _;
    
        location /rss {
            alias /var/www/html/rss;
            autoindex on;
        }
    }

    In this configuration:

    • location /rss tells Nginx to look for files under /var/www/html/rss when accessing http://your-vps-ip/rss.
    • autoindex on will allow you to list the contents of the directory if needed.
  3. Save and exit the file by pressing CTRL + X, then Y, and Enter.


Step 5: Test and Restart Nginx

Before restarting Nginx, test the configuration for any errors:

  1. Test the Nginx configuration:

    sudo nginx -t

    If everything is OK, you will see a message like: syntax is okay and test is successful.

  2. Restart Nginx to apply the changes:

    sudo systemctl restart nginx

Step 6: Access the RSS Feed

Now that Nginx is configured to serve your RSS feed, you can access it via your VPS's IP address.

  1. Open a web browser and visit:

    http://your-vps-ip/rss/vkax_high_value_transactions.xml

    This will display the RSS feed in XML format.

    If you want a nicely formatted display, you may need to use an RSS reader (as discussed earlier).


Step 7: Set Up a Domain Name (Optional)

If you'd like to access your RSS feed via a domain name rather than just the VPS IP, you can set up a domain. Here’s how to do it:

  1. Purchase a domain from a provider (e.g., Namecheap, GoDaddy, etc.).

  2. Point your domain's DNS to the IP address of your VPS (use the A record in your domain’s DNS settings).

  3. After configuring your domain, update Nginx to use the domain:

    Open the Nginx configuration file again:

    sudo nano /etc/nginx/sites-available/default

    Change the server_name to your domain name:

    server_name your-domain.com;
  4. Test and restart Nginx:

    sudo nginx -t
    sudo systemctl restart nginx
  5. You should now be able to access the feed via http://your-domain.com/rss/vkax_high_value_transactions.xml.


Step 8: Automate the RSS Feed Update (Optional)

If the RSS feed updates regularly, you can automate the process of uploading the new feed. Here’s how you can use a cron job to automate this:

  1. Edit the crontab for the ubuntu user:

    crontab -e
  2. Add a cron job that downloads the new RSS feed every hour (or based on your preferred schedule). For example:

    0 * * * * curl -o /var/www/html/rss/vkax_high_value_transactions.xml https://your-script-url.com/rss_feed.xml

    This cron job will fetch the latest RSS feed every hour and replace the old file.

  3. Save and exit the crontab.


Step 9: Secure Your Server (Optional)

While serving the RSS feed is relatively low-risk, securing your server with SSL (HTTPS) is always a good idea.

  1. Install Certbot (to get a free SSL certificate):

    sudo apt install certbot python3-certbot-nginx -y
  2. Obtain an SSL certificate for your domain:

    sudo certbot --nginx -d your-domain.com

    Follow the prompts to complete the SSL setup.

  3. Once SSL is set up, you can access your RSS feed securely via https://your-domain.com/rss/vkax_high_value_transactions.xml.


Etcetera

To read the RSS feed that the Python script generates, you can use several methods depending on your preferences and available tools. Here are the most common ways to read an RSS feed:

1. Use a Web Browser

Most modern web browsers (like Chrome, Firefox, or Edge) can open and display RSS feeds directly.

  • Open the RSS feed in your browser:

    • Navigate to the location where the RSS feed file is saved (e.g., vkax_high_value_transactions.xml).
    • If the file is hosted on a web server (like your own server), you can open the URL to the RSS feed (e.g., https://your-site-url.com/vkax_high_value_transactions.xml).
    • The browser will display the RSS feed in XML format. It won't be nicely formatted but you can still view the data.

    Note: Some browsers, like Firefox, may offer a basic visual interface for reading RSS feeds. For a better experience, you might want to use an RSS reader (described below).

2. Use an RSS Reader

There are many dedicated RSS readers available that will fetch, display, and update your RSS feeds automatically. These can help you read RSS feeds in a more user-friendly format.

  • Popular RSS readers include:

    • Feedly: A cloud-based RSS reader, accessible via browser and mobile apps. You can simply add the URL of your RSS feed to start reading.
    • RSSOwl: A free, desktop-based RSS reader that works on Windows, Linux, and macOS.
    • QuiteRSS: Another free desktop RSS reader with a simple interface and useful features.

    To use any of these:

    1. Add the feed URL: If the RSS feed is hosted online, use the URL where the feed is located (e.g., https://your-site-url.com/vkax_high_value_transactions.xml).
    2. View the feed: The RSS reader will show the feed in an organized way, typically with titles, timestamps, and links to each transaction.

3. Use Command Line Tools

If you are on a Linux-based system and prefer the command line, there are tools you can use to fetch and display RSS feed data.

  • Using w3m (a text-based browser):

    1. Install w3m if it's not already installed:

      sudo apt install w3m
    2. Use w3m to open the RSS feed in the terminal:

      w3m /path/to/vkax_high_value_transactions.xml

    This will render the XML file in a text-based browser.

  • Using rss2email (a command-line RSS reader):

    1. Install rss2email:

      sudo apt install rss2email
    2. Fetch the feed directly from the file or URL:

      rss2email /path/to/vkax_high_value_transactions.xml

    Alternatively, if you have a URL for the feed:

    ```bash
    rss2email https://your-site-url.com/vkax_high_value_transactions.xml
    ```
    

4. Programmatically Read the RSS Feed

If you'd like to programmatically access and process the RSS feed (for example, to display it in a web application or integrate with another service), you can parse the XML file using a programming language like Python.

Here’s an example of how to read an RSS feed in Python:

import feedparser

# URL to the RSS feed
rss_feed_url = "https://your-site-url.com/vkax_high_value_transactions.xml"

# Parse the RSS feed
feed = feedparser.parse(rss_feed_url)

# Display each entry in the feed
for entry in feed.entries:
    print(f"Title: {entry.title}")
    print(f"Link: {entry.link}")
    print(f"Description: {entry.description}")
    print(f"Published: {entry.published}")
    print("-" * 40)

5. Use an RSS to Email Service

If you prefer to receive the RSS feed updates directly in your email, you can use an online service to convert the RSS feed into email notifications.

  • Feedly and other RSS services often provide email notifications.
  • Mailbrew: A service that allows you to receive RSS updates as daily email summaries.

6. Automate RSS Feed Checks (Optional)

If you want to automate checking the RSS feed, you can set up a cron job on your server or computer to periodically fetch the feed and run the necessary logic.

For example, set up a cron job that runs every hour to check for new transactions in the RSS feed.

To automate your RSS feed creation and copying process every 4 hours, you can use cron, which is a time-based job scheduler in Unix-like operating systems. This will allow you to run your Python script and the copy command at regular intervals.

Steps to Automate the Process with Cron

  1. Open the Crontab Configuration:

    Edit the cron jobs for your user by running the following command:

    crontab -e

    This will open the crontab file in your default text editor.

  2. Add a New Cron Job:

    To run your Python script and copy the file every 4 hours, add the following line at the end of the crontab file:

    0 */4 * * * python3 /home/vkaxcoin/create_rss_feed.py && sudo cp /home/vkaxcoin/vkax_high_value_transactions.xml /var/www/html/rss/

    Here's the breakdown of the cron job syntax:

    • 0 */4 * * *:

      • 0 = At minute 0 (start of the hour).
      • */4 = Every 4 hours.
      • * * = Every day of the month, every month, and every weekday.
    • python3 /home/vkaxcoin/create_rss_feed.py = This runs your Python script to create the RSS feed.

    • && = This ensures that the second command only runs if the first one is successful.

    • sudo cp /home/vkaxcoin/vkax_high_value_transactions.xml /var/www/html/rss/ = This copies the generated XML file to the web server's directory.

  3. Ensure Proper Permissions:

    Since you're using sudo to copy the file, make sure that the user running the cron job (in this case, your logged-in user) has sudo privileges to execute the cp command without requiring a password.

    You can configure this in the sudoers file:

    • Run sudo visudo to edit the sudoers file.

    • Add the following line at the end of the file:

      vkaxcoin ALL=(ALL) NOPASSWD: /bin/cp /home/vkaxcoin/vkax_high_value_transactions.xml /var/www/html/rss/

      This allows the user vkaxcoin to run the cp command with sudo without needing to enter a password.

  4. Save and Exit the Crontab File:

    • After adding the line, save and exit the editor:
      • If you're using nano, press CTRL+X, then Y to confirm saving, and Enter to exit.
  5. Verify Cron Job:

    You can check if your cron job is added successfully by running:

    crontab -l

    This will list all your active cron jobs.

  6. Check the Cron Job Logs:

    Cron jobs typically log their output in the system log. You can check if your job runs correctly by looking at the cron log:

    grep CRON /var/log/syslog

    This will show any output from the cron jobs, including any potential errors.

Summary

The cron job you’ve added will:

  • Run your script (/home/vkaxcoin/create_rss_feed.py) every 4 hours.
  • After the script runs successfully, it will copy the RSS feed file (vkax_high_value_transactions.xml) to the Nginx web directory (/var/www/html/rss/).

Conclusion

Now your RSS feed is live and being broadcast from your Ubuntu VPS via Nginx. You can access the feed via your VPS IP or a domain name, and if you’ve set up SSL, your feed will be served securely over HTTPS.


Choose the method that best fits your needs. If you want automatic updates and notifications, an RSS reader or email service is recommended. If you prefer reading it directly from your system, the command line or browser methods work well.

MIT License

Copyright (c) [2024] Setvin

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.