-
Notifications
You must be signed in to change notification settings - Fork 79
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add metadata field to SendMessageRequest and Message model (#399)
* Add metadata field to SendMessageRequest model - Added metadata field to CreateDraftRequest which is inherited by SendMessageRequest - Added test cases for metadata in draft creation and message sending - Updated docstring to include metadata field description Fixes #394 Co-Authored-By: Aaron de Mello <[email protected]> * Update test assertion to use keyword arguments Co-Authored-By: Aaron de Mello <[email protected]> * Update CHANGELOG.md for metadata field addition Co-Authored-By: Aaron de Mello <[email protected]> * Update changelog format to match version entry style Co-Authored-By: Aaron de Mello <[email protected]> * Add E2E example for metadata field functionality Co-Authored-By: Aaron de Mello <[email protected]> * Update metadata example to use local package instead of pip install Co-Authored-By: Aaron de Mello <[email protected]> * Added the metadata property to the Message model --------- Co-authored-by: Devin AI <158243242+devin-ai-integration[bot]@users.noreply.github.com> Co-authored-by: Aaron de Mello <[email protected]>
- Loading branch information
1 parent
5922f8c
commit e0c4cf2
Showing
7 changed files
with
587 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,67 @@ | ||
# Metadata Field Example | ||
|
||
This example demonstrates how to use metadata fields when creating drafts and sending messages using the Nylas Python SDK. | ||
|
||
## Features | ||
|
||
- Create drafts with custom metadata fields | ||
- Send messages with custom metadata fields | ||
- Error handling and environment variable configuration | ||
- Clear output and status messages | ||
|
||
## Prerequisites | ||
|
||
1. A Nylas account with API access | ||
2. Python 3.x installed | ||
3. Local installation of the Nylas Python SDK (this repository) | ||
|
||
## Setup | ||
|
||
1. Install the SDK in development mode from the repository root: | ||
```bash | ||
cd /path/to/nylas-python | ||
pip install -e . | ||
``` | ||
|
||
2. Set your environment variables: | ||
```bash | ||
export NYLAS_API_KEY="your_api_key" | ||
export NYLAS_GRANT_ID="your_grant_id" | ||
export TEST_EMAIL="[email protected]" # Optional | ||
``` | ||
|
||
3. Run the example from the repository root: | ||
```bash | ||
python examples/metadata_field_demo/metadata_example.py | ||
``` | ||
|
||
## Example Output | ||
|
||
``` | ||
Demonstrating Metadata Field Usage | ||
================================= | ||
1. Creating draft with metadata... | ||
✓ Created draft with ID: draft-abc123 | ||
Request ID: req-xyz789 | ||
2. Sending message with metadata... | ||
✓ Sent message with ID: msg-def456 | ||
Request ID: req-uvw321 | ||
Example completed successfully! | ||
``` | ||
|
||
## Error Handling | ||
|
||
The example includes proper error handling for: | ||
- Missing environment variables | ||
- API authentication errors | ||
- Draft creation failures | ||
- Message sending failures | ||
|
||
## Documentation | ||
|
||
For more information about the Nylas Python SDK and its features, visit: | ||
- [Nylas Python SDK Documentation](https://developer.nylas.com/docs/sdks/python/) | ||
- [Nylas API Reference](https://developer.nylas.com/docs/api/) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,137 @@ | ||
#!/usr/bin/env python3 | ||
""" | ||
Nylas SDK Example: Using Metadata Fields with Drafts and Messages | ||
This example demonstrates how to use metadata fields when creating drafts | ||
and sending messages using the Nylas Python SDK. | ||
Required Environment Variables: | ||
NYLAS_API_KEY: Your Nylas API key | ||
NYLAS_GRANT_ID: Your Nylas grant ID | ||
TEST_EMAIL: Email address for sending test messages (optional) | ||
Usage: | ||
First, install the SDK in development mode: | ||
cd /path/to/nylas-python | ||
pip install -e . | ||
Then set environment variables and run: | ||
export NYLAS_API_KEY="your_api_key" | ||
export NYLAS_GRANT_ID="your_grant_id" | ||
export TEST_EMAIL="[email protected]" | ||
python examples/metadata_field_demo/metadata_example.py | ||
""" | ||
|
||
import os | ||
import sys | ||
from typing import Dict, Any, Optional | ||
|
||
# Import from local nylas package | ||
from nylas import Client | ||
from nylas.models.errors import NylasApiError | ||
|
||
|
||
def get_env_or_exit(var_name: str, required: bool = True) -> Optional[str]: | ||
"""Get an environment variable or exit if required and not found.""" | ||
value = os.getenv(var_name) | ||
if required and not value: | ||
print(f"Error: {var_name} environment variable is required") | ||
sys.exit(1) | ||
return value | ||
|
||
|
||
def create_draft_with_metadata( | ||
client: Client, grant_id: str, metadata: Dict[str, Any], recipient: str | ||
) -> str: | ||
"""Create a draft message with metadata fields.""" | ||
try: | ||
draft_request = { | ||
"subject": "Test Draft with Metadata", | ||
"to": [{"email": recipient}], | ||
"body": "This is a test draft with metadata fields.", | ||
"metadata": metadata | ||
} | ||
|
||
draft, request_id = client.drafts.create( | ||
identifier=grant_id, | ||
request_body=draft_request | ||
) | ||
print(f"✓ Created draft with ID: {draft.id}") | ||
print(f" Request ID: {request_id}") | ||
return draft.id | ||
except NylasApiError as e: | ||
print(f"✗ Failed to create draft: {e}") | ||
sys.exit(1) | ||
|
||
|
||
def send_message_with_metadata( | ||
client: Client, grant_id: str, metadata: Dict[str, Any], recipient: str | ||
) -> str: | ||
"""Send a message directly with metadata fields.""" | ||
try: | ||
message_request = { | ||
"subject": "Test Message with Metadata", | ||
"to": [{"email": recipient}], | ||
"body": "This is a test message with metadata fields.", | ||
"metadata": metadata | ||
} | ||
|
||
message, request_id = client.messages.send( | ||
identifier=grant_id, | ||
request_body=message_request | ||
) | ||
print(f"✓ Sent message with ID: {message.id}") | ||
print(f" Request ID: {request_id}") | ||
|
||
return message.id | ||
except NylasApiError as e: | ||
print(f"✗ Failed to send message: {e}") | ||
sys.exit(1) | ||
|
||
|
||
def main(): | ||
"""Main function demonstrating metadata field usage.""" | ||
# Get required environment variables | ||
api_key = get_env_or_exit("NYLAS_API_KEY") | ||
grant_id = get_env_or_exit("NYLAS_GRANT_ID") | ||
recipient = get_env_or_exit("TEST_EMAIL", required=False) or "[email protected]" | ||
|
||
# Initialize Nylas client | ||
client = Client( | ||
api_key=api_key, | ||
) | ||
|
||
# Example metadata | ||
metadata = { | ||
"campaign_id": "example-123", | ||
"user_id": "user-456", | ||
"custom_field": "test-value" | ||
} | ||
|
||
print("\nDemonstrating Metadata Field Usage") | ||
print("=================================") | ||
|
||
# Create a draft with metadata | ||
print("\n1. Creating draft with metadata...") | ||
draft_id = create_draft_with_metadata(client, grant_id, metadata, recipient) | ||
|
||
# Send a message with metadata | ||
print("\n2. Sending message with metadata...") | ||
message_id = send_message_with_metadata(client, grant_id, metadata, recipient) | ||
|
||
print("\nExample completed successfully!") | ||
|
||
# Get the draft and message to demonstrate metadata retrieval | ||
draft = client.drafts.find(identifier=grant_id, draft_id=draft_id) | ||
message = client.messages.find(identifier=grant_id, message_id=message_id) | ||
|
||
print("\nRetrieved Draft Metadata:") | ||
print("-------------------------") | ||
print(draft.data) | ||
|
||
print("\nRetrieved Message Metadata:") | ||
print("---------------------------") | ||
print(message.data) | ||
|
||
if __name__ == "__main__": | ||
main() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,6 +2,7 @@ | |
|
||
from nylas.models.drafts import Draft | ||
from nylas.resources.drafts import Drafts | ||
from nylas.resources.messages import Messages | ||
|
||
|
||
class TestDraft: | ||
|
@@ -143,6 +144,27 @@ def test_create_draft(self, http_client_response): | |
overrides=None, | ||
) | ||
|
||
def test_create_draft_with_metadata(self, http_client_response): | ||
drafts = Drafts(http_client_response) | ||
request_body = { | ||
"subject": "Hello from Nylas!", | ||
"to": [{"name": "Jon Snow", "email": "[email protected]"}], | ||
"cc": [{"name": "Arya Stark", "email": "[email protected]"}], | ||
"body": "This is the body of my draft message.", | ||
"metadata": {"custom_field": "value", "another_field": 123} | ||
} | ||
|
||
drafts.create(identifier="abc-123", request_body=request_body) | ||
|
||
http_client_response._execute.assert_called_once_with( | ||
"POST", | ||
"/v3/grants/abc-123/drafts", | ||
None, | ||
None, | ||
request_body, | ||
overrides=None, | ||
) | ||
|
||
def test_create_draft_small_attachment(self, http_client_response): | ||
drafts = Drafts(http_client_response) | ||
request_body = { | ||
|
@@ -349,6 +371,25 @@ def test_send_draft(self, http_client_response): | |
method="POST", path="/v3/grants/abc-123/drafts/draft-123", overrides=None | ||
) | ||
|
||
def test_send_message_with_metadata(self, http_client_response): | ||
messages = Messages(http_client_response) | ||
request_body = { | ||
"subject": "Hello from Nylas!", | ||
"to": [{"name": "Jon Snow", "email": "[email protected]"}], | ||
"body": "This is the body of my message.", | ||
"metadata": {"custom_field": "value", "another_field": 123} | ||
} | ||
|
||
messages.send(identifier="abc-123", request_body=request_body) | ||
|
||
http_client_response._execute.assert_called_once_with( | ||
method="POST", | ||
path="/v3/grants/abc-123/messages/send", | ||
request_body=request_body, | ||
data=None, | ||
overrides=None, | ||
) | ||
|
||
def test_send_draft_encoded_id(self, http_client_response): | ||
drafts = Drafts(http_client_response) | ||
|
||
|
Oops, something went wrong.