TencentOAuth.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517
  1. ///
  2. /// \file TencentOAuth.h
  3. /// \brief QQ互联开放平台授权登录及相关开放接口实现类
  4. ///
  5. /// Created by Tencent on 12-12-21.
  6. /// Copyright (c) 2012年 Tencent. All rights reserved.
  7. ///
  8. #import <UIKit/UIKit.h>
  9. #import "SDKDef.h"
  10. @protocol TencentSessionDelegate;
  11. @protocol TencentLoginDelegate;
  12. @protocol TencentApiInterfaceDelegate;
  13. @protocol TencentWebViewDelegate;
  14. @class TencentApiReq;
  15. @class TencentApiResp;
  16. typedef NS_ENUM(NSUInteger, TencentAuthorizeState) {
  17. kTencentNotAuthorizeState,
  18. kTencentSSOAuthorizeState,
  19. kTencentWebviewAuthorzieState,
  20. };
  21. typedef NS_ENUM(NSUInteger, TencentAuthMode) {
  22. kAuthModeClientSideToken,
  23. kAuthModeServerSideCode,
  24. };
  25. #pragma mark - TencentOAuth(授权登录及相关开放接口调用)
  26. /**
  27. * \brief TencentOpenAPI授权登录及相关开放接口调用
  28. *
  29. * TencentOAuth实现授权登录逻辑以及相关开放接口的请求调用
  30. */
  31. @interface TencentOAuth : NSObject
  32. {
  33. NSMutableDictionary *_apiRequests;
  34. NSString *_accessToken;
  35. NSDate *_expirationDate;
  36. id<TencentSessionDelegate> _sessionDelegate;
  37. NSString *_localAppId;
  38. NSString *_openId;
  39. NSString *_redirectURI;
  40. NSArray *_permissions;
  41. }
  42. /** Access Token凭证,用于后续访问各开放接口 */
  43. @property(nonatomic, copy) NSString *accessToken;
  44. /** Access Token的失效期 */
  45. @property(nonatomic, copy) NSDate *expirationDate;
  46. /** 已实现的开放接口的回调委托对象 */
  47. @property(nonatomic, weak) id<TencentSessionDelegate> sessionDelegate;
  48. /** 第三方应用在开发过程中设置的URLSchema,用于浏览器登录后后跳到第三方应用 */
  49. @property(nonatomic, copy) NSString *localAppId;
  50. /** 用户授权登录后对该用户的唯一标识 */
  51. @property(nonatomic, copy) NSString *openId;
  52. /** 用户登录成功过后的跳转页面地址 */
  53. @property(nonatomic, copy) NSString *redirectURI;
  54. /** 第三方应用在互联开放平台申请的appID */
  55. @property(nonatomic, retain) NSString *appId;
  56. /** 第三方应用在互联开放平台注册的UniversalLink */
  57. @property(nonatomic, retain) NSString *universalLink;
  58. /** 主要是互娱的游戏设置uin */
  59. @property(nonatomic, retain) NSString *uin;
  60. /** 主要是互娱的游戏设置鉴定票据 */
  61. @property(nonatomic, retain) NSString *skey;
  62. /** 登陆透传的数据 */
  63. @property(nonatomic, copy) NSDictionary *passData;
  64. /** 授权方式(Client Side Token或者Server Side Code) */
  65. @property(nonatomic, assign) TencentAuthMode authMode;
  66. /** union id */
  67. @property(nonatomic, retain) NSString *unionid;
  68. /** 第三方在授权登录/分享 时选择 QQ,还是TIM 。在授权前一定要指定其中一个类型*/
  69. @property(nonatomic, assign) TencentAuthShareType authShareType;
  70. /** SDK打开web登录页,支持自动填充账号 */
  71. @property (nonatomic, copy) NSString *defaultUin;
  72. /**
  73. * 获取上次登录得到的token
  74. *
  75. **/
  76. - (NSString *)getCachedToken;
  77. /**
  78. * 获取上次登录得到的openid
  79. *
  80. **/
  81. - (NSString *)getCachedOpenID;
  82. /**
  83. * 获取上次登录的token过期日期
  84. *
  85. **/
  86. - (NSDate *)getCachedExpirationDate;
  87. /**
  88. * 上次登录的token是否过期(本地判断)
  89. **/
  90. - (BOOL)isCachedTokenValid;
  91. /**
  92. * 删除上次登录登录的token信息
  93. *
  94. **/
  95. - (BOOL)deleteCachedToken;
  96. /**
  97. * 删除openid
  98. *
  99. **/
  100. - (void)deleteOpenId;
  101. /**
  102. * 用来获得当前sdk的版本号
  103. * \return 返回sdk版本号
  104. **/
  105. + (NSString *)sdkVersion;
  106. /**
  107. * 用来获得当前sdk的小版本号
  108. * \return 返回sdk小版本号
  109. **/
  110. + (NSString *)sdkSubVersion;
  111. /**
  112. * 用来获得当前sdk的是否精简版
  113. * \return 返回YES表示精简版
  114. **/
  115. + (BOOL)isLiteSDK;
  116. /**
  117. * 主要是用来帮助判断是否有登陆被发起,但是还没有过返回结果
  118. * \return
  119. * kTencentNotAuthorizeState:无授权
  120. * kTencentSSOAuthorizeState:有人发起了sso授权但无返回
  121. * kTencentWebviewAuthorzieState:有人发起了webview授权还未返回
  122. **/
  123. + (TencentAuthorizeState *)authorizeState;
  124. /**
  125. * 初始化TencentOAuth对象
  126. * \param appId 不可为nil,第三方应用在互联开放平台申请的唯一标识
  127. * \param delegate 不可为nil,第三方应用用于接收请求返回结果的委托对象
  128. * \return 初始化后的授权登录对象
  129. */
  130. - (id)initWithAppId:(NSString *)appId
  131. andDelegate:(id<TencentSessionDelegate>)delegate;
  132. /**
  133. * 初始化TencentOAuth对象(>=3.3.7)
  134. * \param appId 不可为nil,第三方应用在互联开放平台申请的唯一标识
  135. * \param universalLink 可以为nil,第三方应用在互联开放平台注册的UniversalLink,和bundleID一一对应(当为nil时,互联平台会按规则生成universallink,详见官网说明)
  136. * \param delegate 不可为nil,第三方应用用于接收请求返回结果的委托对象
  137. * \return 初始化后的授权登录对象
  138. *
  139. ****【使用说明】*****
  140. * 1、支持BundleId与UniversalLink的一一对应,主要目的“是为了解决应用的iPhone版本和iPad HD版本共用同一个AppId,导致同时安装情况下的跳转问题"。
  141. * 2 、由于手Q版本在 >=8.1.8 后才支持了这种对应方式,所以一旦使用,“务必做到”及时知会用户升级手Q版本。
  142. ****
  143. */
  144. - (id)initWithAppId:(NSString *)appId
  145. andUniversalLink:(NSString *)universalLink
  146. andDelegate:(id<TencentSessionDelegate>)delegate;
  147. /**
  148. * 初始化TencentOAuth对象(>=3.3.8)
  149. * \param appId 不可为nil,第三方应用在互联开放平台申请的唯一标识
  150. * \param enabled 默认为NO,第三方应用是否将sdk和手机QQ的交互方式切换为UniversalLink方式,启用后则在iOS9及以上的系统都会生效UniversalLink方式;否则,默认仅在iOS13及以上的系统生效UniversalLink方式。
  151. * \param universalLink 可以为nil,第三方应用在互联开放平台注册的UniversalLink,和bundleID一一对应(当为nil时,互联平台会按规则生成UniversalLink,详见官网说明)
  152. * \param delegate 不可为nil,第三方应用用于接收请求返回结果的委托对象
  153. * \return 初始化后的授权登录对象
  154. *
  155. *****【使用说明】*****
  156. * 1、支持sdk与手Q的交互切换为UniversalLink模式,主要目的"是为了避免手Q的UrlScheme被其他应用抢注后,导致sdk接口功能受到影响"。
  157. * 2 、由于手Q版本在 >=8.1.3 后才适配了UniversalLink,所以一旦开启了enabled开关,“务必做到”及时知会用户升级手Q版本。
  158. *****
  159. */
  160. - (id)initWithAppId:(NSString *)appId
  161. enableUniveralLink:(BOOL)enabled
  162. universalLink:(NSString *)universalLink
  163. delegate:(id<TencentSessionDelegate>)delegate;
  164. /**
  165. * 设置用户是否已经授权同意授权隐私协议,在主体应用中,用户同意授权隐私协议后再初始化互联SDK,默认未同意授权
  166. * 注意:如未同意授权隐私协议,则互联SDK的所有功能都无法使用,包括初始化!!!
  167. * 从3.5.7版本开始支持该方法
  168. *
  169. * @param isAgreedAuthorization 是否已经授权,isAgreedAuthorization=YES, 表示已经同意授权;isAgreedAuthorization=NO,表示未同意授权,互联SDK的所有功能都无法使用
  170. */
  171. + (void)setIsUserAgreedAuthorization:(BOOL)isUserAgreedAuthorization;
  172. /**
  173. * 获取当前用户是否已经同意授权隐私协议
  174. * 从3.5.7版本开始支持该方法
  175. */
  176. + (BOOL)isUserAgreedAuthorization;
  177. /**
  178. * 判断用户手机上是否安装手机QQ
  179. * \return YES:安装 NO:没安装
  180. *
  181. * \note SDK目前已经支持QQ、TIM授权登录及分享功能, 会按照QQ>TIM的顺序进行调用。
  182. * 只要用户安装了QQ、TIM中任意一个应用,都可为第三方应用进行授权登录、分享功能。
  183. * 第三方应用在接入SDK时不需要判断是否安装QQ、TIM。若有判断安装QQ、TIM的逻辑建议移除。
  184. */
  185. + (BOOL)iphoneQQInstalled;
  186. /**
  187. * 判断用户手机上是否安装手机TIM
  188. * \return YES:安装 NO:没安装
  189. *
  190. * \note SDK目前已经支持QQ、TIM授权登录及分享功能, 会按照QQ>TIM的顺序进行调用。
  191. * 只要用户安装了QQ、TIM中任意一个应用,都可为第三方应用进行授权登录、分享功能。
  192. * 第三方应用在接入SDK时不需要判断是否安装QQ、TIM。若有判断安装QQ、TIM的逻辑建议移除。
  193. */
  194. + (BOOL)iphoneTIMInstalled;
  195. /**
  196. * 登录授权
  197. *
  198. * \param permissions 授权信息列
  199. */
  200. - (BOOL)authorize:(NSArray *)permissions;
  201. /**
  202. * 登录授权
  203. * \param permissions 授权信息列表
  204. * \param localAppId 应用APPID
  205. */
  206. - (BOOL)authorize:(NSArray *)permissions
  207. localAppId:(NSString *)localAppId;
  208. /**
  209. * 登录授权<web为二维码扫码方式>
  210. *
  211. * \param permissions 授权信息列
  212. */
  213. - (BOOL)authorizeWithQRlogin:(NSArray *)permissions;
  214. /**
  215. * 增量授权,因用户没有授予相应接口调用的权限,需要用户确认是否授权
  216. * \param permissions 需增量授权的信息列表
  217. * \return 增量授权调用是否成功
  218. */
  219. - (BOOL)incrAuthWithPermissions:(NSArray *)permissions;
  220. /**
  221. * 重新授权,因token废除或失效导致接口调用失败,需用户重新授权
  222. * \param permissions 授权信息列表,同登录授权
  223. * \return 授权调用是否成功
  224. */
  225. - (BOOL)reauthorizeWithPermissions:(NSArray *)permissions;
  226. /**
  227. * 获取UnindID,可以根据UnindID的比较来确定OpenID是否属于同一个用户
  228. * \return NO未登录,信息不足;YES条件满足,发送请求成功,请等待回调
  229. */
  230. - (BOOL)RequestUnionId;
  231. /**
  232. * (静态方法)处理应用拉起协议
  233. * \param url 处理被其他应用呼起时的逻辑
  234. * \return 处理结果,YES表示成功,NO表示失败
  235. */
  236. + (BOOL)HandleOpenURL:(NSURL *)url;
  237. /**
  238. * (静态方法)sdk是否可以处理应用拉起协议
  239. * \param url 处理被其他应用呼起时的逻辑
  240. * \return 处理结果,YES表示可以 NO表示不行
  241. */
  242. + (BOOL)CanHandleOpenURL:(NSURL *)url;
  243. /**
  244. * (静态方法)处理应用的UniversalLink拉起协议
  245. * \param url 处理被其他应用呼起时的逻辑
  246. * \return 处理结果,YES表示成功,NO表示失败
  247. */
  248. + (BOOL)HandleUniversalLink:(NSURL *)url;
  249. /**
  250. * (静态方法)sdk是否可以处理应用的Universallink拉起协议
  251. * \param url 处理被其他应用呼起时的逻辑(应用的Universallink链接须满足官网注册时的格式要求)
  252. * \return 处理结果,YES表示可以 NO表示不行
  253. * 注:在调用其他Universallink相关处理接口之前,均需进行此项判断
  254. */
  255. + (BOOL)CanHandleUniversalLink:(NSURL *)url;
  256. /**
  257. * (静态方法)获取TencentOAuth调用的上一次错误信息
  258. */
  259. + (NSString *)getLastErrorMsg;
  260. /**
  261. * 以Server Side Code模式授权登录时,通过此接口获取返回的code值;
  262. * 以Client Side Token模式授权登录时,忽略此接口。
  263. */
  264. - (NSString *)getServerSideCode;
  265. /**
  266. * 退出登录(退出登录后,TecentOAuth失效,需要重新初始化)
  267. * \param delegate 第三方应用用于接收请求返回结果的委托对象
  268. */
  269. - (void)logout:(id<TencentSessionDelegate>)delegate;
  270. /**
  271. * 判断登录态是否有效
  272. * \return 处理结果,YES表示有效,NO表示无效,请用户重新登录授权
  273. */
  274. - (BOOL)isSessionValid;
  275. /**
  276. * 获取用户个人信息
  277. * \return 处理结果,YES表示API调用成功,NO表示API调用失败,登录态失败,重新登录
  278. */
  279. - (BOOL)getUserInfo;
  280. /**
  281. * 退出指定API调用
  282. * \param userData 用户调用某条API的时候传入的保留参数
  283. * \return 处理结果,YES表示成功 NO表示失败
  284. */
  285. - (BOOL)cancel:(id)userData;
  286. /**
  287. * CGI类任务创建接口
  288. * \param apiURL CGI请求的URL地址
  289. * \param method CGI请求方式:"GET","POST"
  290. * \param params CGI请求参数字典
  291. * \param callback CGI请求结果的回调接口对象
  292. * \return CGI请求任务实例,用于取消任务,返回nil代表任务创建失败
  293. */
  294. - (TCAPIRequest *)cgiRequestWithURL:(NSURL *)apiURL method:(NSString *)method params:(NSDictionary *)params callback:(id<TCAPIRequestDelegate>)callback;
  295. /**
  296. * TencentOpenApi发送任务统一接口
  297. * \param request 请求发送的任务
  298. * \param callback 任务发送后的回调地址
  299. */
  300. - (BOOL)sendAPIRequest:(TCAPIRequest *)request callback:(id<TCAPIRequestDelegate>)callback;
  301. - (NSString *)getUserOpenID;
  302. /* 获取appSignToken */
  303. + (NSString *)getAppSignToken;
  304. /* 设置appSignToken,跨进程的应用可以通过该方法手动设置appSignToken */
  305. + (void)setupAppSignToken:(NSString *)appSignToken;
  306. @end
  307. #pragma mark - TencentLoginDelegate(授权登录回调协议)
  308. /**
  309. * \brief TencentLoginDelegate iOS Open SDK 1.3 API回调协议
  310. *
  311. * 第三方应用实现登录的回调协议
  312. */
  313. @protocol TencentLoginDelegate <NSObject>
  314. @required
  315. /**
  316. * 登录成功后的回调
  317. */
  318. - (void)tencentDidLogin;
  319. /**
  320. * 登录失败后的回调
  321. * \param cancelled 代表用户是否主动退出登录
  322. */
  323. - (void)tencentDidNotLogin:(BOOL)cancelled;
  324. /**
  325. * 登录时网络有问题的回调
  326. */
  327. - (void)tencentDidNotNetWork;
  328. @optional
  329. /**
  330. * 登录时权限信息的获得
  331. */
  332. - (NSArray *)getAuthorizedPermissions:(NSArray *)permissions withExtraParams:(NSDictionary *)extraParams __attribute__((deprecated("该接口已过期, 建议删除调用")));
  333. /**
  334. * unionID获得
  335. */
  336. - (void)didGetUnionID;
  337. /**
  338. * 强制网页登录,包括账号密码登录和二维码登录
  339. * return YES时,就算本地有手Q也会打开web界面
  340. */
  341. - (BOOL)forceWebLogin;
  342. /* 获得appSignToken回调 */
  343. - (void)tencentDidGetAppSignToken:(NSString *)appSignToken;
  344. @end
  345. #pragma mark - TencentSessionDelegate(开放接口回调协议)
  346. /**
  347. * \brief TencentSessionDelegate iOS Open SDK 1.3 API回调协议
  348. *
  349. * 第三方应用需要实现每条需要调用的API的回调协议
  350. */
  351. @protocol TencentSessionDelegate<NSObject, TencentLoginDelegate,
  352. TencentWebViewDelegate>
  353. @optional
  354. /**
  355. * 退出登录的回调
  356. */
  357. - (void)tencentDidLogout;
  358. /**
  359. * 因用户未授予相应权限而需要执行增量授权。在用户调用某个api接口时,如果服务器返回操作未被授权,则触发该回调协议接口,由第三方决定是否跳转到增量授权页面,让用户重新授权。
  360. * \param tencentOAuth 登录授权对象。
  361. * \param permissions 需增量授权的权限列表。
  362. * \return 是否仍然回调返回原始的api请求结果。
  363. * \note 不实现该协议接口则默认为不开启增量授权流程。若需要增量授权请调用\ref TencentOAuth#incrAuthWithPermissions: \n注意:增量授权时用户可能会修改登录的帐号
  364. */
  365. - (BOOL)tencentNeedPerformIncrAuth:(TencentOAuth *)tencentOAuth withPermissions:(NSArray *)permissions;
  366. /**
  367. * [该逻辑未实现]因token失效而需要执行重新登录授权。在用户调用某个api接口时,如果服务器返回token失效,则触发该回调协议接口,由第三方决定是否跳转到登录授权页面,让用户重新授权。
  368. * \param tencentOAuth 登录授权对象。
  369. * \return 是否仍然回调返回原始的api请求结果。
  370. * \note 不实现该协议接口则默认为不开启重新登录授权流程。若需要重新登录授权请调用\ref TencentOAuth#reauthorizeWithPermissions: \n注意:重新登录授权时用户可能会修改登录的帐号
  371. */
  372. - (BOOL)tencentNeedPerformReAuth:(TencentOAuth *)tencentOAuth;
  373. /**
  374. * 用户通过增量授权流程重新授权登录,token及有效期限等信息已被更新。
  375. * \param tencentOAuth token及有效期限等信息更新后的授权实例对象
  376. * \note 第三方应用需更新已保存的token及有效期限等信息。
  377. */
  378. - (void)tencentDidUpdate:(TencentOAuth *)tencentOAuth;
  379. /**
  380. * 用户增量授权过程中因取消或网络问题导致授权失败
  381. * \param reason 授权失败原因,具体失败原因参见sdkdef.h文件中\ref UpdateFailType
  382. */
  383. - (void)tencentFailedUpdate:(UpdateFailType)reason;
  384. /**
  385. * 获取用户个人信息回调
  386. * \param response API返回结果,具体定义参见sdkdef.h文件中\ref APIResponse
  387. * \remarks 正确返回示例: \snippet example/getUserInfoResponse.exp success
  388. * 错误返回示例: \snippet example/getUserInfoResponse.exp fail
  389. */
  390. - (void)getUserInfoResponse:(APIResponse*) response;
  391. /**
  392. * 社交API统一回调接口
  393. * \param response API返回结果,具体定义参见sdkdef.h文件中\ref APIResponse
  394. * \param message 响应的消息,目前支持‘SendStory’,‘AppInvitation’,‘AppChallenge’,‘AppGiftRequest’
  395. */
  396. - (void)responseDidReceived:(APIResponse*)response forMessage:(NSString *)message;
  397. /**
  398. * post请求的上传进度
  399. * \param tencentOAuth 返回回调的tencentOAuth对象
  400. * \param bytesWritten 本次回调上传的数据字节数
  401. * \param totalBytesWritten 总共已经上传的字节数
  402. * \param totalBytesExpectedToWrite 总共需要上传的字节数
  403. * \param userData 用户自定义数据
  404. */
  405. - (void)tencentOAuth:(TencentOAuth *)tencentOAuth didSendBodyData:(NSInteger)bytesWritten totalBytesWritten:(NSInteger)totalBytesWritten totalBytesExpectedToWrite:(NSInteger)totalBytesExpectedToWrite userData:(id)userData;
  406. /**
  407. * 通知第三方界面需要被关闭
  408. * \param tencentOAuth 返回回调的tencentOAuth对象
  409. * \param viewController 需要关闭的viewController
  410. */
  411. - (void)tencentOAuth:(TencentOAuth *)tencentOAuth doCloseViewController:(UIViewController *)viewController;
  412. @end
  413. #pragma mark - TencentWebViewDelegate(H5登录webview旋转方向回调)
  414. /**
  415. * \brief TencentWebViewDelegate: H5登录webview旋转方向回调协议
  416. *
  417. * 第三方应用可以根据自己APP的旋转方向限制,通过此协议设置
  418. */
  419. @protocol TencentWebViewDelegate <NSObject>
  420. @optional
  421. - (BOOL) tencentWebViewShouldAutorotateToInterfaceOrientation:(UIInterfaceOrientation)toInterfaceOrientation;
  422. - (NSUInteger) tencentWebViewSupportedInterfaceOrientationsWithWebkit;
  423. - (BOOL) tencentWebViewShouldAutorotateWithWebkit;
  424. @end