Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gearplug/calendly-python
calendly-python is an API wrapper for Calendly, written in Python
https://github.com/gearplug/calendly-python
api calendar calendly events oauth2 python webhooks wrapper
Last synced: 5 days ago
JSON representation
calendly-python is an API wrapper for Calendly, written in Python
- Host: GitHub
- URL: https://github.com/gearplug/calendly-python
- Owner: GearPlug
- License: mit
- Created: 2022-12-22T19:30:32.000Z (about 2 years ago)
- Default Branch: main
- Last Pushed: 2024-03-12T18:15:30.000Z (10 months ago)
- Last Synced: 2024-12-22T18:04:45.828Z (23 days ago)
- Topics: api, calendar, calendly, events, oauth2, python, webhooks, wrapper
- Language: Python
- Homepage:
- Size: 10.7 KB
- Stars: 3
- Watchers: 0
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
![](https://img.shields.io/badge/version-0.1.1-success) ![](https://img.shields.io/badge/Python-3.8%20|%203.9%20|%203.10%20|%203.11-4B8BBE?logo=python&logoColor=white)
# calendly-pythoncalendly-python is an API wrapper for Calendly, written in Python
## Installing
```
pip install calendly-python
```
## Usage
```
from calendly.client import Client
client = Client('access_token')user_uri = client.user_uri
user_uuid = client.user_uuid
organization_uri = client.organization_uri
organization_uuid = client.organization_uuid
```If you don't have access_token you can get one using Oauth2, following the next steps:
Check https://developer.calendly.com/how-to-authenticate-with-oauth, for more info.
1. Initiate client:
```
client = Client(client_id="client_id", client_secret="client_secret", redirect_uri="redirect_uri")
```
2. Get authorization URL to get code
```
url = client.authorization_url()
```
3. Get access token using code
```
response = client.get_access_token(code)
```
4. Set access token
```
client.set_token(access_token)
```
If your access token expired, you can get a new one using refresh_token:
```
response = client.refresh_access_token(refresh_token)
```
And then set access token again...
#### Current User
```
current_user = client.get_current_user()
```
#### Get Scheduled Event
```
event = client.get_scheduled_event(event_uuid)
```
### Webhooks
#### Create webhook
```
webhook = client.create_webhook(self, url, events, organization_uri, user_uri, scope)
# events: must be a list of valid events (check calendly API)
# scope: two options: "user" or "organization"
```
#### List webhooks
```
webhooks = client.list_webhooks(self, scope, organization_uri, user_uri=None)
# scope: two options: "user" or "organization"
# Note: must send user_uri if scope = "user"
```
#### Delete webhook
```
client.delete_webhook(webhook_uuid)
```