Python SDK for the Quake API (360.net)
Project description
Quake API Python SDK
A Python client for interacting with the Quake API (quake.360.net).
Features
- Easy-to-use client for all Quake API v3 endpoints.
- Handles API authentication and common request parameters.
- Custom exceptions for specific API errors.
- Session management for efficient requests.
Installation
pip install quake-sdk==0.1.0
(Note: This package will be available on PyPI once published.)
You can also install directly from the repository (once it's public):
pip install git+https://github.com/Explorer1092/quake_sdk.git#subdirectory=quake_sdk_py
Prerequisites
- Python 3.11+
- A Quake API Key. You can obtain one from your Quake User Center (replace with actual link if different).
Usage
The SDK now uses Pydantic models for request parameters and response data, providing type hinting and validation.
from quake_sdk import (
QuakeClient,
QuakeAPIException,
RealtimeSearchQuery,
ScrollSearchQuery,
AggregationQuery,
FaviconSimilarityQuery
)
# Replace 'YOUR_API_KEY' with your actual Quake API key
api_key = "YOUR_API_KEY"
try:
# Using the client as a context manager ensures the session is closed
with QuakeClient(api_key=api_key) as client:
# Get User Info
user_info_response = client.get_user_info()
if user_info_response.data:
print("User Info (Username):", user_info_response.data.user.username)
print("User Credit:", user_info_response.data.credit)
# Search Service Data
service_query_params = RealtimeSearchQuery(
query="port: 80 AND country_cn: \"中国\"",
size=2,
latest=True
)
service_search_response = client.search_service_data(query_params=service_query_params)
print(f"\nService Search Results (first {service_query_params.size} for '{service_query_params.query}'):")
if service_search_response.data:
for item in service_search_response.data:
title = item.service.http.title if item.service and item.service.http else "N/A"
print(f"- IP: {item.ip}, Port: {item.port}, Title: {title}")
if service_search_response.meta and service_search_response.meta.pagination:
print(f"Total service results: {service_search_response.meta.pagination.total}")
# Scroll Service Data (Deep Pagination)
print("\nScrolling service data...")
scroll_query_params_page1 = ScrollSearchQuery(
query="app:\"Apache Tomcat\"",
size=1
)
page1_response = client.scroll_service_data(query_params=scroll_query_params_page1)
if page1_response.data:
print("Page 1 Data Count:", len(page1_response.data))
pagination_id = page1_response.meta.pagination_id if page1_response.meta else None
if pagination_id:
scroll_query_params_page2 = ScrollSearchQuery(
query="app:\"Apache Tomcat\"", # Query must remain the same for subsequent scroll requests
size=1,
pagination_id=pagination_id
)
page2_response = client.scroll_service_data(query_params=scroll_query_params_page2)
if page2_response.data:
print("Page 2 Data Count:", len(page2_response.data))
# Continue scrolling as needed...
# Search Host Data
host_query_params = RealtimeSearchQuery(
query="os: \"Linux\" AND country_cn: \"美国\"",
size=2
)
host_search_response = client.search_host_data(query_params=host_query_params)
print(f"\nHost Search Results (first {host_query_params.size} for '{host_query_params.query}'):")
if host_search_response.data:
for item in host_search_response.data:
location_cn = item.location.country_cn if item.location else "N/A"
print(f"- IP: {item.ip}, OS: {item.os_name}, Location: {location_cn}")
# Aggregate Service Data
agg_query_params = AggregationQuery(
query="country_cn: \"中国\"",
aggregation_list=["service.name", "port"],
size=3
)
agg_response = client.aggregate_service_data(query_params=agg_query_params)
print(f"\nService Aggregation for '{agg_query_params.query}' (top {agg_query_params.size} for each):")
if agg_response.data:
for field, buckets in agg_response.data.items():
print(f" Field: {field}")
for bucket in buckets:
print(f" - {bucket.key}: {bucket.doc_count}")
# Favicon Similarity Search
favicon_query_params = FaviconSimilarityQuery(
favicon_hash="0488faca4c19046b94d07c3ee83cf9d6", # Example hash
similar=0.95,
size=2
)
similar_icons_response = client.query_similar_icons(query_params=favicon_query_params)
print(f"\nSimilar Favicons to '{favicon_query_params.favicon_hash}':")
if similar_icons_response.data:
for item in similar_icons_response.data:
print(f"- Hash: {item.key}, Count: {item.doc_count}")
except QuakeAPIException as e:
print(f"An API error occurred: {e}")
except ValueError as e: # Can be raised by Pydantic validation or API key check
print(f"A value or validation error occurred: {e}")
except Exception as e:
print(f"An unexpected error occurred: {e}")
API Endpoints Covered
The SDK provides methods for the following Quake API v3 endpoints:
User:
/user/info
Service Data:
/filterable/field/quake_service/search/quake_service/scroll/quake_service/aggregation/quake_service(GET for fields, POST for query)
Host Data:
/filterable/field/quake_host/search/quake_host/scroll/quake_host/aggregation/quake_host(GET for fields, POST for query)
Favicon:
/query/similar_icon/aggregation
Refer to the official Quake API documentation for detailed information on query syntax and parameters. (Replace with the correct link from vendor/sdk.md if different).
Error Handling
The SDK defines custom exceptions that inherit from QuakeAPIException:
QuakeAuthException: For authentication issues (e.g., invalid API key).QuakeRateLimitException: When API rate limits are exceeded.QuakeInvalidRequestException: For errors in the request (e.g., bad parameters, syntax errors).QuakeServerException: For server-side errors on Quake's end.
These can be caught specifically to handle different error scenarios.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request or open an issue. (You might want to add more specific contribution guidelines later).
License
This project is licensed under the MIT License - see the LICENSE file for details. (Ensure you add a LICENSE file if you choose MIT or another license).
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file quake_sdk-0.3.0.tar.gz.
File metadata
- Download URL: quake_sdk-0.3.0.tar.gz
- Upload date:
- Size: 39.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7adea20fa12c1632e2f9cdde99df369006d22e7bb067518a7e21cfd8b83a33a6
|
|
| MD5 |
1a8cd86085b3d60671e299cd61f0ffab
|
|
| BLAKE2b-256 |
67db9ee6699b93431dd3e090536bdec72df636701083dc683ea35a6d74248f36
|
File details
Details for the file quake_sdk-0.3.0-py3-none-any.whl.
File metadata
- Download URL: quake_sdk-0.3.0-py3-none-any.whl
- Upload date:
- Size: 17.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.11.11
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
92b7159b25dd381c2ff962e034182a679c4808022fe919a23013e6c05e5751d0
|
|
| MD5 |
fee3babeaa7b69a4c33c2c52cb5f026f
|
|
| BLAKE2b-256 |
9ad9e50b601f4f9f0ef0d770daf0fa835dcd2a3269d4a6a25321e53798c4bcce
|