是否有一种存储web2py应用程序配置设置的好方法?
我编写了一个小应用程序,其中包含一个从LDAP查找用户属性(名称,电子邮件地址等)的脚本。我们的公司LDAP服务器在允许搜索用户详细信息之前需要绑定。
我希望在删除用于绑定的凭据之前,从GitHub存储库共享我的应用程序。
来自.Net背景,我习惯将这样的配置放到app | web.config文件中。但这是web2py中的seems to be frowned on。
这是一种Pythonic或web2pyonic方式吗?
def user_info(username):
#todo: move these parameters to config
ldap_host = 'example.com'
ldap_port = 389
ldap_base_dn = 'OU=DK,DC=example,DC=com'
ldap_bind_dn = 'CN=<removed>,OU=DK,DC=example,DC=com'
ldap_bind_pw = '<removed>'
ldap_attr_uid = 'sAMAccountName'
ldap_attr_forename = 'givenName'
ldap_attr_surname = 'sn'
ldap_attr_display_name = 'displayName'
ldap_attr_department = 'department'
ldap_attr_employee_type = 'employeeType'
ldap_attr_email = 'mail'
l = ldap.initialize('ldap://%s:%s' % (ldap_host, ldap_port))
l.simple_bind_s(ldap_bind_dn, ldap_bind_pw)
r = l.search_s(base=ldap_base_dn,
scope=ldap.SCOPE_SUBTREE,
filterstr='(%s=%s)' % (ldap_attr_uid, username),
attrlist=[
ldap_attr_forename,
ldap_attr_surname,
ldap_attr_email,
ldap_attr_display_name,
ldap_attr_employee_type,
ldap_attr_department])
if r:
dn, e = r[0]
return {
'dn': dn,
'forename': e[ldap_attr_forename][0],
'surname': e[ldap_attr_surname][0],
'email': e[ldap_attr_email][0],
'display_name': e[ldap_attr_display_name][0],
'department': e[ldap_attr_department][0],
'employee_type': e[ldap_attr_employee_type][0]}
return None
答案 0 :(得分:2)
有不同的选项,但一种方法只是将设置放在模块中并导入。在/yourapp/modules/ldap_settings.py中:
ldap_host = 'example.com'
ldap_port = 389
...
然后在你的函数中:
def user_info(username):
from ldap_settings import *
...
答案 1 :(得分:1)
我认为正确的web2py方法是使用AppConfig模块。请在web2py参考手册中查看: http://web2py.com/books/default/chapter/29/13/deployment-recipes#AppConfig-module
答案 2 :(得分:0)
正如Keht所说,AppConfig
是正确的方法。 ini文件存在于私人文件夹中。您可以看到已经存在默认电子邮件smtp设置,web2py用于发送用户验证电子邮件/忘记密码电子邮件。
您可以在此输入所需的键值,然后创建AppConfig对象并读取所需的键。