diff options
Diffstat (limited to 'perc')
-rwxr-xr-x | perc | 48 |
1 files changed, 36 insertions, 12 deletions
@@ -33,6 +33,8 @@ # - Maintains a list of admins allowed to perform admin actions # 3.4: # - Ability to add new users added +# 3.4.1: +# - Can now clone (-c/--clone) existing users to create new users (also allows other options in addition such as -s -f to further customise a new user) import copy import decimal @@ -45,7 +47,7 @@ import sys from datetime import datetime, date, timedelta, time PROG = "perc" -VERSION = "3.4" +VERSION = "3.4.1" CONFIG_FILE = "perc.cfg" @@ -442,20 +444,29 @@ class TimeRange(object): def toDict(self): return { "start": self._start, "finish": self._finish } + + def __copy__(self): + return TimeRange(self._start, self._finish, self.user) + + def __deepcopy__(self, memo): + return TimeRange(self._start, self._finish, self.user) class User(object): PROPERTIES = ["start", "finish", "format", "output", "lunch"] - Name = property(fget=lambda self: self._name) + Name = property(fget=lambda self: self._name, fset=lambda self, value: setattr(self, "_name", value)) - def __init__(self, name): + def __init__(self, name, data=None): self._name = name.lower() - try: - self.data = self.__parseData(CONFIG["DEFAULTS"][name]) - except KeyError: - self.data = {} + if data: + self.data = data + else: + try: + self.data = self.__parseData(CONFIG["DEFAULTS"][name]) + except KeyError: + self.data = {} def __parseData(self, data): data = copy.deepcopy(data) @@ -532,6 +543,12 @@ class User(object): self.__defaultDeleter(name) else: super(User, self).__delattr__(name) + + def __copy__(self): + return User(copy.copy(self.data)) + + def __deepcopy__(self, memo): + return User(self.Name, copy.deepcopy(self.data)) def admin(args): if USER.Name not in CONFIG["ADMINS"]: @@ -544,6 +561,7 @@ def admin(args): parser.add_option("-v", "--version", action="store_true", dest="version", help="Display the version of %s" % PROG) parser.add_option("-a", "--add-event", action="store", dest="add_event", help="Add the named event to {prog} to be used in the usual !{prog} <event_name> way".format(prog=PROG)) parser.add_option("-u", "--user", action="store", dest="user", help="Reference the named user. Used in tandem with -l and -s and -f commands. If only used with -s and/or -f then sets start and finish times of entire day for user. If used with -l and -s and/or -f commands sets the lunch times of that user.") + parser.add_option("-c", "--clone", action="store", dest="clone", help="") parser.add_option("-l", "--lunch", action="store_true", default=False, dest="lunch", help="Indicate that lunch times are to be set.") parser.add_option("-r", "--remove-event", action="store", dest="remove_event", help="Remove a named event from %s" % PROG) parser.add_option("-s", "--start", action="store", dest="start", help="Used in conjunction with -a/--add-event option. The start date/time of the event.") @@ -558,30 +576,36 @@ def admin(args): sys.exit(0) if options.user: - user = User(options.user) + user = None + if options.clone: + user = copy.deepcopy(User(options.clone)) + user.Name = options.user + else: + user = User(options.user) + if options.lunch: lunch_start = "13:00" lunch_finish = "14:00" - + if options.start: lunch_start, f = parseTime(options.start) lunch_start = lunch_start.strftime("%H:%M") if options.finish: lunch_finish, f = parseTime(options.finish) lunch_finish = lunch_finish.strftime("%H:%M") - + lunch = TimeRange(lunch_start, lunch_finish, user) user.lunch = lunch else: if options.start: start, f = parseTime(options.start) user.start = start.strftime("%H:%M") - + if options.finish: finish, f = parseTime(options.finish) user.finish = finish.strftime("%H:%M") - + if options.format: user.format = options.format if options.output: |