pytbox 0.2.6__py3-none-any.whl → 0.2.7__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 pytbox might be problematic. Click here for more details.

pytbox/network/meraki.py CHANGED
@@ -4,6 +4,7 @@ from typing import Any, Literal
4
4
  import requests
5
5
  from ..utils.response import ReturnResponse
6
6
 
7
+
7
8
  class Meraki:
8
9
  '''
9
10
  Meraki Client
@@ -166,4 +167,83 @@ class Meraki:
166
167
  params=params,
167
168
  timeout=self.timeout
168
169
  )
169
- return ReturnResponse(code=0, msg=f"获取设备健康状态成功", data=r.json())
170
+ return ReturnResponse(code=0, msg=f"获取设备健康状态成功", data=r.json())
171
+
172
+ def reboot_device(self, serial: str) -> ReturnResponse:
173
+ '''
174
+ 该接口 60s 只能执行一次
175
+
176
+ Args:
177
+ serial (str): _description_
178
+
179
+ Returns:
180
+ ReturnResponse: _description_
181
+ '''
182
+ r = requests.post(
183
+ url=f"{self.base_url}/devices/{serial}/reboot",
184
+ headers=self.headers,
185
+ timeout=self.timeout
186
+ )
187
+ if r.status_code == 202 and r.json()['success'] == True:
188
+ return ReturnResponse(code=0, msg=f"重启 {serial} 成功", data=r.json())
189
+
190
+ try:
191
+ error_msg = r.json()['error']
192
+ except KeyError:
193
+ error_msg = r.json()
194
+ return ReturnResponse(code=1, msg=f"重启 {serial} 失败, 报错 {error_msg}", data=None)
195
+
196
+ def get_alerts(self):
197
+ # from datetime import datetime, timedelta
198
+ params = {}
199
+ params['tsStart'] = "2025-10-20T00:00:00Z"
200
+ params['tsEnd'] = "2025-10-30T00:00:00Z"
201
+ # # 获取昨天0:00的时间戳(秒)
202
+ # yesterday = datetime.now().replace(hour=0, minute=0, second=0, microsecond=0) - timedelta(days=1)
203
+ # ts_start = int(yesterday.timestamp()) * 1000
204
+ # params['tsStart'] = str(ts_start)
205
+ # print(params)
206
+ r = requests.get(
207
+ url=f"{self.base_url}/organizations/{self.organization_id}/assurance/alerts",
208
+ headers=self.headers,
209
+ timeout=self.timeout,
210
+ params=params
211
+ )
212
+ for i in r.json():
213
+ print(i)
214
+ # return ReturnResponse(code=0, msg="获取告警成功", data=r.json())
215
+
216
+ def get_network_events(self, network_id):
217
+ params = {}
218
+ params['productType'] = "wireless"
219
+
220
+ print(params)
221
+ r = requests.get(
222
+ url=f"{self.base_url}/networks/{network_id}/events",
223
+ headers=self.headers,
224
+ timeout=self.timeout,
225
+ params=params
226
+ )
227
+ if r.status_code == 200:
228
+ return ReturnResponse(code=0, msg=f"获取网络事件成功", data=r.json())
229
+ return ReturnResponse(code=1, msg=f"获取网络事件失败: {r.status_code} - {r.text}", data=None)
230
+
231
+ def get_wireless_failcounter(self, network_id: str, timespan: int=5*60, serial: str=None):
232
+ '''
233
+ https://developer.cisco.com/meraki/api-v1/get-network-wireless-failed-connections/
234
+ '''
235
+ params = {}
236
+ params['timespan'] = timespan
237
+ if serial:
238
+ params['serial'] = serial
239
+
240
+ r = requests.get(
241
+ url=f"{self.base_url}/networks/{network_id}/wireless/failedConnections",
242
+ headers=self.headers,
243
+ timeout=self.timeout,
244
+ params=params
245
+ )
246
+ if r.status_code == 200:
247
+ return ReturnResponse(code=0, msg=f"获取无线失败连接成功", data=r.json())
248
+ return ReturnResponse(code=1, msg=f"获取无线失败连接失败: {r.status_code} - {r.text}", data=None)
249
+
@@ -1,6 +1,6 @@
1
1
  Metadata-Version: 2.4
2
2
  Name: pytbox
3
- Version: 0.2.6
3
+ Version: 0.2.7
4
4
  Summary: A collection of Python integrations and utilities (Feishu, Dida365, VictoriaMetrics, ...)
5
5
  Author-email: mingming hou <houm01@foxmail.com>
6
6
  License-Expression: MIT
@@ -56,7 +56,7 @@ pytbox/log/victorialog.py,sha256=gffEiq38adv9sC5oZeMcyKghd3SGfRuqtZOFuqHQF6E,413
56
56
  pytbox/mail/alimail.py,sha256=njKA3PUbIaiKFaxKvUObmklmEEHg2YA-O5rpgsgT5_w,5147
57
57
  pytbox/mail/client.py,sha256=RNgWhhTXFTpD43U4p7hbmnfRdmltuZmbm890gaZTzhI,6278
58
58
  pytbox/mail/mail_detail.py,sha256=6u8DK-7WzYPSuX6TdicSCh2Os_9Ou6Rn9xc6WRvv85M,699
59
- pytbox/network/meraki.py,sha256=054E3C5KzAuXs9aPalvdAOUo6Hc5aOKZSWUaVbPquy4,6112
59
+ pytbox/network/meraki.py,sha256=qyJZtpxDLMMjPkGvU_xEc603sRg_ZLH8cMP_pUL20jY,9102
60
60
  pytbox/utils/cronjob.py,sha256=b17CY1fmaFTdQojicXAXHliov_JZdmT7cZhtO4v5sCo,3080
61
61
  pytbox/utils/env.py,sha256=gD2-NyL3K3Vg1B1eGeD1hRtlSHPGgF8Oi9mchuQL6_o,646
62
62
  pytbox/utils/load_config.py,sha256=R4pGerBinbewsym41hQ8Z-I5I7gepuEKODjIrli4C08,5043
@@ -65,8 +65,8 @@ pytbox/utils/response.py,sha256=kXjlwt0WVmLRam2eu1shzX2cQ7ux4cCQryaPGYwle5g,1247
65
65
  pytbox/utils/richutils.py,sha256=OT9_q2Q1bthzB0g1GlhZVvM4ZAepJRKL6a_Vsr6vEqo,487
66
66
  pytbox/utils/timeutils.py,sha256=uSKgwt20mVcgIGKLsH2tNum8v3rcpzgmBibPvyPQFgM,20433
67
67
  pytbox/win/ad.py,sha256=-3pWfL3dElz-XoO4j4M9lrgu3KJtlhrS9gCWJBpafAU,1147
68
- pytbox-0.2.6.dist-info/METADATA,sha256=imFjJeLVrjd09kC9dBKWYtVIGXH4hphvPh7mTAQTw9A,6319
69
- pytbox-0.2.6.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
70
- pytbox-0.2.6.dist-info/entry_points.txt,sha256=YaTOJ2oPjOiv2SZwY0UC-UA9QS2phRH1oMvxGnxO0Js,43
71
- pytbox-0.2.6.dist-info/top_level.txt,sha256=YADgWue-Oe128ptN3J2hS3GB0Ncc5uZaSUM3e1rwswE,7
72
- pytbox-0.2.6.dist-info/RECORD,,
68
+ pytbox-0.2.7.dist-info/METADATA,sha256=zWSHsiovVdu04JNt1xHIpVXh7mNbf7_YTYAvtxgn1IM,6319
69
+ pytbox-0.2.7.dist-info/WHEEL,sha256=_zCd3N1l69ArxyTb8rzEoP9TpbYXkqRFSNOD5OuxnTs,91
70
+ pytbox-0.2.7.dist-info/entry_points.txt,sha256=YaTOJ2oPjOiv2SZwY0UC-UA9QS2phRH1oMvxGnxO0Js,43
71
+ pytbox-0.2.7.dist-info/top_level.txt,sha256=YADgWue-Oe128ptN3J2hS3GB0Ncc5uZaSUM3e1rwswE,7
72
+ pytbox-0.2.7.dist-info/RECORD,,
File without changes