Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cloud-py-api/nc_py_api
Nextcloud Python Framework
https://github.com/cloud-py-api/nc_py_api
app async nextcloud python
Last synced: 2 days ago
JSON representation
Nextcloud Python Framework
- Host: GitHub
- URL: https://github.com/cloud-py-api/nc_py_api
- Owner: cloud-py-api
- License: other
- Created: 2023-06-20T11:45:54.000Z (over 1 year ago)
- Default Branch: main
- Last Pushed: 2025-01-06T18:02:49.000Z (18 days ago)
- Last Synced: 2025-01-08T08:02:04.755Z (16 days ago)
- Topics: app, async, nextcloud, python
- Language: Python
- Homepage: https://cloud-py-api.github.io/nc_py_api/
- Size: 5.81 MB
- Stars: 103
- Watchers: 7
- Forks: 7
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE.txt
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
- Authors: AUTHORS
Awesome Lists containing this project
README
# Nextcloud Python Framework
[![Analysis & Coverage](https://github.com/cloud-py-api/nc_py_api/actions/workflows/analysis-coverage.yml/badge.svg)](https://github.com/cloud-py-api/nc_py_api/actions/workflows/analysis-coverage.yml)
[![Docs](https://github.com/cloud-py-api/nc_py_api/actions/workflows/docs.yml/badge.svg)](https://cloud-py-api.github.io/nc_py_api/)
[![codecov](https://codecov.io/github/cloud-py-api/nc_py_api/branch/main/graph/badge.svg?token=C91PL3FYDQ)](https://codecov.io/github/cloud-py-api/nc_py_api)![NextcloudVersion](https://img.shields.io/badge/Nextcloud-27%20%7C%2028%20%7C%2029%20%7C%2030-blue)
![PythonVersion](https://img.shields.io/badge/python-3.10%20%7C%203.11%20%7C%203.12-blue)
![impl](https://img.shields.io/pypi/implementation/nc_py_api)
![pypi](https://img.shields.io/pypi/v/nc_py_api.svg)Python library that provides a robust and well-documented API that allows developers to interact with and extend Nextcloud's functionality.
### The key features are:
* **Fast**: High performance, and as low-latency as possible.
* **Intuitive**: Fast to code, easy to use.
* **Reliable**: Minimum number of incompatible changes.
* **Robust**: All code is covered with tests as much as possible.
* **Easy**: Designed to be easy to use with excellent documentation.
* **Sync + Async**: Provides both sync and async APIs.### Capabilities
| **_Capability_** | Nextcloud 27 | Nextcloud 28 | Nextcloud 29 | Nextcloud 30 |
|------------------------------|:------------:|:------------:|:------------:|:------------:|
| Calendar | ✅ | ✅ | ✅ | ✅ |
| File System & Tags | ✅ | ✅ | ✅ | ✅ |
| Nextcloud Talk | ✅ | ✅ | ✅ | ✅ |
| Notifications | ✅ | ✅ | ✅ | ✅ |
| Shares | ✅ | ✅ | ✅ | ✅ |
| Users & Groups | ✅ | ✅ | ✅ | ✅ |
| User & Weather status | ✅ | ✅ | ✅ | ✅ |
| Other APIs** | ✅ | ✅ | ✅ | ✅ |
| Talk Bot API* | ✅ | ✅ | ✅ | ✅ |
| Settings UI API* | N/A | N/A | ✅ | ✅ |
| TaskProcessing Provider API* | N/A | N/A | N/A | ✅ |*_available only for **NextcloudApp**_
**_Activity, Notes_### Differences between the Nextcloud and NextcloudApp classes
The **Nextcloud** class functions as a standard Nextcloud client,
enabling you to make API requests using a username and password.On the other hand, the **NextcloudApp** class is designed for creating applications for Nextcloud.
It uses [AppAPI](https://github.com/cloud-py-api/app_api) to provide additional functionality allowing
applications have their own graphical interface, fulfill requests from different users,
and everything else that is necessary to implement full-fledged applications.Both classes offer most of the same APIs,
but NextcloudApp has a broader selection since applications typically require access to more APIs.Any code written for the Nextcloud class can easily be adapted for use with the NextcloudApp class,
as long as it doesn't involve calls that require user password verification.**NextcloudApp** avalaible only from Nextcloud 27.1.2 and greater version with installed **AppAPI**.
### Nextcloud skeleton app in Python
```python3
from contextlib import asynccontextmanagerfrom fastapi import FastAPI
from nc_py_api import NextcloudApp
from nc_py_api.ex_app import AppAPIAuthMiddleware, LogLvl, run_app, set_handlers@asynccontextmanager
async def lifespan(app: FastAPI):
set_handlers(app, enabled_handler)
yieldAPP = FastAPI(lifespan=lifespan)
APP.add_middleware(AppAPIAuthMiddleware)def enabled_handler(enabled: bool, nc: NextcloudApp) -> str:
if enabled:
nc.log(LogLvl.WARNING, "Hello from nc_py_api.")
else:
nc.log(LogLvl.WARNING, "Bye bye from nc_py_api.")
return ""if __name__ == "__main__":
run_app("main:APP", log_level="trace")
```### Support
You can support us in several ways:
- ⭐️ Star our work (it really motivates)
- ❗️ Create an Issue or feature request (bring to us an excellent idea)
- 💁 Resolve some Issue or create a Pull Request (contribute to this project)
- 🙏 Write an example of its use or correct a typo in the documentation.## More Information
- [Documentation](https://cloud-py-api.github.io/nc_py_api/)
- [First steps](https://cloud-py-api.github.io/nc_py_api/FirstSteps.html)
- [More APIs](https://cloud-py-api.github.io/nc_py_api/MoreAPIs.html)
- [Writing a simple Nextcloud Application](https://cloud-py-api.github.io/nc_py_api/NextcloudApp.html)
- [Using Nextcloud Talk Bot API in Application](https://cloud-py-api.github.io/nc_py_api/NextcloudTalkBot.html)
- [Using Language Models In Application](https://cloud-py-api.github.io/nc_py_api/NextcloudTalkBotTransformers.html)
- [Writing a Nextcloud System Application](https://cloud-py-api.github.io/nc_py_api/NextcloudSysApp.html)
- [Examples](https://github.com/cloud-py-api/nc_py_api/tree/main/examples)
- [Contribute](https://github.com/cloud-py-api/nc_py_api/blob/main/.github/CONTRIBUTING.md)
- [Discussions](https://github.com/cloud-py-api/nc_py_api/discussions)
- [Issues](https://github.com/cloud-py-api/nc_py_api/issues)
- [Setting up dev environment](https://cloud-py-api.github.io/nc_py_api/DevSetup.html)
- [Changelog](https://github.com/cloud-py-api/nc_py_api/blob/main/CHANGELOG.md)