root/dev/: dmcl-3.4.2 metadata and description

Simple index Newer version available

Course Lesson Service for Darsman Academy

author Ellnamin
author_email ellnamin.business@gmail.com
requires_dist
  • annotated-types==0.6.0
  • grpcio==1.62.1
  • grpcio-tools==1.62.1
  • protobuf==4.25.3
  • pydantic==2.7.0
  • pydantic-settings==2.10.1
  • pydantic-core==2.18.1
  • typing-inspection==0.4.1
  • typing-extensions==4.14.1

Because this project isn't in the mirror_whitelist, no releases from root/pypi are included.

File Tox results History
dmcl-3.4.2-py3-none-any.whl
Size
16 KB
Type
Python Wheel
Python
3
  • Uploaded to root/dev by root 2025-12-16 09:05:37
dmcl-3.4.2.tar.gz
Size
16 KB
Type
Source
  • Uploaded to root/dev by root 2025-12-16 09:05:38
# Darsman Course Lesson

## Requirements

- Python (== 3.10)
- grpcio-tools (>=1.62.1)

## Installation

Run the following command using pip:

```bash
pip install dmcl
```

## Sample code

```python
import asyncio
from dmcl import Course, Lesson, Package


# Note:
# Course has the widest functionality so is used here.
# Lesson and Package should be used in the same way.

async def main():
# see `Env example` for confgs, you may want to only fill host,port and api_key
course = Course()

# Get one course using its identifier
await course.fetch_one(
identifier="b2f6c8e2-7e3a-4cb3-a58e-ef4e3f893708",
timeout="3.5", # Optional: override default timeout
wait_for_ready=True # Optional: wait for channel if not ready
)

# Get all courses
await course.fetch_all(order_by="title", page_size=1, page_number=1)

# Like a course
await course.like(
course_identifier="b2f6c8e2-7e3a-4cb3-a58e-ef4e3f893708",
)

# Unlike a course
await course.unlike(
course_identifier="b2f6c8e2-7e3a-4cb3-a58e-ef4e3f893708",
)

# Add comment to a course
await course.comment(
name="Utaab",
content="Hello I'm Utaab",
owner_identifier="b2f6c8e2-7e3a-4cb3-a58e-ef4e3f893708"
)

if __name__ == "__main__":
loop = asyncio.get_event_loop()
loop.run_until_complete(main())

```

## Env example

```python
### === COURSE_LESSON SDK CONFIG === ###

# Server config
COURSE_LESSON_SDK_HOST=127.0.0.1
COURSE_LESSON_SDK_PORT=50051
COURSE_LESSON_SDK_API_KEY=your_api_key_here

# Graceful shutdown
COURSE_LESSON_SDK_CHANNEL_SHUTDOWN_GRACE=10

# Keepalive (for long-lived connection health checks)
COURSE_LESSON_SDK_KEEPALIVE_TIME_MS=60000
COURSE_LESSON_SDK_KEEPALIVE_TIMEOUT_MS=5000
COURSE_LESSON_SDK_KEEPALIVE_PERMIT_WITHOUT_CALLS=1
COURSE_LESSON_SDK_MAX_PINGS_WITHOUT_DATA=0

# Retry policy
COURSE_LESSON_SDK_MAX_ATTEMPTS=5 # more than 5 isn't allowed by grpc
COURSE_LESSON_SDK_INITIAL_BACKOFF=0.1s
COURSE_LESSON_SDK_MAX_BACKOFF=1.5s
COURSE_LESSON_SDK_BACKOFF_MULTIPLIER=2.0
COURSE_LESSON_SDK_RETRYABLE_STATUS_CODES=["UNAVAILABLE", "RESOURCE_EXHAUSTED", "ABORTED"]

# RPC-level configs
COURSE_LESSON_SDK_WAIT_FOR_READY=true
COURSE_LESSON_SDK_TIMEOUT=5.0
```


Render warnings:
<string>:18: (WARNING/2) Inline literal start-string without end-string.