mixpeek 0.6.25__tar.gz → 0.6.27__tar.gz

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.
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: mixpeek
3
- Version: 0.6.25
3
+ Version: 0.6.27
4
4
  Summary: Mixpeek Python SDK
5
5
  Home-page: https://github.com/mixpeek/mixpeek-python
6
6
  Author: Ethan Steininger
@@ -11,7 +11,7 @@ from .endpoints.pipelines import Pipelines
11
11
  class Mixpeek:
12
12
  def __init__(self, api_key: str):
13
13
  self.api_key = api_key
14
- self.base_url = "http://localhost:8000/"
14
+ self.base_url = "https://api.mixpeek.com/"
15
15
  self.headers = {
16
16
  "Authorization": f"Bearer {self.api_key}",
17
17
  "Content-Type": "application/json"
@@ -16,16 +16,21 @@ class Connections:
16
16
  response = requests.post(url, json=data, headers=self.headers)
17
17
  return response.json()
18
18
 
19
- # mixpeek.connections.data.insert(connection_id="123", payload={"key": "value"})
20
19
  class Data:
21
20
  def __init__(self, parent):
22
21
  self.base_url = parent.base_url
23
22
  self.headers = parent.headers
24
23
 
24
+ # mixpeek.connections.data.insert(connection_id="123", payload={"key": "value"})
25
25
  def insert(self, connection_id: str, payload: list):
26
26
  pass
27
27
 
28
+ # mixpeek.connections.data.delete(connection_id="123", filters={"key": "value"})
28
29
  def delete(self, connection_id: str, filters: dict):
29
30
  pass
31
+
32
+ # mixpeek.connections.data.upsert(connection_id="123", payload={"key": "value"}, filters={"key": "value"})
33
+ def upsert(self, connection_id: str, payload: dict, filters: dict):
34
+ pass
30
35
 
31
36
 
@@ -0,0 +1,55 @@
1
+ import requests
2
+
3
+ class Extract:
4
+ def __init__(self, base_url, headers):
5
+ self.base_url = base_url
6
+ self.headers = headers
7
+
8
+ def automatic(self, input: str, input_type: str):
9
+ url = f"{self.base_url}extract/"
10
+ data = {
11
+ "input": input,
12
+ "input_type": input_type
13
+ }
14
+ response = requests.post(url, json=data, headers=self.headers)
15
+ return response.json()
16
+
17
+ def video(self, input: str, input_type: str):
18
+ url = f"{self.base_url}extract/"
19
+ data = {
20
+ "modality": "video",
21
+ "input": input,
22
+ "input_type": input_type
23
+ }
24
+ response = requests.post(url, json=data, headers=self.headers)
25
+ return response.json()
26
+
27
+ def audio(self, input: str, input_type: str):
28
+ url = f"{self.base_url}extract/"
29
+ data = {
30
+ "modality": "audio",
31
+ "input": input,
32
+ "input_type": input_type
33
+ }
34
+ response = requests.post(url, json=data, headers=self.headers)
35
+ return response.json()
36
+
37
+ def image(self, input: str, input_type: str):
38
+ url = f"{self.base_url}extract/"
39
+ data = {
40
+ "modality": "image",
41
+ "input": input,
42
+ "input_type": input_type
43
+ }
44
+ response = requests.post(url, json=data, headers=self.headers)
45
+ return response.json()
46
+
47
+ def text(self, input: str, input_type: str):
48
+ url = f"{self.base_url}extract/"
49
+ data = {
50
+ "modality": "text",
51
+ "input": input,
52
+ "input_type": input_type
53
+ }
54
+ response = requests.post(url, json=data, headers=self.headers)
55
+ return response.json()
@@ -0,0 +1,24 @@
1
+ import requests
2
+
3
+
4
+ class Tools:
5
+ def __init__(self, base_url, headers):
6
+ self.base_url = base_url
7
+ self.headers = headers
8
+ self.video = self.Video(self)
9
+
10
+ class Video:
11
+ def __init__(self, parent):
12
+ self.base_url = parent.base_url
13
+ self.headers = parent.headers
14
+
15
+ def process(self, url: str, frame_interval: int, resolution: list, return_base64: bool):
16
+ endpoint = f"{self.base_url}tools/video/process"
17
+ data = {
18
+ "url": url,
19
+ "frame_interval": frame_interval,
20
+ "resolution": resolution,
21
+ "return_base64": return_base64
22
+ }
23
+ response = requests.post(endpoint, json=data, headers=self.headers)
24
+ return response.json()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: mixpeek
3
- Version: 0.6.25
3
+ Version: 0.6.27
4
4
  Summary: Mixpeek Python SDK
5
5
  Home-page: https://github.com/mixpeek/mixpeek-python
6
6
  Author: Ethan Steininger
@@ -6,7 +6,7 @@ with open('requirements.txt') as f:
6
6
 
7
7
  setup(
8
8
  name='mixpeek',
9
- version='0.6.25',
9
+ version='0.6.27',
10
10
  author='Ethan Steininger',
11
11
  author_email='ethan@mixpeek.com',
12
12
  description='Mixpeek Python SDK',
@@ -1,16 +0,0 @@
1
- import requests
2
-
3
- class Extract:
4
- def __init__(self, base_url, headers):
5
- self.base_url = base_url
6
- self.headers = headers
7
-
8
- def extract(self, modality: str, input: str, input_type: str):
9
- url = f"{self.base_url}extract/"
10
- data = {
11
- "modality": modality,
12
- "input": input,
13
- "input_type": input_type
14
- }
15
- response = requests.post(url, json=data, headers=self.headers)
16
- return response.json()
@@ -1,79 +0,0 @@
1
- import requests
2
- from magika import Magika
3
-
4
-
5
- modality_to_content_types = {
6
- "text": [
7
- "application/pdf",
8
- "text/html",
9
- "text/html; charset=utf-8",
10
- "text/csv",
11
- "text/plain",
12
- "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",
13
- "application/vnd.ms-powerpoint",
14
- "application/vnd.openxmlformats-officedocument.presentationml.presentation",
15
- "application/vnd.openxmlformats-officedocument.wordprocessingml.document",
16
- "text/plain",
17
- "text/markdown",
18
- "application/xml",
19
- ],
20
- "image": [
21
- "image/png",
22
- "image/jpeg",
23
- "image/gif",
24
- "image/bmp",
25
- "image/tiff",
26
- "image/webp",
27
- ],
28
- "audio": [
29
- "audio/mpeg",
30
- "audio/wav",
31
- "audio/ogg",
32
- "audio/flac",
33
- "audio/mp4",
34
- "audio/aac",
35
- "audio/mp3",
36
- ],
37
- "video": [
38
- "video/mp4",
39
- "video/x-msvideo",
40
- "video/quicktime",
41
- "video/x-ms-wmv",
42
- "video/x-flv",
43
- ],
44
- }
45
-
46
-
47
-
48
- class Tools:
49
- def __init__(self, base_url, headers):
50
- self.base_url = base_url
51
- self.headers = headers
52
- self.video = self.Video(self)
53
-
54
- def detect(self, url: str):
55
- # Fetch the file from the URL
56
- response = requests.get(url)
57
- content_type = response.headers.get('Content-Type', '').split(';')[0] # Get the base MIME type without parameters
58
-
59
- # Determine modality based on MIME type and Magika detection
60
- for modality, types in modality_to_content_types.items():
61
- if content_type in types:
62
- return modality
63
- return 'unknown'
64
-
65
- class Video:
66
- def __init__(self, parent):
67
- self.base_url = parent.base_url
68
- self.headers = parent.headers
69
-
70
- def process(self, url: str, frame_interval: int, resolution: list, return_base64: bool):
71
- endpoint = f"{self.base_url}tools/video/process"
72
- data = {
73
- "url": url,
74
- "frame_interval": frame_interval,
75
- "resolution": resolution,
76
- "return_base64": return_base64
77
- }
78
- response = requests.post(endpoint, json=data, headers=self.headers)
79
- return response.json()
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes