Skip to main content

EchoScan package for Python

Project description

echoscan (Python)

中文 | English

中文

可用调用方式

  • EchoScanLiteClient(api_key=...)
  • EchoScanProClient(api_key=...)

方法:

  • Lite: get_report(imprint)
  • Pro: get_report(imprint), get_history(imprint, days=..., from_=..., to=..., recent=...)

History 查询:

仅 Pro 客户端可用(需要 Pro API Key)。

返回值与错误

get_report() 顶层结构:

{
  "analysis": {},
  "lyingCount": 0,
  "projection": {}
}

get_history() 顶层结构:

{
  "imprint": "fp_session_...",
  "range": {},
  "recent": [],
  "summary": {},
  "timeline": []
}

Geo 字段说明(重要)

  • SDK 只透传服务端返回,不在客户端自行做 IP 地理定位。
  • 若服务端仅有 GeoLite2-Country.mmdb,通常只能返回国家级 geo;region/city 可能为空。
  • 若服务端 geo enrichment 不可用,返回会降级(例如仅有 country_hint 或无 geo 字段)。
  • 若服务端 geo enrichment 可用,主要查看 projection.geo.data.geo_public,字段包括:country_codecountry_nameregion_coderegion_namecitytimezone
  • analysis.geo 提供主地理结果聚合字段:final_ipcountry_codecountry_nameregion_coderegion_namecity
  • projection.geo.data 还会带 confidencegeo_low_trust(例如 locale 与 IP 国家冲突)用于前端展示可信度提示。
  • 在存储/调试字段中:geo_source_ip 是主判定 IP(canonical/best-effort),geo_request_client_ip 是请求链路观测 IP(证据);两者可能不同(代理或多跳网络常见)。
  • confidencegeo_low_trust 评价的是主结果(geo_public + geo_source_ip),不是 geo_request_client_ip 的评分。
  • 若你的产品对外展示 MaxMind GeoLite 数据,请附署名:This product includes GeoLite Data created by MaxMind, available from https://www.maxmind.com.

完整字段说明链接:echoscan

示例

import os
from echoscan import EchoScanProClient

pro = EchoScanProClient(api_key=os.environ["ECHOSCAN_PRO_KEY"])
report = pro.get_report("fp_session_123")
history = pro.get_history("fp_session_123", from_="2026-03-01", to="2026-03-18", recent=20)

print(report)
print(history)

English

Usage

  • EchoScanLiteClient(api_key=...)
  • EchoScanProClient(api_key=...)

Methods:

  • Lite: get_report(imprint)
  • Pro: get_report(imprint), get_history(imprint, days=..., from_=..., to=..., recent=...)

History query:

Pro-only (requires a Pro API key).

Response and errors

get_report() top-level shape:

{
  "analysis": {},
  "lyingCount": 0,
  "projection": {}
}

get_history() top-level shape:

{
  "imprint": "fp_session_...",
  "range": {},
  "recent": [],
  "summary": {},
  "timeline": []
}

Geo fields (important)

  • The SDK forwards server responses and does not perform client-side IP geolocation.
  • If the backend only has GeoLite2-Country.mmdb, geo is typically country-level only; region/city may be empty.
  • If backend geo enrichment is unavailable, responses degrade (for example country_hint only, or no geo fields).
  • When geo enrichment is available, the primary display payload is projection.geo.data.geo_public with fields: country_code, country_name, region_code, region_name, city, timezone.
  • analysis.geo provides a flattened primary result: final_ip, country_code, country_name, region_code, region_name, city.
  • projection.geo.data also includes confidence and geo_low_trust (for example locale vs IP-country mismatch) for trust-aware UX.
  • In storage/debug fields, geo_source_ip is the primary canonical (best-effort) lookup IP, while geo_request_client_ip is request-chain observed evidence; they may differ (common with proxies or multi-hop networks).
  • confidence and geo_low_trust rate the primary result (geo_public derived from geo_source_ip), not geo_request_client_ip.
  • If your product displays MaxMind GeoLite data externally, include attribution: This product includes GeoLite Data created by MaxMind, available from https://www.maxmind.com.

Full field reference: echoscan

Example

import os
from echoscan import EchoScanProClient

pro = EchoScanProClient(api_key=os.environ["ECHOSCAN_PRO_KEY"])
report = pro.get_report("fp_session_123")
history = pro.get_history("fp_session_123", from_="2026-03-01", to="2026-03-18", recent=20)

print(report)
print(history)

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

echoscan-0.2.1.tar.gz (5.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

echoscan-0.2.1-py3-none-any.whl (5.5 kB view details)

Uploaded Python 3

File details

Details for the file echoscan-0.2.1.tar.gz.

File metadata

  • Download URL: echoscan-0.2.1.tar.gz
  • Upload date:
  • Size: 5.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for echoscan-0.2.1.tar.gz
Algorithm Hash digest
SHA256 9cc7f1227b845967f9f822a3116272569aea057b08bdb3203f7211414b3ff72d
MD5 be670a1e5b1d8c2b81a67209a99fa465
BLAKE2b-256 6af85e18814918d557041755af9e38cfe19a405e8720c66af6d229a7c1254034

See more details on using hashes here.

Provenance

The following attestation bundles were made for echoscan-0.2.1.tar.gz:

Publisher: publish-python.yml on ozzxzzo/fingerprint-system

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file echoscan-0.2.1-py3-none-any.whl.

File metadata

  • Download URL: echoscan-0.2.1-py3-none-any.whl
  • Upload date:
  • Size: 5.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for echoscan-0.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5f10a01fac43c1ce06c8764e2449843e6a601bfcaf381ac6e85a448570b1fb1c
MD5 7a26865faad7d332c3232e6fe5ecc60a
BLAKE2b-256 56ddb3672d6c7e8df9fa608cd91a3ed386b3b2348eb22ef109d505cd2222d216

See more details on using hashes here.

Provenance

The following attestation bundles were made for echoscan-0.2.1-py3-none-any.whl:

Publisher: publish-python.yml on ozzxzzo/fingerprint-system

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page