Skip to content

A repository containing the latest poverty scale in a way that is convenient to access from Python and from Docassemble. This also contains a JSON file you can reference directly without the Python frontend.

License

Notifications You must be signed in to change notification settings

SuffolkLITLab/docassemble-PovertyScale

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

28 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

PovertyScale

PyPI version

Poverty scale, updated approximately on an annual basis, to use for calculating income eligibility in the United States.

Just get the JSON file

Justification

https://github.com/codeforamerica/fplapi exists but requires a dedicated server, and hasn't been updated in recent years. At Suffolk we are already maintaining and consuming this information in multiple apps; it's simple for us to maintain the API alongside it.

The intent is that you will run this on your own Docassemble server, but we may maintain a public endpoint at some point. If you run your own Docassemble server, this allows you have one source of truth for both use in Docassemble interviews (without the overhead of the REST call) and for use in any non-Docassemble webapps you may have.

Update frequency

The Federal Poverty Guidelines are updated annually, but not usually published in the federal register until a month or so into a new year. We will try to closely track that update timeline. Pull requests with updated figures are welcome.

Examples

See example and demo in demo_poverty_scale.yml

This package contains a JSON file, federal_poverty_scale.json, which can be referenced directly, as well as a module poverty.py which exports poverty_scale_income_qualifies

REST API

Once this file is installed, you can access it as a REST API with a JSON response. The following endpoints are created on your Docassemble server:

  • /poverty_guidelines (same as the JSON file)
  • /poverty_guidelines/household_size/ (per-household size)
  • /poverty_guidelines/household_size/?state=ak|hi&multiplier=2
  • /poverty_guidelines/qualifies/household_size/<household_size>?income=1000&state=AK&multiplier=1.5

You can just use the API endpoint to retrieve the contents of the JSON file, or specify a household size and optional state and multiplier to get a tailored response, with either the income limit for a given household size or a determination that someone's income is below the poverty guideline.

Income is expected to be provided on a monthly basis.

Python function signatures

def poverty_scale_income_qualifies(total_monthly_income:float, household_size:int=1, multiplier:int=1)->Union[bool,None]:
  """
  Given monthly income, household size, and an optional multiplier, return whether an individual
  is at or below the federal poverty level.
  
  Returns None if the poverty level data JSON could not be loaded.
  """
  
def poverty_scale_get_income_limit(household_size:int=1, multiplier:int=1)->Union[int, None]:
  """
  Return the income limit matching the given household size.
  """
  

About

A repository containing the latest poverty scale in a way that is convenient to access from Python and from Docassemble. This also contains a JSON file you can reference directly without the Python frontend.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages