Python Example for Calling API
Python Example for Calling the CatFee.IO REST API
Prerequisites
You need a valid API Key and API Secret.
Make sure your environment has the requests
library installed. You can install it using:
pip install requests
Use Python version 3.6 or above.
Example Code
import hashlib
import hmac
import base64
import time
import requests
from urllib.parse import urlencode
API_KEY = "your_api_key" # Replace with your actual API Key
API_SECRET = "your_api_secret" # Replace with your actual API Secret
BASE_URL = "https://api.catfee.io"
def generate_timestamp():
"""Generate current timestamp in ISO 8601 format (UTC)"""
return time.strftime('%Y-%m-%dT%H:%M:%S.000Z', time.gmtime())
def build_request_path(path, query_params):
"""Build request path with query parameters"""
if not query_params:
return path
query_string = urlencode(query_params)
return f"{path}?{query_string}"
def generate_signature(timestamp, method, request_path):
"""Generate request signature"""
sign_string = timestamp + method + request_path
return hmac_sha256(sign_string, API_SECRET)
def hmac_sha256(data, secret):
"""Generate HMAC-SHA256 signature"""
return base64.b64encode(
hmac.new(secret.encode('utf-8'), data.encode('utf-8'), hashlib.sha256).digest()
).decode()
def create_request(url, method, timestamp, signature):
"""Create and send HTTP request"""
headers = {
"Content-Type": "application/json",
"CF-ACCESS-KEY": API_KEY,
"CF-ACCESS-SIGN": signature,
"CF-ACCESS-TIMESTAMP": timestamp,
}
if method == "POST":
response = requests.post(url, headers=headers)
elif method == "GET":
response = requests.get(url, headers=headers)
elif method == "PUT":
response = requests.put(url, headers=headers)
elif method == "DELETE":
response = requests.delete(url, headers=headers)
else:
raise ValueError(f"Unsupported HTTP method: {method}")
return response
def main():
method = "POST" # Can be changed to "GET", "PUT", or "DELETE"
path = "/v1/order"
# Example: Create Order
query_params = {
"quantity": "65000",
"receiver": "TRON_ADDRESS",
"duration": "1h"
}
# Generate request headers
timestamp = generate_timestamp()
request_path = build_request_path(path, query_params)
signature = generate_signature(timestamp, method, request_path)
# Construct full request URL
url = BASE_URL + request_path
# Send request
response = create_request(url, method, timestamp, signature)
# Print response
print("Response Code:", response.status_code)
print("Response Body:", response.text)
# Handle possible error
if response.status_code != 200:
print("Error:", response.json())
if __name__ == "__main__":
main()
Code Explanation
generate_timestamp()
Generates the current UTC timestamp in ISO 8601 format usingtime.strftime('%Y-%m-%dT%H:%M:%S.000Z')
.build_request_path()
Builds the full request path including query parameters. If no parameters are provided, it returns the original path.generate_signature()
Concatenatestimestamp + method + request_path
, then generates a signature using thehmac_sha256()
function.hmac_sha256()
Uses the HMAC-SHA256 algorithm with yourAPI_SECRET
as the key, and encodes the result with Base64.create_request()
Sends the HTTP request using therequests
library. Supports POST, GET, PUT, and DELETE methods.main()
The main function sets the HTTP method, prepares query parameters, builds headers and request path, sends the request, and prints the response.
Notes
API Key and Secret Replace
API_KEY
andAPI_SECRET
with the actual credentials you obtained from CatFee.IO.Error Handling If the response status code is not 200, the code will print the error details.
HTTP Methods This example supports POST, GET, PUT, and DELETE. You can modify the
method
variable based on your needs.
Summary
This example demonstrates how to use Python to securely call the CatFee.IO Rest API. It ensures security through HMAC-SHA256 signature authentication. You can adjust the code as needed to support different endpoints and HTTP methods.
If you have any questions or need further assistance, feel free to contact the CatFee.IO support team.
Last updated
Was this helpful?