def new_f(self, domain): formok = True errors = [] items = {} try: ParamChecker.checkDomain('domain') except InvalidParameterFormat as ipf: formok = False errors.append(ipf.message) if not formok: self.session['errors'] = errors self.session['reqparams'] = {} # @TODO request.params may contain multiple values per key... test & fix for k in self.request.params.iterkeys(): self.session['reqparams'][k] = self.request.params[k] self.session.save() raise HTTPRedirect('/mails/editDomain') else: items['domain'] = domain return f(self, items)
def new_f(self, domain): formok = True errors = [] items = {} try: ParamChecker.checkDomain("domain") except InvalidParameterFormat as ipf: formok = False errors.append(ipf.message) if not formok: self.session["errors"] = errors self.session["reqparams"] = {} # @TODO request.params may contain multiple values per key... test & fix for k in self.request.params.iterkeys(): self.session["reqparams"][k] = self.request.params[k] self.session.save() raise HTTPRedirect("/mails/editDomain") else: items["domain"] = domain return f(self, items)
def listAliases(self, domain, *args, **kwargs): try: ParamChecker.checkDomain('domain', param=True) except: raise HTTPRedirect('/mails/index') c = TemplateContext() c.heading = _('Aliases for domain: %s') % (domain) c.domain = domain c.aliases = self.mf.getAliases(domain) return self.render('/mails/listAliases.mako', template_context=c)
def listAliases(self, domain, *args, **kwargs): try: ParamChecker.checkDomain("domain", param=True) except: raise HTTPRedirect("/mails/index") c = TemplateContext() c.heading = _("Aliases for domain: %s") % (domain) c.domain = domain c.aliases = self.mf.getAliases(domain) return self.render("/mails/listAliases.mako", template_context=c)
def editDomain(self, domain=None): c = TemplateContext() # vary form depending on mode (do that over ajax) if domain is None: action = 'Adding' c.mode = 'add' else: try: ParamChecker.checkDomain('domain') except: return self.index() action = 'Editing' c.mode = 'edit' try: c.domain = self.mf.getDomain(domain) except LookupError: msg = _('No such domain!') return self.index(msg=msg) c.heading = '%s domain' % (action) return self.render('/mails/editDomain.mako', template_context=c)
def deleteDomain(self, domain): return 'HARD disabled ... you do not want to mess with this in production!!!' try: ParamChecker.checkDomain('domain', param=True) except: raise HTTPRedirect('/mails/index') try: result = self.mf.deleteDomain(domain) if result: msg = _('Domain successfully deleted') msg_class = 'success' else: msg = _('Failed to delete domain!') msg_class = 'error' except: msg = _('Failed to delete domain!') msg_class = 'error' self.session.save() return self.index(msg=msg, msg_class=msg_class)
def editDomain(self, domain=None): c = TemplateContext() # vary form depending on mode (do that over ajax) if domain is None: action = "Adding" c.mode = "add" else: try: ParamChecker.checkDomain("domain") except: return self.index() action = "Editing" c.mode = "edit" try: c.domain = self.mf.getDomain(domain) except LookupError: msg = _("No such domain!") return self.index(msg=msg) c.heading = "%s domain" % (action) return self.render("/mails/editDomain.mako", template_context=c)
def deleteDomain(self, domain): return "HARD disabled ... you do not want to mess with this in production!!!" try: ParamChecker.checkDomain("domain", param=True) except: raise HTTPRedirect("/mails/index") try: result = self.mf.deleteDomain(domain) if result: msg = _("Domain successfully deleted") msg_class = "success" else: msg = _("Failed to delete domain!") msg_class = "error" except: msg = _("Failed to delete domain!") msg_class = "error" self.session.save() return self.index(msg=msg, msg_class=msg_class)
def new_f(self, mode, alias, domain, mail=None, maildrop=None): formok = True errors = [] items = {} if not mode in ['add', 'edit']: raise HTTPRedirect('/mails/index') if mode == 'add': try: ParamChecker.checkDomain('domain') except InvalidParameterFormat as ipf: formok = False errors.append(ipf.message) alias += '@' + domain domain = alias.split('@')[1] try: ParamChecker.checkDomain(domain, param=False) except InvalidParameterFormat as ipf: formok = False errors.append(ipf.message) # @TODO improve check try: ParamChecker.checkString('maildrop', min_len=0, max_len=300) except InvalidParameterFormat as ipf: formok = False errors.append(_('Invalid mail destination!')) if mail and not mail == '': for k in mail.split('\n'): m = k.replace('\r', '').replace(' ', '') if m == '': continue try: ParamChecker.checkEmail(m, param=False) except: formok = False break m_domain = m.split('@')[1] if not m_domain == domain: formok = False errors.append(_('All aliases need to be within the same domain!')) break if len(mail) > 300: formok = False if not formok: errors.append(_('Invalid related aliases!')) if not formok: self.session['errors'] = errors self.session['reqparams'] = {} # @TODO request.params may contain multiple values per key... test & fix for k in cherrypy.request.params.iterkeys(): self.session['reqparams'][k] = cherrypy.request.params[k] self.session.save() if mode == 'edit': raise HTTPRedirect('/mails/editAlias/?alias={0}'.format(alias)) else: raise HTTPRedirect('/mails/editAlias') else: items['mode'] = mode items['alias'] = alias items['mail'] = [] items['maildrop'] = [] if mail and len(mail) > 0: for k in mail.split('\n'): m = k.replace('\r', '').replace(' ', '') if m == '': continue items['mail'].append(m) if maildrop and len(maildrop) > 0: for k in maildrop.split('\n'): m = k.replace('\r', '').replace(' ', '') if m == '': continue items['maildrop'].append(m) return f(self, items)
def new_f(self, mode, alias, domain, mail=None, maildrop=None): formok = True errors = [] items = {} if not mode in ["add", "edit"]: raise HTTPRedirect("/mails/index") if mode == "add": try: ParamChecker.checkDomain("domain") except InvalidParameterFormat as ipf: formok = False errors.append(ipf.message) alias += "@" + domain domain = alias.split("@")[1] try: ParamChecker.checkDomain(domain, param=False) except InvalidParameterFormat as ipf: formok = False errors.append(ipf.message) # @TODO improve check try: ParamChecker.checkString("maildrop", min_len=0, max_len=300) except InvalidParameterFormat as ipf: formok = False errors.append(_("Invalid mail destination!")) if mail and not mail == "": for k in mail.split("\n"): m = k.replace("\r", "").replace(" ", "") if m == "": continue try: ParamChecker.checkEmail(m, param=False) except: formok = False break m_domain = m.split("@")[1] if not m_domain == domain: formok = False errors.append(_("All aliases need to be within the same domain!")) break if len(mail) > 300: formok = False if not formok: errors.append(_("Invalid related aliases!")) if not formok: self.session["errors"] = errors self.session["reqparams"] = {} # @TODO request.params may contain multiple values per key... test & fix for k in cherrypy.request.params.iterkeys(): self.session["reqparams"][k] = cherrypy.request.params[k] self.session.save() if mode == "edit": raise HTTPRedirect("/mails/editAlias/?alias={0}".format(alias)) else: raise HTTPRedirect("/mails/editAlias") else: items["mode"] = mode items["alias"] = alias items["mail"] = [] items["maildrop"] = [] if mail and len(mail) > 0: for k in mail.split("\n"): m = k.replace("\r", "").replace(" ", "") if m == "": continue items["mail"].append(m) if maildrop and len(maildrop) > 0: for k in maildrop.split("\n"): m = k.replace("\r", "").replace(" ", "") if m == "": continue items["maildrop"].append(m) return f(self, items)