WeiboSDK.h 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669
  1. //
  2. // WeiboSDKHeaders.h
  3. // WeiboSDKDemo
  4. //
  5. // Created by Wade Cheng on 4/3/13.
  6. // Copyright (c) 2013 SINA iOS Team. All rights reserved.
  7. //
  8. #import <Foundation/Foundation.h>
  9. #import <UIKit/UIKit.h>
  10. #import "WBHttpRequest.h"
  11. typedef NS_ENUM(NSInteger, WeiboSDKResponseStatusCode)
  12. {
  13. WeiboSDKResponseStatusCodeSuccess = 0,//成功
  14. WeiboSDKResponseStatusCodeUserCancel = -1,//用户取消发送
  15. WeiboSDKResponseStatusCodeSentFail = -2,//发送失败
  16. WeiboSDKResponseStatusCodeAuthDeny = -3,//授权失败
  17. WeiboSDKResponseStatusCodeUserCancelInstall = -4,//用户取消安装微博客户端
  18. WeiboSDKResponseStatusCodeShareInSDKFailed = -8,//分享失败 详情见response UserInfo
  19. WeiboSDKResponseStatusCodeUnsupport = -99,//不支持的请求
  20. WeiboSDKResponseStatusCodeUnknown = -100,
  21. };
  22. @protocol WeiboSDKDelegate;
  23. @protocol WBHttpRequestDelegate;
  24. @class WBBaseRequest;
  25. @class WBBaseResponse;
  26. @class WBMessageObject;
  27. @class WBImageObject;
  28. @class WBBaseMediaObject;
  29. @class WBHttpRequest;
  30. @class PHAsset;
  31. @class WBNewVideoObject;
  32. /**
  33. 微博SDK接口类
  34. */
  35. @interface WeiboSDK : NSObject
  36. /**
  37. 检查用户是否安装了微博客户端程序
  38. @return 已安装返回YES,未安装返回NO
  39. */
  40. + (BOOL)isWeiboAppInstalled;
  41. /**
  42. 检查用户是否可以通过微博客户端进行分享
  43. @return 可以使用返回YES,不可以使用返回NO
  44. */
  45. + (BOOL)isCanShareInWeiboAPP;
  46. /**
  47. 检查用户是否可以使用微博客户端进行SSO授权
  48. @return 可以使用返回YES,不可以使用返回NO
  49. */
  50. + (BOOL)isCanSSOInWeiboApp;
  51. /**
  52. 打开微博客户端程序
  53. @return 成功打开返回YES,失败返回NO
  54. */
  55. + (BOOL)openWeiboApp;
  56. /**
  57. 获取微博客户端程序的itunes安装地址
  58. @return 微博客户端程序的itunes安装地址
  59. */
  60. + (NSString *)getWeiboAppInstallUrl;
  61. /**
  62. 获取当前微博SDK的版本号
  63. @return 当前微博SDK的版本号
  64. */
  65. + (NSString *)getSDKVersion;
  66. extern NSString * const WeiboSDKGetAidSucessNotification;
  67. extern NSString * const WeiboSDKGetAidFailNotification;
  68. /**
  69. 获取当前微博SDK的aid
  70. 返回的aid值可能为 nil ,当值为 nil 时会尝试获取 aid 值。
  71. 当获取成功( aid 值变为有效值)时,SDK会发出名为 WeiboSDKGetAidSucessNotification 的通知,通知中带有 aid 值。
  72. 当获取失败时,SDK会发出名为 WeiboSDKGetAidFailNotification 的通知,通知中带有 NSError 对象。
  73. @return aid 用于广告的与设备信息相关的标识符
  74. */
  75. + (NSString *)getWeiboAid;
  76. /**
  77. 向微博客户端程序注册第三方应用
  78. @param appKey 微博开放平台第三方应用appKey
  79. @return 注册成功返回YES,失败返回NO
  80. */
  81. + (BOOL)registerApp:(NSString *)appKey;
  82. /**
  83. 处理微博客户端程序通过URL启动第三方应用时传递的数据
  84. 需要在 application:openURL:sourceApplication:annotation:或者application:handleOpenURL中调用
  85. @param url 启动第三方应用的URL
  86. @param delegate WeiboSDKDelegate对象,用于接收微博触发的消息
  87. @see WeiboSDKDelegate
  88. */
  89. + (BOOL)handleOpenURL:(NSURL *)url delegate:(id<WeiboSDKDelegate>)delegate;
  90. /**
  91. 发送请求给微博客户端程序,并切换到微博
  92. 请求发送给微博客户端程序之后,微博客户端程序会进行相关的处理,处理完成之后一定会调用 [WeiboSDKDelegate didReceiveWeiboResponse:] 方法将处理结果返回给第三方应用
  93. @param request 具体的发送请求
  94. @see [WeiboSDKDelegate didReceiveWeiboResponse:]
  95. @see WBBaseResponse
  96. */
  97. + (BOOL)sendRequest:(WBBaseRequest *)request;
  98. /**
  99. 收到微博客户端程序的请求后,发送对应的应答给微博客户端端程序,并切换到微博
  100. 第三方应用收到微博的请求后,异步处理该请求,完成后必须调用该函数将应答返回给微博
  101. @param response 具体的应答内容
  102. @see WBBaseRequest
  103. */
  104. + (BOOL)sendResponse:(WBBaseResponse *)response;
  105. /**
  106. 设置WeiboSDK的调试模式
  107. 当开启调试模式时,WeiboSDK会在控制台输出详细的日志信息,开发者可以据此调试自己的程序。默认为 NO
  108. @param enabled 开启或关闭WeiboSDK的调试模式
  109. */
  110. + (void)enableDebugMode:(BOOL)enabled;
  111. /**
  112. 取消授权,登出接口
  113. 调用此接口后,token将失效
  114. @param token 第三方应用之前申请的Token
  115. @param delegate WBHttpRequestDelegate对象,用于接收微博SDK对于发起的接口请求的请求的响应
  116. @param tag 用户自定义TAG,将通过回调WBHttpRequest实例的tag属性返回
  117. */
  118. + (void)logOutWithToken:(NSString *)token delegate:(id<WBHttpRequestDelegate>)delegate withTag:(NSString*)tag;
  119. /**
  120. 呼起微博客户端或打开微博H5页面,SDK自动检测是否安装微博客户端,当调用SDK相关方法时:
  121. 有的话呼起微博客户端定位到对应界面;
  122. 没有的话打开 webView 加载相应的微博H5页面;
  123. @param uid 用户id
  124. @param mid 微博id
  125. @param aid 文章id
  126. */
  127. //连接到指定用户的微博个人主页,连接后可进行加关注等互动
  128. + (void)linkToUser:(NSString *)uid;
  129. //连接到指定的单条微博详情页,连接后可对这条微博进行转、评、赞等互动
  130. + (void)linkToSingleBlog:(NSString *)uid blogID:(NSString *)mid;
  131. //连接到指定的微博头条文章页
  132. + (void)linkToArticle:(NSString *)aid;
  133. //分享到微博
  134. + (void)shareToWeibo:(NSString *)content;
  135. //评论指定的微博
  136. + (void)commentToWeibo:(NSString *)mid;
  137. //连接到微博搜索内容流
  138. + (void)linkToSearch:(NSString *)keyword;
  139. //连接到我的微博消息流
  140. + (void)linkToTimeLine;
  141. //连接到我的微博个人主页
  142. + (void)linkToProfile;
  143. @end
  144. /**
  145. 接收并处理来至微博客户端程序的事件消息
  146. */
  147. @protocol WeiboSDKDelegate <NSObject>
  148. /**
  149. 收到一个来自微博客户端程序的请求
  150. 收到微博的请求后,第三方应用应该按照请求类型进行处理,处理完后必须通过 [WeiboSDK sendResponse:] 将结果回传给微博
  151. @param request 具体的请求对象
  152. */
  153. - (void)didReceiveWeiboRequest:(WBBaseRequest *)request;
  154. /**
  155. 收到一个来自微博客户端程序的响应
  156. 收到微博的响应后,第三方应用可以通过响应类型、响应的数据和 WBBaseResponse.userInfo 中的数据完成自己的功能
  157. @param response 具体的响应对象
  158. */
  159. - (void)didReceiveWeiboResponse:(WBBaseResponse *)response;
  160. @end
  161. #pragma mark - DataTransferObject and Base Request/Response
  162. /**
  163. 微博客户端程序和第三方应用之间传输数据信息的基类
  164. */
  165. @interface WBDataTransferObject : NSObject
  166. /**
  167. 自定义信息字典,用于数据传输过程中存储相关的上下文环境数据
  168. 第三方应用给微博客户端程序发送 request 时,可以在 userInfo 中存储请求相关的信息。
  169. @warning userInfo中的数据必须是实现了 `NSCoding` 协议的对象,必须保证能序列化和反序列化
  170. @warning 序列化后的数据不能大于10M
  171. */
  172. @property (nonatomic, strong) NSDictionary *userInfo;
  173. /**
  174. 发送该数据对象的SDK版本号
  175. 如果数据对象是自己生成的,则sdkVersion为当前SDK的版本号;如果是接收到的数据对象,则sdkVersion为数据发送方SDK版本号
  176. */
  177. @property (strong, nonatomic, readonly) NSString *sdkVersion;
  178. /**
  179. 当用户没有安装微博客户端程序时是否提示用户打开微博安装页面
  180. 如果设置为YES,当用户未安装微博时会弹出Alert询问用户是否要打开微博App的安装页面。默认为YES
  181. */
  182. @property (nonatomic, assign) BOOL shouldOpenWeiboAppInstallPageIfNotInstalled;
  183. @end
  184. /**
  185. 微博SDK所有请求类的基类
  186. */
  187. @interface WBBaseRequest : WBDataTransferObject
  188. /**
  189. 返回一个 WBBaseRequest 对象
  190. @return 返回一个*自动释放的*WBBaseRequest对象
  191. */
  192. + (id)request;
  193. @end
  194. /**
  195. 微博SDK所有响应类的基类
  196. */
  197. @interface WBBaseResponse : WBDataTransferObject
  198. /**
  199. 对应的 request 中的自定义信息字典
  200. 如果当前 response 是由微博客户端响应给第三方应用的,则 requestUserInfo 中会包含原 request.userInfo 中的所有数据
  201. @see WBBaseRequest.userInfo
  202. */
  203. @property (strong, nonatomic, readonly) NSDictionary *requestUserInfo;
  204. /**
  205. 响应状态码
  206. 第三方应用可以通过statusCode判断请求的处理结果
  207. */
  208. @property (nonatomic, assign) WeiboSDKResponseStatusCode statusCode;
  209. /**
  210. 返回一个 WBBaseResponse 对象
  211. @return 返回一个*自动释放的*WBBaseResponse对象
  212. */
  213. + (id)response;
  214. @end
  215. #pragma mark - Authorize Request/Response
  216. /**
  217. 第三方应用向微博客户端请求认证的消息结构
  218. 第三方应用向微博客户端申请认证时,需要调用 [WeiboSDK sendRequest:] 函数, 向微博客户端发送一个 WBAuthorizeRequest 的消息结构。
  219. 微博客户端处理完后会向第三方应用发送一个结构为 WBAuthorizeResponse 的处理结果。
  220. */
  221. @interface WBAuthorizeRequest : WBBaseRequest
  222. /**
  223. 微博开放平台第三方应用授权回调页地址,默认为`http://`
  224. 参考 http://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E#.E5.AE.A2.E6.88.B7.E7.AB.AF.E9.BB.98.E8.AE.A4.E5.9B.9E.E8.B0.83.E9.A1.B5
  225. @warning 必须保证和在微博开放平台应用管理界面配置的“授权回调页”地址一致,如未进行配置则默认为`http://`
  226. @warning 不能为空,长度小于1K
  227. */
  228. @property (nonatomic, strong) NSString *redirectURI;
  229. /**
  230. 微博开放平台第三方应用scope,多个scrope用逗号分隔
  231. 参考 http://open.weibo.com/wiki/%E6%8E%88%E6%9D%83%E6%9C%BA%E5%88%B6%E8%AF%B4%E6%98%8E#scope
  232. @warning 长度小于1K
  233. */
  234. @property (nonatomic, strong) NSString *scope;
  235. /**
  236. 当用户没有安装微博客户端或微博客户端过低无法支持SSO的时候是否弹出SDK自带的Webview进行授权
  237. 如果设置为YES,当用户没有安装微博客户端或微博客户端过低无法支持SSO的时候会自动弹出SDK自带的Webview进行授权。
  238. 如果设置为NO,会根据 shouldOpenWeiboAppInstallPageIfNotInstalled 属性判断是否弹出安装/更新微博的对话框
  239. 默认为YES
  240. */
  241. @property (nonatomic, assign) BOOL shouldShowWebViewForAuthIfCannotSSO;
  242. @end
  243. /**
  244. 微博客户端处理完第三方应用的认证申请后向第三方应用回送的处理结果
  245. WBAuthorizeResponse 结构中仅包含常用的 userID 、accessToken 和 expirationDate 信息,其他的认证信息(比如部分应用可以获取的 refresh_token 信息)会统一存放到 userInfo 中
  246. */
  247. @interface WBAuthorizeResponse : WBBaseResponse
  248. /**
  249. 用户ID
  250. */
  251. @property (nonatomic, strong) NSString *userID;
  252. /**
  253. 认证口令
  254. */
  255. @property (nonatomic, strong) NSString *accessToken;
  256. /**
  257. 认证过期时间
  258. */
  259. @property (nonatomic, strong) NSDate *expirationDate;
  260. /**
  261. 当认证口令过期时用于换取认证口令的更新口令
  262. */
  263. @property (nonatomic, strong) NSString *refreshToken;
  264. @end
  265. #pragma mark - ProvideMessageForWeibo Request/Response
  266. /**
  267. 微博客户端向第三方程序请求提供内容的消息结构
  268. */
  269. @interface WBProvideMessageForWeiboRequest : WBBaseRequest
  270. @end
  271. /**
  272. 微博客户端向第三方应用请求提供内容,第三方应用向微博客户端返回的消息结构
  273. */
  274. @interface WBProvideMessageForWeiboResponse : WBBaseResponse
  275. /**
  276. 提供给微博客户端的消息
  277. */
  278. @property (nonatomic, strong) WBMessageObject *message;
  279. /**
  280. 返回一个 WBProvideMessageForWeiboResponse 对象
  281. @param message 需要回送给微博客户端程序的消息对象
  282. @return 返回一个*自动释放的*WBProvideMessageForWeiboResponse对象
  283. */
  284. + (id)responseWithMessage:(WBMessageObject *)message;
  285. @end
  286. #pragma mark - SendMessageToWeibo Request/Response
  287. /**
  288. 第三方应用发送消息至微博客户端程序的消息结构体
  289. */
  290. @interface WBSendMessageToWeiboRequest : WBBaseRequest
  291. /**
  292. 发送给微博客户端的消息
  293. */
  294. @property (nonatomic, strong) WBMessageObject *message;
  295. /**
  296. 返回一个 WBSendMessageToWeiboRequest 对象
  297. 此方法生成对象被[WeiboSDK sendRequest:]会唤起微博客户端的发布器进行分享,如果未安装微博客户端或客户端版本太低
  298. 会根据 shouldOpenWeiboAppInstallPageIfNotInstalled 属性判断是否弹出安装/更新微博的对话框
  299. @param message 需要发送给微博客户端的消息对象
  300. @return 返回一个*自动释放的*WBSendMessageToWeiboRequest对象
  301. */
  302. + (id)requestWithMessage:(WBMessageObject *)message;
  303. /**
  304. 返回一个 WBSendMessageToWeiboRequest 对象
  305. 当用户安装了可以支持微博客户端內分享的微博客户端时,会自动唤起微博并分享
  306. 当用户没有安装微博客户端或微博客户端过低无法支持通过客户端內分享的时候会自动唤起SDK內微博发布器
  307. @param message 需要发送给微博的消息对象
  308. @param authRequest 授权相关信息,与access_token二者至少有一个不为空,当access_token为空并且需要弹出SDK內发布器时会通过此信息先进行授权后再分享
  309. @param access_token 第三方应用之前申请的Token,当此值不为空并且无法通过客户端分享的时候,会使用此token进行分享。
  310. @return 返回一个*自动释放的*WBSendMessageToWeiboRequest对象
  311. */
  312. + (id)requestWithMessage:(WBMessageObject *)message
  313. authInfo:(WBAuthorizeRequest *)authRequest
  314. access_token:(NSString *)access_token;
  315. @end
  316. /**
  317. WBSendMessageToWeiboResponse
  318. */
  319. @interface WBSendMessageToWeiboResponse : WBBaseResponse
  320. /**
  321. 可能在分享过程中用户进行了授权操作,当此值不为空时,为用户相应授权信息
  322. */
  323. @property (nonatomic,strong) WBAuthorizeResponse *authResponse;
  324. @end
  325. #pragma mark - MessageObject / ImageObject
  326. /**
  327. 微博客户端程序和第三方应用之间传递的消息结构
  328. 一个消息结构由三部分组成:文字、图片和多媒体数据。三部分内容中至少有一项不为空,图片和多媒体数据不能共存。(新版的多图和视频属于图片数据,并且图片和视频也不能共存)
  329. */
  330. @interface WBMessageObject : NSObject
  331. /**
  332. 消息的文本内容
  333. @warning 长度小于2000个汉字
  334. */
  335. @property (nonatomic, strong) NSString *text;
  336. /**
  337. 消息的图片内容
  338. @see WBImageObject
  339. */
  340. @property (nonatomic, strong) WBImageObject *imageObject;
  341. /**
  342. 消息的多媒体内容
  343. @see WBBaseMediaObject
  344. */
  345. @property (nonatomic, strong) WBBaseMediaObject *mediaObject;
  346. /**
  347. 消息的视频内容
  348. @see WBVideoObject
  349. */
  350. @property (nonatomic, strong) WBNewVideoObject *videoObject;
  351. /**
  352. 返回一个 WBMessageObject 对象
  353. @return 返回一个*自动释放的*WBMessageObject对象
  354. */
  355. + (id)message;
  356. @end
  357. /**
  358. 图片视频分享时错误枚举
  359. */
  360. typedef NS_ENUM(NSInteger, WBSDKMediaTransferErrorCode)
  361. {
  362. WBSDKMediaTransferAlbumPermissionError = 0,//相册权限
  363. WBSDKMediaTransferAlbumWriteError = 1,//相册写入错误
  364. WBSDKMediaTransferAlbumAssetTypeError = 2,//资源类型错误
  365. };
  366. /**
  367. 图片视频分享协议
  368. */
  369. @protocol WBMediaTransferProtocol <NSObject>
  370. /**
  371. 数据准备成功回调
  372. */
  373. -(void)wbsdk_TransferDidReceiveObject:(id)object;
  374. /**
  375. 数据准备失败回调
  376. */
  377. -(void)wbsdk_TransferDidFailWithErrorCode:(WBSDKMediaTransferErrorCode)errorCode andError:(NSError*)error;
  378. @end
  379. /**
  380. 消息中包含的图片数据对象
  381. */
  382. @interface WBImageObject : NSObject
  383. /**
  384. 图片真实数据内容,图片数据与图片数组finalAssetArray只能存在一项,图片数据不能为空并且大小不能超过10M,
  385. 网页分享使用图片数据
  386. @warning 大小不能超过10M
  387. */
  388. @property (nonatomic, strong) NSData *imageData;
  389. /**
  390. 是否分享到story
  391. */
  392. @property (nonatomic) BOOL isShareToStory;
  393. /**
  394. 返回一个 WBImageObject 对象
  395. @return 返回一个*自动释放的*WBImageObject对象
  396. */
  397. + (id)object;
  398. /**
  399. 返回一个 UIImage 对象
  400. @return 返回一个*自动释放的*UIImage对象
  401. */
  402. - (UIImage *)image;
  403. /**
  404. 多图分享委托
  405. */
  406. @property(nonatomic,weak)id<WBMediaTransferProtocol> delegate;
  407. /**
  408. 图片对象添加图片数组
  409. */
  410. - (void)addImages:(NSArray<UIImage *>*)imageArray;
  411. /**
  412. 图片对象添加照片数组
  413. */
  414. - (void)addImageAssets:(NSArray<PHAsset*>*)assetArray;
  415. /**
  416. 多图最终传递对象
  417. */
  418. -(NSArray*)finalAssetArray;
  419. @end
  420. @interface WBNewVideoObject : NSObject
  421. /**
  422. 返回一个 WBNewVideoObject 对象
  423. @return 返回一个*自动释放的*WBNewVideoObject对象
  424. */
  425. + (id)object;
  426. /**
  427. 是否分享到story
  428. */
  429. @property (nonatomic) BOOL isShareToStory;
  430. /**
  431. 多图分享委托
  432. */
  433. @property(nonatomic,weak)id<WBMediaTransferProtocol> delegate;
  434. /**
  435. 视频对象添加视频
  436. */
  437. -(void)addVideo:(NSURL*)videoUrl;
  438. /**
  439. 视频对象添加视频资源
  440. */
  441. -(void)addVideoAsset:(PHAsset*)videoAsset;
  442. /**
  443. 视频最终传递对象
  444. */
  445. -(NSString*)finalAsset;
  446. @end
  447. #pragma mark - Message Media Objects
  448. /**
  449. 消息中包含的多媒体数据对象基类,该类后期会被废弃,在发布器不再显示为linkcard样式,只显示为普通网络连接
  450. */
  451. @interface WBBaseMediaObject : NSObject
  452. /**
  453. 对象唯一ID,用于唯一标识一个多媒体内容
  454. 当第三方应用分享多媒体内容到微博时,应该将此参数设置为被分享的内容在自己的系统中的唯一标识
  455. @warning 不能为空,长度小于255
  456. */
  457. @property (nonatomic, strong) NSString *objectID;
  458. /**
  459. 多媒体内容标题
  460. @warning 不能为空且长度小于1k
  461. */
  462. @property (nonatomic, strong) NSString *title;
  463. /**
  464. 多媒体内容描述
  465. @warning 长度小于1k
  466. */
  467. @property (nonatomic, strong) NSString *description;
  468. /**
  469. 多媒体内容缩略图
  470. @warning 大小小于32k
  471. */
  472. @property (nonatomic, strong) NSData *thumbnailData;
  473. /**
  474. 点击多媒体内容之后呼起第三方应用特定页面的scheme
  475. @warning 长度小于255
  476. */
  477. @property (nonatomic, strong) NSString *scheme;
  478. /**
  479. 返回一个 WBBaseMediaObject 对象
  480. @return 返回一个*自动释放的*WBBaseMediaObject对象
  481. */
  482. + (id)object;
  483. @end
  484. #pragma mark - Message WebPage Objects
  485. /**
  486. 消息中包含的网页数据对象
  487. */
  488. @interface WBWebpageObject : WBBaseMediaObject
  489. /**
  490. 网页的url地址
  491. @warning 不能为空且长度不能超过255
  492. */
  493. @property (nonatomic, strong) NSString *webpageUrl;
  494. @end