192 lines
9.4 KiB
Python
192 lines
9.4 KiB
Python
#!/usr/bin/env python3
|
||
# -*- coding: utf-8 -*-
|
||
# @FileName: WEWORK_ops.py
|
||
# @Software:
|
||
# @Author: Leven Xiang
|
||
# @Mail: xiangle0109@outlook.com
|
||
# @Date: 2021/5/18 16:55
|
||
from __future__ import absolute_import, unicode_literals
|
||
|
||
import os
|
||
|
||
from pwdselfservice import cache_storage
|
||
from utils.storage.cache import WeWorkCache
|
||
from utils.wework_api.abstract_api import *
|
||
|
||
APP_ENV = os.getenv('APP_ENV')
|
||
if APP_ENV == 'dev':
|
||
from conf.local_settings_dev import *
|
||
else:
|
||
from conf.local_settings import *
|
||
|
||
CORP_API_TYPE = {
|
||
'GET_USER_TICKET_OAUTH2': ['/cgi-bin/auth/getuserinfo?access_token=ACCESS_TOKEN', 'GET'],
|
||
'GET_USER_INFO_OAUTH2': ['/cgi-bin/auth/getuserdetail?access_token=ACCESS_TOKEN', 'POST'],
|
||
'GET_ACCESS_TOKEN': ['/cgi-bin/gettoken', 'GET'],
|
||
'USER_CREATE': ['/cgi-bin/user/create?access_token=ACCESS_TOKEN', 'POST'],
|
||
'USER_GET': ['/cgi-bin/user/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'USER_UPDATE': ['/cgi-bin/user/update?access_token=ACCESS_TOKEN', 'POST'],
|
||
'USER_DELETE': ['/cgi-bin/user/delete?access_token=ACCESS_TOKEN', 'GET'],
|
||
'USER_BATCH_DELETE': ['/cgi-bin/user/batchdelete?access_token=ACCESS_TOKEN', 'POST'],
|
||
'USER_SIMPLE_LIST': ['/cgi-bin/user/simplelist?access_token=ACCESS_TOKEN', 'GET'],
|
||
'USER_LIST': ['/cgi-bin/user/list?access_token=ACCESS_TOKEN', 'GET'],
|
||
'USERID_TO_OPENID': ['/cgi-bin/user/convert_to_openid?access_token=ACCESS_TOKEN', 'POST'],
|
||
'OPENID_TO_USERID': ['/cgi-bin/user/convert_to_userid?access_token=ACCESS_TOKEN', 'POST'],
|
||
'USER_AUTH_SUCCESS': ['/cgi-bin/user/authsucc?access_token=ACCESS_TOKEN', 'GET'],
|
||
'DEPARTMENT_CREATE': ['/cgi-bin/department/create?access_token=ACCESS_TOKEN', 'POST'],
|
||
'DEPARTMENT_UPDATE': ['/cgi-bin/department/update?access_token=ACCESS_TOKEN', 'POST'],
|
||
'DEPARTMENT_DELETE': ['/cgi-bin/department/delete?access_token=ACCESS_TOKEN', 'GET'],
|
||
'DEPARTMENT_LIST': ['/cgi-bin/department/list?access_token=ACCESS_TOKEN', 'GET'],
|
||
'TAG_CREATE': ['/cgi-bin/tag/create?access_token=ACCESS_TOKEN', 'POST'],
|
||
'TAG_UPDATE': ['/cgi-bin/tag/update?access_token=ACCESS_TOKEN', 'POST'],
|
||
'TAG_DELETE': ['/cgi-bin/tag/delete?access_token=ACCESS_TOKEN', 'GET'],
|
||
'TAG_GET_USER': ['/cgi-bin/tag/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'TAG_ADD_USER': ['/cgi-bin/tag/addtagusers?access_token=ACCESS_TOKEN', 'POST'],
|
||
'TAG_DELETE_USER': ['/cgi-bin/tag/deltagusers?access_token=ACCESS_TOKEN', 'POST'],
|
||
'TAG_GET_LIST': ['/cgi-bin/tag/list?access_token=ACCESS_TOKEN', 'GET'],
|
||
'BATCH_JOB_GET_RESULT': ['/cgi-bin/batch/getresult?access_token=ACCESS_TOKEN', 'GET'],
|
||
'BATCH_INVITE': ['/cgi-bin/batch/invite?access_token=ACCESS_TOKEN', 'POST'],
|
||
'AGENT_GET': ['/cgi-bin/agent/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'AGENT_SET': ['/cgi-bin/agent/set?access_token=ACCESS_TOKEN', 'POST'],
|
||
'AGENT_GET_LIST': ['/cgi-bin/agent/list?access_token=ACCESS_TOKEN', 'GET'],
|
||
'MENU_CREATE': ['/cgi-bin/menu/create?access_token=ACCESS_TOKEN', 'POST'],
|
||
'MENU_GET': ['/cgi-bin/menu/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'MENU_DELETE': ['/cgi-bin/menu/delete?access_token=ACCESS_TOKEN', 'GET'],
|
||
'MESSAGE_SEND': ['/cgi-bin/message/send?access_token=ACCESS_TOKEN', 'POST'],
|
||
'MESSAGE_REVOKE': ['/cgi-bin/message/revoke?access_token=ACCESS_TOKEN', 'POST'],
|
||
'MEDIA_GET': ['/cgi-bin/media/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'GET_USER_INFO_BY_CODE': ['/cgi-bin/user/getuserinfo?access_token=ACCESS_TOKEN', 'GET'],
|
||
'GET_USER_DETAIL': ['/cgi-bin/user/getuserdetail?access_token=ACCESS_TOKEN', 'POST'],
|
||
'GET_TICKET': ['/cgi-bin/ticket/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'GET_JSAPI_TICKET': ['/cgi-bin/get_jsapi_ticket?access_token=ACCESS_TOKEN', 'GET'],
|
||
'GET_CHECKIN_OPTION': ['/cgi-bin/checkin/getcheckinoption?access_token=ACCESS_TOKEN', 'POST'],
|
||
'GET_CHECKIN_DATA': ['/cgi-bin/checkin/getcheckindata?access_token=ACCESS_TOKEN', 'POST'],
|
||
'GET_APPROVAL_DATA': ['/cgi-bin/corp/getapprovaldata?access_token=ACCESS_TOKEN', 'POST'],
|
||
'GET_INVOICE_INFO': ['/cgi-bin/card/invoice/reimburse/getinvoiceinfo?access_token=ACCESS_TOKEN', 'POST'],
|
||
'UPDATE_INVOICE_STATUS':
|
||
['/cgi-bin/card/invoice/reimburse/updateinvoicestatus?access_token=ACCESS_TOKEN', 'POST'],
|
||
'BATCH_UPDATE_INVOICE_STATUS':
|
||
['/cgi-bin/card/invoice/reimburse/updatestatusbatch?access_token=ACCESS_TOKEN', 'POST'],
|
||
'BATCH_GET_INVOICE_INFO':
|
||
['/cgi-bin/card/invoice/reimburse/getinvoiceinfobatch?access_token=ACCESS_TOKEN', 'POST'],
|
||
|
||
'APP_CHAT_CREATE': ['/cgi-bin/appchat/create?access_token=ACCESS_TOKEN', 'POST'],
|
||
'APP_CHAT_GET': ['/cgi-bin/appchat/get?access_token=ACCESS_TOKEN', 'GET'],
|
||
'APP_CHAT_UPDATE': ['/cgi-bin/appchat/update?access_token=ACCESS_TOKEN', 'POST'],
|
||
'APP_CHAT_SEND': ['/cgi-bin/appchat/send?access_token=ACCESS_TOKEN', 'POST'],
|
||
|
||
'MINIPROGRAM_CODE_TO_SESSION_KEY': ['/cgi-bin/miniprogram/jscode2session?access_token=ACCESS_TOKEN', 'GET'],
|
||
}
|
||
|
||
|
||
class WeWorkOps(AbstractApi):
|
||
def __init__(self, corp_id=WEWORK_CORP_ID, agent_id=WEWORK_AGENT_ID, agent_secret=WEWORK_AGNET_SECRET,
|
||
storage=cache_storage, prefix='wework'):
|
||
super().__init__()
|
||
self.corp_id = corp_id
|
||
self.agent_id = agent_id
|
||
self.agent_secret = agent_secret
|
||
self.storage = storage
|
||
self.cache = WeWorkCache(self.storage, "%s:%s" % (prefix, "corp_id:%s" % self.corp_id))
|
||
|
||
def access_token(self):
|
||
access_token = self.cache.access_token.get()
|
||
if access_token is None:
|
||
ret = self.get_access_token()
|
||
access_token = ret['access_token']
|
||
expires_in = ret.get('expires_in', 7200)
|
||
self.cache.access_token.set(value=access_token, ttl=expires_in)
|
||
return access_token
|
||
|
||
def get_access_token(self):
|
||
return self.http_call(
|
||
CORP_API_TYPE['GET_ACCESS_TOKEN'],
|
||
{
|
||
'corpid': self.corp_id,
|
||
'corpsecret': self.agent_secret,
|
||
})
|
||
|
||
def get_user_id_by_code(self, code):
|
||
try:
|
||
return True, self.http_call(
|
||
CORP_API_TYPE['GET_USER_INFO_BY_CODE'],
|
||
{
|
||
'code': code,
|
||
}).get('UserId')
|
||
except ApiException as e:
|
||
return False, "get_user_id_by_code: {}-{}".format(e.errCode, e.errMsg)
|
||
except Exception as e:
|
||
return False, "get_user_id_by_code: {}".format(e)
|
||
|
||
def get_user_detail_by_user_id(self, user_id):
|
||
try:
|
||
return True, self.http_call(
|
||
CORP_API_TYPE['USER_GET'],
|
||
{
|
||
'userid': user_id,
|
||
})
|
||
except ApiException as e:
|
||
return False, "get_user_detail_by_user_id: {}-{}".format(e.errCode, e.errMsg)
|
||
except Exception as e:
|
||
return False, "get_user_detail_by_user_id: {}".format(e)
|
||
|
||
def get_user_ticket_by_code_with_oauth2(self, code):
|
||
try:
|
||
return True, self.http_call(
|
||
CORP_API_TYPE['GET_USER_TICKET_OAUTH2'],
|
||
{
|
||
'code': code,
|
||
})
|
||
except ApiException as e:
|
||
return False, "get_user_ticket_by_code_with_oauth2: {}-{}".format(e.errCode, e.errMsg)
|
||
except Exception as e:
|
||
return False, "get_user_ticket_by_code_with_oauth2: {}".format(e)
|
||
|
||
def get_user_info_by_ticket_with_oauth2(self, user_ticket):
|
||
try:
|
||
return True, self.http_call(
|
||
CORP_API_TYPE['GET_USER_INFO_OAUTH2'],
|
||
{
|
||
'user_ticket': user_ticket
|
||
})
|
||
except ApiException as e:
|
||
return False, "get_user_info_by_ticket_with_oauth2: {}-{}".format(e.errCode, e.errMsg)
|
||
except Exception as e:
|
||
return False, "get_user_info_by_ticket_with_oauth2: {}".format(e)
|
||
|
||
def get_user_detail(self, code, home_url):
|
||
"""
|
||
临时授权码换取userinfo
|
||
"""
|
||
_status, ticket_data = self.get_user_ticket_by_code_with_oauth2(code)
|
||
# 判断 user_ticket 是否存在
|
||
if not _status:
|
||
context = {'global_title': TITLE,
|
||
'msg': '获取userid失败,错误信息:{}'.format(ticket_data),
|
||
'button_click': "window.location.href='%s'" % '/auth',
|
||
'button_display': "重新认证授权"
|
||
}
|
||
return False, context, ticket_data
|
||
|
||
user_id = ticket_data.get('userid')
|
||
if ticket_data.get('user_ticket') is None:
|
||
context = {'global_title': TITLE,
|
||
'msg': '获取用户Ticket失败,当前扫码用户[{}]可能未加入企业!'.format(user_id),
|
||
'button_click': "window.location.href='%s'" % home_url,
|
||
'button_display': "返回修改密码"
|
||
}
|
||
return False, context, user_id
|
||
|
||
# 通过user_ticket获取企业微信用户详情信息
|
||
detail_status, user_info = self.get_user_info_by_ticket_with_oauth2(ticket_data.get('user_ticket'))
|
||
print("get_user_info_by_ticket_with_oauth2 --- ", user_info)
|
||
if not detail_status:
|
||
context = {'global_title': TITLE,
|
||
'msg': '获取用户信息失败,错误信息:{}'.format(user_id),
|
||
'button_click': "window.location.href='%s'" % '/auth',
|
||
'button_display': "重新认证授权"
|
||
}
|
||
return False, context
|
||
return True, user_id, user_info
|
||
|