Page 3 of 3
Re: AD linking > packet groups
Published: March 17, 2017 - 4:07 PM
by fbetil
Hello,
I encountered this problem in another forum post. It's now fixed and working.
Now, is it possible to automatically force (via cron, etc.) the search for Active Directory groups on workstations so I don't have to right-click?
Thanks in advance,
Florian
Re: AD linking > packet groups
Published: March 17, 2017 - 5:21 PM
by htouvet
Yes, there is a script for that:
https://github.com/tranquilit/WAPT/blob ... l_hosts.py
Copy this file to the Wapt directory of your management machine.
and run the script
Code: Select all
c:\wapt\waptpython c:\wapt\update_all_hosts.py -c %LOCALAPPDATA%\waptconsole\waptconsole.ini
You can also add a "base" package to all your machines using the same method.
Re: AD linking > packet groups
Published: March 20, 2017 - 10:03
by fbetil
Hello and thank you.
For your information, I had to modify the get_computer_groups function as follows (see
https://github.com/tranquilit/WAPT/comm...4ad1c1dcb1):
Code: Select all
def get_computer_groups(computername):
"""Try to finc the computer in the Active Directory
and return the list of groups
"""
groups = []
computer = active_directory.find_computer(computername)
if computer:
computer_groups = computer.memberOf
if computer_groups:
if not isinstance(computer_groups,(tuple,list)):
computer_groups = [computer_groups]
for group in computer_groups:
# extract first component of group's DN
cn = group.split(',')[0].split('=')[1]
groups.append(cn.lower())
return groups
to which I added the conversion to lowercase.
Good day,
Re: AD linking > packet groups
Published: March 20, 2017 - 10:08
by htouvet
Thanks for the feedback

, I'll push it to GitHub.
Hubert
Re: AD linking > packet groups
Published: May 29, 2017 - 11:38
by fbetil
Hello,
For your information, in version 1.3.12.13, the function to import AD groups as a dependency fails if the case is not identical (forced to lowercase in WapT, which is not the case in our AD).
Could you please ignore case sensitivity in the `add_ads_groups` function of the `waptdevutils.py` package?
Thank you in advance,
Best regards,
Re: AD linking > packet groups
Published: March 12, 2019 - 10:52 PM
by fbetil
htouvet wrote: ↑March 17, 2017 - 5:21 PM
Yes, there is a script for that:
https://github.com/tranquilit/WAPT/blob ... l_hosts.py
Copy this file to the Wapt directory of your management machine.
and run the script
Code: Select all
c:\wapt\waptpython c:\wapt\update_all_hosts.py -c %LOCALAPPDATA%\waptconsole\waptconsole.ini
You can also add a "base" package to all your machines using the same method.
Good morning,
Following the update to v1.6.2.7, this script no longer works. Is there an equivalent for the latest versions?
Thank you in advance
Sincerely,
Florian
Re: AD linking > packet groups
Published: March 15, 2019 - 5:09 PM
by fbetil
Good morning,
Finally, by slightly modifying the code of the "update_all_hosts.py" script, it works (in v1.7.3.5):
Code: Select all
#!/usr/bin/python
# -*- coding: utf-8 -*-
# -----------------------------------------------------------------------
# This file is part of WAPT
# Copyright (C) 2013 Tranquil IT Systems http://www.tranquil.it
# WAPT aims to help Windows systems administrators to deploy
# setup and update applications on users PC.
#
# WAPT is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 3 of the License, or
# (at your option) any later version.
#
# WAPT is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU General Public License for more details.
#
# You should have received a copy of the GNU General Public License
# along with WAPT. If not, see <http://www.gnu.org/licenses/>.
#
# ---------------------------------------------------------------------
#
# Sample script which updates dependencies of all hosts registered on waptserver
# - append a list of basic packages that all hosts should install
# - query active directory for the groups of each host.
# if the CN of the group match a wapt package, the package is appended as dependency
#
# This allows to install packages based on computers active directory memberships
#------------------------------------------------
"""
Sample script which updates dependencies of all hosts registered on waptserver
- append a list of basic packages that all hosts should install
- query active directory for the groups of each host.
if the CN of the group match a wapt package, the package is appended as dependency
This allows to install packages based on computers active directory memberships
"""
import sys,os
from common import *
from waptpackage import *
from tempfile import mkdtemp
from shutil import rmtree
from getpass import getpass
import active_directory
from optparse import OptionParser
def ensure_list(csv_or_list,ignore_empty_args=True):
"""if argument is not a list, return a list from a csv string"""
if csv_or_list is None:
return []
if isinstance(csv_or_list,tuple):
return list(csv_or_list)
elif not isinstance(csv_or_list,list):
if ignore_empty_args:
return [s.strip() for s in csv_or_list.split(',') if s.strip() != '']
else:
return [s.strip() for s in csv_or_list.split(',')]
else:
return csv_or_list
def get_computer_groups(computername):
"""Try to finc the computer in the Active Directory
and return the list of groups
"""
groups = []
computer = active_directory.find_computer(computername)
if computer:
computer_groups = computer.memberOf
if computer_groups:
if not isinstance(computer_groups,(tuple,list)):
computer_groups = [computer_groups]
for group in computer_groups:
# extract first component of group's DN
cn = group.split(',')[0].split('=')[1]
groups.append(cn)
return groups
if __name__ == '__main__':
parser=OptionParser(usage=__doc__)
parser.add_option("-p","--password", dest="password", default='', help="Server password")
parser.add_option("-g","--groups", dest="groups", default='', help="List of packages to append to all hosts (default: %default)")
parser.add_option("-c","--config", dest="config", default=os.path.join(os.path.dirname(sys.argv[0]),'wapt-get.ini') , help="Config file full path (default: %default)")
parser.add_option("-d","--dry-run", dest="dry_run", default=False, action='store_true', help="Dry run (default: %default)")
(options,args) = parser.parse_args()
server_password = options.password
# put at least these packages to all computers
base_packages = ensure_list(options.groups)
# initialise wapt api with local config file
wapt = Wapt(config_filename = options.config)
wapt.dbpath=':memory:'
# get current packages status from repositories
wapt.update()
for package in base_packages:
if not wapt.is_available(package):
raise Exception('Package %s is not available in your repository.'%package)
# get the collection of hosts from waptserver inventory
hosts = wapt.waptserver.get('api/v1/hosts',auth=('admin',server_password))
for h in hosts['result']:
try:
hostname = h['computer_fqdn']
groups = base_packages + get_computer_groups(h['computer_name'])
print 'Computer %s: %s ' % (hostname, groups)
# try to get comp
# now update the host package : download and append missing packages
tmpdir = mkdtemp()
try:
package = wapt.edit_host(hostname,target_directory = tmpdir)
control = package
depends = ensure_list(control.depends)
additional = [ group for group in groups if not group in depends and wapt.is_available(group) ]
#there ara additional packages to add as dependencies to host package
if additional:
control.depends = ','.join(depends+additional)
control.save_control_to_wapt(package['sourcespath'])
# build and post the new wapt package
if options.dry_run:
result = wapt.build_package(package['sourcespath'])
else:
result = wapt.build_upload(package['sourcespath'], wapt_server_user='admin', wapt_server_passwd=server_password, private_key_passwd=server_password,inc_package_release=True)[0]
print " done, new packages : %s" % (','.join(additional))
if os.path.isfile(result):
os.remove(result)
else:
print " skipped, current packages: %s" % (','.join(depends))
finally:
# cleanup of temporary
if os.path.isdir(tmpdir):
rmtree(tmpdir)
except Exception as e:
print " error %s" % e
raise
Sincerely,
Florian