Getting Started with Justopinion

Justopinion works by downloading data about judicial opinions from the Caselaw Access Project API.

To take advantage of all the features of the API (and of justopinion), you’ll need to register with the Caselaw Access Project and get an API key. Then, you can use justopinion to create a CAPClient object that will hold your API key and automate some of the steps of downloading.

Your API Key

Your API key should remain secret like a password. It’s best not to include your API key in any Python code you write, because you might accidentally upload it to a public repository where other people can see it, such as a GitHub repository.

A safer way to handle your API key is to use python-dotenv. To use python-dotenv, add a file in the root directory of your project called .env. Also add .env to your .gitignore file. The .env file should contain a line that looks like CAP_API_KEY=your-api-key-here. Then within your Python code, you can import a variable called CAP_API_KEY that will hold your API key.

>>> import os
>>> from dotenv import load_dotenv
>>> load_dotenv()
True
>>> CAP_API_KEY = os.getenv('CAP_API_KEY')

Next, use the CAP_API_KEY variable to create a CAPClient.

>>> from justopinion.download import CAPClient
>>> client = CAPClient(CAP_API_KEY)

Fetching a Case

Let’s download Oracle America v. Google, 750 F.3d 1339 (2014), a case that appears in the AuthoritySpoke tutorial.

>>> from justopinion import CAPClient
>>> client = CAPClient(api_token=CAP_API_KEY)
>>> oracle_download = client.fetch(query="750 F.3d 1339")

We can get the JSON data from the response with the .json() method. By looking at the name field from the API response, we can verify that we have the correct case name.

>>> oracle_data = oracle_download.json()
>>> oracle_data["results"][0]["name"]
'ORACLE AMERICA, INC., Plaintiff-Appellant, v. GOOGLE INC., Defendant-Cross-Appellant'

But we haven’t loaded the case as a Decision yet. Instead it’s just a Python dict. To load the case as a Decision, we can use the read_decision_from_response() method.

>>> oracle = client.read_decision_from_response(oracle_download)
>>> oracle.name_abbreviation
'Oracle America, Inc. v. Google Inc.'
>>> oracle.id
4066790
>>> oracle.decision_date.isoformat()
'2014-05-09'

We also could have skipped the step of using the fetch() method and instead used the read() method to get a Decision directly from the CAPClient.

Although the Decision object has attributes with information about the case, it doesn’t have fields about the Opinions filed in the case. To get the Opinions, we can set the full_case parameter to True.

The CAP API generally limits users to downloading 500 full cases per day. If you accidentally make a query that returns hundreds of full cases, you could hit your limit before you know it. You should first try out your API queries without the full_case=True parameter, and then only request full cases once you’re confident you’ll receive what you expect.

Using the full_case parameter allows us to access information extracted from the text of the opinions, including the party names, on the casebody attribute.

>>> thornton = client.read_cite("1 Breese 34", full_case=True)
>>> thornton.casebody.data.parties[0]
'John Thornton and others, Appellants, v. George Smiley and John Bradshaw, Appellees.'

The full_case parameter also allows access to the opinions attribute.

>>> thornton.opinions[0].type
'majority'

Selecting Text from an Opinion

The locate_text() method can be used to find the start and endpoints of a phrase in the text of an opinion.

>>> thornton.opinions[0].locate_text("The court knows of no power in the administrator")
TextPositionSet{TextPositionSelector[22, 70)}

The select_text() method goes in the opposite direction, getting a text quotation from start and end positions.

>>> selection = thornton.opinions[0].select_text([(258, 294), (312, 359)])
>>> str(selection)
'…The note was made to West alone, and…the suit should have been commenced in his name…'

Viewing the Cases Cited by a Decision

When you download a Decision, you can access a list of citations to other cases detected by the Caselaw Access Project. Each of these CAPCitation objects can be used as a query to download more cases.

In this example, we’ll start with Thornton v. Smiley, the same case we downloaded in Fetching a Case above.

>>> thornton.name_abbreviation
'Thornton v. Smiley'

We can see that Thornton v. Smiley cites to only one other case.

>>> len(thornton.cites_to)
1
>>> str(thornton.cites_to[0])
'Citation to 15 Ill., 284'

By passing the citation to the read() method, we can get an object representing the cited Decision.

>>> cited = client.read_cite(thornton.cites_to[0], full_case=True)
>>> str(cited)
'Marsh v. People, 15 Ill. 284 (1853-12-01)'

And we’ve learned an important lesson: not to assume that citations in publised caselaw always point backwards in time. The publisher of the Breese caselaw reporter seems to have added a supporting citation to a case that was decided decades after Thornton v. Smiley.