import CryptoBoxPlugin

RESERVED_USERS = [ "admin" ]

class user_manager(CryptoBoxPlugin.CryptoBoxPlugin):

	pluginCapabilities = [ "system" ]
	requestAuth = True
	rank = 45

	def doAction(self, store=None, user=None, new_pw=None, new_pw2=None):
		import re
		adminDict = self.cbox.prefs.userDB["admins"]
		self.__cleanHDF()
		if store is None:
			pass
		elif store == "add_user":
			if (user is None) or (re.search(u'\W', user)):
				self.hdf["Data.Warning"] = "Plugins.user_manager.InvalidUserName"
			elif not new_pw:
				self.hdf["Data.Warning"] = "EmptyNewPassword"
			elif new_pw != new_pw2:
				self.hdf["Data.Warning"] = "DifferentPasswords"
			elif user in adminDict.keys():
				self.hdf["Data.Warning"] = "Plugins.user_manager.UserAlreadyExists"
			else:
				adminDict[user] = self.cbox.prefs.userDB.getDigest(new_pw)
				self.hdf["Data.Success"] = "Plugins.user_manager.UserAdded"
				try:
					self.cbox.prefs.userDB.write()
				except IOError:
					self.cbox.log.warn("failed to write user database")
		elif store == "change_password":
			if not new_pw:
				self.hdf["Data.Warning"] = "EmptyNewPassword"
			elif new_pw != new_pw2:
				self.hdf["Data.Warning"] = "DifferentPasswords"
			elif user in adminDict.keys():
				adminDict[user] = self.cbox.prefs.userDB.getDigest(new_pw)
				self.hdf["Data.Success"] = "Plugins.user_manager.PasswordChanged"
				try:
					self.cbox.prefs.userDB.write()
				except IOError:
					self.cbox.log.warn("failed to write user database")
			else:
				self.cbox.log.info("user_manager: invalid user choosen (%s)" % str(user))
		elif store == "del_user":
			if user in RESERVED_USERS:
				self.cbox.log.info("user_manager: tried to remove reserved user (%s)" % user)
			elif user in adminDict.keys():
				del adminDict[user]
				self.hdf["Data.Success"] = "Plugins.user_manager.UserAdded"
				try:
					self.cbox.prefs.userDB.write()
				except IOError:
					self.cbox.log.warn("failed to write user database")
			else:
				self.cbox.log.info("user_manager: tried to remove non-existing user (%s)" % str(user))
		else:
			self.cbox.log.info("user_manager: invalid value of 'store' (%s)" % store)
		self.__prepareHDF(adminDict)
		return "user_list"


	def getStatus(self):
		return "/".join(self.cbox.prefs.userDB["admins"].keys())


	def __cleanHDF(self):
		for key in self.hdf.keys():
			del self.hdf[key]


	def __prepareHDF(self, dict):
		## sort by name
		users = dict.keys()
		users.sort()
		## export all users
		for name in users:
			self.hdf[self.hdf_prefix + "Users." + name] = name