sdkdef.h 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444
  1. ///
  2. /// \file sdkdef.h
  3. /// \brief SDK中相关常量定义
  4. ///
  5. /// Created by Tencent on 12-12-25.
  6. /// Copyright (c) 2012年 Tencent. All rights reserved.
  7. ///
  8. #import <Foundation/Foundation.h>
  9. #import <UIKit/UIKit.h>
  10. /**
  11. * \brief 设置sdk的log等级
  12. */
  13. typedef enum {
  14. TCOLogLevel_Disabled = -1, // 关闭所有log
  15. TCOLogLevel_Error = 0,
  16. TCOLogLevel_Warning,
  17. TCOLogLevel_Info,
  18. TCOLogLevel_Debug,
  19. } TCOLogLevel;
  20. /**
  21. * \brief 手机qq的当前版本
  22. */
  23. typedef enum QQVersion
  24. {
  25. kQQUninstall,
  26. kQQVersion3_0,
  27. kQQVersion4_0, //支持sso登陆
  28. kQQVersion4_2_1, //ios7兼容
  29. kQQVersion4_5, //4.5版本,wpa会话
  30. kQQVersion4_6, //4.6版本,sso登陆信令通道切换
  31. kQQVersion4_7, //4.7版本 不确定新支持了什么样的属性
  32. } QQVersion;
  33. /**
  34. * \breif TIM的当前版本
  35. */
  36. typedef enum TIMVersion {
  37. kTIMUinstall,
  38. kTIMVersion1_1,
  39. }TIMVersion;
  40. /**
  41. * \breif 授权/分享 方式
  42. */
  43. typedef enum TencentAuthShareType {
  44. AuthShareType_QQ,
  45. AuthShareType_TIM,
  46. }TencentAuthShareType;
  47. /**
  48. * \brief APIResponse.retCode可能的枚举常量
  49. */
  50. typedef enum
  51. {
  52. URLREQUEST_SUCCEED = 0, /**< 网络请求成功发送至服务器,并且服务器返回数据格式正确
  53. * \note 这里包括所请求业务操作失败的情况,例如没有授权等原因导致
  54. */
  55. URLREQUEST_FAILED = 1, /**< 网络异常,或服务器返回的数据格式不正确导致无法解析 */
  56. } REPONSE_RESULT;
  57. /**
  58. * \brief 增量授权失败原因
  59. *
  60. * \note 增量授权失败不影响原token的有效性(原token已失效的情况除外)
  61. */
  62. typedef enum
  63. {
  64. kUpdateFailUnknown = 1, ///< 未知原因
  65. kUpdateFailUserCancel, ///< 用户取消
  66. kUpdateFailNetwork, ///< 网络问题
  67. } UpdateFailType;
  68. /**
  69. * \brief 封装服务器返回的结果
  70. *
  71. * APIResponse用于封装所有请求的返回结果,包括错误码、错误信息、原始返回数据以及返回数据的json格式字典
  72. */
  73. @interface APIResponse : NSObject<NSCoding> {
  74. int _detailRetCode;
  75. int _retCode;
  76. int _seq;
  77. NSString *_errorMsg;
  78. NSDictionary *_jsonResponse;
  79. NSString *_message;
  80. id _userData;
  81. }
  82. /**
  83. * 新增的详细错误码\n
  84. * detailRetCode主要用于区分不同的错误情况,参见\ref OpenSDKError
  85. */
  86. @property (nonatomic, assign) int detailRetCode;
  87. /**
  88. * 网络请求是否成功送达服务器,以及服务器返回的数据格式是否正确\n
  89. * retCode具体取值可参考\ref REPONSE_RESULT
  90. */
  91. @property (nonatomic, assign) int retCode;
  92. /**
  93. * 网络请求对应的递增序列号,方便内部管理
  94. */
  95. @property (nonatomic, assign) int seq;
  96. /**
  97. * 错误提示语
  98. */
  99. @property (nonatomic, retain) NSString *errorMsg;
  100. /**
  101. * 服务器返回数据的json格式字典\n
  102. * 字典内具体参数的命名和含义请参考\ref api_spec
  103. */
  104. @property (nonatomic, retain) NSDictionary *jsonResponse;
  105. /**
  106. * 服务器返回的原始数据字符串
  107. */
  108. @property (nonatomic, retain) NSString *message;
  109. /**
  110. * 用户保留数据
  111. */
  112. @property (nonatomic, retain) id userData;
  113. @end
  114. /**
  115. * 用户自定义的保留字段
  116. */
  117. FOUNDATION_EXTERN NSString * const PARAM_USER_DATA;
  118. /**
  119. * \name 应用邀请参数字段定义
  120. */
  121. ///@{
  122. /** 应用邀请展示图片url的key */
  123. FOUNDATION_EXTERN NSString * const PARAM_APP_ICON;
  124. /** 应用邀请描述文本的key */
  125. FOUNDATION_EXTERN NSString * const PARAM_APP_DESC;
  126. /** 应用邀请好友列表的key */
  127. FOUNDATION_EXTERN NSString * const PARAM_APP_INVITED_OPENIDS;
  128. ///@}
  129. /**
  130. * \name sendStory新分享参数字段定义
  131. */
  132. ///@{
  133. /** 预填入接受人列表的key */
  134. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_RECEIVER;
  135. /** 分享feeds标题的key */
  136. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_TITLE;
  137. /** 分享feeds评论内容的key */
  138. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_COMMENT;
  139. /** 分享feeds摘要的key */
  140. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_SUMMARY;
  141. /** 分享feeds展示图片url的key */
  142. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_IMAGE;
  143. /** 分享feeds跳转链接url的key */
  144. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_URL;
  145. /** 分享feeds点击操作默认行为的key */
  146. FOUNDATION_EXTERN NSString * const PARAM_SENDSTORY_ACT;
  147. ///@}
  148. /**
  149. * \name 设置头像参数字段定义
  150. */
  151. ///@{
  152. /** 头像图片数据的key */
  153. FOUNDATION_EXTERN NSString * const PARAM_SETUSERHEAD_PIC;
  154. /** 头像图片文件名的key */
  155. FOUNDATION_EXTERN NSString * const PARAM_SETUSERHEAD_FILENAME;
  156. ///@}
  157. /**
  158. * \name 服务器返回数据的参数字段定义
  159. */
  160. ///@{
  161. /** 服务器返回码的key */
  162. FOUNDATION_EXTERN NSString * const PARAM_RETCODE;
  163. /** 服务器返回错误信息的key */
  164. FOUNDATION_EXTERN NSString * const PARAM_MESSAGE;
  165. /** 服务器返回额外数据的key */
  166. FOUNDATION_EXTERN NSString * const PARAM_DATA;
  167. ///@}
  168. /**
  169. * \name 错误信息相关常量定义
  170. */
  171. ///@{
  172. /** 详细错误信息字典中额外信息的key */
  173. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorKeyExtraInfo;
  174. /** 详细错误信息字典中返回码的key */
  175. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorKeyRetCode;
  176. /** 详细错误信息字典中错误语句的key */
  177. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorKeyMsg;
  178. /** 不支持的接口 */
  179. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgUnsupportedAPI;
  180. /** 操作成功 */
  181. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgSuccess;
  182. /** 未知错误 */
  183. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgUnknown;
  184. /** 用户取消 */
  185. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgUserCancel;
  186. /** 请重新登录 */
  187. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgReLogin;
  188. /** 应用没有操作权限 */
  189. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgOperationDeny;
  190. /** 网络异常或没有网络 */
  191. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgNetwork;
  192. /** URL格式或协议错误 */
  193. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgURL;
  194. /** 解析数据出错 */
  195. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgDataParse;
  196. /** 传入参数有误 */
  197. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgParam;
  198. /** 连接超时 */
  199. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgTimeout;
  200. /** 安全问题 */
  201. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgSecurity;
  202. /** 文件读写错误 */
  203. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgIO;
  204. /** 服务器端错误 */
  205. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgServer;
  206. /** 页面错误 */
  207. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgWebPage;
  208. /** 设置头像图片过大 */
  209. FOUNDATION_EXTERN NSString * const TCOpenSDKErrorMsgUserHeadPicLarge;
  210. ///@}
  211. /**
  212. * \brief SDK新增详细错误常量
  213. */
  214. typedef enum
  215. {
  216. kOpenSDKInvalid = -1, ///< 无效的错误码
  217. kOpenSDKErrorUnsupportedAPI = -2, ///< 不支持的接口
  218. /**
  219. * \name CommonErrorCode
  220. * 公共错误码
  221. */
  222. ///@{
  223. kOpenSDKErrorSuccess = 0, ///< 成功
  224. kOpenSDKErrorUnknown, ///< 未知错误
  225. kOpenSDKErrorUserCancel, ///< 用户取消
  226. kOpenSDKErrorReLogin, ///< token无效或用户未授权相应权限需要重新登录
  227. kOpenSDKErrorOperationDeny, ///< 第三方应用没有该api操作的权限
  228. ///@}
  229. /**
  230. * \name NetworkRelatedErrorCode
  231. * 网络相关错误码
  232. */
  233. ///@{
  234. kOpenSDKErrorNetwork, ///< 网络错误,网络不通或连接不到服务器
  235. kOpenSDKErrorURL, ///< URL格式或协议错误
  236. kOpenSDKErrorDataParse, ///< 数据解析错误,服务器返回的数据解析出错
  237. kOpenSDKErrorParam, ///< 传入参数错误
  238. kOpenSDKErrorConnTimeout, ///< http连接超时
  239. kOpenSDKErrorSecurity, ///< 安全问题
  240. kOpenSDKErrorIO, ///< 下载和文件IO错误
  241. kOpenSDKErrorServer, ///< 服务器端错误
  242. ///@}
  243. /**
  244. * \name WebViewRelatedError
  245. * webview特有错误
  246. */
  247. ///@{
  248. kOpenSDKErrorWebPage, ///< 页面错误
  249. ///@}
  250. /**
  251. * \name SetUserHeadRelatedErrorCode
  252. * 设置头像自定义错误码段
  253. */
  254. ///@{
  255. kOpenSDKErrorUserHeadPicLarge = 0x010000, ///< 图片过大 设置头像自定义错误码
  256. ///@}
  257. } OpenSDKError;
  258. /**
  259. * \name SDK版本(v1.3)支持的授权列表常量
  260. */
  261. ///@{
  262. /** 发表一条说说到QQ空间(<b>需要申请权限</b>) */
  263. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_ADD_TOPIC;
  264. /** 发表一篇日志到QQ空间(<b>需要申请权限</b>) */
  265. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_ADD_ONE_BLOG;
  266. /** 创建一个QQ空间相册(<b>需要申请权限</b>) */
  267. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_ADD_ALBUM;
  268. /** 上传一张照片到QQ空间相册(<b>需要申请权限</b>) */
  269. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_UPLOAD_PIC;
  270. /** 获取用户QQ空间相册列表(<b>需要申请权限</b>) */
  271. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_LIST_ALBUM;
  272. /** 同步分享到QQ空间、腾讯微博 */
  273. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_ADD_SHARE;
  274. /** 验证是否认证空间粉丝 */
  275. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_CHECK_PAGE_FANS;
  276. /** 获取登录用户自己的详细信息 */
  277. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_GET_INFO;
  278. /** 获取其他用户的详细信息 */
  279. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_GET_OTHER_INFO;
  280. /** 获取会员用户基本信息 */
  281. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_GET_VIP_INFO;
  282. /** 获取会员用户详细信息 */
  283. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_GET_VIP_RICH_INFO;
  284. /** 获取用户信息 */
  285. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_GET_USER_INFO;
  286. /** 移动端获取用户信息 */
  287. FOUNDATION_EXTERN NSString *const kOPEN_PERMISSION_GET_SIMPLE_USER_INFO;
  288. ///@}
  289. /**
  290. * \name CGI接口相关参数类型定义
  291. */
  292. ///@{
  293. /** 必填的字符串类型参数 */
  294. typedef NSString *TCRequiredStr;
  295. /** 必填的UIImage类型参数 */
  296. typedef UIImage *TCRequiredImage;
  297. /** 必填的整型参数 */
  298. typedef NSInteger TCRequiredInt;
  299. /** 必填的数字类型 */
  300. typedef NSNumber *TCRequiredNumber;
  301. /** 必填的NSData参数 */
  302. typedef NSData *TCRequiredData;
  303. /** 可选的字符串类型参数 */
  304. typedef NSString *TCOptionalStr;
  305. /** 可选的UIImage类型参数 */
  306. typedef UIImage *TCOptionalImage;
  307. /** 可选的整型参数 */
  308. typedef NSInteger TCOptionalInt;
  309. /** 可选的数字类型 */
  310. typedef NSNumber *TCOptionalNumber;
  311. /** 可选的不定类型参数 */
  312. typedef id TCRequiredId;
  313. ///@}
  314. /**
  315. * \brief CGI请求的参数字典封装辅助基类
  316. *
  317. * 将相应属性的值以key-value的形式保存到参数字典中
  318. */
  319. @interface TCAPIRequest : NSMutableDictionary
  320. /** CGI请求的URL地址 */
  321. @property (nonatomic, readonly) NSURL *apiURL;
  322. /** CGI请求方式:"GET","POST" */
  323. @property (nonatomic, readonly) NSString *method;
  324. /**
  325. * API参数中的保留字段,可以塞入任意字典支持的类型,再调用完成后会带回给调用方
  326. */
  327. @property (nonatomic, retain) TCRequiredId paramUserData;
  328. /**
  329. * APIResponse,API的返回结果
  330. */
  331. @property (nonatomic, readonly) APIResponse *response;
  332. /** 取消相应的CGI请求任务 */
  333. - (void)cancel;
  334. @end
  335. @protocol TCAPIRequestDelegate <NSObject>
  336. @optional
  337. - (void)cgiRequest:(TCAPIRequest *)request didResponse:(APIResponse *)response;
  338. @end