Python快速调用Teambition接口

Python快速调用Teambition接口

需求描述:

      Teambition是一个简单、高效的项目协作工具,是一款企业协作软件,很多企业用来作为任务跟踪管理和BUG管理工具.

      2019年阿里收购了Teambition,不知道未来使用的企业会不会越来越多.

      Teambition有导入导出功能,可以导入导出excel,csv文件,在工作中很方便.一般来说,除了一开始使用时会批量导入任务,其他时候很少使用批量导入,任务直接创建就可以了.

      企业在定期(如每周)跟踪任务进度时,会经常需要批量导出.但批量导出的格式比较固定,有时候可能不符合我们的要求,如需要按老板指定的格式,或者需要将数据添加到其他平台上等.

      Teambition提供了API接口,我们可以注册成为开发者,然后通过接口获取Teambition的数据,按照需求的格式保存和分析.

一、注册Teambition开发者 

1.登录Teambition,要有管理员的权限,点击左上角的菜单按钮,然后点击进入企业的"管理后台".

Python快速调用Teambition接口_第1张图片

2.然后点击"应用管理"

Python快速调用Teambition接口_第2张图片

3.在应用管理页面点击"立即创建"创建应用,弹出创建应用的窗口

Python快速调用Teambition接口_第3张图片

4.在应用创建窗口中填写"应用名称",所属企业为当前管理员用户所在的企业,然后点击确定,就会进入teambition开发者中心的"基本信息"界面

Python快速调用Teambition接口_第4张图片

5.在"基本信息"界面,已经默认生成了当前应用的Client ID和Client Secret,我们在调用Teambition API时,会使用到这两个值

Python快速调用Teambition接口_第5张图片

6.在teambition开发者中心的"OAuth 2配置"页面,填入回调地址,这里的回调地址填企业首页的地址就可以了,然后点保存,下方的"OAuth 2介绍"里介绍了通过Client_id和redirect_url获取一次性code,然后根据code获取access_token的步骤,Teambition所有的API都要通过access_token来调用

Python快速调用Teambition接口_第6张图片

7.在teambition开发者中心的"Webhook 配置"页面填写teambition服务器地址,点击保存

Python快速调用Teambition接口_第7张图片

完成以上步骤后,就可以根据Client ID,Client Secret,redirect_url获取到access_token,然后调用Teambition的API

二、获取Teambition access_token

    这一步是调用Teambition API最重要的步骤,需要花点时间完成.直接上代码,在注释里说明每步的作用

    发送请求通过强大的requests库,因为获取code是通过回调URL携带回来的,登录过程需要点击"授权登录"按钮,所以会使用selenium库模拟浏览器输入内容和点击按钮,具体的使用方法考:

https://mp.csdn.net/postedit/89527113

sleep是因为Teambition登录时会有加载过程,用sleep来等待页面加载.

完整伪代码如下,记得下载对应浏览器版本的chromedriver.exe到代码所在目录下,然后把company_id, client_id, client_secret, user_email, user_password换成自己的值,然后运行就可以了获得token了.

打印出token后,将token值赋值给__init__()下的self.token,后面的方法就直接使用token值了.

import requests
from selenium import webdriver
import time


class GetTeamBitionEvents(object):

    def __init__(self):
        # 进入teambition企业首页的url,可以通用,后面拼接不同的企业id即进入不同企业的首页
        self.company_url = 'https://www.teambition.com/organization/'
        # 登录Teambition默认进入您的企业首页,url中有企业的id,复制到此,企业创建后id不会改变
        self.company_id = 'xxxxxxxxxxxxxxxxxxxxxx'
        # 在开发者中心OAuth2配置处填的回调地址,与这里拼接的回调地址保持一致
        self.callback_url = self.company_url + self.company_id
        # 在teambition开发者中心,创建应用时的Client ID,复制到此
        self.client_id = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
        # 在teambition开发者中心,创建应用时的Client Secret,复制到此
        self.client_secret = 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
        # 获取一次性code的url
        self.auth_url = 'https://account.teambition.com/oauth2/authorize?client_id=' + self.client_id + '&redirect_uri=' + self.callback_url
        # 具有管理员权限的用户邮箱,填您的登录邮箱
        self.user_email = '[email protected]'
        # 您的登录密码
        self.user_password = 'qwert!@#$%'
        # 获取token的url
        self.token_url = 'https://account.teambition.com/oauth2/access_token'
        self.token = ''

    def get_code(self):
        """
        模拟浏览器获取code
        """
        # 声明一个浏览器对象,指定使用chrome浏览器
        browser = webdriver.Chrome()
        try:
            # get打开指定的url,传入要打开的url
            browser.get(self.auth_url)
            browser.find_element_by_name('email').send_keys(self.user_email)
            browser.find_element_by_name('password').send_keys(self.user_password)
            browser.find_element_by_class_name('anim-blue-all').click()
            time.sleep(2)
            browser.find_element_by_class_name('authorize-btn').click()
            code = browser.current_url.split('=')[1]
            time.sleep(10)
            browser.close()
            return code
        except Exception as e:
            print("模拟登录获取code失败:{}".format(e))
            browser.close()

    def get_token(self):
        """
        根据code获取token
        """
        code = self.get_code()
        access_data = {'client_id': self.client_id, 'client_secret': self.client_secret, 'code': code}
        result = requests.post(self.token_url, data=access_data)
        return result.text


if __name__ == '__main__':
    tb = GetTeamBitionEvents()
    token = tb.get_token()
    print(token)

三、根据access_token调用Teambition API

Teambition API decumentation:  https://docs.teambition.com/

Teambition接口文档中提供了所有可以调用的接口,如果有更新,调用的时候以最新的为准就可以了.

在上面的代码后面(同一个类里),加入如下两个类方法,分别是根据url获取数据的方法,根据项目id获取项目中所有事件的方法.这里面的参数all=ture是联系Teambition后台开发人员后加的.所以,按照接口文档调用时有问题可以与他们联系.

    def get_by_url(self, url):
        """
        根据url获取结果
        """
        params = {'access_token': self.token['access_token']}
        try:
            result = requests.get(url, params=params)
            return result.text
        except Exception as e:
            print(e)
            return

    def get_event_by_project(self, project_id):
        """
        根据项目id获取项目中的events
        """
        url = 'https://api.teambition.com/api/projects/' + project_id + '/tasks'
        params = {'access_token': self.token['access_token'], 'all': 'true'}
        try:
            result = requests.get(url, params=params)
            return result.text
        except Exception as e:
            print(e)
            return

可以看到,调用非常简单,直接使用requests发送请求,就会返回json数据,从数据中解析我们需要的数值即可.

然后根据自己需要的值到接口文当中找到适合的API,如法炮制~~~

 

(事实上,python有一个第三方库就叫teambitiom,对接口做了封装,但亲自试用了,很多接口反而不通,所以直接掉Teambition API)

Python快速调用Teambition接口_第8张图片

 

你可能感兴趣的:(Python/PYPI)