webscout 7.9__py3-none-any.whl → 8.1__py3-none-any.whl

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.

Potentially problematic release.


This version of webscout might be problematic. Click here for more details.

Files changed (69) hide show
  1. webscout/Extra/GitToolkit/__init__.py +10 -0
  2. webscout/Extra/GitToolkit/gitapi/__init__.py +12 -0
  3. webscout/Extra/GitToolkit/gitapi/repository.py +195 -0
  4. webscout/Extra/GitToolkit/gitapi/user.py +96 -0
  5. webscout/Extra/GitToolkit/gitapi/utils.py +62 -0
  6. webscout/Extra/YTToolkit/ytapi/video.py +232 -103
  7. webscout/Provider/AISEARCH/DeepFind.py +1 -1
  8. webscout/Provider/AISEARCH/ISou.py +1 -1
  9. webscout/Provider/AISEARCH/__init__.py +6 -1
  10. webscout/Provider/AISEARCH/felo_search.py +1 -1
  11. webscout/Provider/AISEARCH/genspark_search.py +1 -1
  12. webscout/Provider/AISEARCH/hika_search.py +194 -0
  13. webscout/Provider/AISEARCH/iask_search.py +436 -0
  14. webscout/Provider/AISEARCH/monica_search.py +246 -0
  15. webscout/Provider/AISEARCH/scira_search.py +320 -0
  16. webscout/Provider/AISEARCH/webpilotai_search.py +281 -0
  17. webscout/Provider/AllenAI.py +255 -122
  18. webscout/Provider/DeepSeek.py +1 -2
  19. webscout/Provider/Deepinfra.py +17 -9
  20. webscout/Provider/ExaAI.py +261 -0
  21. webscout/Provider/ExaChat.py +8 -1
  22. webscout/Provider/GithubChat.py +2 -1
  23. webscout/Provider/Jadve.py +2 -2
  24. webscout/Provider/Netwrck.py +3 -2
  25. webscout/Provider/OPENAI/__init__.py +17 -0
  26. webscout/Provider/OPENAI/base.py +46 -0
  27. webscout/Provider/OPENAI/c4ai.py +347 -0
  28. webscout/Provider/OPENAI/chatgptclone.py +460 -0
  29. webscout/Provider/OPENAI/deepinfra.py +284 -0
  30. webscout/Provider/OPENAI/exaai.py +419 -0
  31. webscout/Provider/OPENAI/exachat.py +421 -0
  32. webscout/Provider/OPENAI/freeaichat.py +355 -0
  33. webscout/Provider/OPENAI/glider.py +314 -0
  34. webscout/Provider/OPENAI/heckai.py +337 -0
  35. webscout/Provider/OPENAI/llmchatco.py +325 -0
  36. webscout/Provider/OPENAI/netwrck.py +348 -0
  37. webscout/Provider/OPENAI/scirachat.py +459 -0
  38. webscout/Provider/OPENAI/sonus.py +294 -0
  39. webscout/Provider/OPENAI/typegpt.py +361 -0
  40. webscout/Provider/OPENAI/utils.py +211 -0
  41. webscout/Provider/OPENAI/venice.py +428 -0
  42. webscout/Provider/OPENAI/wisecat.py +381 -0
  43. webscout/Provider/OPENAI/x0gpt.py +389 -0
  44. webscout/Provider/OPENAI/yep.py +329 -0
  45. webscout/Provider/OpenGPT.py +199 -0
  46. webscout/Provider/PI.py +39 -24
  47. webscout/Provider/Venice.py +1 -1
  48. webscout/Provider/Youchat.py +326 -296
  49. webscout/Provider/__init__.py +16 -6
  50. webscout/Provider/ai4chat.py +58 -56
  51. webscout/Provider/akashgpt.py +34 -22
  52. webscout/Provider/freeaichat.py +1 -1
  53. webscout/Provider/labyrinth.py +121 -20
  54. webscout/Provider/llmchatco.py +306 -0
  55. webscout/Provider/scira_chat.py +274 -0
  56. webscout/Provider/typefully.py +280 -0
  57. webscout/Provider/typegpt.py +3 -184
  58. webscout/prompt_manager.py +2 -1
  59. webscout/version.py +1 -1
  60. webscout/webscout_search.py +118 -54
  61. webscout/webscout_search_async.py +109 -45
  62. webscout-8.1.dist-info/METADATA +683 -0
  63. {webscout-7.9.dist-info → webscout-8.1.dist-info}/RECORD +67 -33
  64. webscout/Provider/flowith.py +0 -207
  65. webscout-7.9.dist-info/METADATA +0 -995
  66. {webscout-7.9.dist-info → webscout-8.1.dist-info}/LICENSE.md +0 -0
  67. {webscout-7.9.dist-info → webscout-8.1.dist-info}/WHEEL +0 -0
  68. {webscout-7.9.dist-info → webscout-8.1.dist-info}/entry_points.txt +0 -0
  69. {webscout-7.9.dist-info → webscout-8.1.dist-info}/top_level.txt +0 -0
@@ -0,0 +1,10 @@
1
+ from .gitapi import *
2
+
3
+ __all__ = [
4
+ 'Repository',
5
+ 'User',
6
+ 'GitError',
7
+ 'RateLimitError',
8
+ 'NotFoundError',
9
+ 'RequestError'
10
+ ]
@@ -0,0 +1,12 @@
1
+ from .repository import Repository
2
+ from .user import User
3
+ from .utils import GitError, RateLimitError, NotFoundError, RequestError
4
+
5
+ __all__ = [
6
+ 'Repository',
7
+ 'User',
8
+ 'GitError',
9
+ 'RateLimitError',
10
+ 'NotFoundError',
11
+ 'RequestError'
12
+ ]
@@ -0,0 +1,195 @@
1
+ from typing import List, Dict, Any, Optional
2
+ from .utils import request
3
+ from urllib.parse import quote
4
+
5
+ class Repository:
6
+ """Class for interacting with GitHub repositories"""
7
+
8
+ def __init__(self, owner: str, repo: str):
9
+ """
10
+ Initialize repository client
11
+
12
+ Args:
13
+ owner: Repository owner
14
+ repo: Repository name
15
+ """
16
+ self.owner = owner
17
+ self.repo = repo
18
+ self.base_url = f"https://api.github.com/repos/{owner}/{repo}"
19
+
20
+ def get_info(self) -> Dict[str, Any]:
21
+ """Get basic repository information"""
22
+ return request(self.base_url)
23
+
24
+ def get_commits(self, page: int = 1, per_page: int = 30, sha: str = None) -> List[Dict[str, Any]]:
25
+ """
26
+ Get repository commits
27
+
28
+ Args:
29
+ page: Page number
30
+ per_page: Items per page
31
+ sha: SHA or branch name to start listing commits from
32
+ """
33
+ url = f"{self.base_url}/commits?page={page}&per_page={per_page}"
34
+ if sha:
35
+ url += f"&sha={sha}"
36
+ return request(url)
37
+
38
+ def get_commit(self, sha: str) -> Dict[str, Any]:
39
+ """Get a specific commit details"""
40
+ url = f"{self.base_url}/commits/{sha}"
41
+ return request(url)
42
+
43
+ def get_pull_requests(self, state: str = "all", page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
44
+ """
45
+ Get repository pull requests
46
+
47
+ Args:
48
+ state: State of PRs to return (open/closed/all)
49
+ page: Page number
50
+ per_page: Items per page
51
+ """
52
+ url = f"{self.base_url}/pulls?state={state}&page={page}&per_page={per_page}"
53
+ return request(url)
54
+
55
+ def get_pull_request(self, pr_number: int) -> Dict[str, Any]:
56
+ """Get specific pull request details"""
57
+ url = f"{self.base_url}/pulls/{pr_number}"
58
+ return request(url)
59
+
60
+ def get_pull_request_commits(self, pr_number: int) -> List[Dict[str, Any]]:
61
+ """Get commits in a specific pull request"""
62
+ url = f"{self.base_url}/pulls/{pr_number}/commits"
63
+ return request(url)
64
+
65
+ def get_pull_request_files(self, pr_number: int) -> List[Dict[str, Any]]:
66
+ """Get files changed in a specific pull request"""
67
+ url = f"{self.base_url}/pulls/{pr_number}/files"
68
+ return request(url)
69
+
70
+ def get_issues(self, state: str = "all", page: int = 1, per_page: int = 30, labels: str = None) -> List[Dict[str, Any]]:
71
+ """
72
+ Get repository issues
73
+
74
+ Args:
75
+ state: State of issues to return (open/closed/all)
76
+ page: Page number
77
+ per_page: Items per page
78
+ labels: Comma-separated list of label names
79
+ """
80
+ url = f"{self.base_url}/issues?state={state}&page={page}&per_page={per_page}"
81
+ if labels:
82
+ url += f"&labels={labels}"
83
+ return request(url)
84
+
85
+ def get_issue(self, issue_number: int) -> Dict[str, Any]:
86
+ """Get specific issue details"""
87
+ url = f"{self.base_url}/issues/{issue_number}"
88
+ return request(url)
89
+
90
+ def get_issue_comments(self, issue_number: int) -> List[Dict[str, Any]]:
91
+ """Get comments on a specific issue"""
92
+ url = f"{self.base_url}/issues/{issue_number}/comments"
93
+ return request(url)
94
+
95
+ def get_labels(self) -> List[Dict[str, Any]]:
96
+ """Get repository labels"""
97
+ url = f"{self.base_url}/labels"
98
+ return request(url)
99
+
100
+ def get_milestones(self, state: str = "all") -> List[Dict[str, Any]]:
101
+ """Get repository milestones"""
102
+ url = f"{self.base_url}/milestones?state={state}"
103
+ return request(url)
104
+
105
+ def get_contributors(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
106
+ """Get repository contributors"""
107
+ url = f"{self.base_url}/contributors?page={page}&per_page={per_page}"
108
+ return request(url)
109
+
110
+ def get_languages(self) -> Dict[str, int]:
111
+ """Get repository language breakdown"""
112
+ url = f"{self.base_url}/languages"
113
+ return request(url)
114
+
115
+ def get_teams(self) -> List[Dict[str, Any]]:
116
+ """Get teams with access to repository"""
117
+ url = f"{self.base_url}/teams"
118
+ return request(url)
119
+
120
+ def get_tags(self) -> List[Dict[str, Any]]:
121
+ """Get repository tags"""
122
+ url = f"{self.base_url}/tags"
123
+ return request(url)
124
+
125
+ def get_releases(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
126
+ """Get repository releases"""
127
+ url = f"{self.base_url}/releases?page={page}&per_page={per_page}"
128
+ return request(url)
129
+
130
+ def get_release(self, release_id: str) -> Dict[str, Any]:
131
+ """Get specific release details"""
132
+ url = f"{self.base_url}/releases/{release_id}"
133
+ return request(url)
134
+
135
+ def get_latest_release(self) -> Dict[str, Any]:
136
+ """Get latest release"""
137
+ url = f"{self.base_url}/releases/latest"
138
+ return request(url)
139
+
140
+ def get_branches(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
141
+ """Get repository branches"""
142
+ url = f"{self.base_url}/branches?page={page}&per_page={per_page}"
143
+ return request(url)
144
+
145
+ def get_branch(self, branch: str) -> Dict[str, Any]:
146
+ """Get specific branch details"""
147
+ url = f"{self.base_url}/branches/{branch}"
148
+ return request(url)
149
+
150
+ def get_contents(self, path: str = "", ref: Optional[str] = None) -> Dict[str, Any]:
151
+ """Get contents of file or directory"""
152
+ url = f"{self.base_url}/contents/{quote(path)}"
153
+ if ref:
154
+ url += f"?ref={ref}"
155
+ return request(url)
156
+
157
+ def get_collaborators(self) -> List[Dict[str, Any]]:
158
+ """Get repository collaborators"""
159
+ url = f"{self.base_url}/collaborators"
160
+ return request(url)
161
+
162
+ def get_workflows(self) -> List[Dict[str, Any]]:
163
+ """Get repository GitHub Actions workflows"""
164
+ url = f"{self.base_url}/actions/workflows"
165
+ return request(url)
166
+
167
+ def get_workflow_runs(self, workflow_id: str) -> List[Dict[str, Any]]:
168
+ """Get workflow runs for a specific workflow"""
169
+ url = f"{self.base_url}/actions/workflows/{workflow_id}/runs"
170
+ return request(url)
171
+
172
+ def get_deployments(self) -> List[Dict[str, Any]]:
173
+ """Get repository deployments"""
174
+ url = f"{self.base_url}/deployments"
175
+ return request(url)
176
+
177
+ def get_traffic(self) -> Dict[str, Any]:
178
+ """Get repository traffic data"""
179
+ url = f"{self.base_url}/traffic/views"
180
+ return request(url)
181
+
182
+ def get_code_frequency(self) -> List[List[int]]:
183
+ """Get weekly commit activity"""
184
+ url = f"{self.base_url}/stats/code_frequency"
185
+ return request(url)
186
+
187
+ def get_commit_activity(self) -> List[Dict[str, Any]]:
188
+ """Get last year of commit activity"""
189
+ url = f"{self.base_url}/stats/commit_activity"
190
+ return request(url)
191
+
192
+ def get_community_profile(self) -> Dict[str, Any]:
193
+ """Get community profile metrics"""
194
+ url = f"{self.base_url}/community/profile"
195
+ return request(url)
@@ -0,0 +1,96 @@
1
+ from typing import List, Dict, Any
2
+ from .utils import request
3
+
4
+ class User:
5
+ """Class for interacting with GitHub user data"""
6
+
7
+ def __init__(self, username: str):
8
+ """
9
+ Initialize user client
10
+
11
+ Args:
12
+ username: GitHub username
13
+ """
14
+ self.username = username
15
+ self.base_url = f"https://api.github.com/users/{username}"
16
+
17
+ def get_profile(self) -> Dict[str, Any]:
18
+ """Get user profile information"""
19
+ return request(self.base_url)
20
+
21
+ def get_repositories(self, page: int = 1, per_page: int = 30, type: str = "all") -> List[Dict[str, Any]]:
22
+ """
23
+ Get user's public repositories
24
+
25
+ Args:
26
+ page: Page number
27
+ per_page: Items per page
28
+ type: Type of repositories (all/owner/member)
29
+ """
30
+ url = f"{self.base_url}/repos?page={page}&per_page={per_page}&type={type}"
31
+ return request(url)
32
+
33
+ def get_starred(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
34
+ """Get repositories starred by user"""
35
+ url = f"{self.base_url}/starred?page={page}&per_page={per_page}"
36
+ return request(url)
37
+
38
+ def get_followers(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
39
+ """Get user's followers"""
40
+ url = f"{self.base_url}/followers?page={page}&per_page={per_page}"
41
+ return request(url)
42
+
43
+ def get_following(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
44
+ """Get users followed by this user"""
45
+ url = f"{self.base_url}/following?page={page}&per_page={per_page}"
46
+ return request(url)
47
+
48
+ def get_gists(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
49
+ """Get user's public gists"""
50
+ url = f"{self.base_url}/gists?page={page}&per_page={per_page}"
51
+ return request(url)
52
+
53
+ def get_organizations(self) -> List[Dict[str, Any]]:
54
+ """Get user's organizations"""
55
+ url = f"{self.base_url}/orgs"
56
+ return request(url)
57
+
58
+ def get_received_events(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
59
+ """Get events received by user"""
60
+ url = f"{self.base_url}/received_events?page={page}&per_page={per_page}"
61
+ return request(url)
62
+
63
+ def get_public_events(self, page: int = 1, per_page: int = 30) -> List[Dict[str, Any]]:
64
+ """Get user's public events"""
65
+ url = f"{self.base_url}/events/public?page={page}&per_page={per_page}"
66
+ return request(url)
67
+
68
+ def get_starred_gists(self) -> List[Dict[str, Any]]:
69
+ """Get gists starred by user"""
70
+ url = f"{self.base_url}/starred_gists"
71
+ return request(url)
72
+
73
+ def get_subscriptions(self) -> List[Dict[str, Any]]:
74
+ """Get repositories user is watching"""
75
+ url = f"{self.base_url}/subscriptions"
76
+ return request(url)
77
+
78
+ def get_hovercard(self) -> Dict[str, Any]:
79
+ """Get user's hovercard information"""
80
+ url = f"{self.base_url}/hovercard"
81
+ return request(url)
82
+
83
+ def get_installation(self) -> Dict[str, Any]:
84
+ """Get user's GitHub App installations"""
85
+ url = f"{self.base_url}/installation"
86
+ return request(url)
87
+
88
+ def get_keys(self) -> List[Dict[str, Any]]:
89
+ """Get user's public SSH keys"""
90
+ url = f"{self.base_url}/keys"
91
+ return request(url)
92
+
93
+ def get_gpg_keys(self) -> List[Dict[str, Any]]:
94
+ """Get user's public GPG keys"""
95
+ url = f"{self.base_url}/gpg_keys"
96
+ return request(url)
@@ -0,0 +1,62 @@
1
+ from urllib.request import Request, urlopen
2
+ from urllib.error import HTTPError
3
+ import json
4
+ from typing import Dict, Any
5
+ from webscout.litagent import LitAgent
6
+
7
+ class GitError(Exception):
8
+ """Base exception for GitHub API errors"""
9
+ pass
10
+
11
+ class RateLimitError(GitError):
12
+ """Raised when hitting GitHub API rate limits"""
13
+ pass
14
+
15
+ class NotFoundError(GitError):
16
+ """Raised when resource is not found"""
17
+ pass
18
+
19
+ class RequestError(GitError):
20
+ """Raised for general request errors"""
21
+ pass
22
+
23
+ _USER_AGENT_GENERATOR = LitAgent()
24
+
25
+ def request(url: str, retry_attempts: int = 3) -> Dict[str, Any]:
26
+ """
27
+ Send a request to GitHub API with retry mechanism
28
+
29
+ Args:
30
+ url: GitHub API endpoint URL
31
+ retry_attempts: Number of retry attempts
32
+
33
+ Returns:
34
+ Parsed JSON response
35
+
36
+ Raises:
37
+ NotFoundError: If resource not found
38
+ RateLimitError: If rate limited
39
+ RequestError: For other request errors
40
+ """
41
+ headers = {
42
+ "User-Agent": _USER_AGENT_GENERATOR.random(),
43
+ "Accept": "application/vnd.github+json"
44
+ }
45
+
46
+ for attempt in range(retry_attempts):
47
+ try:
48
+ req = Request(url, headers=headers)
49
+ response = urlopen(req)
50
+ return json.loads(response.read().decode('utf-8'))
51
+
52
+ except HTTPError as e:
53
+ if e.code == 404:
54
+ raise NotFoundError(f"Resource not found: {url}")
55
+ if e.code == 429:
56
+ raise RateLimitError(f"Rate limited on attempt {attempt + 1}")
57
+ if attempt == retry_attempts - 1:
58
+ raise RequestError(f"HTTP Error {e.code}: {e.reason}")
59
+
60
+ except Exception as e:
61
+ if attempt == retry_attempts - 1:
62
+ raise RequestError(f"Request failed: {str(e)}")