Skip to content

Commit

Permalink
Add configuration for thresholds and runtime
Browse files Browse the repository at this point in the history
Add PR changes
  • Loading branch information
susilnem committed Jul 4, 2024
1 parent 4bb5049 commit fd02db0
Show file tree
Hide file tree
Showing 26 changed files with 230 additions and 146 deletions.
6 changes: 5 additions & 1 deletion api/management/commands/cron_job_monitor.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@
from django.conf import settings
from django.core.management.base import BaseCommand

from main.sentry import SentryMonitor
from main.sentry import SentryMonitor, SentryMonitorConfig
from main.settings import SENTRY_DSN

logger = logging.getLogger(__name__)
Expand Down Expand Up @@ -48,6 +48,10 @@ def handle(self, *args, **options):
"type": "crontab",
"value": str(schedule),
},
"tz": settings.TIME_ZONE,
"checkin_margin": SentryMonitorConfig.get_checkin_margin(cronjob),
"failure_issue_threshold": SentryMonitorConfig.get_failure_issue_threshold(cronjob),
"recovery_threshold": SentryMonitorConfig.get_recovery_threshold(cronjob),
},
"environment": settings.GO_ENVIRONMENT,
"status": "ok",
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/index_and_notify.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,7 +67,6 @@
}


@monitor(monitor_slug=SentryMonitor.INDEX_AND_NOTIFY)
class Command(BaseCommand):
help = "Index and send notifications about new/changed records"

Expand Down Expand Up @@ -920,6 +919,7 @@ def check_ingest_issues(self, having_ingest_issue):
+ ", notification sent to IM team"
)

@monitor(monitor_slug=SentryMonitor.INDEX_AND_NOTIFY)
def handle(self, *args, **options):
if self.is_digest_mode():
time_diff = self.diff_1_week() # in digest mode (once a week, for new_entities only) we use a bigger interval
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/ingest_appeals.py
Original file line number Diff line number Diff line change
Expand Up @@ -33,7 +33,6 @@
GEC_CODES = GECCode.objects.select_related("country").all()


@monitor(monitor_slug=SentryMonitor.INGEST_APPEALS)
class Command(BaseCommand):
help = "Add new entries from Access database file"

Expand Down Expand Up @@ -292,6 +291,7 @@ def parse_appeal_record(self, r, **options):

return fields

@monitor(monitor_slug=SentryMonitor.INGEST_APPEALS)
def handle(self, *args, **options):
logger.info("Starting appeals ingest")
start_appeals_count = Appeal.objects.all().count()
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/ingest_disaster_law.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_DISASTER_LAW)
class Command(BaseCommand):
help = "Add ICRC data"

@monitor(monitor_slug=SentryMonitor.INGEST_DISASTER_LAW)
def handle(self, *args, **kwargs):
logger.info("Starting Disaster Law data")
home_url = "https://disasterlaw.ifrc.org/"
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/ingest_icrc.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_ICRC)
class Command(BaseCommand):
help = "Add ICRC data"

@monitor(monitor_slug=SentryMonitor.INGEST_ICRC)
def handle(self, *args, **kwargs):
logger.info("Strating ICRC data ingest")
HEADERS = {
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/ingest_ns_capacity.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,10 +8,10 @@
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_NS_CAPACITY)
class Command(BaseCommand):
help = "Add ns contact details"

@monitor(monitor_slug=SentryMonitor.INGEST_NS_CAPACITY)
def handle(self, *args, **kwargs):
logger.info("Starting NS Contacts")

Expand Down
4 changes: 3 additions & 1 deletion api/management/commands/ingest_ns_contact.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@
import xmltodict
from django.conf import settings
from django.core.management.base import BaseCommand
from django.db import transaction
from requests.auth import HTTPBasicAuth
from sentry_sdk.crons import monitor

Expand All @@ -13,10 +14,11 @@
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_NS_CONTACT)
class Command(BaseCommand):
help = "Add ns contact details"

@monitor(monitor_slug=SentryMonitor.INGEST_NS_CONTACT)
@transaction.atomic
def handle(self, *args, **kwargs):
logger.info("Starting NS Contacts")
url = "https://go-api.ifrc.org/"
Expand Down
12 changes: 8 additions & 4 deletions api/management/commands/ingest_ns_directory.py
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
import xmltodict
from django.conf import settings
from django.core.management.base import BaseCommand
from django.db import transaction
from requests.auth import HTTPBasicAuth
from sentry_sdk.crons import monitor

Expand All @@ -10,10 +11,11 @@
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_NS_DIRECTORY)
class Command(BaseCommand):
help = "Add ns contact details"

@monitor(monitor_slug=SentryMonitor.INGEST_NS_DIRECTORY)
@transaction.atomic
def handle(self, *args, **kwargs):
def postprocessor(path, key, value):
if key == "@i:nil":
Expand Down Expand Up @@ -41,6 +43,7 @@ def postprocessor(path, key, value):
raise Exception("Error querying NationalSocietiesContacts")

added = 0
created_country_directory_ids = []
dict_data = xmltodict.parse(response.content, postprocessor=postprocessor)
for data in dict_data["ArrayOfNationalSocietiesContacts"]["NationalSocietiesContacts"]:
country_name = data["CON_country"] if isinstance(data["CON_country"], str) else None
Expand All @@ -62,14 +65,15 @@ def postprocessor(path, key, value):
"position": data["CON_title"],
"country": country,
}
existing_qs = CountryDirectory.objects.filter(
country_directory, _ = CountryDirectory.objects.get_or_create(
country=country,
first_name__iexact=data["first_name"],
last_name__iexact=data["last_name"],
position__iexact=data["position"],
)
if not existing_qs.exists():
CountryDirectory.objects.create(**data)
created_country_directory_ids.append(country_directory.pk)
# NOTE: Deleting the country directory which are not available in the source
CountryDirectory.objects.exclude(id__in=created_country_directory_ids).delete()
text_to_log = "%s Ns Directory added" % added
logger.info(text_to_log)
body = {"name": "ingest_ns_directory", "message": text_to_log, "num_result": added, "status": CronJobStatus.SUCCESSFUL}
Expand Down
69 changes: 42 additions & 27 deletions api/management/commands/ingest_ns_document.py
Original file line number Diff line number Diff line change
Expand Up @@ -5,17 +5,18 @@
import requests
from django.conf import settings
from django.core.management.base import BaseCommand
from django.db import transaction
from sentry_sdk.crons import monitor

from api.logger import logger
from api.models import Country, CountryKeyDocument, CronJob, CronJobStatus
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_NS_DOCUMENT)
class Command(BaseCommand):
help = "Add ns documents"

@monitor(monitor_slug=SentryMonitor.INGEST_NS_DOCUMENT)
def handle(self, *args, **kwargs):
logger.info("Starting NS Key Documents")

Expand Down Expand Up @@ -98,32 +99,46 @@ def fetch_all_country_documents(self, api_key, country_table):

def save_documents_to_database(self, result):
added = 0
for document in result:
country = Country.objects.filter(fdrs=document["country_code"]).first()
if country is None:
continue

country_key_document, created = CountryKeyDocument.objects.get_or_create(
country=country,
url=document["url"],
defaults={
"name": document["name"],
"thumbnail": document["thumbnail"],
"document_type": document["document_type"],
"year": document["year"],
"end_year": document["end_year"],
"year_text": document["year_text"],
},
)
if not created:
country_key_document.name = document["name"]
country_key_document.thumbnail = document["thumbnail"]
country_key_document.document_type = document["document_type"]
country_key_document.year = document["year"]
country_key_document.end_year = document["end_year"]
country_key_document.year_text = document["year_text"]
country_key_document.save(update_fields=["name", "thumbnail", "document_type", "year", "end_year", "year_text"])
added += 1
created_country_key_document_ids = []
with transaction.atomic():
for document in result:
country = Country.objects.filter(fdrs=document["country_code"]).first()
if country is None:
continue

country_key_document, created = CountryKeyDocument.objects.get_or_create(
country=country,
url=document["url"],
defaults={
"name": document["name"],
"thumbnail": document["thumbnail"],
"document_type": document["document_type"],
"year": document["year"],
"end_year": document["end_year"],
"year_text": document["year_text"],
},
)
if not created:
country_key_document.name = document["name"]
country_key_document.thumbnail = document["thumbnail"]
country_key_document.document_type = document["document_type"]
country_key_document.year = document["year"]
country_key_document.end_year = document["end_year"]
country_key_document.year_text = document["year_text"]
country_key_document.save(
update_fields=[
"name",
"thumbnail",
"document_type",
"year",
"end_year",
"year_text",
]
)
created_country_key_document_ids.append(country_key_document.pk)
added += 1
# NOTE: Deleting the CountryKeyDocument that are not in the source
CountryKeyDocument.objects.exclude(id__in=created_country_key_document_ids).delete()
return added

def sync_cron_success(self, text_to_log, added):
Expand Down
52 changes: 29 additions & 23 deletions api/management/commands/ingest_ns_initiatives.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,17 +3,18 @@
import requests
from django.conf import settings
from django.core.management.base import BaseCommand
from django.db import transaction
from sentry_sdk.crons import monitor

from api.logger import logger
from api.models import Country, CronJob, CronJobStatus, NSDInitiatives
from main.sentry import SentryMonitor


@monitor(monitor_slug=SentryMonitor.INGEST_NS_INITIATIVES)
class Command(BaseCommand):
help = "Add ns initiatives"

@monitor(monitor_slug=SentryMonitor.INGEST_NS_INITIATIVES)
def handle(self, *args, **kwargs):
logger.info("Starting NS Inititatives")
api_key = settings.NS_INITIATIVES_API_KEY
Expand Down Expand Up @@ -43,28 +44,33 @@ def handle(self, *args, **kwargs):
],
)
funding_data = funding_data.replace({np.nan: None})
for data in funding_data.values.tolist():
# TODO: Filter not by society name
country = Country.objects.filter(society_name__iexact=data[0]).first()
if country:
nsd_initiatives, created = NSDInitiatives.objects.get_or_create(
country=country,
year=data[1],
fund_type=data[2],
defaults={
"title": data[3],
"categories": data[4],
"allocation": data[5],
"funding_period": data[6],
},
)
if not created:
nsd_initiatives.title = data[3]
nsd_initiatives.allocation = data[5]
nsd_initiatives.funding_period = data[6]
nsd_initiatives.categories = data[4]
nsd_initiatives.save(update_fields=["title", "allocation", "funding_period", "categories"])
added += 1
created_ns_initiatives_pk = []
with transaction.atomic():
for data in funding_data.values.tolist():
# TODO: Filter not by society name
country = Country.objects.filter(society_name__iexact=data[0]).first()
if country:
nsd_initiatives, created = NSDInitiatives.objects.get_or_create(
country=country,
year=data[1],
fund_type=data[2],
defaults={
"title": data[3],
"categories": data[4],
"allocation": data[5],
"funding_period": data[6],
},
)
if not created:
nsd_initiatives.title = data[3]
nsd_initiatives.categories = data[4]
nsd_initiatives.allocation = data[5]
nsd_initiatives.funding_period = data[6]
nsd_initiatives.save(update_fields=["title", "categories", "allocation", "funding_period"])
created_ns_initiatives_pk.append(nsd_initiatives.pk)
added += 1
# NOTE: Delete the NSDInitiatives that are not in the source
NSDInitiatives.objects.exclude(id__in=created_ns_initiatives_pk).delete()

text_to_log = "%s Ns initiatives added" % added
logger.info(text_to_log)
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/revoke_staff_status.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,6 @@
# from registrations.views import is_valid_domain


@monitor(monitor_slug=SentryMonitor.REVOKE_STAFF_STATUS)
class Command(BaseCommand):
help = 'Update staff status in auth_user table according to "Read only" group'

Expand Down Expand Up @@ -53,6 +52,7 @@ def get_ifrc_domain_users(self):
#
# return editors

@monitor(monitor_slug=SentryMonitor.REVOKE_STAFF_STATUS)
def handle(self, *args, **options):
logger.info("Moving Read only users out of staff status...")

Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/sync_appealdocs.py
Original file line number Diff line number Diff line change
Expand Up @@ -21,7 +21,6 @@
FEDNET_SOURCE = "https://go-api.ifrc.org/Api/FedNetAppeals?Hidden=false&BaseAppealnumber="


@monitor(monitor_slug=SentryMonitor.SYNC_APPEALDOCS)
class Command(BaseCommand):
help = "Ingest existing appeal documents"

Expand All @@ -37,6 +36,7 @@ def parse_date(self, date_string):
timeformat = "%Y-%m-%dT%H:%M:%S"
return datetime.strptime(date_string[:18], timeformat).replace(tzinfo=timezone.utc)

@monitor(monitor_slug=SentryMonitor.SYNC_APPEALDOCS)
def handle(self, *args, **options):
logger.info("Starting appeal document ingest")

Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/sync_molnix.py
Original file line number Diff line number Diff line change
Expand Up @@ -519,10 +519,10 @@ def sync_open_positions(molnix_positions, molnix_api, countries):
return messages, warnings, successful_creates


@monitor(monitor_slug=SentryMonitor.SYNC_MOLNIX)
class Command(BaseCommand):
help = "Sync data from Molnix API to GO db"

@monitor(monitor_slug=SentryMonitor.SYNC_MOLNIX)
@transaction.atomic
def handle(self, *args, **options):
logger.info("Starting Sync Molnix job")
Expand Down
2 changes: 1 addition & 1 deletion api/management/commands/user_registration_reminder.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,13 +10,13 @@
from registrations.models import Pending


@monitor(monitor_slug=SentryMonitor.USER_REGISTRATION_REMINDER)
class Command(BaseCommand):
help = "Send reminder about the pending registrations"

def diff_3_day(self):
return datetime.utcnow().replace(tzinfo=timezone.utc) - timedelta(days=3)

@monitor(monitor_slug=SentryMonitor.USER_REGISTRATION_REMINDER)
def handle(self, *args, **options):
region_ids = Region.objects.all().values_list("id", flat=True)
time_diff_3_day = self.diff_3_day()
Expand Down
Loading

0 comments on commit fd02db0

Please sign in to comment.