专栏首页恩蓝脚本Python3批量创建Crowd用户并分配组

Python3批量创建Crowd用户并分配组

背景

迁移 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\?username\=daodaotest

注意:此处-u的参数为 Crowd 中应用(Application)的用户名和密码,Crowd 的管理员是不能添加用户。

Python 实现脚本

实现添加 Crowd 用户,用户添加到指定组,读取 csv 文件批量添加用户和设定的多个组。

crowdUsers.csv 用户数据 csv 文件

name,displayName,email daodaotest1,daodaotest1,daodaotest1@daodaotest.com daodaotest2,daodaotest2,daodaotest2@daodaotest.com daodaotest3,daodaotest3,daodaotest3@daodaotest.com ……

addCrowdUsers.py 批量添加 Crowd 用户和用户组脚本

#!/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?username='+username,
headers=headers,
auth=HTTPBasicAuth(auth_username,auth_password),
data=data
)
# 状态码
status_code=response.status_code
# 响应报文信息
text=response.text
# 状态判断
if str(status_code).startswith("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()

以上就是本文的全部内容,希望对大家的学习有所帮助。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • python如何使用代码运行助手

    python代码运行助手是能在网页上运行python语言的工具。因为python的运行环境在很多教程里都是用dos的,黑乎乎的界面看的有点简陋,所以出了这pyt...

    砸漏
  • Linux中创建新用户并赋予指定目录的相关权限

    这种方式创建的用户可以使用ssh登录,但只有只读权限可以浏览下载部分文件无法写和修改。

    砸漏
  • Python 抓取数据存储到Redis中的操作

    redis是一个key-value存储结构。和Memcached类似,它支持存储的value类型相对更多,包括string(字符串)、list(链表)、set(...

    砸漏
  • BSidesSF 2019 CTF writeup

    在网上刷的题目,难度还好,一些题目很有借鉴意义,收录了一些web方面的writeup,用来学习。有更好的解题思路欢迎留言。

    用户5878089
  • 精细化用户增长案例:事件、留存、漏斗分析方法是什么?

    事件分析法的应用领域非常广泛,不同学者从本领域视角对其进行了阐述。事件研究是根据某一事件发生前后的资料统计,采用特定技术测量该事件影响性的一种定量分析方法。

    1480
  • 事件、留存、漏斗分析到底是个啥?

    小五今天给大家带来的这篇文章,是关于用户精细化分析的,总体来说涉及到四个方面,分别是事件分析、留存分析、漏斗分析和分布分析。

    朱小五
  • 封装内嵌UICollectionView和UIPageControl的ScrollView

    在需求中涉及到一个比较通用的控件,ScrollView里面嵌入CollectionView,封装一下,后面再有相同交互不用重复造轮子。 一。交互样式 控件交互...

    MelonTeam
  • mvn archetype:create和mvn archetype:generate

    create is deprecated in maven 3.0.5 and beyond,在maven3.0.5以上版本舍弃了create,使用genera...

    WindWant
  • ABTest中的统计学 - 基础篇

    一 、ABTest与统计学 ABTest的目的是为了快速验证一个版本是不是比另外一个版本要好。为了简化问题,我们假设要验证的app是手机QQ浏览器,同时假设衡...

    腾讯移动品质中心TMQ
  • 反应式编程 RxJava 设计原理解析

    ReactiveX 的全称为Reactive Extension,一般缩写为 Rx,即我们平常所说的反应式编程。其设计原理主要使用了观察者模式,区分数据的生产者...

    2020labs小助手

扫码关注云+社区

领取腾讯云代金券