Compare commits

...

10 Commits
1.1.0 ... 1.1.2

Author SHA1 Message Date
Josiah Baldwin
e226fff8dd Merge pull request #36 from HuFlungDu/hotfix/1.1.2
Hotfix/1.1.2

Fixes #35 

Update Cryptography version to fix SSL vulnerability.
2025-02-17 12:11:08 -08:00
Josiah Baldwin
a07b0f129a Updated changelog 2025-02-17 12:07:19 -08:00
Josiah Baldwin
64dc5eccdf Updated cryptography requirement 2025-02-17 12:06:10 -08:00
Josiah Baldwin
1a7714663a Updated changelog 2025-02-17 11:51:13 -08:00
Josiah Baldwin
0a59edd19a Fixed semvar for requirements 2025-02-17 11:50:50 -08:00
Josiah Baldwin
351f425ce5 Merge pull request #32 from HuFlungDu/hotfix/1.1.1
Hotfix/1.1.1

Fix #29
2025-02-05 12:37:00 -08:00
Josiah Baldwin
77e76aeb7c Updated changelog 2025-02-05 12:35:23 -08:00
Josiah Baldwin
5393321f7b Fixed issue with getting device_info when multiple meshes are available 2025-02-05 12:30:13 -08:00
Josiah Baldwin
79554ebad6 Added differintiation between admin device info and unprivileged device info for tests, as unprivileged doesn't have any mesh info at the time of testing 2025-02-05 12:28:06 -08:00
Josiah Baldwin
1dbcd012ec Added test to check for issue with mulitple meshes 2025-02-05 12:16:01 -08:00
7 changed files with 34 additions and 16 deletions

View File

@@ -2,6 +2,19 @@
Changelog Changelog
========= =========
version 1.1.2
=============
Bugs:
* Fixed semver for requirements. New version of websockets broke this library.
Security:
* Updated cryptogaphy to ~44.0.1 to fix ssl vulnerability.
Version 1.1.1
=============
Bugs:
* Fixed bug when running device_info when user has access to multiple meshes
Version 1.1.0 Version 1.1.0
============= =============
Features: Features:

View File

@@ -5,8 +5,8 @@ sphinx>=3.2.1
sphinx-jinja2-compat>=0.1.1 sphinx-jinja2-compat>=0.1.1
sphinx-toolbox>=2.16.0 sphinx-toolbox>=2.16.0
# sphinx_rtd_theme # sphinx_rtd_theme
cffi==1.17.1 cffi~=1.17.1
cryptography==43.0.3 cryptography~=44.0.1
pycparser==2.22 pycparser~=2.22
websockets==13.1 websockets~=14.2
enum_tools enum_tools

Binary file not shown.

View File

@@ -44,9 +44,9 @@ python_requires = >=3.8
# For more information, check out https://semver.org/. # For more information, check out https://semver.org/.
install_requires = install_requires =
importlib-metadata importlib-metadata
cryptography>=43.0.3 cryptography~=44.0.1
websockets>=13.1 websockets~=14.2
python-socks[asyncio] python-socks[asyncio]~=2.5.3
[options.packages.find] [options.packages.find]

View File

@@ -1363,10 +1363,10 @@ class Session(object):
node["meshid"] = meshid node["meshid"] = meshid
if _mesh is not None: if _mesh is not None:
node["mesh"] = _mesh node["mesh"] = _mesh
sysinfo["node"] = node break
sysinfo["nodeid"] = nodeid else:
del sysinfo["result"] continue
del sysinfo["noinfo"] break
if node is None: if node is None:
raise ValueError("Invalid device id") raise ValueError("Invalid device id")
if lastconnect is not None: if lastconnect is not None:

View File

@@ -1,6 +1,6 @@
requests requests
pytest-asyncio pytest-asyncio
cffi==1.17.1 cffi==1.17.1
cryptography==43.0.3 cryptography~=44.0.1
pycparser==2.22 pycparser==2.22
websockets==13.1 websockets~=14.2

View File

@@ -200,15 +200,17 @@ async def test_mesh_device(env):
assert r[0].description == "New description", "Description either failed to change, or was changed by a user without permission to do so" assert r[0].description == "New description", "Description either failed to change, or was changed by a user without permission to do so"
# There once was a bug that occured whenever running run_commands with multiple meshes. We need to add devices to both meshes to be sure that bug is squashed.
with env.create_agent(mesh.short_meshid) as agent,\ with env.create_agent(mesh.short_meshid) as agent,\
env.create_agent(mesh.short_meshid) as agent2: env.create_agent(mesh.short_meshid) as agent2,\
env.create_agent(mesh2.short_meshid) as agent3:
# Test agent added to device group being propagated correctly # Test agent added to device group being propagated correctly
# Create agent isn't so good at waiting for the agent to show in the sessions. Give it a couple seconds to appear. # Create agent isn't so good at waiting for the agent to show in the sessions. Give it a couple seconds to appear.
for i in range(3): for i in range(3):
try: try:
r = await admin_session.list_devices(timeout=10) r = await admin_session.list_devices(timeout=10)
print("\ninfo list_devices: {}\n".format(r)) print("\ninfo list_devices: {}\n".format(r))
assert len(r) == 2, "Incorrect number of agents connected" assert len(r) == 3, "Incorrect number of agents connected"
except: except:
if i == 2: if i == 2:
raise raise
@@ -227,6 +229,9 @@ async def test_mesh_device(env):
r = await admin_session.list_devices(meshid=mesh.meshid, timeout=10) r = await admin_session.list_devices(meshid=mesh.meshid, timeout=10)
print("\ninfo list_devices_meshid: {}\n".format(r)) print("\ninfo list_devices_meshid: {}\n".format(r))
r = await admin_session.device_info(agent.nodeid, timeout=10)
print("\ninfo admin_device_info: {}\n".format(r))
# Test editing device info propagating correctly # Test editing device info propagating correctly
assert await admin_session.edit_device(agent.nodeid, name="new_name", description="New Description", tags="device", consent=meshctrl.constants.ConsentFlags.all, timeout=10), "Failed to edit device info" assert await admin_session.edit_device(agent.nodeid, name="new_name", description="New Description", tags="device", consent=meshctrl.constants.ConsentFlags.all, timeout=10), "Failed to edit device info"
@@ -269,7 +274,7 @@ async def test_mesh_device(env):
# Test getting individual device info # Test getting individual device info
r = await unprivileged_session.device_info(agent.nodeid, timeout=10) r = await unprivileged_session.device_info(agent.nodeid, timeout=10)
print("\ninfo device_info: {}\n".format(r)) print("\ninfo unprivileged_device_info: {}\n".format(r))
# This device info includes the mesh ID of the device, even though the user doesn't have acces to that mesh. That's odd. # This device info includes the mesh ID of the device, even though the user doesn't have acces to that mesh. That's odd.
# assert r.meshid is None, "Individual device is exposing its meshid" # assert r.meshid is None, "Individual device is exposing its meshid"