diff options
| author | jwijenbergh <jeroenwijenbergh@protonmail.com> | 2022-05-03 16:33:37 +0200 |
|---|---|---|
| committer | jwijenbergh <jeroenwijenbergh@protonmail.com> | 2022-05-03 16:33:37 +0200 |
| commit | 657776055cd07c1f9279e982fbfef88dca1ca71b (patch) | |
| tree | 4952be2ac2f999e74446601c5b138566a909e5e2 /wrappers/python/eduvpncommon/__init__.py | |
| parent | a94316159904e37ada2b932757a2594ef796efe0 (diff) | |
Python: Place py files in src
Diffstat (limited to 'wrappers/python/eduvpncommon/__init__.py')
| -rw-r--r-- | wrappers/python/eduvpncommon/__init__.py | 60 |
1 files changed, 0 insertions, 60 deletions
diff --git a/wrappers/python/eduvpncommon/__init__.py b/wrappers/python/eduvpncommon/__init__.py deleted file mode 100644 index 1df305b..0000000 --- a/wrappers/python/eduvpncommon/__init__.py +++ /dev/null @@ -1,60 +0,0 @@ -from ctypes import * -from collections import defaultdict -import pathlib -import platform - -_lib_prefixes = defaultdict( - lambda: "lib", - { - "windows": "", - }, -) - -_lib_suffixes = defaultdict( - lambda: ".so", - { - "windows": ".dll", - "darwin": ".dylib", - }, -) - -_os = platform.system().lower() - -_libname = "eduvpn_common" -_libfile = f"{_lib_prefixes[_os]}{_libname}{_lib_suffixes[_os]}" -# Library should have been copied to the lib/ folder -lib = cdll.LoadLibrary(str(pathlib.Path(__file__).parent / "lib" / _libfile)) - - -class DataError(Structure): - _fields_ = [("data", c_void_p), ("error", c_void_p)] - - -VPNStateChange = CFUNCTYPE(None, c_char_p, c_char_p, c_char_p) - -# Exposed functions -lib.Connect.argtypes, lib.Connect.restype = [c_char_p, c_char_p], DataError -lib.Deregister.argtypes, lib.Deregister.restype = [c_char_p], c_void_p -lib.Register.argtypes, lib.Register.restype = [c_char_p, c_char_p, VPNStateChange, c_int], c_void_p -lib.GetOrganizationsList.argtypes, lib.GetOrganizationsList.restype = [c_char_p], DataError -lib.GetServersList.argtypes, lib.GetServersList.restype = [c_char_p], DataError -lib.CancelOAuth.argtypes, lib.CancelOAuth.restype = [c_char_p], c_void_p -lib.SetProfileID.argtypes, lib.SetProfileID.restype = [c_char_p, c_char_p], c_void_p -# We have to use c_void_p instead of c_char_p to free it properly -# See https://stackoverflow.com/questions/13445568/python-ctypes-how-to-free-memory-getting-invalid-pointer-error -lib.FreeString.argtypes, lib.FreeString.restype = [c_void_p], None - - -def GetPtrString(ptr): - if ptr: - string = cast(ptr, c_char_p).value - lib.FreeString(ptr) - if string: - return string.decode() - return "" - - -def GetDataError(data_error): - data = GetPtrString(data_error.data) - error = GetPtrString(data_error.error) - return data, error |
