日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

Python3批量創建Crowd用戶并分配組

瀏覽:248日期:2022-07-25 09:03:42

背景

遷移 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,emaildaodaotest1,daodaotest1,daodaotest1@daodaotest.comdaodaotest2,daodaotest2,daodaotest2@daodaotest.comdaodaotest3,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 requestsfrom requests.auth import HTTPBasicAuthimport csvfrom itertools import islice# 請求 headersheaders = { ’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,textdef 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,textdef 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()

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
欧美日韩黑人| 伊人影院久久| 亚洲理论在线| 在线视频精品| 99国产精品久久久久久久成人热 | 国产亚洲精品美女久久| 日韩国产在线观看一区| 日韩精品导航| 91嫩草精品| 国产精品久久久免费| 美女毛片一区二区三区四区最新中文字幕亚洲 | 日韩久久精品网| 高清不卡亚洲| 亚洲小说欧美另类婷婷| 欧美日韩日本国产亚洲在线| 伊人成人在线视频| 亚洲精品黄色| 国产欧美视频在线| 欧美激情aⅴ一区二区三区 | 国产一区二区三区免费在线| 国产激情在线播放| 亚洲www啪成人一区二区| 亚洲国产专区| 老司机精品久久| 蜜桃av一区| 日本va欧美va精品发布| 国产精品免费精品自在线观看| 麻豆成人在线观看| 国产在线不卡一区二区三区| 香蕉成人av| 国产毛片一区| 91福利精品在线观看| 久久精品九色| 久久影院一区| 婷婷综合一区| 精品久久中文| 黄页网站一区| 欧美伊人久久| 麻豆mv在线观看| 欧美午夜不卡| 奇米777国产一区国产二区| 9999国产精品| 日韩中文字幕91| 国产欧美日韩精品一区二区三区 | 伊人久久婷婷| 国产欧美在线| 欧美日韩免费观看视频| 91久久亚洲| 国产精品极品| av亚洲免费| 欧美在线91| 日韩大片在线播放| 国产模特精品视频久久久久| 国产精品久久久久久模特| 色婷婷久久久| 日韩精品导航| 成人看片网站| 91嫩草精品| 激情综合自拍| 国产日韩1区| 激情自拍一区| 欧美a一区二区| 性一交一乱一区二区洋洋av| 久久一区精品| 视频在线在亚洲| 成人午夜在线| 亚洲精品一级| 婷婷激情一区| 欧美日本久久| 一本一道久久a久久精品蜜桃| 国产精品久久久久av蜜臀| 欧美日韩三区| 国产精品久久久久蜜臀| 亚洲三级国产| 久久久国产精品一区二区中文| 久久国产生活片100| 国产综合视频| 国产精品久久久久久久久久齐齐 | 石原莉奈在线亚洲二区| 成人免费一区| 日韩欧美美女在线观看| 欧美精品一区二区久久| 精品精品99| 欧美一级二级三级视频| 中文一区二区| 久久久久国产一区二区| 麻豆一区二区在线| 日韩欧美高清一区二区三区| 欧美~级网站不卡| 精品中文字幕一区二区三区四区| 亚洲在线久久| 欧美日韩国产综合网| 伊人久久视频| 国产精品v亚洲精品v日韩精品| 丝袜亚洲另类欧美| 三上悠亚国产精品一区二区三区| 国产精品蜜月aⅴ在线| 婷婷综合一区| 国产精品日韩欧美一区| 欧美日韩尤物久久| 精品国产鲁一鲁****| 久久国内精品视频| 日韩不卡一二三区| 综合一区在线| 蜜臀av一区二区三区| 午夜久久tv| 亚洲一级高清| 久久精品123| 日韩一区二区三区免费播放| 久久97视频| 国产精品一级在线观看| 色综合视频一区二区三区日韩| 久久国产精品99国产| 欧美~级网站不卡| 亚洲午夜久久久久久尤物| 免费高潮视频95在线观看网站| 久久精品国产一区二区| 麻豆精品久久久| 欧美国产日本| 美女久久久久久 | 免费一二一二在线视频| 国产aⅴ精品一区二区三区久久| 国产剧情在线观看一区| 日韩精品成人在线观看| 蜜桃视频欧美| 午夜在线视频一区二区区别| 欧美aa在线视频| 国产三级精品三级在线观看国产| 国产极品久久久久久久久波多结野| 亚洲va久久久噜噜噜久久| 久久久久国产精品一区二区| 视频一区日韩精品| 九九99久久精品在免费线bt| 欧美日韩色图| 日韩激情一二三区| 国产极品一区| 日韩精品麻豆| 奇米狠狠一区二区三区| 99久久久久久中文字幕一区| 亚久久调教视频| 久久亚洲一区| 日韩啪啪电影网| 日本不卡高清| 欧美69视频| 精品国产亚洲一区二区三区在线| 日韩三区在线| 久久精品av| 国产一区久久| 免费看的黄色欧美网站| 午夜在线一区| 欧美日韩中文一区二区| 欧美激情另类| 日韩黄色大片| 蜜桃tv一区二区三区| 一区二区三区四区日本视频| 亚洲精品午夜av福利久久蜜桃| 亚洲精品福利| 精品久久中文| 99久久99久久精品国产片果冰 | 国产一区二区三区日韩精品 | 欧美午夜三级| 国产精品婷婷| 一区二区电影| 亚洲天堂日韩在线| 精品视频国内| 蜜臀av国产精品久久久久| 日韩二区在线观看| 999精品在线| 丁香婷婷久久| 日韩精品免费一区二区夜夜嗨| 日韩欧美精品| 国产精品久久久久久久久久齐齐| 欧美专区在线| 国产精品亚洲综合久久| 综合日韩在线| 日韩在线a电影| 蜜臀av国产精品久久久久 | 欧美亚洲网站| 欧美另类专区| 综合激情五月婷婷| 美女国产精品| 国产中文字幕一区二区三区| 亚洲精品在线影院| 99国产精品| 国产日韩欧美中文在线| 99成人超碰| 日韩av一级片| 女生影院久久| 亚洲免费影院| 国产精品片aa在线观看| 免费精品国产| 国产精品色婷婷在线观看| 欧美一区二区三区高清视频 | 欧洲在线一区| 亚州精品视频| 亚洲最新无码中文字幕久久| 一区二区电影| 日韩不卡免费高清视频| 日韩va欧美va亚洲va久久| 久久久久免费av|