Lightweight analytics tool for Okapi-based services. Based on the original ldlite package from the Library Data Platform project: https://github.com/library-data-platform/ldlite
Project description
LDLite-RTR
Copyright (C) 2021-2024 The Open Library Foundation. This software is distributed under the terms of the Apache License, Version 2.0. See the file LICENSE for more information.
LDLite-RTR is a fork of the original LDLite tool from the Library Data Platform project that supports Refresh Token Rotation (RTR) in the Quesnelia release (and later) of FOLIO. It should function as a drop-in replacement for the original ldlite library.
LDLite-RTR is a lightweight, open source reporting tool for Okapi-based services. It is part of the Library Data Platform project and provides basic LDP functions without requiring the server to be installed.
To install LDLite or upgrade to the latest version:
$ python -m pip install --upgrade ldlite-rtr
(On some systems it might be python3 rather than python.)
To extract and transform data:
$ python
>> > import ldlite
>> > ld = ldlite.LDLite()
>> > ld.connect_okapi(url='https://folio-juniper-okapi.dev.folio.org/',
tenant='diku',
user='diku_admin',
password='admin')
>> > db = ld.connect_db()
>> > _ = ld.query(table='g', path='/groups', query='cql.allRecords=1 sortby id')
ldlite: querying: / groups
ldlite: created
tables: g, g__t, g__tcatalog
>> > ld.select(table='g__t')
__id | id | desc | expiration_offset_in_days | group
------+--------------------------------------+-----------------------+---------------------------+-----------
1 | 3684a786-6671-4268-8ed0-9db82ebca60b | Staff Member | 730 | staff
2 | 503a81cd-6c26-400f-b620-14c08943697c | Faculty Member | 365 | faculty
3 | ad0bc554-d5bc-463c-85d1-5562127ae91b | Graduate Student | | graduate
4 | bdc2b6d4-5ceb-4a12-ab46-249b9a68473e | Undergraduate Student | | undergrad
(4 rows)
>> > _ = ld.query(table='u', path='/users', query='cql.allRecords=1 sortby id')
ldlite: querying: / users
ldlite: created
tables: u, u__t, u__t__departments, u__t__personal__addresses, u__t__proxy_for, u__tcatalog
>> > cur = db.cursor()
>> > _ = cur.execute("""
CREATE TABLE user_groups AS
SELECT u__t.id, u__t.username, g__t.group
FROM u__t
JOIN g__t ON u__t.patron_group = g__t.id;
""")
>> > ld.export_excel(table='user_groups', filename='groups.xlsx')
Features
- Queries Okapi-based modules and transforms JSON data into tables for easier reporting
- Full SQL query support and export to CSV or Excel
- Compatible with DBeaver database tool
- Compatible with DuckDB and PostgreSQL database systems
- PostgreSQL support enables:
- Sharing the data in a multiuser database
- Access to the data using more database tools
- Storing the data in an existing LDP database if available
- Runs on Windows, macOS, and Linux.
More examples
LDLite resources
Note: the following resources are for the original ldlite project. There shouldn't be any significant differences right now, but that could change
-
The LDP project runs a Slack workspace which is a good place to ask questions or to share your work. It also serves as a community space for working together on library data problems. To request an invitation, use the Contact page on the LDP website.
Other resources
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ldlite_rtr-0.1.1.tar.gz.
File metadata
- Download URL: ldlite_rtr-0.1.1.tar.gz
- Upload date:
- Size: 19.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1ac6ee5d1b55f82b7961f7fd05295bacdc0de68a968dac13d4030491a3fa443e
|
|
| MD5 |
866e32ad750a484b926a390165c6841f
|
|
| BLAKE2b-256 |
9631c2545dcab623e29ad88da28b8a0c2d8a125cf042d7972510c5b19b756aed
|
Provenance
The following attestation bundles were made for ldlite_rtr-0.1.1.tar.gz:
Publisher:
publish.yml on bltravis/ldlite-rtr
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ldlite_rtr-0.1.1.tar.gz -
Subject digest:
1ac6ee5d1b55f82b7961f7fd05295bacdc0de68a968dac13d4030491a3fa443e - Sigstore transparency entry: 162534845
- Sigstore integration time:
-
Permalink:
bltravis/ldlite-rtr@e1225ac518405eaf206ee7e75b818c7625725267 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/bltravis
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@e1225ac518405eaf206ee7e75b818c7625725267 -
Trigger Event:
release
-
Statement type:
File details
Details for the file ldlite_rtr-0.1.1-py3-none-any.whl.
File metadata
- Download URL: ldlite_rtr-0.1.1-py3-none-any.whl
- Upload date:
- Size: 21.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.0.1 CPython/3.12.8
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
69e073411748b37c8b7ad291b11b444c741e1b6f217a21a2a1159b071a27458d
|
|
| MD5 |
3805c95f90c20eb2830d1444977c5771
|
|
| BLAKE2b-256 |
4f456502a6ab0f7afa5ebd4ea4cdfc501deee6d9d556acf5a0b92f239b68fc5f
|
Provenance
The following attestation bundles were made for ldlite_rtr-0.1.1-py3-none-any.whl:
Publisher:
publish.yml on bltravis/ldlite-rtr
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
ldlite_rtr-0.1.1-py3-none-any.whl -
Subject digest:
69e073411748b37c8b7ad291b11b444c741e1b6f217a21a2a1159b071a27458d - Sigstore transparency entry: 162534848
- Sigstore integration time:
-
Permalink:
bltravis/ldlite-rtr@e1225ac518405eaf206ee7e75b818c7625725267 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/bltravis
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@e1225ac518405eaf206ee7e75b818c7625725267 -
Trigger Event:
release
-
Statement type: