Experimental Python class abstraction layer for `spond` package.
Project description
Spond-classes
About
Spond is a team/group-oriented events system.
The unofficial Python spond
library package gets
data from the Spond API and returns dict
objects.
This unofficial Python spond-classes
package parses those dict
objects to create
class instances, i.e. provides an object abstraction layer.
Experimental, very partial, read-only implementation.
Install
Install from PyPI, e.g:
pip install spond-classes
Or if you're using Poetry:
poetry add spond-classes
Example code
Adapting the example code in Spond
README:
import asyncio
from spond import spond
import spond_classes
# fake credentials and ids
username = 'my@mail.invalid'
password = 'Pa55worD'
group_id = 'G1'
subgroup_id = 'SG1'
async def main():
s = spond.Spond(username=username, password=password)
group_data = await s.get_group(group_id)
await s.clientsession.close()
# Now we can create a class instance ...
group = spond_classes.Group(**group_data)
# ... use class properties instead of dict keys ...
print(group.name)
# ... access nested instances and their properties ...
for member in group.members:
print(f"{member.full_name} is in the {group.name} group")
# ... and use some helper methods
subgroup = group.subgroup_by_id(subgroup_id)
for member in group.members_by_subgroup(subgroup)
print(f"{member.full_name} is in the {subgroup.name} subgroup")
asyncio.run(main())
Key features
- Create
Group
instance from the dict returned from the API by the correspondingSpond
method:
spond_classes.Group(**dict)
- Then access class instance attributes and methods:
Group.uid: str
Group.members: list[Member]
Group.name: str
Group.roles: list[Role]
Group.subgroups: list[Subgroup]
Group.member_by_id() -> Member
Group.role_by_id() -> Role
Group.subgroup_by_id() -> Subgroup
Group.members_by_subgroup(subgroup: Subgroup) -> list[Member]
Group.members_by_role(role: Role) -> list[Member]
- Also provides access to nested
Member
,Role
,Subgroup
instances:
Member.uid: str
Member.created_time: datetime
Member.email: str
Member.first_name: str
Member.full_name: str
Member.last_name: str
Member.phone_number: str
Member.Profile.uid: str
Member.role_uids: list[str]
Member.subgroup_uids: list[str]
Role.uid: str
Role.name: str
Subgroup.uid: str
Subgroup.name: str
- Create
Event
instance from the dict returned from the API by the correspondingSpond
method:
spond_classes.Event(**dict)
- Then access attributes:
Event.uid: str
Event.heading: str
Event.start_time: datetime
Event.Responses.accepted_uids: list[str]
Event.Responses.declined_uids: list[str]
Event.Responses.unanswered_uids: list[str]
Event.Responses.waiting_list_uids: list[str]
Event.Responses.unconfirmed_uids: list[str]
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
spond_classes-0.10.0.post0.tar.gz
(18.8 kB
view hashes)
Built Distribution
Close
Hashes for spond_classes-0.10.0.post0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 221e56812b1ecb8e913e58402f217ffa61a472978bffc0248f74bafd605223c4 |
|
MD5 | b9f8165163892e5d141d513f5a6c14ba |
|
BLAKE2b-256 | 96f1c9373142685e900e35ec97482ef8789edb9823e649562db4a47016e6adbc |
Close
Hashes for spond_classes-0.10.0.post0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 8e335ff5775f3077b65e2d2681d3fa6ac3b705f569123baf7f63f51f62ebee13 |
|
MD5 | fd18e7a6e44779b6bdb97ddc6c4366f0 |
|
BLAKE2b-256 | c50a03f30f59f48a432b3901f8cca5759d1b135645ab8317366a3b5a4ef201c0 |