Skip to content

Commit

Permalink
Merge pull request #149 from openstates/update-resolve-bill-method
Browse files Browse the repository at this point in the history
Update resolve_bill method
  • Loading branch information
alexobaseki authored Oct 18, 2024
2 parents 251a29c + ee73cf2 commit 2819bc2
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 9 deletions.
4 changes: 4 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,9 @@
# Changelog

## 6.20.8 - Oct 18, 2024q

* Improve resolve bill to capture at least the most recent session

## 6.20.7 - Oct 10, 2024

* Fix matching committee organizations when chamber is specified for an organizational bill sponsor
Expand Down
36 changes: 28 additions & 8 deletions openstates/importers/base.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
import json
import logging
import typing
from datetime import datetime, timedelta
from datetime import datetime
from django.db.models import Q, Model
from django.db.models.signals import post_save
from .. import settings
Expand Down Expand Up @@ -128,6 +128,10 @@ def __init__(self, jurisdiction_id: str, do_postimport=True) -> None:
self.pseudo_id_cache: typing.Dict[str, typing.Optional[_ID]] = {}
self.person_cache: typing.Dict[_PersonCacheKey, typing.Optional[str]] = {}
self.session_cache: typing.Dict[str, LegislativeSession] = {}
# Get all_session_cache is a list of all sessions available for this jurisdiction.
# It is different from session_cache: which is a dictionary session(s) that is loaded a session
# session_cache may not contain all jurisdiction legislative sessions while all_session_cache will.
self.all_sessions_cache: typing.List[LegislativeSession] = []
self.logger = logging.getLogger("openstates")
self.info = self.logger.info
self.debug = self.logger.debug
Expand All @@ -139,6 +143,13 @@ def __init__(self, jurisdiction_id: str, do_postimport=True) -> None:
if settings.IMPORT_TRANSFORMERS.get(self._type):
self.cached_transformers = settings.IMPORT_TRANSFORMERS[self._type]

def get_all_sessions(self) -> typing.List[LegislativeSession]:
if not self.all_sessions_cache:
self.all_sessions_cache = LegislativeSession.objects.filter(
jurisdiction_id=self.jurisdiction_id
).order_by("-start_date")
return self.all_sessions_cache

def get_session(self, identifier: str) -> LegislativeSession:
if identifier not in self.session_cache:
self.session_cache[identifier] = LegislativeSession.objects.get(
Expand Down Expand Up @@ -166,18 +177,27 @@ def resolve_bill(self, bill_id: str, *, date: str) -> typing.Optional[_ID]:
bill_transform_func = settings.IMPORT_TRANSFORMERS.get("bill", {}).get(
"identifier", None
)
all_sessions = self.get_all_sessions()
if bill_transform_func:
bill_id = bill_transform_func(bill_id)

# move the start_date up a bit in case the event is on the last day of a session to compare with end_date
date = datetime.fromisoformat(date)
new_date = date - timedelta(days=1)
# Some steps here to first find the session that matches the incoming entity using the entity date
# If a unique session is not found, then use the session with the latest "start_date"
date = datetime.fromisoformat(date).strftime("%Y-%m-%d")
session_ids = [
session.id
for session in all_sessions
if session.start_date <= date
and (session.end_date >= date or not session.end_date)
]

if len(session_ids) == 1:
session_id = session_ids.pop()
else:
session_id = all_sessions[0].id if all_sessions else None

objects = Bill.objects.filter(
Q(legislative_session__end_date__gte=new_date)
| Q(legislative_session__end_date=""),
legislative_session__start_date__lte=date,
legislative_session__jurisdiction_id=self.jurisdiction_id,
legislative_session__id=session_id,
identifier=bill_id,
)
ids = {each.id for each in objects}
Expand Down
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
[tool.poetry]
name = "openstates"
version = "6.20.7"
version = "6.20.8"
description = "core infrastructure for the openstates project"
authors = ["James Turk <dev@jamesturk.net>"]
license = "MIT"
Expand Down

0 comments on commit 2819bc2

Please sign in to comment.