背景
迁移 Crowd 完成后(之前采用 LDAP 方式,新迁移 Crowd 不采用),需要批量创建公司所有员工的用户以及分配组,手工创建以及之前 Postman 的方式还是比较低效。
Python 在 N 多年前入门,写了几个爬虫脚本后,再也没用过,借这个机会顺便再熟悉下 Python 脚本。
归根结底的原因就是:本人很懒~
Crowd Api
https://docs.atlassian.com/atlassian-crowd/3.2.0/REST/
如下示例是基于 Crowd 3.2.0 版本的 Api,不同版本间的 Api 稍有差异。
# 添加用户
$ curl -u "application-name:password" -X POST -H "Content-Type: application/json" -H "Accept: application/json" -d "{\"name\" : \"test.user\", \"display-name\" : \"Test User\", \"active\" : true, \"first-name\" : \"Test\", \"email\" : \"test.user@ourdomain.com\", \"last-name\" : \"User\", \"password\" : {\"value\" : \"mypassword\"} }" http://localhost:8095/crowd/rest/usermanagement/1/user# 用户添加到组
$ curl -u "application-name:password" -X POST -H "Content-Type: application/json" -d "{\"name\" : \"all-users\"}" http://localhost:8095/crowd/rest/usermanagement/1/user/group/direct\"htmlcode">#!/usr/bin/python # -*- coding: UTF-8 -*- # # Filename addCrowdUsers.py # Revision 0.0.1 # Date 2020/5/14 # Author jiangliheng # Email jiang_liheng@163.com # Website https://jiangliheng.github.io/ # Description 批量添加 Crowd 用户和用户组 import requests from requests.auth import HTTPBasicAuth import csv from itertools import islice # 请求 headers headers = { 'Accept': 'application/json', 'Content-type': 'application/json', } # crowd 访问基础路径 base_url='http://localhost:8095' # 添加用户的默认用户组和密码 auth_username='application-name' auth_password='password' # 用户默认密码 password='daodaotest' def addUser(name,displayName,email): """ 添加单用户 :param name: 登录用户,建议拼音全称,如:jiangliheng :param displayName: 显示名称,建议中文全称,如:蒋李恒 :param email: 邮箱地址 :return: status_code 状态码,text 响应报文信息 """ # 请求 json 数据 data = '{ "name" :"' + name + '", "email" : "' + email + '", "active" : true, "first-name" : "' + displayName + '", "last-name" : "' + displayName + '", "display-name" : "'+ displayName + '", "password" : { "value" : "' + password + '" } }' # 发起请求 # 解决中文乱码问题 data.encode("utf-8").decode("latin1") response = requests.post( base_url + '/crowd/rest/usermanagement/1/user', headers=headers, auth=HTTPBasicAuth(auth_username,auth_password), data=data.encode("utf-8").decode("latin1") ) # 状态码 status_code=response.status_code # 响应报文信息 text=response.text # 状态判断 if str(status_code).startswith("2"): print("%s 用户添加成功,状态码:%s ,响应报文信息:%s" % (name,status_code,text)) else: print("%s 用户添加失败,状态码:%s ,响应报文信息:%s" % (name,status_code,text)) # 返回 状态码,响应报文信息 return status_code,text def addGroup(username,groupname): """ 用户添加到组 :param username: 登录用户,建议拼音全称,如:jiangliheng :param groups: 用户组,用逗号隔开,如:bitbucket-users,bamboo-users :return: status_code 状态码,text 响应报文信息 """ # 请求 json 数据 data = '{ "name" :"' + groupname + '" }' # 发起请求 response = requests.post( base_url + '/crowd/rest/usermanagement/1/user/group/direct"2"): print("%s 用户添加组 %s 成功,状态码:%s ,响应报文信息:%s" % (username,groupname,status_code,text)) else: print("%s 用户添加组 %s 失败,状态码:%s ,响应报文信息:%s" % (username,groupname,status_code,text)) # 返回 状态码,响应报文信息 return status_code,text def addUserByCsv(csvfile): """ 通过 CSV 文件批量添加用户,并加到组 :param filename: Crowd 用户 csv 文件 """ # 批量读取 csv 的用户 with open(csvfile, 'r', encoding='utf-8') as f: fieldnames = ("name", "displayName", "email") reader = csv.DictReader(f, fieldnames) for row in islice(reader, 1, None): print("批量添加用户 %s" % (row["name"])) # 添加用户 addUser(row["name"],row["displayName"],row["email"]) # 添加多个组 addGroup(row["name"],"all-users") addGroup(row["name"],"bitbucket-users") addGroup(row["name"],"confluence-users") addGroup(row["name"],"jira-software-users") addGroup(row["name"],"sonar-users") f.close() def main(): # 通过 CSV 文件批量添加用户,并加到组 addUserByCsv("crowdUsers.csv") # 添加单用户 # addUser("daodaotest","叨叨软件测试","daodaotest@daodaotest.com") # 添加用户到组 # addGroup("daodaotest","all-users") if __name__ == "__main__": main()以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- PatriciaPaay-Playmate(ExpandedEditionRemastered2024)[24Bit-96kHz]FLAC
- 蒋志光韦绮姗.2014-传奇巨声【环星】【WAV+CUE】
- 关淑怡.2008-演唱会+无尽经典3CD【环球】【WAV+CUE】
- 伍佰.2002-冬之火九重天演唱会特选录音专辑2CD【滚石】【WAV+CUE】
- 李宗盛1996《李宗盛的凡人歌2CD》滚石[WAV+CUE][1G]
- 刘德华 《天意》1:1直刻黑胶LPCD[WAV+CUE][1.1G]
- 刘德丽2024《赤的疑惑HQCD》头版限量编号MQA[低速原抓WAV+CUE]
- 英雄联盟万圣节有什么皮肤返场 2024万圣节皮肤返场一览
- lol万圣节赠礼活动什么时候开始 2024万圣节活动时间介绍
- 2024全球总决赛blg是全华班吗 全球总决赛blg选手所属国家介绍
- 《LOL》S14半决赛:T1战胜GEN晋级决赛!对决BLG
- 《完蛋美女前传》白白演员抱怨:都没人玩我的线
- 玩家热议OLED屏对画面提升巨大:比PS5 Pro值得买
- PatriciaPaay-TheLadyIsAChamp(ExpandedEdition)(2024)[24Bit-96kHz]FLAC
- 尚士达.2024-莫回头【智慧小狗】【DTS-WAV分轨】