diff options
author | Nate Sesti <sestinj@gmail.com> | 2023-08-07 15:38:47 -0700 |
---|---|---|
committer | Nate Sesti <sestinj@gmail.com> | 2023-08-07 15:38:47 -0700 |
commit | 6467759012a139e76dcf022a681355f7d310a30d (patch) | |
tree | b7202325fb6bec03c7977c841a37d3462ce48860 /continuedev | |
parent | 18779801745502236aea94c679f07cc8f19d4824 (diff) | |
download | sncontinue-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.py | 51 |
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 |