micrOSDevToolKit 2.9.6__py3-none-any.whl → 2.9.8__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 micrOSDevToolKit might be problematic. Click here for more details.

Files changed (85) hide show
  1. micrOS/release_info/micrOS_ReleaseInfo/system_analysis_sum.json +11 -11
  2. micrOS/source/Espnow.py +89 -56
  3. micrOS/source/LM_L298N_DCmotor.py +4 -4
  4. micrOS/source/LM_L9110_DCmotor.py +3 -3
  5. micrOS/source/LM_VL53L0X.py +2 -2
  6. micrOS/source/LM_aht10.py +2 -2
  7. micrOS/source/LM_bme280.py +2 -2
  8. micrOS/source/LM_buzzer.py +12 -15
  9. micrOS/source/LM_cct.py +10 -13
  10. micrOS/source/LM_co2.py +3 -3
  11. micrOS/source/LM_dht11.py +2 -2
  12. micrOS/source/LM_dht22.py +2 -2
  13. micrOS/source/LM_dimmer.py +2 -2
  14. micrOS/source/LM_distance.py +3 -3
  15. micrOS/source/LM_ds18.py +2 -2
  16. micrOS/source/LM_genIO.py +52 -37
  17. micrOS/source/LM_haptic.py +2 -2
  18. micrOS/source/LM_i2c.py +2 -2
  19. micrOS/source/LM_i2s_mic.py +5 -5
  20. micrOS/source/LM_keychain.py +2 -2
  21. micrOS/source/LM_ld2410.py +2 -2
  22. micrOS/source/LM_light_sensor.py +2 -2
  23. micrOS/source/LM_neopixel.py +9 -12
  24. micrOS/source/LM_oled.py +2 -2
  25. micrOS/source/LM_oled_sh1106.py +3 -3
  26. micrOS/source/LM_oled_ui.py +2 -2
  27. micrOS/source/LM_ph_sensor.py +3 -3
  28. micrOS/source/LM_presence.py +2 -2
  29. micrOS/source/LM_rencoder.py +2 -2
  30. micrOS/source/LM_rgb.py +15 -22
  31. micrOS/source/LM_servo.py +3 -3
  32. micrOS/source/LM_stepper.py +5 -5
  33. micrOS/source/LM_switch.py +5 -5
  34. micrOS/source/LM_trackball.py +3 -3
  35. micrOS/source/LM_veml7700.py +2 -2
  36. micrOS/source/Shell.py +1 -1
  37. micrOS/source/microIO.py +27 -9
  38. {micrOSDevToolKit-2.9.6.dist-info → micrOSDevToolKit-2.9.8.dist-info}/METADATA +1 -1
  39. {micrOSDevToolKit-2.9.6.dist-info → micrOSDevToolKit-2.9.8.dist-info}/RECORD +83 -84
  40. toolkit/LM_to_compile.dat +1 -1
  41. toolkit/dashboard_apps/SystemTest.py +1 -1
  42. toolkit/dashboard_apps/uLightDemo.py +1 -1
  43. toolkit/workspace/precompiled/Espnow.mpy +0 -0
  44. toolkit/workspace/precompiled/LM_L298N_DCmotor.mpy +0 -0
  45. toolkit/workspace/precompiled/LM_L9110_DCmotor.py +3 -3
  46. toolkit/workspace/precompiled/LM_VL53L0X.py +2 -2
  47. toolkit/workspace/precompiled/LM_aht10.mpy +0 -0
  48. toolkit/workspace/precompiled/LM_bme280.mpy +0 -0
  49. toolkit/workspace/precompiled/LM_buzzer.mpy +0 -0
  50. toolkit/workspace/precompiled/LM_cct.mpy +0 -0
  51. toolkit/workspace/precompiled/LM_co2.mpy +0 -0
  52. toolkit/workspace/precompiled/LM_dht11.mpy +0 -0
  53. toolkit/workspace/precompiled/LM_dht22.mpy +0 -0
  54. toolkit/workspace/precompiled/LM_dimmer.mpy +0 -0
  55. toolkit/workspace/precompiled/LM_distance.mpy +0 -0
  56. toolkit/workspace/precompiled/LM_ds18.mpy +0 -0
  57. toolkit/workspace/precompiled/LM_genIO.mpy +0 -0
  58. toolkit/workspace/precompiled/LM_haptic.mpy +0 -0
  59. toolkit/workspace/precompiled/LM_i2c.py +2 -2
  60. toolkit/workspace/precompiled/LM_i2s_mic.mpy +0 -0
  61. toolkit/workspace/precompiled/LM_keychain.mpy +0 -0
  62. toolkit/workspace/precompiled/LM_ld2410.mpy +0 -0
  63. toolkit/workspace/precompiled/LM_light_sensor.mpy +0 -0
  64. toolkit/workspace/precompiled/LM_neopixel.mpy +0 -0
  65. toolkit/workspace/precompiled/LM_oled.mpy +0 -0
  66. toolkit/workspace/precompiled/LM_oled_sh1106.mpy +0 -0
  67. toolkit/workspace/precompiled/LM_oled_ui.mpy +0 -0
  68. toolkit/workspace/precompiled/LM_pacman.mpy +0 -0
  69. toolkit/workspace/precompiled/LM_ph_sensor.py +3 -3
  70. toolkit/workspace/precompiled/LM_presence.mpy +0 -0
  71. toolkit/workspace/precompiled/LM_rencoder.py +2 -2
  72. toolkit/workspace/precompiled/LM_rgb.mpy +0 -0
  73. toolkit/workspace/precompiled/LM_servo.mpy +0 -0
  74. toolkit/workspace/precompiled/LM_stepper.mpy +0 -0
  75. toolkit/workspace/precompiled/LM_switch.mpy +0 -0
  76. toolkit/workspace/precompiled/LM_trackball.mpy +0 -0
  77. toolkit/workspace/precompiled/LM_veml7700.mpy +0 -0
  78. toolkit/workspace/precompiled/Shell.mpy +0 -0
  79. toolkit/workspace/precompiled/microIO.mpy +0 -0
  80. toolkit/workspace/precompiled/LM_pacman.py +0 -248
  81. toolkit/workspace/precompiled/node_config.json +0 -1
  82. {micrOSDevToolKit-2.9.6.data → micrOSDevToolKit-2.9.8.data}/scripts/devToolKit.py +0 -0
  83. {micrOSDevToolKit-2.9.6.dist-info → micrOSDevToolKit-2.9.8.dist-info}/LICENSE +0 -0
  84. {micrOSDevToolKit-2.9.6.dist-info → micrOSDevToolKit-2.9.8.dist-info}/WHEEL +0 -0
  85. {micrOSDevToolKit-2.9.6.dist-info → micrOSDevToolKit-2.9.8.dist-info}/top_level.txt +0 -0
@@ -1,248 +0,0 @@
1
- from uos import listdir, remove, stat
2
- from sys import modules
3
- from Common import socket_stream
4
-
5
- WEB_EXT = ('html', 'js', 'css')
6
- DATA_TYPES = ('log', 'pds', 'dat')
7
-
8
- def _is_app_resource(path='/'):
9
- if stat(path)[0] & 0x4000: # Dir check
10
- return True, 'd'
11
- file_name = path.split("/")[-1]
12
- if file_name.startswith('LM_') or file_name.split('.')[-1] in WEB_EXT + DATA_TYPES:
13
- return True, 'f'
14
- return False, '?'
15
-
16
-
17
- #############################################
18
- # Safe file system handler functions #
19
- #############################################
20
-
21
- def ls(path="/", content='*', raw=False):
22
- """
23
- Linux like ls command - list app resources and app folders
24
- :param path: path to list, default: /
25
- :param content: content type, default all, f-file, d-dir can be selected
26
- :param raw: keep raw output [(is_app, type), ...]
27
- """
28
- path = path if path.endswith('/') else f"{path}/"
29
- items = []
30
- for item in listdir(path):
31
- is_app, item_type = _is_app_resource(path + item)
32
- if is_app and (content == "*" or item_type == content):
33
- items.append((item_type, item))
34
- if raw:
35
- return items
36
- formatted_output = ""
37
- i = 0
38
- for f in items:
39
- i += 1
40
- spacer = " " * (4 - len(str(i)))
41
- formatted_output += f"{i}{spacer}{f[0]} {f[1]}\n"
42
- return formatted_output
43
-
44
-
45
- def rm(path):
46
- """
47
- Linux like rm command - delete app resources and folders
48
- :param path: app resource name/path, ex.: LM_robustness.py
49
- """
50
- if 'pacman.' in path or 'system.' in path or "/" == path.strip():
51
- return f'Load module {path} is protected, skip delete.'
52
- is_app, item_type = _is_app_resource(path)
53
- if is_app:
54
- remove(path)
55
- return f"Remove: {path} {'dir' if item_type == 'd' else 'file'}"
56
- return f"Invalid path {path}"
57
-
58
-
59
- def dirtree(path="/", raw=False):
60
- """Return only directories from a given path."""
61
- path = path if path.endswith('/') else f"{path}/"
62
- folders = [f"{path}/{item}" for item in listdir(path) if _is_app_resource(f"{path}{item}")[1] == 'd']
63
- folder_contents = {folder:listdir(folder) for folder in folders}
64
- if raw:
65
- return folder_contents
66
- formatted_output = ""
67
- for k, v in folder_contents.items():
68
- formatted_output += f"{k}\n"
69
- for val in v:
70
- formatted_output += f"\t{val}\n"
71
- return formatted_output
72
-
73
-
74
- def download(url=None, package=None):
75
- """
76
- [BETA] Load Module downloader with mip
77
- :param url: github url path, ex. BxNxM/micrOS/master/toolkit/workspace/precompiled/LM_robustness.py
78
- :param package: mip package name or raw url (hack)
79
- """
80
- if url is None and package is None:
81
- return "Nothing to download, url=None package=None"
82
- if package is None:
83
- base_url = "https://raw.githubusercontent.com/"
84
- file_name = url.split("/")[-1]
85
- if not(file_name.endswith("py") and file_name.startswith("LM_")):
86
- return "Invalid file name in url ending, hint: /LM_*.mpy or /LM_*.py"
87
- # Convert GitHub URL to raw content URL
88
- if "github.com" in url and "blob" in url:
89
- url = url.replace("https://github.com/", base_url).replace("/blob", "")
90
- else:
91
- url = f"{base_url}{url}"
92
- else:
93
- url = package
94
- from mip import install
95
- verdict = ""
96
- try:
97
- verdict += f"Install {url}\n"
98
- install(url)
99
- verdict += "\n|- Done"
100
- except Exception as e:
101
- verdict += f"|- Cannot install: {url}\n{e}"
102
- return verdict
103
-
104
-
105
- def del_duplicates():
106
- """
107
- Load module package manager (Not just load modules)
108
- - delete duplicated .mpy and .py resources, keep .mpy resource!
109
- """
110
- msg_buf = []
111
- py = list((res.split('.')[0] for res in listdir() if res.endswith('.py'))) # Normally smaller list
112
- mpy = (res.split('.')[0] for res in listdir() if res.endswith('.mpy'))
113
- for m in mpy:
114
- # Iterate over mpy resources
115
- state = True
116
- if m in py and m != 'main':
117
- to_delete = f'{m}.py'
118
- try:
119
- remove(to_delete)
120
- except:
121
- state = False
122
- msg_buf.append(f' Delete {to_delete} {state}')
123
- return '\n'.join(msg_buf) if len(msg_buf) > 0 else 'Nothing to delete.'
124
-
125
-
126
- def moduls(unload=None):
127
- """
128
- List / unload loaded upython Load Modules
129
- :param unload: module name to unload
130
- :param unload: None - list active modules
131
- :return str: verdict
132
- """
133
- if unload is None:
134
- return list(modules.keys())
135
- if unload in modules.keys():
136
- del modules[unload]
137
- return f"Module unload {unload} done."
138
- return f"Module unload {unload} failed."
139
-
140
-
141
- @socket_stream
142
- def cachedump(delpds=None, msgobj=None):
143
- """
144
- Cache system persistent data storage files (.pds)
145
- :param delpds: cache name to delete
146
- """
147
- if delpds is None:
148
- # List pds files aka application cache
149
- msg_buf = []
150
- for pds in (_pds for _pds in listdir() if _pds.endswith('.pds')):
151
- with open(pds, 'r') as f:
152
- if msgobj is None:
153
- msg_buf.append(f'{pds}: {f.read()}')
154
- else:
155
- msgobj(f'{pds}: {f.read()}')
156
- return msg_buf if len(msg_buf) > 0 else ''
157
- # Remove given pds file
158
- try:
159
- remove(f'{delpds}.pds')
160
- return f'{delpds}.pds delete done.'
161
- except:
162
- return f'{delpds}.pds not exists'
163
-
164
-
165
- def dat_dump():
166
- """
167
- Generic .dat file dump
168
- - logged data from LMs, sensor datat, etc...
169
- """
170
- logs_dir = "/logs/"
171
- dats = (f for f in listdir(logs_dir) if f.endswith('.dat'))
172
- out = {}
173
- for dat in dats:
174
- with open(f"{logs_dir}{dat}", 'r') as f:
175
- out[dat] = f.read()
176
- return out
177
-
178
- #############################################
179
- # Legacy features #
180
- #############################################
181
-
182
-
183
- @socket_stream
184
- def listmods(msgobj=None):
185
- """
186
- Load module package manager
187
- - list all load modules
188
- """
189
- # Dump available LMs
190
- msg_buf = []
191
- for k in (res.replace('LM_', '') for res in listdir("/")
192
- if res.startswith('LM_') or res.split('.')[-1] in WEB_EXT):
193
- if msgobj is None:
194
- msg_buf.append(f' {k}')
195
- else:
196
- msgobj(f' {k}')
197
- return msg_buf if len(msg_buf) > 0 else ''
198
-
199
-
200
- def delmod(mod=None):
201
- """
202
- Module package manager
203
- :param mod:
204
- Delete Load Module with full name: module.py or module.mpy
205
- OR delete any web resource: *.js, *.css, *.html
206
- """
207
- if mod is not None and (mod.endswith('py') or mod.split('.')[-1] in WEB_EXT):
208
- # LM exception list - system and pacman cannot be deleted
209
- if 'pacman.' in mod or 'system.' in mod:
210
- return f'Load module {mod} is in use, skip delete.'
211
- try:
212
- to_remove = mod if mod.split('.')[-1] in WEB_EXT else f'LM_{mod}'
213
- remove(to_remove)
214
- return f'Delete module: {mod}'
215
- except Exception as e:
216
- return f'Cannot delete: {mod}: {e}'
217
- return f'Invalid value: {mod}'
218
-
219
-
220
- @socket_stream
221
- def micros_checksum(msgobj=None):
222
- from hashlib import sha1
223
- from binascii import hexlify
224
- from Config import cfgget
225
-
226
- for f_name in (_pds for _pds in listdir() if _pds.endswith('py')):
227
- with open(f_name, 'rb') as f:
228
- cs = hexlify(sha1(f.read()).digest()).decode('utf-8')
229
- msgobj(f"{cs} {f_name}")
230
- # GC collect?
231
- return f"micrOS version: {cfgget('version')}"
232
-
233
-
234
- def help(widgets=False):
235
- """
236
- [i] micrOS LM naming convention - built-in help message
237
- :return tuple:
238
- (widgets=False) list of functions implemented by this application
239
- (widgets=True) list of widget json for UI generation
240
- """
241
- return ('listmods', 'delmod mod=<module>.py/.mpy or .js/.html/.css', 'del_duplicates',
242
- 'moduls unload="LM_rgb/None"',
243
- 'cachedump delpds="rgb/None"',
244
- 'dat_dump',
245
- 'download url="BxNxM/micrOS/master/toolkit/workspace/precompiled/LM_robustness.py"',
246
- 'micros_checksum',
247
- 'ls path="/" content="*/f/d"',
248
- 'rm <path>', 'dirtree path="/"')
@@ -1 +0,0 @@
1
- {"irq2": false, "irq2_cbf": "n/a", "irq3_cbf": "n/a", "timirq": true, "irq4": false, "auth": false, "irq4_cbf": "n/a", "devip": "10.0.1.129", "soctout": 100, "appwd": "ADmin123", "timirqcbf": "rgb run_transition", "timirqseq": 800, "hwuid": "micr8caab594e9d4OS", "staessid": "T-3588F3;elektroncsakpozitivan_2G", "irq1_cbf": "rgb toggle", "cron": true, "irq4_trig": "n/a", "nwmd": "STA", "boothook": "rgb load_n_init", "version": "1.41.0-0", "irq_prell_ms": 300, "crontasks": "sunrise!rgb set_transition 400 0 0 3600;sunset!rgb run_transition 143 330 0 300;*:9:0:0!rgb set_transition 0 300 300 1800;*:12:0:0!rgb toggle False;*:20:0:0!rgb set_transition 600 211 2 3600;*:21:2:0!rgb rgb 100 30 0;*:23:0:0!rgb toggle False", "aioqueue": 3, "utc": 60, "boostmd": true, "irq1_trig": "n/a", "guimeta": "...", "socport": 9008, "webui": true, "cstmpmap": "n/a", "telegram": "n/a", "irq3_trig": "n/a", "dbg": true, "irq2_trig": "n/a", "irq3": false, "devfid": "ujelet", "stapwd": "jBRU7SJmreae8n5p;BNM3,1415", "irq1": false}