Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
3 changes: 2 additions & 1 deletion examples/basic/verify-token.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,8 @@ def your_function_or_handler():
token = str(uuid4()) # This is an example UUIDv4

# This handles the connections with a session and can be reused
# for better performance
# for better performance. The `verification_url` keyword arguement
# can be set to your url or leave blank to use a default one
verifier = TokenVerifier()

try:
Expand Down
4 changes: 3 additions & 1 deletion examples/flask/app.py
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,9 @@ def get_token_verifier() -> TokenVerifier:
It's a good practice in order to reuse connections.
"""
if "VQueueTokenVerifier" not in g:
g.VQueueTokenVerifier = TokenVerifier()
# This is an example, the `verification_url` keyword arguement can be set to
# your verification url or leave blank to use a default url
g.VQueueTokenVerifier = TokenVerifier(verification_url="http://localhost:8000")

return g.VQueueTokenVerifier

Expand Down
Empty file added src/vqueue/py.typed
Empty file.
11 changes: 8 additions & 3 deletions src/vqueue/queues.py
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,14 @@
class TokenVerifier:
"""Client to verify Virtual Queue tokens"""

def __init__(self):
"""Initialize the TokenVerifier with a network session"""
def __init__(self, *, verification_url: str | None = None):
"""Initialize the TokenVerifier with a network session

Args:
verification_url: URL of the verification service. If none is given, a default value will be used
"""
self.session = requests.Session()
self._verification_token = verification_url or VERIFY_API_URL

def close(self):
self.session.close()
Expand Down Expand Up @@ -49,7 +54,7 @@ def verify_token(self, token: str) -> VerificationResult:
uuid_token = validate_uuidv4(token)

try:
response = self.session.get(f"{VERIFY_API_URL}?token={uuid_token}")
response = self.session.get(f"{self._verification_token}?token={uuid_token}")
response_data = response.json()
except requests.JSONDecodeError as e:
raise VQueueError("Invalid JSON response") from e
Expand Down
Loading