3 Commits
1.0.5 ... 1.0.6

Author SHA1 Message Date
Jason SECULA
3a77226870 Updated build number
All checks were successful
Build python package / Build (push) Successful in 32s
2026-04-27 14:57:37 +02:00
8b34682e59 Added entities selection methods and updated profile selection methods
All checks were successful
Build python package / Build (push) Successful in 36s
2026-04-25 21:56:37 +02:00
d433b2957e Updated profile interaction methods 2026-04-25 21:20:06 +02:00
2 changed files with 71 additions and 10 deletions

View File

@@ -12,9 +12,11 @@ class GLPIAPI:
self.StatusCode = None self.StatusCode = None
self.Headers = None self.Headers = None
self.ActiveProfile = None self.ActiveProfile = None
self.ActiveEntity = None
self.RecurseEntity = True
self.InitConnection() self.InitConnection()
if(Profile == None): if(Profile == None):
self.ActiveProfile = self.GetActiveProfile() self.ActiveProfile = self.GetActiveProfile()[0]
else: else:
self.ActiveProfile = Profile self.ActiveProfile = Profile
profileId = self.GetItems('Profile', 'Profile.name', Profile)[1]['2'] profileId = self.GetItems('Profile', 'Profile.name', Profile)[1]['2']
@@ -39,9 +41,20 @@ class GLPIAPI:
"Session-Token": self.SessionToken, "Session-Token": self.SessionToken,
"App-Token": self.AppToken "App-Token": self.AppToken
} }
if(self.GetActiveProfile() != self.ActiveProfile and self.ActiveProfile != None): if(self.GetActiveProfile()[0] != self.ActiveProfile and self.ActiveProfile != None):
profileId = self.GetItems('Profile', 'Profile.name', self.ActiveProfile)[1]['2'] profile = [p for p in self.GetUserProfiles() if p["name"] == self.ActiveProfile]
self.SetActiveProfile(profileId) if(profile != []):
self.SetActiveProfile(profile[0]["id"])
else:
raise Exception(f"{self.ActiveProfile} is not in user profiles")
ActiveEntities = self.GetActiveEntity()
if((ActiveEntities[0] != self.ActiveEntity or ActiveEntities[1] != self.RecurseEntity) and self.ActiveEntity != None):
entity = [e for e in self.GetUserEntities() if e["id"] == self.ActiveEntity]
if(entity != []):
self.SetActiveEntity(entity[0]["id"], self.RecurseEntity)
else:
raise Exception(f"{self.ActiveEntity} is not in user entities")
else: else:
raise Exception(f"{result.status_code} - {result.json()[0]}") raise Exception(f"{result.status_code} - {result.json()[0]}")
@@ -50,14 +63,14 @@ class GLPIAPI:
result = requests.get(sessionUri, headers=self.Headers) result = requests.get(sessionUri, headers=self.Headers)
if(result.status_code != 200 and result.json()[0] == 'ERROR_SESSION_TOKEN_INVALID'): if(result.status_code != 200 and result.json()[0] == 'ERROR_SESSION_TOKEN_INVALID'):
self.InitConnection() self.InitConnection()
return return result.status_code
def GetUserProfiles(self): def GetUserProfiles(self):
self.CheckConnection() self.CheckConnection()
uri = f"{self.Server}/apirest.php/getMyProfiles" uri = f"{self.Server}/apirest.php/getMyProfiles"
req = requests.get(uri, headers=self.Headers) req = requests.get(uri, headers=self.Headers)
if(req.status_code == 200): if(req.status_code == 200):
return req.json() return req.json()['myprofiles']
else: else:
return req.status_code return req.status_code
@@ -66,18 +79,66 @@ class GLPIAPI:
uri = f"{self.Server}/apirest.php/getActiveProfile" uri = f"{self.Server}/apirest.php/getActiveProfile"
req = requests.get(uri, headers=self.Headers) req = requests.get(uri, headers=self.Headers)
if(req.status_code == 200): if(req.status_code == 200):
return req.json()['active_profile']['name'] return (req.json()['active_profile']['name'],req.json()['active_profile']['id'])
else: else:
return req.status_code return req.status_code
def SetActiveProfile(self, profileId): def SetActiveProfile(self, profile):
self.CheckConnection() self.CheckConnection()
if(type(profile) == str):
profileFound = [p for p in self.GetUserProfiles() if p["name"] == profile]
if(profileFound != []):
profileId = profileFound[0]["id"]
else:
profileId = profile
body = { body = {
"profiles_id" : profileId "profiles_id" : profileId
} }
uri = f"{self.Server}/apirest.php/changeActiveProfile" uri = f"{self.Server}/apirest.php/changeActiveProfile"
return requests.post(uri, headers=self.Headers, json=body) req = requests.post(uri, headers=self.Headers, json=body)
if(req.status_code == 200):
self.ActiveProfile = self.GetActiveProfile()[0]
return req.status_code
def GetUserEntities(self):
self.CheckConnection()
uri = f"{self.Server}/apirest.php/getMyEntities"
req = requests.get(uri, headers=self.Headers)
if(req.status_code == 200):
return req.json()["myentities"]
else:
return req.status_code
def GetActiveEntity(self):
self.CheckConnection()
uri = f"{self.Server}/apirest.php/getActiveEntities"
req = requests.get(uri, headers=self.Headers)
if(req.status_code == 200):
return (req.json()['active_entity']['id'], req.json()['active_entity']['active_entity_recursive'], req.json()['active_entity']['active_entities'])
else:
return req.status_code
def SetActiveEntity(self, entity, recurse=True):
self.CheckConnection()
if(type(entity) == str):
entityFound = [e for e in self.GetUserEntities() if e["name"] == entity]
if(entityFound != []):
entityId = entityFound[0]["id"]
else:
entityId = entity
body = {
"entities_id" : entityId,
"is_recursive" : recurse
}
uri = f"{self.Server}/apirest.php/changeActiveEntities"
req = requests.post(uri, headers=self.Headers, json=body)
if(req.status_code == 200):
ActiveEntities = self.GetActiveEntity()
self.ActiveEntity = ActiveEntities[0]
self.RecurseEntity = ActiveEntities[1]
return req.status_code
def GetComputers(self, deviceName=None, serialNumber=None, user=None, imei=None, airwatchDevice=None, fieldsToDisplay=[], trashbin=0): def GetComputers(self, deviceName=None, serialNumber=None, user=None, imei=None, airwatchDevice=None, fieldsToDisplay=[], trashbin=0):
''' '''

View File

@@ -7,7 +7,7 @@ build-backend = "setuptools.build_meta"
[project] [project]
name = "GLPIAPI" name = "GLPIAPI"
version = "1.0.5" version = "1.0.6"
description = "A module python to make it easier to use GLPI API" description = "A module python to make it easier to use GLPI API"
readme = "README.md" readme = "README.md"
dependencies = [ dependencies = [