GT3CaptchaManager.h 13KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419
  1. //
  2. // GTCaptchaManager.h
  3. // GTCaptcha
  4. //
  5. // Created by NikoXu on 8/22/16.
  6. // Copyright © 2016 Geetest. All rights reserved.
  7. //
  8. #import <Foundation/Foundation.h>
  9. #import "GT3Utils.h"
  10. #import "GT3Error.h"
  11. @protocol GT3CaptchaManagerDelegate, GT3CaptchaNetworkDelegate, GT3CaptchaManagerViewDelegate, GT3CaptchaManagerStatisticDelegate;
  12. @interface GT3CaptchaManager : NSObject
  13. /** SDK版本号 */
  14. + (NSString *)sdkVersion;
  15. /** 验证管理代理 */
  16. @property (nonatomic, weak) id<GT3CaptchaManagerDelegate> delegate;
  17. /** 验证网络代理 */
  18. @property (nonatomic, weak) id<GT3CaptchaNetworkDelegate> networkDelegate;
  19. /** 验证视图代理 */
  20. @property (nonatomic, weak) id<GT3CaptchaManagerViewDelegate> viewDelegate;
  21. /** 验证统计代理 */
  22. @property (nonatomic, weak) id<GT3CaptchaManagerStatisticDelegate> statisticDelegate;
  23. /** 验证状态 */
  24. @property (nonatomic, readonly) GT3CaptchaState captchaState;
  25. /** 图形验证的展示状态 */
  26. @property (nonatomic, readonly) BOOL isShowing;
  27. /** 获取启动验证参数的接口 */
  28. @property (nonatomic, readonly) NSURL *API_1;
  29. /** 进行二次验证的接口 */
  30. @property (nonatomic, readonly) NSURL *API_2;
  31. /** 验证的ID */
  32. @property (nonatomic, readonly, strong) NSString *gt_captcha_id;
  33. /** 验证的会话标识 */
  34. @property (nonatomic, readonly, strong) NSString *gt_challenge;
  35. /** 验证的服务状态, 1正常/0宕机 */
  36. @property (nonatomic, readonly, strong) NSNumber *gt_success_code;
  37. /** 背景验证 */
  38. @property (nonatomic, strong) UIColor *maskColor;
  39. #pragma mark 基本方法
  40. /** 验证单例 */
  41. + (instancetype)sharedGTManagerWithAPI1:(NSString *)api_1
  42. API2:(NSString *)api_2
  43. timeout:(NSTimeInterval)timeout;
  44. /**
  45. * @abstract 验证初始化方法
  46. *
  47. * @discussion 请不要在接口api_1和api_2的URL上带动态参数, 如果需要对api_1和api_2的请求做修改见GT3CaptchaManagerDelegate代理方法`gtCaptcha:willSendRequestAPI1:withReplacedHandler:`及 `gtCaptcha:willSendSecondaryCaptchaRequest:withReplacedRequest:`
  48. *
  49. * @seealso `gtCaptcha:willSendRequestAPI1:withReplacedHandler:`及`gtCaptcha:willSendSecondaryCaptchaRequest:withReplacedRequest:`
  50. *
  51. * @param api_1 获取验证参数的接口
  52. * @param api_2 进行二次验证的接口
  53. * @param timeout 超时时长
  54. * @return GT3CaptchaManager 实例
  55. *
  56. */
  57. - (instancetype)initWithAPI1:(NSString *)api_1
  58. API2:(NSString *)api_2
  59. timeout:(NSTimeInterval)timeout NS_DESIGNATED_INITIALIZER;
  60. /**
  61. * @abstract 取消异步请求
  62. *
  63. * @discussion
  64. * 当希望取消正在执行的<b>NSURLSessionDataTask</b>时,调用此方法
  65. *
  66. * ❗️<b>内部请求基于NSURLSeesion</b>
  67. */
  68. - (void)cancelRequest;
  69. /**
  70. * @abstract 自定义配置验证参数
  71. *
  72. * @discussion
  73. * 从后端sdk获取的验证参数, 其中单个challenge只能使用在同一次验证会话中
  74. *
  75. * @param gt_public_key 在官网申请的captcha_id
  76. * @param gt_challenge 根据极验服务器sdk生成的challenge
  77. * @param gt_success_code 网站主服务器监测geetest服务的可用状态 0/1 不可用/可用
  78. * @param api_2 用于二次验证的接口.网站主根据极验服务端sdk来部署.
  79. *
  80. */
  81. - (void)configureGTest:(NSString *)gt_public_key
  82. challenge:(NSString *)gt_challenge
  83. success:(NSNumber *)gt_success_code
  84. withAPI2:(NSString *)api_2;
  85. /**
  86. *
  87. * @abstract 注册验证
  88. *
  89. * @param completionHandler 注册成功后的回调
  90. */
  91. - (void)registerCaptcha:(GT3CaptchaDefaultBlock)completionHandler;
  92. /**
  93. * ❗️<b>必要方法</b>❗️
  94. * @abstract 开始验证
  95. *
  96. * @discussion
  97. * 获取姿态, 提交分析后, 如有必要在`[[UIApplication sharedApplication].delegate window]`上显示极验验证的GTView验证视图
  98. * 极验验证GTWebView通过JS与SDK通信
  99. * 内部逻辑会根据当前的`captchaState`属性的状态不同而变更
  100. *
  101. */
  102. - (void)startGTCaptchaWithAnimated:(BOOL)animated;
  103. /**
  104. * 终止验证
  105. */
  106. - (void)stopGTCaptcha;
  107. /**
  108. * @abstract 重置验证
  109. *
  110. * @discussion
  111. * 内部先调用`stopGTCaptcha`后, 在主线程延迟0.3秒后
  112. * 执行`startCaptcha`的内部方法。
  113. * 只在`GT3CaptchaStateFail`,`GT3CaptchaStateError`,
  114. * `GT3CaptchaStateSuccess`, `GT3CaptchaStateCancel`状态下执行。
  115. */
  116. - (void)resetGTCaptcha;
  117. /**
  118. * 若验证显示则关闭验证界面
  119. */
  120. - (void)closeGTViewIfIsOpen;
  121. /**
  122. * 获取cookie value
  123. *
  124. * @param cookieName cookie的键名
  125. * @return 对应的cookie的值
  126. */
  127. - (NSString *)getCookieValue:(NSString *)cookieName;
  128. #pragma mark 其他配置的方法
  129. /**
  130. * @abstract 图形验证超时的时长
  131. *
  132. * @param timeout GT3WebView资源请求超时时间
  133. */
  134. - (void)useGTViewWithTimeout:(NSTimeInterval)timeout;
  135. /**
  136. * @abstract 验证标题
  137. *
  138. * @discussion
  139. * 默认不开启. 字符长度不能超过28, 一个中文字符为两个2字符长度.
  140. *
  141. * @param title 验证标题字符串
  142. */
  143. - (void)useGTViewWithTitle:(NSString *)title;
  144. /**
  145. * @abstract 配置状态指示器
  146. *
  147. * @discussion
  148. * 为了能方便的调试动画,真机调试模拟低速网络 Settings->Developer
  149. * ->Status->Enable->Edge(😂)
  150. *
  151. * @param animationBlock 自定义时需要实现的动画block,仅在type配置为GTIndicatorCustomType时才执行
  152. * @param type 状态指示器的类型
  153. */
  154. - (void)useAnimatedAcitvityIndicator:(GT3IndicatorAnimationViewBlock)animationBlock
  155. withIndicatorType:(GT3ActivityIndicatorType)type;
  156. /**
  157. * @abstract 配置背景模糊
  158. *
  159. * @discussion
  160. * iOS8以上生效
  161. *
  162. * @param blurEffect 模糊特效
  163. */
  164. - (void)useVisualViewWithEffect:(UIBlurEffect *)blurEffect;
  165. /**
  166. * @abstract 切换验证语言
  167. *
  168. * @discussion
  169. * 默认中文
  170. *
  171. * @param type 语言类型
  172. */
  173. - (void)useLanguage:(GT3LanguageType)type;
  174. /**
  175. * @abstract 完全使用HTTPS协议请求验证
  176. *
  177. * @discussion
  178. * 默认开启HTTPS
  179. *
  180. * @param disable 是否禁止https支持
  181. */
  182. - (void)disableSecurityAuthentication:(BOOL)disable;
  183. /**
  184. * @abstract 验证背景交互事件的开关
  185. *
  186. * @discussion 默认关闭
  187. *
  188. * @param disable YES忽略交互事件/NO接受交互事件
  189. */
  190. - (void)disableBackgroundUserInteraction:(BOOL)disable;
  191. /**
  192. * @abstract 控制验证管理器内部的网络可达性检测
  193. *
  194. * @param enable YES 开启/NO 关闭. 默认YES.
  195. */
  196. - (void)enableNetworkReachability:(BOOL)enable;
  197. /**
  198. * @abstract Debug Mode
  199. *
  200. * @discussion
  201. * 开启debugMode,在开启验证之前调用此方法
  202. * 默认不开启
  203. *
  204. * @param enable YES开启,NO关闭
  205. */
  206. - (void)enableDebugMode:(BOOL)enable;
  207. @end
  208. #pragma mark - 验证代理方法
  209. @protocol GT3CaptchaManagerDelegate <NSObject>
  210. @required
  211. /**
  212. * 验证错误处理
  213. *
  214. * @discussion 抛出内部错误, 比如GTWebView等错误
  215. *
  216. * @param manager 验证管理器
  217. * @param error 错误源
  218. */
  219. - (void)gtCaptcha:(GT3CaptchaManager *)manager errorHandler:(GT3Error *)error;
  220. /**
  221. * @abstract 通知已经收到二次验证结果, 在此处理最终验证结果
  222. *
  223. * @discussion
  224. * 二次验证的错误只在这里返回, `decisionHandler`需要处理
  225. *
  226. * @param manager 验证管理器
  227. * @param data 二次验证返回的数据
  228. * @param response 二次验证的响应
  229. * @param error 错误源
  230. * @param decisionHandler 更新验证结果的视图
  231. */
  232. - (void)gtCaptcha:(GT3CaptchaManager *)manager didReceiveSecondaryCaptchaData:(NSData *)data response:(NSURLResponse *)response error:(GT3Error *)error decisionHandler:(void (^)(GT3SecondaryCaptchaPolicy captchaPolicy))decisionHandler;
  233. @optional
  234. /**
  235. * @abstract 是否使用内部默认的API1请求逻辑
  236. *
  237. * @param manager 验证管理器
  238. * @return YES使用,NO不使用
  239. */
  240. - (BOOL)shouldUseDefaultRegisterAPI:(GT3CaptchaManager *)manager;
  241. /**
  242. * @abstract 将要向<b>API1</b>发送请求的时候调用此方法, 通过此方法可以修改将要发送的请求
  243. *
  244. * @warning 不支持子线程操作。
  245. *
  246. * @discussion 调用此方法的时候必须执行<b>requestHandler</b>, 否则可能导致内存泄露。
  247. *
  248. * @param manager 验证管理器
  249. * @param originalRequest 默认发送的请求对象
  250. * @param replacedHandler 修改请求的执行block
  251. */
  252. - (void)gtCaptcha:(GT3CaptchaManager *)manager willSendRequestAPI1:(NSURLRequest *)originalRequest withReplacedHandler:(void (^)(NSURLRequest * request))replacedHandler;
  253. /**
  254. * @abstract 当接收到从<b>API1</b>的数据, 通知返回字典, 包括<b>gt_public_key</b>,
  255. * <b>gt_challenge</b>, <b>gt_success_code</b>
  256. *
  257. * @warning 不支持子线程操作。
  258. *
  259. * @discussion
  260. * 如果实现此方法, 需要解析验证需要的数据并返回。
  261. 如果不返回验证初始化数据, 使用内部的解析规则进行解析。默认先解析一级结构, 再匹配键名为"data"或"gtcap"中的数据。
  262. *
  263. * @param manager 验证管理器
  264. * @param dictionary API1返回的数据(未解析)
  265. * @param error 返回的错误
  266. *
  267. * @return 验证初始化数据, 格式见下方
  268. <pre>
  269. {
  270. "challenge" : "12ae1159ffdfcbbc306897e8d9bf6d06",
  271. "gt" : "ad872a4e1a51888967bdb7cb45589605",
  272. "success" : 1
  273. }
  274. </pre>
  275. */
  276. - (NSDictionary *)gtCaptcha:(GT3CaptchaManager *)manager didReceiveDataFromAPI1:(NSDictionary *)dictionary withError:(GT3Error *)error;
  277. /**
  278. * @abstract 通知接收到返回的验证交互结果
  279. *
  280. * @discussion 此方法仅仅是前端返回的初步结果, 并非验证最终结果。
  281. *
  282. * @param manager 验证管理器
  283. * @param code 验证交互结果, 0失败/1成功
  284. * @param result 二次验证数据
  285. * @param message 附带消息
  286. */
  287. - (void)gtCaptcha:(GT3CaptchaManager *)manager didReceiveCaptchaCode:(NSString *)code result:(NSDictionary *)result message:(NSString *)message;
  288. /**
  289. * @abstract 是否使用内部默认的API2请求逻辑
  290. *
  291. * @discussion 默认返回YES;
  292. *
  293. * @param manager 验证管理器
  294. * @return YES使用,NO不使用
  295. */
  296. - (BOOL)shouldUseDefaultSecondaryValidate:(GT3CaptchaManager *)manager;
  297. /**
  298. * @abstract 通知即将进行二次验证, 再次修改发送至<b>API2</b>的验证。
  299. *
  300. * @warning 不支持子线程操作。
  301. *
  302. * @discussion
  303. * 请不要修改<b>requestHandler</b>执行所在的线程或队列, 否则可能导
  304. * 请求修改失败. 二次验证的请求方式应为<b>POST</b>, 头部信息应为:
  305. * <pre>{"Content-Type":@"application/x-www-form-urlencoded;charset=UTF-8"}</pre>
  306. *
  307. * @param manager 验证管理器
  308. * @param replacedRequest 修改二次验证请求的block
  309. */
  310. - (void)gtCaptcha:(GT3CaptchaManager *)manager willSendSecondaryCaptchaRequest:(NSURLRequest *)originalRequest withReplacedRequest:(void (^)(NSMutableURLRequest * request))replacedRequest;
  311. /**
  312. * @abstract 用户主动关闭了验证码界面
  313. *
  314. * @param manager 验证管理器
  315. */
  316. - (void)gtCaptchaUserDidCloseGTView:(GT3CaptchaManager *)manager;
  317. @end
  318. @protocol GT3CaptchaNetworkDelegate <NSObject>
  319. - (void)gtCaptcha:(GT3CaptchaManager *)manager didReceiveChallenge:(NSURLAuthenticationChallenge *)challenge
  320. completionHandler:(void (^)(NSURLSessionAuthChallengeDisposition disposition, NSURLCredential * credential))completionHandler;
  321. @end
  322. @protocol GT3CaptchaManagerViewDelegate <NSObject>
  323. @optional
  324. /**
  325. * @abstract 通知验证模式
  326. *
  327. * @param manager 验证管理器
  328. * @param mode 验证模式
  329. */
  330. - (void)gtCaptcha:(GT3CaptchaManager *)manager notifyCaptchaMode:(GT3CaptchaMode)mode;
  331. /**
  332. * @abstract 通知将要显示图形验证
  333. *
  334. * @param manager 验证管理器
  335. */
  336. - (void)gtCaptchaWillShowGTView:(GT3CaptchaManager *)manager;
  337. /**
  338. * @abstract 更新验证状态
  339. *
  340. * @param manager 验证管理器
  341. * @param state 验证状态
  342. * @param error 错误信息
  343. */
  344. - (void)gtCaptcha:(GT3CaptchaManager *)manager updateCaptchaStatus:(GT3CaptchaState)state error:(GT3Error *)error;
  345. /**
  346. * @abstract 更新验证视图
  347. *
  348. * @param manager 验证管理器
  349. * @param fromValue 起始值
  350. * @param toValue 终止值
  351. * @param timeInterval 时间间隔
  352. */
  353. - (void)gtCaptcha:(GT3CaptchaManager *)manager updateCaptchaViewWithFactor:(CGFloat)fromValue to:(CGFloat)toValue timeInterval:(NSTimeInterval)timeInterval;
  354. @end
  355. @protocol GT3CaptchaManagerStatisticDelegate <NSObject>
  356. @optional
  357. - (void)gtCaptchaDidStartCaptcha:(GT3CaptchaManager *)manager;
  358. - (void)gtCaptcha:(GT3CaptchaManager *)manager didReceiveFullpageResult:(NSString *)result;
  359. - (void)gtCaptchaNotifyGTViewDidReady:(GT3CaptchaManager *)manager;
  360. - (void)gtCaptcha:(GT3CaptchaManager *)manager didReturnStatisticInfomation:(NSData *)data;
  361. @end