Fingerprint Server API allows you to get, search, and update Events in a server environment. It can be used for data exports, decision-making, and data analysis scenarios. Server API is intended for server-side usage, it's not intended to be used from the client side, whether it's a browser or a mobile device.
Project description
Fingerprint Server Python SDK
Fingerprint is a device intelligence platform offering industry-leading accuracy. The Fingerprint Server Python SDK is an easy way to interact with the Fingerprint Server API from your Python application. You can retrieve visitor history or individual identification events.
This Python package is automatically generated by the OpenAPI Generator project:
- API version: 4
- Package version: 9.2.0
- Generator version: 7.19.0
- Build package: org.openapitools.codegen.languages.PythonClientCodegen
Requirements
The following Python versions are supported:
- Python 3.9+
Installation & Usage
pip install
You can install the package directly from the Github
pip install git+https://github.com/fingerprintjs/python-sdk.git
Or from the PyPI
pip install fingerprint_server_sdk
Then import the package:
import fingerprint_server_sdk
Setuptools
Install via Setuptools.
python setup.py install --user
(or sudo python setup.py install to install the package for all users)
Then import the package:
import fingerprint_server_sdk
Getting Started
Please follow the installation procedure and then run the following:
import os
import fingerprint_server_sdk
from fingerprint_server_sdk.configuration import Region
# Configure API key authorization and region
configuration = fingerprint_server_sdk.Configuration(
api_key = os.environ["SECRET_API_KEY"],
region = Region.US
)
# create an instance of the API class
api_instance = fingerprint_server_sdk.FingerprintApi(configuration)
Examples
Delete visitor data using visitorId:
import os
import fingerprint_server_sdk
from fingerprint_server_sdk import ApiException, ErrorResponse
from fingerprint_server_sdk.configuration import Region
# Configure API key authorization and region
configuration = fingerprint_server_sdk.Configuration(
api_key = os.environ["SECRET_API_KEY"],
region = Region.US
)
api_instance = fingerprint_server_sdk.FingerprintApi(configuration)
visitor_id = 'visitor_id_example'
try:
api_instance.delete_visitor_data(visitor_id)
except ApiException as e:
if e.body is not None:
error_response = ErrorResponse.from_json(e.body)
if error_response is not None:
message = f"API request failed: {error_response.error.code} {error_response.error.message}"
else:
message = f"API request failed with unexpected error format: {e}"
else:
message = f'Exception when calling FingerprintApi->delete_visitor_data: {e}'
print(message)
To learn more, refer to example located in examples/delete_visitor_example.py.
Fetching event details for eventId:
import os
import fingerprint_server_sdk
from fingerprint_server_sdk import ApiException, ErrorResponse
from fingerprint_server_sdk.configuration import Region
# Configure API key authorization and region
configuration = fingerprint_server_sdk.Configuration(
api_key = os.environ["SECRET_API_KEY"],
region = Region.US
)
api_instance = fingerprint_server_sdk.FingerprintApi(configuration)
event_id = 'event_id_example'
try:
events_response = api_instance.get_event(event_id)
except ApiException as e:
if e.body is not None:
error_response = ErrorResponse.from_json(e.body)
if error_response is not None:
message = f"API request failed: {error_response.error.code} {error_response.error.message}"
else:
message = f"API request failed with unexpected error format: {e}"
else:
message = f'Exception when calling FingerprintApi->get_event: {e}'
print(message)
To learn more, refer to example located in examples/get_event_example.py.
Search events with custom filters:
import os
import fingerprint_server_sdk
from fingerprint_server_sdk import ApiException, SearchEventsBot, ErrorResponse
from fingerprint_server_sdk.configuration import Region
# Configure API key authorization and region
configuration = fingerprint_server_sdk.Configuration(
api_key = os.environ["SECRET_API_KEY"],
region = Region.US
)
api_instance = fingerprint_server_sdk.FingerprintApi(configuration)
limit = 20
pagination_key = 'key_example'
visitor_id = 'VISITOR_ID'
bot = SearchEventsBot.GOOD
ip_address = '192.168.0.1/32'
linked_id = 'linked_id_example'
start = 1738687200000
end = 1738773600000
reverse = True
suspect = False
try:
# Get events via search
api_response = api_instance.search_events(limit, pagination_key=pagination_key, visitor_id=visitor_id, bot=bot, ip_address=ip_address, linked_id=linked_id, start=start, end=end, reverse=reverse, suspect=suspect)
print(api_response)
except ApiException as e:
if e.body is not None:
error_response = ErrorResponse.from_json(e.body)
if error_response is not None:
message = f"API request failed: {error_response.error.code} {error_response.error.message}"
else:
message = f"API request failed with unexpected error format: {e}"
else:
message = f'Exception when calling FingerprintApi->get_event: {e}'
print(message)
To learn more, refer to example located in examples/search_events_example.py.
Update event for eventId:
import os
import fingerprint_server_sdk
from fingerprint_server_sdk import ApiException, EventUpdate, ErrorResponse
from fingerprint_server_sdk.configuration import Region
# Configure API key authorization and region
configuration = fingerprint_server_sdk.Configuration(
api_key = os.environ["SECRET_API_KEY"],
region = Region.US
)
api_instance = fingerprint_server_sdk.FingerprintApi(configuration)
event_id = 'event_id_example'
body = EventUpdate(linked_id='foo')
# body = EventUpdate(tags={'bar': 123})
# body = EventUpdate(suspect=True)
# body = EventUpdate(linked_id='foo', tags={'bar': 123}, suspect=False)
try:
api_instance.update_event(event_id, body)
except ApiException as e:
if e.body is not None:
error_response = ErrorResponse.from_json(e.body)
if error_response is not None:
message = f"API request failed: {error_response.error.code} {error_response.error.message}"
else:
message = f"API request failed with unexpected error format: {e}"
else:
message = f'Exception when calling FingerprintApi->update_event: {e}'
print(message)
To learn more, refer to example located in examples/update_event_example.py.
Sealed results
This SDK provides utility methods for decoding sealed results.
import base64
import os
from dotenv import load_dotenv
from fingerprint_server_sdk import unseal_event_response, DecryptionKey, DecryptionAlgorithm
load_dotenv()
sealed_result = base64.b64decode(os.environ["BASE64_SEALED_RESULT"])
key = base64.b64decode(os.environ["BASE64_KEY"])
try:
event_response = unseal_event_response(sealed_result, [DecryptionKey(key, DecryptionAlgorithm['Aes256Gcm'])])
print("\n\n\nEvent response: \n", event_response)
except Exception as e:
print(f'Exception when calling unsealing events response: {e}\n')
exit(1)
print("Unseal successful!")
exit(0)
To learn more, refer to example located in examples/sealed_results_example.py.
Webhook signature validation
This SDK provides utility method for verifying the HMAC signature of the incoming webhook request.
import os
from flask import Flask, request, jsonify
from fingerprint_server_sdk import WebhookValidation
app = Flask(__name__)
@app.route('/api/webhook', methods=['POST'])
def webhook_handler():
try:
# Retrieve the secret key from environment variables
secret = os.getenv("WEBHOOK_SIGNATURE_SECRET")
if not secret:
return jsonify({"message": "Secret key is not configured."}), 400
# Get the "fpjs-event-signature" header from the incoming request
header = request.headers.get('fpjs-event-signature')
if not header:
return jsonify({"message": "Missing fpjs-event-signature header."}), 400
# Read the raw body of the incoming request
data = request.get_data()
# Validate the webhook signature
is_valid = WebhookValidation.is_valid_webhook_signature(header, data, secret)
if not is_valid:
return jsonify({"message": "Webhook signature is invalid."}), 403
# Process the webhook data here
return jsonify({"message": "Webhook received."}), 200
except Exception as e:
# Handle any unexpected errors
return jsonify({"error": str(e)}), 500
if __name__ == '__main__':
# Start the Flask application on the specified host and port
app.run(host='0.0.0.0', port=5000)
To learn more, refer to example located in examples/webhook_signature_example.py.
Documentation for API Endpoints
All URIs are relative to https://api.fpjs.io/v4
| Class | Method | HTTP request | Description |
|---|---|---|---|
| FingerprintApi | delete_visitor_data | DELETE /visitors/{visitor_id} | Delete data by visitor ID |
| FingerprintApi | get_event | GET /events/{event_id} | Get an event by event ID |
| FingerprintApi | search_events | GET /events | Search events |
| FingerprintApi | update_event | PATCH /events/{event_id} | Update an event |
Documentation For Models
- BotInfo
- BotResult
- BrowserDetails
- Canvas
- Emoji
- Error
- ErrorCode
- ErrorResponse
- Event
- EventRuleAction
- EventRuleActionAllow
- EventRuleActionBlock
- EventSearch
- EventUpdate
- FontPreferences
- Geolocation
- GeolocationSubdivisionsInner
- IPBlockList
- IPInfo
- IPInfoV4
- IPInfoV6
- Identification
- IdentificationConfidence
- IncrementalIdentificationStatus
- Integration
- IntegrationSubintegration
- PluginsInner
- PluginsInnerMimeTypesInner
- Proximity
- ProxyConfidence
- ProxyDetails
- RareDevicePercentileBucket
- RawDeviceAttributes
- RequestHeaderModifications
- RuleActionHeaderField
- RuleActionType
- SDK
- SearchEventsBot
- SearchEventsIncrementalIdentificationStatus
- SearchEventsRareDevicePercentileBucket
- SearchEventsSdkPlatform
- SearchEventsVpnConfidence
- SupplementaryIDHighRecall
- TamperingConfidence
- TamperingDetails
- TouchSupport
- Velocity
- VelocityData
- VpnConfidence
- VpnMethods
- WebGlBasics
- WebGlExtensions
Documentation for sealed results
Support
To report problems, ask questions or provide feedback, please use Issues. If you need private support, you can email us at oss-support@fingerprint.com.
License
This project is licensed under the MIT 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 fingerprint_server_sdk-9.2.0.tar.gz.
File metadata
- Download URL: fingerprint_server_sdk-9.2.0.tar.gz
- Upload date:
- Size: 77.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
80ed992a6a5e31c8b4b72114c853a7b5a896354423916da192081124a1c5c415
|
|
| MD5 |
ab72436c6f54c1b93c8d6c40cac7bc01
|
|
| BLAKE2b-256 |
ebd542fdd5e9557afa4df935726f03cc8e506274abcc11e53732f4866ad019d5
|
Provenance
The following attestation bundles were made for fingerprint_server_sdk-9.2.0.tar.gz:
Publisher:
publish.yml on fingerprintjs/python-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fingerprint_server_sdk-9.2.0.tar.gz -
Subject digest:
80ed992a6a5e31c8b4b72114c853a7b5a896354423916da192081124a1c5c415 - Sigstore transparency entry: 1437423414
- Sigstore integration time:
-
Permalink:
fingerprintjs/python-sdk@03ed58bebb33e31499d332747cd980d4ba2ed0d6 -
Branch / Tag:
refs/tags/v9.2.0 - Owner: https://github.com/fingerprintjs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@03ed58bebb33e31499d332747cd980d4ba2ed0d6 -
Trigger Event:
release
-
Statement type:
File details
Details for the file fingerprint_server_sdk-9.2.0-py3-none-any.whl.
File metadata
- Download URL: fingerprint_server_sdk-9.2.0-py3-none-any.whl
- Upload date:
- Size: 125.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0c157201cbbb32f1ef282dae7d0e984708aba70fc951768aebfa870935210596
|
|
| MD5 |
8269ad53a0536e92b25177a842388ec7
|
|
| BLAKE2b-256 |
a0886582b2cea83731b7b1c2f871c65cd85920e4b371519be7f9567829247ee6
|
Provenance
The following attestation bundles were made for fingerprint_server_sdk-9.2.0-py3-none-any.whl:
Publisher:
publish.yml on fingerprintjs/python-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fingerprint_server_sdk-9.2.0-py3-none-any.whl -
Subject digest:
0c157201cbbb32f1ef282dae7d0e984708aba70fc951768aebfa870935210596 - Sigstore transparency entry: 1437423416
- Sigstore integration time:
-
Permalink:
fingerprintjs/python-sdk@03ed58bebb33e31499d332747cd980d4ba2ed0d6 -
Branch / Tag:
refs/tags/v9.2.0 - Owner: https://github.com/fingerprintjs
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@03ed58bebb33e31499d332747cd980d4ba2ed0d6 -
Trigger Event:
release
-
Statement type: