falcon适配ldap密码同步
问题
小米的openfalcon在使用ldap首次登陆成功后,会在本地创建同名的账号, 这就有个问题当你更新了ldap的密码时,openfalcon是没有同步本地账号密码的功能
二次改造
方便我们debug, 先把日志的debug打开,默认是没有运行时日志的,只有console日志
# 编辑文件 dashboard/rrd/utils/logger.pyimportsysfrom rrdimportconfigimportloggingfile_handler = logging.FileHandler(filename='/data1/dev/open-falcon/dashboard/var/running.log')formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')file_handler.setFormatter(formatter)logging.getLogger().addHandler(file_handler)logging.getLogger().setLevel(logging.DEBUG)添加两个util方法 dashboard/rrd/view/utils.py
def get_Apitoken(name, password):d = {"name": name,"password": password}h = {"Content-type":"application/json"}r = requests.post("%s/user/login"%(config.API_ADDR,), \data=json.dumps(d), headers=h)ifr.status_code !=200:raise Exception("%s %s"%(r.status_code, r.text))sig = json.loads(r.text)["sig"]returnjson.dumps({"name":name,"sig":sig})def get_user_id(name, Apitoken):h = {"Content-type":"application/json","Apitoken":Apitoken}r = requests.get("%s/user/name/%s"%(config.API_ADDR,name), headers=h)ifr.status_code !=200:user_id = -1returnuser_iduser_id = json.loads(r.text)["id"]returnuser_id重构登陆函数
diff --git a/rrd/view/auth/auth.py b/rrd/view/auth/auth.pyindex c203c4c..a546b95100644--- a/rrd/view/auth/auth.py+++ b/rrd/view/auth/auth.py@@ -17,6+17,7@@from flaskimportrequest, g, abort, render_template, redirectfrom flask.ext.babelimportrefreshimportrequests+importtracebackimportjsonfrom rrdimportappfrom rrdimportconfig@@ -48,6+49,7@@ def auth_login():ifldap =="1":try:ldap_info = view_utils.ldap_login_user(name, password)+ log.debug("ldap_info: %s"%ldap_info)h = {"Content-type":"application/json"}d = {@@ -58,12+60,20@@ def auth_login():"phone": ldap_info['phone'],}- r = requests.post("%s/user/create"%(config.API_ADDR,), \+ Apitoken = view_utils.get_Apitoken('admin','admin_password')+ user_id = view_utils.get_user_id(name, Apitoken)+ log.debug('apitoken:%s, user_id:%s'%(Apitoken, user_id))++ifuser_id >0:+ r = requests.put("%s/admin/change_user_passwd"%(config.API_ADDR), data=json.dumps({"user_id":user_id,"passwor+ log.debug('ldap login success and synchronize user password')+else:+ r = requests.post("%s/user/create"%(config.API_ADDR,), \data=json.dumps(d), headers=h)- log.debug("%s:%s"%(r.status_code, r.text))+ log.debug("create user status %s:%s"%(r.status_code, r.text))- #TODO: update password in dbifldap password changedexcept Exception as e:+ log.debug(traceback.format_exc())ret["msg"] = str(e)returnjson.dumps(ret)完
falcon适配ldap密码同步的更多相关文章
- 记一次LDAP主从同步配置
LDAP主从同步 OpenLDAP在2.3版本之前的同步复制带有一系列缺点如只支持一主多从模式等,在此缺点就不多说,下文着重介绍一下OpenLDAP V2.4以后的同步负复制功能 同步功能 2.4版最 ...
- Azure Active Directory Connect密码同步问题
这几天一直在弄O365与本地域账号的密码同步问题.由于微软即将用Azure Active Directory Connect(以下简称AADC)这个同步工具替代之前的DirSync,所以我也研究了下这 ...
- 如何将多个 Apple 设备中保存在 iCloud 里面密码同步
如何将多个 Apple 设备中保存在 iCloud 里面密码同步 iCloud 钥匙串 密码同步 数据迁移 iOS iCloud 钥匙串会记住一些信息,因此您就无需记忆这些信息. 它会在您批准的任何设 ...
- 通过PowerShell启用AADC的密码同步功能
在AADC工具里面也可以启用. 下面这个是世纪互联工程师提供的Powershell脚本(我测试了下是可以的),其中,$adConnector和$aadConnector可以在AADC工具里面找到. $ ...
- 19 Go的全能ORM简单入门
gorm 昨天我的ldap账户改了以后,openfalcon(v2.1)-dashboard竟然无法登陆了!显然,没有把我的密码同步到本地数据库里面,怎么办?只能改openfalcon用户认证的源码了 ...
- 实验记录贴 —— 账号同步实验 RTX 和 LDAP(AD域)
目前,公司有多个系统,RTX,邮箱(MD),OA,NC. 这些系统之间,如果要实现单点登录的话,账户肯定需要同步,或者某一种映射机制. 如果所有数据都和中央账号数据库(LDAP,这里是AD域)看齐,那 ...
- [原创]django+ldap实现统一认证部分一(django-auth-ldap实践)
前言 接之前我的文章,django+ldap+memcache实现单点登录+统一认证 ,ldap部署相关,ldap双机\LAM配置管理\ldap备份还原,目前来说,我们已经有了高可用性的ldap环境了 ...
- 07: Django 使用ldap登录、注销等
目录:Django其他篇 01:Django基础篇 02:Django进阶篇 03:Django数据库操作--->Model 04: Form 验证用户数据 & 生成html 05:Mo ...
- lsyncd 实时同步
1. 几大实时同步工具比较 1.1 inotify + rsync 最近一直在寻求生产服务服务器上的同步替代方案,原先使用的是inotify + rsync,但随着文件数量的增大到100W+,目录下的 ...
随机推荐
- linux下设置mysql表名不区分大小写
原文:http://blog.csdn.net/johnsonvily/article/details/6703902 1.Linux下mysql安装完后是默认:区分表名的大小写,不区分列名的大小写: ...
- 使用unidac 在linux 上无驱动直接访问MS SQL SERVER
随着delphi 10.2 开始了对Linux 的重新支持.devart 也迅速的发布了unidac 7.0, 最大的特性就是支持linux和MongoDB. 并有了其他更新: In this rel ...
- 40、IOS自动打包-Python脚本
第一种:基于编译的打包 编译工程--找到.app文件--新建Payload文件夹--拷贝.app到Payload文件夹--压缩成zip--更改后缀名为ipa--完成! 第二种(有问题,暂时不需要看) ...
- substr()和substring()函数
区别:主要是两者的参数不同 功能:相似. substr :返回一个从指定位置开始的指定长度的子字符串 substring :返回位于 String 对象中指定位置的子字符串. 用法: stringva ...
- list集合去除重复对象的实现
下面小编就为大家带来一篇list集合去除重复对象的实现.小编觉得挺不错的,现在就分享给大家,也给大家做个参考.一起跟随小编过来看看吧 对象重复是指对象里面的变量的值都相等,并不定是地址.list集合存 ...
- mysql (_mysql_exceptions.OperationalError) (1055, "Expression #1 of SELECT list is not in GROUP BY clause
sudo gedit /etc/mysql/my.cnf在打开的my.cnf文件中添加 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES 保存,退 ...
- mybatis 时间区间比较
直接上代码,此时数据库使用的Date类型: <if test="minCreateTime != null and minCreateTime != ''"> < ...
- 如何使用vs进行代码比较
当我们在进行团队合作开始项目时,有时候不仅自己要写代码还需要修改bug,当我们修改代码以后,为了保持代码库中代码的整洁美观和一直性,有些误操作,比如多一个或多个空格,多一行,少一行,格式对齐等,这样的 ...
- (记忆化搜索)Jury Compromise (poj 1015)
http://acm.fzu.edu.cn/problem.php?pid=1005 Description The fastfood chain McBurger owns several rest ...
- 查看和杀死进程ps
$ps -ef #查看执行的进程. $ps -aux | grep java #查看java进程 $sudo kill 进程号 [1] http://www.cnblogs.com/peida/arc ...