Skip to main content

powerschool is a Python client for the PowerSchool API

Project description

PowerSchool

powerschool is a Python client for the PowerSchool SIS API

Installation

Use the package manager pip to install powerschool.

pip install powerschool

Getting Started

  1. Ensure you have a valid plugin installed with the proper data access provisioned for your purposes.

  2. Instantiate the client by passing the host name of your server.

import powerschool
ps = powerschool.PowerSchool('my.host.name')
  1. Authorize the client using:
    • client credentials (a tuple)
    my_credentials = (client_id, client_secret)
    ps.authorize(client_credentials=my_credentials)
    
    • a previously saved access token (dict)
    with open(token_file, 'r') as f:
        my_token = json.load(f)
    
    ps.authorize(access_token=my_token)
    

Usage

Instantiate a table or PowerQuery object:

schools_table = ps.get_schema_table('schools')
powerquery = ps.get_named_query('com.pearson.core.student.search.get_student_basic_info')

Get the record count for a table, passing a query filter:

schools_table.count()

Query all records, all columns on a table:

schools_table.query()

Query all records on a table, with filter and columns list:

params = {
    'q': 'id=ge=10000',
    'projection': 'school_number,abbreviation',
}
schools_table.query(**params)

Query a specific record on a table:

schools_table.query(dcid=123)

Execute a PowerQuery, passing arguments in the body:

payload = {
    'studentdcid': '5432',
}
powerquery.query(body=payload)

Contributing

Pull requests are welcome. For major changes, please open an issue first to discuss what you would like to change.

Please make sure to update tests as appropriate.

Notice

PowerSchool® is a registered trademark in the U.S. and/or other countries owned by PowerSchool Education, Inc. or its affiliates. PowerSchool® is used under license.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

powerschool-0.2.0.tar.gz (17.1 kB view hashes)

Uploaded Source

Built Distribution

powerschool-0.2.0-py3-none-any.whl (17.3 kB view hashes)

Uploaded Python 3

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page