metrics.py 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. from prometheus_client import Counter, Histogram
  2. metrics = {}
  3. def get(name):
  4. return metrics.get(name)
  5. def set_counter(name, *args, **kwargs):
  6. metrics[name] = Counter(name, *args, **kwargs)
  7. def set_histogram(name, *args, **kwargs):
  8. metrics[name] = Histogram(name, *args, **kwargs)
  9. # models.py metrics
  10. set_counter('desecapi_captcha_content_created', 'number of times captcha content created', ['kind'])
  11. set_counter('desecapi_autodelegation_created', 'number of autodelegations added')
  12. set_counter('desecapi_autodelegation_deleted', 'number of autodelegations deleted')
  13. set_histogram('desecapi_messages_queued', 'number of emails queued', ['reason', 'user', 'lane'],
  14. buckets=[0, 1, float("inf")])
  15. # views.py metrics
  16. set_counter('desecapi_dynDNS12_domain_not_found', 'number of times dynDNS12 domain is not found')
  17. # crypto.py metrics
  18. set_counter('desecapi_key_encryption_success', 'number of times key encryption was successful', ['context'])
  19. set_counter('desecapi_key_decryption_success', 'number of times key decryption was successful', ['context'])
  20. # exception_handlers.py metrics
  21. set_counter('desecapi_database_unavailable', 'number of times database was unavailable')
  22. # pdns.py metrics
  23. set_counter('desecapi_pdns_request_success', 'number of times pdns request was successful', ['method', 'status'])
  24. set_counter('desecapi_pdns_keys_fetched', 'number of times pdns keys were fetched')
  25. # pdns_change_tracker.py metrics
  26. set_counter('desecapi_pdns_catalog_updated', 'number of times pdns catalog was updated successfully')
  27. # throttling.py metrics
  28. set_counter('desecapi_throttle_failure', 'number of requests throttled', ['method', 'scope', 'user', 'bucket'])