Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

added discord connector #783

Open
wants to merge 30 commits into
base: develop
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 3 commits
Commits
Show all changes
30 commits
Select commit Hold shift + click to select a range
1df7cb2
added discord connector
SubramanyamChalla24 Oct 14, 2023
3b59c1b
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 18, 2023
cb154e7
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 20, 2023
07e3130
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 21, 2023
626ca3c
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 21, 2023
ce0b420
included reviews
SubramanyamChalla24 Oct 21, 2023
eba8e63
added qdrant connector
SubramanyamChalla24 Oct 23, 2023
d263792
qdrant connector settings
SubramanyamChalla24 Oct 23, 2023
075aac1
Merge branch 'swirlai:develop' into develop
SubramanyamChalla24 Oct 23, 2023
38a7035
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 23, 2023
02736f4
small update
SubramanyamChalla24 Oct 23, 2023
53c2293
Merge remote-tracking branch 'origin/develop' into develop
SubramanyamChalla24 Oct 23, 2023
5fc45d6
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 23, 2023
3b4f088
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 24, 2023
f5f5ad0
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 25, 2023
5de12db
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 25, 2023
f5bf934
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 25, 2023
465799c
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 25, 2023
3e6f960
added requirements
SubramanyamChalla24 Oct 26, 2023
88c43c9
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 27, 2023
6444614
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 30, 2023
1f8e750
Merge branch 'develop' into develop
SubramanyamChalla24 Oct 30, 2023
5c67c00
Merge branch 'develop' into develop
SubramanyamChalla24 Nov 1, 2023
b320abd
updated connectors and search providers
SubramanyamChalla24 Nov 1, 2023
3cfaebe
updated requirements.txt
SubramanyamChalla24 Nov 1, 2023
5640a30
Merge branch 'develop' into develop
SubramanyamChalla24 Nov 1, 2023
8d61944
Merge branch 'develop' into develop
SubramanyamChalla24 Nov 2, 2023
a9d25d6
Merge branch 'develop' into develop
SubramanyamChalla24 Nov 3, 2023
76e2970
Merge branch 'develop' into develop
SubramanyamChalla24 Nov 7, 2023
2d65bc6
Merge branch 'develop' into develop
SubramanyamChalla24 Nov 8, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
22 changes: 22 additions & 0 deletions SearchProviders/discord.json
SubramanyamChalla24 marked this conversation as resolved.
Show resolved Hide resolved
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
{
"name": "Discord",
"active": true,
"default": true,
"connector": "Discord",
"url": "",
"query_template": "Fetch last {limit} messages from channel {channel_id}",
"query_processors": [
"DiscordMessageQueryProcessor"
],
"query_mappings": "NOT=True",
"result_processors": [
"MappingResultProcessor"
],
"response_mappings": "AUTHOR=message.author.name, CONTENT=message.content, TIMESTAMP=message.created_at",
"result_mappings": "MESSAGE_CONTENT=message['Content']",
"results_per_query": 5,
"credentials": "add token here",
"tags": [
"Discord"
]
}
2 changes: 1 addition & 1 deletion swirl/connectors/__init__.py
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
from swirl.connectors.microsoft_graph import M365OutlookCalendar
from swirl.connectors.microsoft_graph import M365SharePointSites
from swirl.connectors.microsoft_graph import MicrosoftTeams

from swirl.connectors.discord import Discord

# uncomment the line below to enable PostgreSQL
# from swirl.connectors.postgresql import PostgreSQL
Expand Down
66 changes: 66 additions & 0 deletions swirl/connectors/discord.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,66 @@
import asyncio

import discord
from django.conf import settings

from swirl.connectors.connector import Connector
from swirl.connectors.mappings import *

logger = get_task_logger(__name__)
path.append(swirl_setdir())
environ.setdefault('DJANGO_SETTINGS_MODULE', 'swirl_server.settings')
django.setup()


class Discord(Connector):
type = "Discord"

def __init__(self, provider_id, search_id, update, request_id=''):
self.client = discord.Client(intents=discord.Intents.all())
super().__init__(provider_id, search_id, update, request_id)
self.client.event(self.on_ready)

async def on_ready(self):
await self.client.wait_until_ready()
await asyncio.sleep(2)
#replace your channel id here
channel_id = 718114919056146528
SubramanyamChalla24 marked this conversation as resolved.
Show resolved Hide resolved
target_channel = self.client.get_channel(channel_id)
if target_channel is None:
print('Channel not found')
SubramanyamChalla24 marked this conversation as resolved.
Show resolved Hide resolved
self.status = "ERR_CHANNEL_NOT_FOUND"
return

print('Connected')
messages_data = []
async for message in target_channel.history(limit=5):
messages_data.append({
SubramanyamChalla24 marked this conversation as resolved.
Show resolved Hide resolved
"author": message.author.name,
"body": message.content,
"title": "discord"
})
SubramanyamChalla24 marked this conversation as resolved.
Show resolved Hide resolved
self.response = messages_data
logger.info(f"data={messages_data}")
await self.client.close()

def execute_search(self, session=None):
if self.provider.credentials:
token = self.provider.credentials
else:
if getattr(settings, 'DISCORD_BOT_TOKEN', None):
token = settings.DISCORD_BOT_TOKEN
logger.info(f"token={token}")
else:
self.status = "ERR_NO_CREDENTIALS"
return
try:
self.client.run(token)
except Exception as e:
logger.error(f"Failed to start client: {e}")
self.status = "ERR_CLIENT_START_FAILURE"

def normalize_response(self):

logger.debug(f"{self}: normalize_response()")
self.results = self.response
return
1 change: 1 addition & 0 deletions swirl/models.py
Original file line number Diff line number Diff line change
Expand Up @@ -67,6 +67,7 @@ class SearchProvider(models.Model):
'MicrosoftTeams': 'Microsoft',
})
CONNECTOR_CHOICES = [
('Discord', 'Discord'),
('ChatGPT', 'ChatGPT Query String'),
('RequestsGet', 'HTTP/GET returning JSON'),
('RequestsPost', 'HTTP/POST returning JSON'),
Expand Down