#!/usr/bin/env python #------------------------------------------------------------------------------ # Copyright (c) Perforce Software, Inc., 2007-2015. All rights reserved # # Redistribution and use in source and binary forms, with or without # modification, are permitted provided that the following conditions are met: # # 1 Redistributions of source code must retain the above copyright # notice, this list of conditions and the following disclaimer. # # 2. Redistributions in binary form must reproduce the above copyright # notice, this list of conditions and the following disclaimer in the # documentation and/or other materials provided with the distribution. # # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS # FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL PERFORCE # SOFTWARE, INC. BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON # ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR # TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF # THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH # DAMAGE. #------------------------------------------------------------------------------ USAGE = """ This script will look for the specified users in all groups and remove them. Usage: removeuserfromgroups.py [instance] USER removeuserfromgroups.py [instance] FILE USER can be a single username or, it can be a FILE with a list of users. instance defaults to 1 if not given. """ import os import re import string import sys import time import platform import ConfigParser if len(sys.argv) > 2: P4INSTANCE = str(sys.argv[1]) else: P4INSTANCE = '1' config = ConfigParser.RawConfigParser() config.read('maintenance.cfg') ########################################################################## ##### ##### ##### CONFIGURATION VARIABLES: Modify in maintenance.cfg as needed. ##### ##### ##### server = (config.get(P4INSTANCE, 'server')) p4user = (config.get(P4INSTANCE, 'p4user')) passwd = (config.get(P4INSTANCE, 'passwd')) if platform.system() == "Windows": p4="p4.exe -p %s -u %s" % (server, p4user) else: p4="/p4/1/bin/p4_1 -p %s -u %s" % (server, p4user) os.system('echo %s| %s login' % (passwd, p4)) def removeuserfromfile(groupfile, username): infile = open (groupfile, "r") outfile = open (groupfile + ".new", "w") for line in infile.readlines(): if username.lower() != (line.strip()).lower(): outfile.write(line) infile.close() outfile.close() os.remove(groupfile) newgroupfile = groupfile + ".new" os.rename(newgroupfile, groupfile) def removeuser(username): usersgroups = [] for line in os.popen("%s groups %s" % (p4, username)): line = line.strip() print("Removing %s from %s" % (username, line)) groupname = re.sub("/", "_", line) groupfile = "%s.group" % groupname if not os.path.exists(groupfile): os.system ("%s group -o %s > %s" % (p4, line, + groupfile)) usersgroups.append (line) if line not in groups: groups.append (line.strip()) for group in usersgroups: groupname = re.sub("/", "_", group) groupfile = "%s.group" % groupname removeuserfromfile(groupfile, username) def savegroups(): print("Saving groups on server") for group in groups: groupname = re.sub("/", "_", group) groupfile = "%s.group" % groupname os.system ("%s group -i < %s" % (p4, groupfile)) def cleanup(): print("Cleaning temp files") for group in groups: try: groupname = re.sub("/", "_", group) groupfile = "%s.group" % groupname os.remove(groupfile) except: print("Failed to delete %s." % groupfile) def automain(userlist): global initialized initialized = 0 global groups groups = [] for user in userlist: removeuser(user) savegroups() cleanup() def main(): if len (sys.argv) < 2: print(USAGE) sys.exit (1) # Handle the optional instance parameter shift if len(sys.argv) > 2: userorfile=(sys.argv[2]) else: userorfile=(sys.argv[1]) global initialized initialized = 0 global groups groups = [] try: userlistfile = open( userorfile, "r" ) for line in userlistfile.readlines(): line = line.strip() if line: removeuser(line) userlistfile.close() except: print("No file %s available, assuming it is the actual user name." % userorfile) removeuser(userorfile.strip()) savegroups() cleanup() if __name__ == '__main__': main()
# | Change | User | Description | Committed | |
---|---|---|---|---|---|
#11 | 27331 | C. Thomas Tyler |
Released SDP 2020.1.27325 (2021/01/29). Copy Up using 'p4 copy -r -b perforce_software-sdp-dev'. |
||
#10 | 26161 | C. Thomas Tyler |
Released SDP 2019.3.26159 (2019/11/06). Copy Up using 'p4 copy -r -b perforce_software-sdp-dev'. |
||
#9 | 22685 | Russell C. Jackson (Rusty) | Update main with current changes from dev. | ||
#8 | 20997 | C. Thomas Tyler |
Released SDP 2016.2.20995 (2016/11/07). Copy Up using 'p4 copy -r -b perforce_software-sdp-dev'. |
||
#7 | 20974 | C. Thomas Tyler |
Released SDP 2016.2.20972 (2016/11/01). Copy Up using 'p4 copy -r -b perforce_software-sdp-dev'. |
||
#6 | 16581 | Robert Cowham |
Standardised processing and formatting. Made python 2/3 compatible. These need automated testing! |
||
#5 | 15856 | C. Thomas Tyler |
Replaced the big license comment block with a shortened form referencing the LICENSE file included with the SDP package, and also by the URL for the license file in The Workshop. |
||
#4 | 13908 | C. Thomas Tyler | Pushing SDP 2015.1.13906. | ||
#3 | 11583 | Russell C. Jackson (Rusty) |
Added -Fs to client delete in case shelves can't be deleted for some reason. Added replacement of / with _ for group file names to avoid errors with groups that have a / in the name. |
||
#2 | 11524 | Russell C. Jackson (Rusty) | Released updated version of the SDP from Dev. | ||
#1 | 10148 | C. Thomas Tyler | Promoted the Perforce Server Deployment Package to The Workshop. |