Skip to content

Latest commit

 

History

History
307 lines (230 loc) · 11.1 KB

README.md

File metadata and controls

307 lines (230 loc) · 11.1 KB

EthNodeMap

EthNodeMap, Ethereum ağındaki düğüm verilerini harita üzerinde ve graf olarak görselleştirmek için geliştirilmiş bir projedir.

Link

ÖZELLİKLER

  • Düğüm Filtreleme ve Görüntüleme: Kullanıcılar, harita üzerinde görüntüledikleri Ethereum düğümlerini ülke, işletim sistemi, internet servis sağlayıcı ve istemci türüne göre filtreleyebilirler. Ayrıca harita üzerinde üzerine tıkladıkları düğümlerin verilerini haritanın altında görüntüleyebilirler.
  • İstatistik Tabloları: Haritanın sağında bulunan istatistik tablosunda çeşitli özelliklere göre düğümlerin dağılımını görebilirler.
  • Dinamik Veriler: Haritanın solunda bulunan alanda yeni eklenen düğümleri ve bazı bilgileri (örn. toplam düğüm sayısı) görüntüleyebilirler.
  • Graf Görünümü: Graf görünümü için ilgili butona basarak, seçilen ülke veya ülkelerin ağaç graf yapısını D3.js sayesinde görselleştirebilirler.

KURULUM

Gereksinimler

  • Python 3.7+
  • HTML, CSS ve JavaScript
  • Flask: API'yi oluşturmak için.
  • Flask-CORS: API'ye çapraz kaynak isteği (CORS) desteği eklemek için.
  • Neo4j: Düğümleri depolayıp, ilişkiler kurmak için.
  • BeautifulSoup4: Etherscan sitesinden düğüm verilerini çekmek için.
  • Requests: HTTP istekleri yapmak için.
  • D3.js: Grafı görselleştirmek için.
  • Leaflet.js: Harita üzerinde düğümlerin konumunu göstermek için.
  • Nginx (Server): Sunucumu web sunucusu olarak kullanmak için.

Yükleme (Sunucu)

  1. Python bağımlılıklarını yükleyin:
pip install flask flask-cors neo4j beautifulsoup4 requests
  1. Neo4j veritabanını çalıştırın ve aşağıdaki gibi yapılandırın:
sudo systemctl start neo4j

Ortam Değişkenleri

  • API_KEY: ipgeolocation'dan gerekli verileri almak için API anahtarı.
  • NEO4J_URI: Neo4j veritabanı URI'si (örneğin, bolt://localhost:7687).
  • NEO4J_USERNAME: Neo4j kullanıcı adı.
  • NEO4J_PASSWORD: Neo4j parolası.

BACKEND

API Uç Noktaları

  • /nodes: Tüm düğümleri listele (Özellikleri ile birlikte).
  • /nodes/details/<node_id>: Belirli bir düğümün detaylarını al.
  • /nodes/count: Toplam düğüm sayısını al.
  • /nodes/ids: Tüm benzersiz düğüm id'lerini listele.
  • /nodes/os-types: Tüm benzersiz işletim sistemi türlerini listele.
  • /nodes/client-types: Tüm benzersiz istemci türlerini listele.
  • /nodes/countries: Tüm benzersiz ülkeleri listele.
  • /nodes/isps: Tüm benzersiz internet servis sağlayıcılarını listele.
  • /nodes/latest: En son eklenen düğümleri listele.
  • /nodes/country/<country_name>: Belirli bir ülkedeki düğüm ilişkilerini al.
  • /statistics/<data_type>: Belirtilen veri türü için istatistikleri al (os, client, isp, country).

Çalıştırma

Uygulamayı başlatmak için aşağıdaki komutu kullanın:

python3 api.py

Local API, http://127.0.0.1:5001 adresinde çalışacaktır. Server API, http://0.0.0.0:5001 adresinde çalışacaktır.

Veri Toplama ve Güncelleme

Düğüm Verilerini Toplama

fetch-nodes.py dosyasını çalıştırarak Ethereum düğümlerini toplanır ve Neo4j veritabanına eklenir:

python3 fetch-nodes.py

Düğüm Uptime Bilgisini Elde Etme

fetch-status.py dosyasını çalıştırarak düğüm durumlarını kontrol edilir ve güncellenir:

python3 fetch-status.py

İlişkileri İçe Aktarma

Düğüm ilişkilerini içe aktarmak için import-relationships.py dosyasını çalıştırın (fetch-status.py ve fetch-nodes.py dosyalarının içinde otomatik olarak çalışıyor):

python3 import-relationships.py

FRONTEND

Harita Görünümü

index.html dosyası, düğümleri Leaflet.js kullanarak dünya haritası üzerinde görüntülemek için kullanılır.

index1

index2

Ağaç Graf Görünümü

graph.html dosyası, düğümleri ve ilişkilerini D3.js kullanarak grafiksel olarak görüntülemek için kullanılır.

graph

DATABASE

neo4j

neo4j2

BeautifulSoup4 kullanılarak Etherscan sitesinden çekilen örnek bir düğüm yapısı:

client: Nethermind
host: 89.58.47.72
id: ec68c46aa0874badc8f9c02e68af8bae3a3f94027124f27c9bca02f7bf83ee700083602b91cf5781985bcb48d5ce7e2af144fcaa340f4adc8ae82117d651a393
os: linux-arm64
port: 30303

fetch-nodes.py betiği kullanılarak IPGeolocation API enpointine yollanan 'host' bilgisinin geri döndürdüğü bilgiler ile birlikte veri tabanına eklenen örnek bir düğüm yapısı:

<elementId>: 4:574bd6e8-3b31-4b0f-ae15-03f2f836b8ff:658
<id>: 658
client: Nethermind
country_name: Germany
created_at: 2024-05-25T20:35:15.918528
host: 89.58.47.72
id: ec68c46aa0874badc8f9c02e68af8bae3a3f94027124f27c9bca02f7bf83ee700083602b91cf5781985bcb48d5ce7e2af144fcaa340f4adc8ae82117d651a393
isp: netcup GmbH
latitude: 49.45434
longitude: 11.07349
os: linux-arm64
port: 30303
status: 1

World kök düğümünü oluşturma:

CREATE (root:Root {name: 'Dünya'})

Düğümlerden ülke bilgilerini çekip kök düğüme bağlı ülke düğümlerini yaratma::

MATCH (n) 
WITH DISTINCT n.country_name AS country_name 
CREATE (c:Country {name: country_name}) 
WITH c
MATCH (root:Root {name: 'Dünya'}) 
MERGE (root)-[:HAS_COUNTRY]->(c)

Her ülkeye bağlı ISP düğümlerini yaratma:

MATCH (c:Country)
UNWIND ['Contabo', 'AWS', 'Azure', 'Google', 'Alibaba', 'Oracle', 'IBM', 'Tencent', 'OVHCloud', 'DigitalOcean', 'Linode', 'Salesforce', 'Huawei', 'Dell', 'Vultr', 'Heroku', 'Hetzner', 'Scaleway', 'Upcloud', 'Kamatera', "Diğer İSS'ler"] AS isp_name
CREATE (isp:ISP {name: isp_name})
MERGE (c)-[:HAS_ISP]->(isp)

Her ISP'ye bağlı OS düğümlerini yaratma:

MATCH (isp:ISP)
UNWIND ['Linux', 'Windows', 'MacOS', 'Android', 'FreeBSD', 'Darwin', "Diğer İS'ler"] AS os_name
CREATE (os:OS {name: os_name})
MERGE (isp)-[:HAS_OS]->(os)

Her OS'a bağlı client düğümlerini yaratma:

MATCH (os:OS)
UNWIND ['Geth', 'Nethermind', 'Besu', 'Erigon', 'Reth', 'EthereumJS', 'Diğer İstemciler'] AS client_name
CREATE (client:Client {name: client_name})
MERGE (os)-[:HAS_CLIENT]->(client)

Düğümleri Bağlama:

MATCH (n:Node)
WITH n,
    COALESCE(n.country_name, 'Diğer Ülkeler') AS country_name,
    CASE
        WHEN toLower(n.isp) CONTAINS 'contabo' THEN 'Contabo'
        WHEN toLower(n.isp) CONTAINS 'aws' OR toLower(n.isp) CONTAINS 'amazon' THEN 'AWS'
        WHEN toLower(n.isp) CONTAINS 'azure' OR toLower(n.isp) CONTAINS 'microsoft' THEN 'Azure'
        WHEN toLower(n.isp) CONTAINS 'google' THEN 'Google'
        WHEN toLower(n.isp) CONTAINS 'alibaba' THEN 'Alibaba'
        WHEN toLower(n.isp) CONTAINS 'oracle' THEN 'Oracle'
        WHEN toLower(n.isp) CONTAINS 'ibm' THEN 'IBM'
        WHEN toLower(n.isp) CONTAINS 'tencent' THEN 'Tencent'
        WHEN toLower(n.isp) CONTAINS 'ovh' THEN 'OVHCloud'
        WHEN toLower(n.isp) CONTAINS 'digitalocean' THEN 'DigitalOcean'
        WHEN toLower(n.isp) CONTAINS 'linode' OR toLower(n.isp) CONTAINS 'akamai' THEN 'Linode'
        WHEN toLower(n.isp) CONTAINS 'akamai' THEN 'Linode'
        WHEN toLower(n.isp) CONTAINS 'salesforce' THEN 'Salesforce'
        WHEN toLower(n.isp) CONTAINS 'huawei' AND toLower(n.isp) CONTAINS 'cloud' THEN 'Huawei'
        WHEN toLower(n.isp) CONTAINS 'dell' AND toLower(n.isp) CONTAINS 'cloud' THEN 'Dell'
        WHEN toLower(n.isp) CONTAINS 'vultr' THEN 'Vultr'
        WHEN toLower(n.isp) CONTAINS 'heroku' THEN 'Heroku'
        WHEN toLower(n.isp) CONTAINS 'hetzner' THEN 'Hetzner'
        WHEN toLower(n.isp) CONTAINS 'scaleway' THEN 'Scaleway'
        WHEN toLower(n.isp) CONTAINS 'upcloud' THEN 'Upcloud'
        WHEN toLower(n.isp) CONTAINS 'kamatera' THEN 'Kamatera'
        ELSE "Diğer İSS'ler"
    END AS isp_name,
    CASE
        WHEN toLower(n.os) CONTAINS 'linux' THEN 'Linux'
        WHEN toLower(n.os) CONTAINS 'windows' THEN 'Windows'
        WHEN toLower(n.os) CONTAINS 'macos' THEN 'MacOS'
        WHEN toLower(n.os) CONTAINS 'android' THEN 'Android'
        WHEN toLower(n.os) CONTAINS 'freebsd' THEN 'FreeBSD'
        WHEN toLower(n.os) CONTAINS 'darwin' THEN 'Darwin'
        ELSE "Diğer İS'ler"
    END AS os_name,
    CASE
        WHEN toLower(n.client) CONTAINS 'geth' THEN 'Geth'
        WHEN toLower(n.client) CONTAINS 'nethermind' THEN 'Nethermind'
        WHEN toLower(n.client) CONTAINS 'besu' THEN 'Besu'
        WHEN toLower(n.client) CONTAINS 'erigon' THEN 'Erigon'
        WHEN toLower(n.client) CONTAINS 'reth' THEN 'Reth'
        WHEN toLower(n.client) CONTAINS 'ethereumjs' THEN 'EthereumJS'
        ELSE 'Diğer İstemciler'
    END AS client_name
MATCH (root:Root {name: 'Dünya'})
MERGE (country:Country {name: country_name})<-[:HAS_COUNTRY]-(root)
MERGE (country)-[:HAS_ISP]->(isp:ISP {name: isp_name})
MERGE (isp)-[:HAS_OS]->(os:OS {name: os_name})
MERGE (os)-[:HAS_CLIENT]->(client:Client {name: client_name})
MERGE (client)-[:HAS_NODE]->(n)

Belirli Bir Ülkeye Bağlı Düğümleri Görselleştirme:

MATCH (root:Root)-[:HAS_COUNTRY]->(c:Country)-[:HAS_ISP]->(isp:ISP)-[:HAS_OS]->(os:OS)-[:HAS_CLIENT]->(client:Client)-[:HAS_NODE]->(n:Node {country_name : "Croatia"})
RETURN root, c, isp, os, client, n

Tüm İlişkileri Silme:

MATCH ()-[r]->()
DELETE r

Kök, Ülke, İSS, İS ve İstemci Düğümlerini Silme:

MATCH (n:Root) DELETE n
MATCH (n:Country) DELETE n
MATCH (n:ISP) DELETE n
MATCH (n:OS) DELETE n
MATCH (n:Client) DELETE n

KAYNAKÇA

Programlama Dilleri

Kütüphaneler

API ve Diğer Kaynaklar