2 Commits

Author SHA1 Message Date
Jason SECULA
8dec92b43a Adding profile selection methods
All checks were successful
Build python package / Build (push) Successful in 32s
2026-04-23 16:26:03 +02:00
Jason SECULA
9ac724ed4c Fixed error with id not shown in GetItems() 2026-04-23 16:07:31 +02:00
2 changed files with 43 additions and 4 deletions

View File

@@ -3,7 +3,7 @@ import json
from datetime import datetime from datetime import datetime
class GLPIAPI: class GLPIAPI:
def __init__(self, Server, AppToken, UserToken, UserAgent="GLPI API"): def __init__(self, Server, AppToken, UserToken, UserAgent="GLPI API", Profile=None):
self.Server = Server self.Server = Server
self.AppToken = AppToken self.AppToken = AppToken
self.UserToken = UserToken self.UserToken = UserToken
@@ -11,7 +11,14 @@ class GLPIAPI:
self.SessionToken = None self.SessionToken = None
self.StatusCode = None self.StatusCode = None
self.Headers = None self.Headers = None
self.ActiveProfile = None
self.InitConnection() self.InitConnection()
if(Profile == None):
self.ActiveProfile = self.GetActiveProfile()
else:
self.ActiveProfile = Profile
profileId = self.GetItems('Profile', 'Profile.name', Profile)[1]['2']
self.SetActiveProfile(profileId)
def InitConnection(self): def InitConnection(self):
initURI = '/apirest.php/initSession/' initURI = '/apirest.php/initSession/'
@@ -32,6 +39,9 @@ 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):
profileId = self.GetItems('Profile', 'Profile.name', self.ActiveProfile)[1]['2']
self.SetActiveProfile(profileId)
else: else:
raise Exception(f"{result.status_code} - {result.json()[0]}") raise Exception(f"{result.status_code} - {result.json()[0]}")
@@ -42,6 +52,33 @@ class GLPIAPI:
self.InitConnection() self.InitConnection()
return return
def GetUserProfiles(self):
self.CheckConnection()
uri = f"{self.Server}/apirest.php/getMyProfiles"
req = requests.get(uri, headers=self.Headers)
if(req.status_code == 200):
return req.json()
else:
return req.status_code
def GetActiveProfile(self):
self.CheckConnection()
uri = f"{self.Server}/apirest.php/getActiveProfile"
req = requests.get(uri, headers=self.Headers)
if(req.status_code == 200):
return req.json()['active_profile']['name']
else:
return req.status_code
def SetActiveProfile(self, profileId):
self.CheckConnection()
body = {
"profiles_id" : profileId
}
uri = f"{self.Server}/apirest.php/changeActiveProfile"
return requests.post(uri, headers=self.Headers, json=body)
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):
''' '''
Search for computer items in GLPI based on one of the possibles parameters : Search for computer items in GLPI based on one of the possibles parameters :
@@ -146,8 +183,11 @@ class GLPIAPI:
else: else:
searchUri = f"{self.Server}/apirest.php/search/{itemType}?{search_parameter}" searchUri = f"{self.Server}/apirest.php/search/{itemType}?{search_parameter}"
idFieldNumber = list(self.GetSearchOptions(itemType, f'{itemType}.id'))[0]
searchUri += f"&forcedisplay[0]={idFieldNumber}"
if(fieldsToDisplay != []): if(fieldsToDisplay != []):
for i in range(len(fieldsToDisplay)): for i in range(1, len(fieldsToDisplay+1)):
searchUri += f"&forcedisplay[{i}]={fieldsToDisplay[i]}" searchUri += f"&forcedisplay[{i}]={fieldsToDisplay[i]}"
search = requests.get(searchUri, headers=self.Headers) search = requests.get(searchUri, headers=self.Headers)
@@ -161,7 +201,6 @@ class GLPIAPI:
return itemID, data, search["totalcount"] return itemID, data, search["totalcount"]
elif(search["totalcount"] > 1): elif(search["totalcount"] > 1):
if(searchAll): if(searchAll):
idFieldNumber = list(self.GetSearchOptions(itemType, f'{itemType}.id'))[0]
itemID = [i[idFieldNumber] for i in search["data"]] itemID = [i[idFieldNumber] for i in search["data"]]
else: else:
itemID = list(search["data"].keys()) itemID = list(search["data"].keys())

View File

@@ -7,7 +7,7 @@ build-backend = "setuptools.build_meta"
[project] [project]
name = "GLPIAPI" name = "GLPIAPI"
version = "1.0.4" version = "1.0.5"
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 = [