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

Table of Contents

Installation

Use the package manager pip to install powerschool.

pip install powerschool

Generate Client ID and Client Secret

You can collect the Client ID and Client Secret directly by signing into the PowerSchool Admin portal and navigating to System > System Settings > Plugin Management Dashboard > {Your Plugin}.

Getting Started

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

  2. Instantiate a client by passing the host name of your server and one form of authentication:

    • client credentials (tuple)
     import powerschool
     
     client_id = 'CLi3N7-Id'
     client_secret = 'cL13N7-53cR37'
     my_credentials = (client_id, client_secret)
     
     ps = powerschool.PowerSchool('my.host.name', auth=my_credentials)
    
    • access token (dict)
     import powerschool
     
     with open('/path/to/token_file.json', 'r') as f:
         my_token = json.load(f)
         
     ps = powerschool.PowerSchool('my.host.name', auth=my_token)
    

Usage

Refer to the docs for full functionality, including resources, searching, and pagination.

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:

schools_table.count()

Query all records, all columns on a table:

Pagination is handled automatically by the client. However, you can manually pass pagesize and page parameters, should you choose.

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-3.0.0.tar.gz (18.2 kB view details)

Uploaded Source

Built Distribution

powerschool-3.0.0-py3-none-any.whl (18.4 kB view details)

Uploaded Python 3

File details

Details for the file powerschool-3.0.0.tar.gz.

File metadata

  • Download URL: powerschool-3.0.0.tar.gz
  • Upload date:
  • Size: 18.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.9.7 Linux/5.10.60.1-microsoft-standard-WSL2

File hashes

Hashes for powerschool-3.0.0.tar.gz
Algorithm Hash digest
SHA256 c4d5a6cd3f4c987fb9284b3da94ae5d03f9c09f4608bd55d5020da63e24b959a
MD5 dfbc69808cd271174fba1cd6c89ccf5d
BLAKE2b-256 92d597fd83f13cfc5781ba00c3c1d701c63e5414ff724333e15aaeb39e95984f

See more details on using hashes here.

File details

Details for the file powerschool-3.0.0-py3-none-any.whl.

File metadata

  • Download URL: powerschool-3.0.0-py3-none-any.whl
  • Upload date:
  • Size: 18.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.9.7 Linux/5.10.60.1-microsoft-standard-WSL2

File hashes

Hashes for powerschool-3.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 78cb30c31f059d6125e24be2bc74e8ea7496f5f9ec127e9e68835d9b7a6db4e2
MD5 e7912f61e5e48b42cc5d8dcc0b5a326c
BLAKE2b-256 98408dfa1d9c32d14e2612d90d301214372e68b77d23af983c9c4ce4d1668aef

See more details on using hashes here.

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