mixpeek 0.6.23__tar.gz → 0.6.25__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.23
3
+ Version: 0.6.25
4
4
  Summary: Mixpeek Python SDK
5
5
  Home-page: https://github.com/mixpeek/mixpeek-python
6
6
  Author: Ethan Steininger
@@ -16,12 +16,13 @@ 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"})
19
20
  class Data:
20
21
  def __init__(self, parent):
21
22
  self.base_url = parent.base_url
22
23
  self.headers = parent.headers
23
24
 
24
- def insert(self, connection_id: str, payload: dict):
25
+ def insert(self, connection_id: str, payload: list):
25
26
  pass
26
27
 
27
28
  def delete(self, connection_id: str, filters: dict):
@@ -5,6 +5,16 @@ class Pipelines:
5
5
  self.base_url = base_url
6
6
  self.headers = headers
7
7
 
8
+ # mixpeek.pipelines.enable
9
+ def enable(self, pipeline_id: str, enable: bool):
10
+ url = f"{self.base_url}pipelines/{pipeline_id}/enable"
11
+ data = {
12
+ "enable": enable
13
+ }
14
+ response = requests.patch(url, json=data, headers=self.headers)
15
+ return response.json()
16
+
17
+ # mixpeek.pipelines.create
8
18
  def create(self, alias: str, code: str, destination: dict, source: dict):
9
19
  url = f"{self.base_url}pipelines/"
10
20
  data = {
@@ -16,6 +26,7 @@ class Pipelines:
16
26
  response = requests.post(url, json=data, headers=self.headers)
17
27
  return response.json()
18
28
 
29
+ # mixpeek.pipelines.invoke
19
30
  def invoke(self, pipeline_id: str, payload: dict, options: dict):
20
31
  url = f"{self.base_url}pipelines/invoke/{pipeline_id}"
21
32
  data = {
@@ -0,0 +1,79 @@
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()
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.1
2
2
  Name: mixpeek
3
- Version: 0.6.23
3
+ Version: 0.6.25
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.23',
9
+ version='0.6.25',
10
10
  author='Ethan Steininger',
11
11
  author_email='ethan@mixpeek.com',
12
12
  description='Mixpeek Python SDK',
@@ -1,23 +0,0 @@
1
- import requests
2
-
3
- class Tools:
4
- def __init__(self, base_url, headers):
5
- self.base_url = base_url
6
- self.headers = headers
7
- self.video = self.Video(self)
8
-
9
- class Video:
10
- def __init__(self, parent):
11
- self.base_url = parent.base_url
12
- self.headers = parent.headers
13
-
14
- def process(self, url: str, frame_interval: int, resolution: list, return_base64: bool):
15
- endpoint = f"{self.base_url}tools/video/process"
16
- data = {
17
- "url": url,
18
- "frame_interval": frame_interval,
19
- "resolution": resolution,
20
- "use_base64": return_base64
21
- }
22
- response = requests.post(endpoint, json=data, headers=self.headers)
23
- return response.json()
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes
File without changes