summaryrefslogtreecommitdiff
path: root/continuedev
diff options
context:
space:
mode:
authorNate Sesti <sestinj@gmail.com>2023-08-07 15:38:47 -0700
committerNate Sesti <sestinj@gmail.com>2023-08-07 15:38:47 -0700
commit6467759012a139e76dcf022a681355f7d310a30d (patch)
treeb7202325fb6bec03c7977c841a37d3462ce48860 /continuedev
parent18779801745502236aea94c679f07cc8f19d4824 (diff)
downloadsncontinue-6467759012a139e76dcf022a681355f7d310a30d.tar.gz
sncontinue-6467759012a139e76dcf022a681355f7d310a30d.tar.bz2
sncontinue-6467759012a139e76dcf022a681355f7d310a30d.zip
feat: :construction: first work on URLContextProvider
Diffstat (limited to 'continuedev')
-rw-r--r--continuedev/src/continuedev/plugins/context_providers/url.py51
1 files changed, 51 insertions, 0 deletions
diff --git a/continuedev/src/continuedev/plugins/context_providers/url.py b/continuedev/src/continuedev/plugins/context_providers/url.py
new file mode 100644
index 00000000..d6a74d95
--- /dev/null
+++ b/continuedev/src/continuedev/plugins/context_providers/url.py
@@ -0,0 +1,51 @@
+from typing import List
+
+from .util import remove_meilisearch_disallowed_chars
+from ...core.main import ContextItem, ContextItemDescription, ContextItemId
+from ...core.context import ContextProvider
+
+
+class URLContextProvider(ContextProvider):
+ title = "url"
+
+ URL_CONTEXT_ITEM_ID = "url"
+
+ @property
+ def BASE_CONTEXT_ITEM(self):
+ return ContextItem(
+ content="",
+ description=ContextItemDescription(
+ name="URL",
+ description="Reference the contents of a webpage (e.g. '@url https://www.w3schools.com/python/python_ref_functions.asp')",
+ id=ContextItemId(
+ provider_title=self.title,
+ item_id=self.URL_CONTEXT_ITEM_ID
+ )
+ )
+ )
+
+ def _get_url_text_contents(self, url: str):
+ import requests
+
+ response = requests.get(url)
+ return response.text
+
+ async def provide_context_items(self, workspace_dir: str) -> List[ContextItem]:
+ self.workspace_dir = workspace_dir
+ return [self.BASE_CONTEXT_ITEM]
+
+ async def get_item(self, id: ContextItemId, query: str) -> ContextItem:
+ if not id.item_id == self.URL_CONTEXT_ITEM_ID:
+ raise Exception("Invalid item id")
+
+ query = query.lstrip("url ")
+ url = query.strip()
+ content = await self._get_url_text_contents(url)
+
+ ctx_item = self.BASE_CONTEXT_ITEM.copy()
+ ctx_item.content = content
+ ctx_item.description.name = url.replace(
+ "https://", "").replace("http://", "")
+ ctx_item.description.id.item_id = remove_meilisearch_disallowed_chars(
+ query)
+ return ctx_item