Blame view

Pods/mob_sharesdk/ShareSDK/Support/PlatformSDK/WeChatSDK/WXApi.h 7.09 KB
75d24c15   yangbin   123
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
  //
  //  WXApi.h
  //  所有Api接口
  //
  //  Created by Wechat on 12-2-28.
  //  Copyright (c) 2012 Tencent. All rights reserved.
  //
  
  #import <Foundation/Foundation.h>
  #import "WXApiObject.h"
  
  NS_ASSUME_NONNULL_BEGIN
  
  #pragma mark - WXApiDelegate
  /*! @brief 接收并处理来自微信终端程序的事件消息
   *
   * 接收并处理来自微信终端程序的事件消息,期间微信界面会切换到第三方应用程序。
   * WXApiDelegate 会在handleOpenURL:delegate:中使用并触发。
   */
  @protocol WXApiDelegate <NSObject>
  @optional
  
  /*! @brief 收到一个来自微信的请求,第三方应用程序处理完后调用sendResp向微信发送结果
   *
   * 收到一个来自微信的请求,异步处理完成后必须调用sendResp发送处理结果给微信。
   * 可能收到的请求有GetMessageFromWXReqShowMessageFromWXReq等。
   * @param req 具体请求内容,是自动释放的
   */
  - (void)onReq:(BaseReq*)req;
  
  
  
  /*! @brief 发送一个sendReq后,收到微信的回应
   *
   * 收到一个来自微信的处理结果。调用一次sendReq后会收到onResp
   * 可能收到的处理结果有SendMessageToWXRespSendAuthResp等。
   * @param resp具体的回应内容,是自动释放的
   */
  - (void)onResp:(BaseResp*)resp;
  
  @end
  
  #pragma mark - WXApiLogDelegate
  
  @protocol WXApiLogDelegate <NSObject>
  
  - (void)onLog:(NSString*)log logLevel:(WXLogLevel)level;
  
  @end
  
  
  #pragma mark - WXApi
  
  /*! @brief 微信Api接口函数类
   *
   * 该类封装了微信终端SDK的所有接口
   */
  @interface WXApi : NSObject
  
  /*! @brief WXApi的成员函数,向微信终端程序注册第三方应用。
   *
   * 需要在每次启动第三方应用程序时调用。
   * @attention 请保证在主线程中调用此函数
   * @param appid 微信开发者ID
   * @param universalLink 微信开发者Universal Link
   * @return 成功返回YES,失败返回NO
   */
  + (BOOL)registerApp:(NSString *)appid universalLink:(NSString *)universalLink;
  
  
  /*! @brief 处理旧版微信通过URL启动App时传递的数据
   *
   * 需要在 application:openURL:sourceApplication:annotation:或者application:handleOpenURL中调用。
   * @param url 微信启动第三方应用时传递过来的URL
   * @param delegate  WXApiDelegate对象,用来接收微信触发的消息。
   * @return 成功返回YES,失败返回NO
   */
  + (BOOL)handleOpenURL:(NSURL *)url delegate:(nullable id<WXApiDelegate>)delegate;
  
  
  /*! @brief 处理微信通过Universal Link启动App时传递的数据
   *
   * 需要在 application:continueUserActivity:restorationHandler:中调用。
   * @param userActivity 微信启动第三方应用时系统API传递过来的userActivity
   * @param delegate  WXApiDelegate对象,用来接收微信触发的消息。
   * @return 成功返回YES,失败返回NO
   */
  + (BOOL)handleOpenUniversalLink:(NSUserActivity *)userActivity delegate:(nullable id<WXApiDelegate>)delegate;
  
  
  /*! @brief 检查微信是否已被用户安装
   *
   * @return 微信已安装返回YES,未安装返回NO
   */
  + (BOOL)isWXAppInstalled;
  
  
  
  /*! @brief 判断当前微信的版本是否支持OpenApi
   *
   * @return 支持返回YES,不支持返回NO
   */
  + (BOOL)isWXAppSupportApi;
  
  
  /*! @brief 判断当前微信的版本是否支持分享微信状态功能
   *
   * @attention 需在工程LSApplicationQueriesSchemes配置中添加weixinStateAPI
   * @return 支持返回YES,不支持返回NO
   */
  + (BOOL)isWXAppSupportStateAPI;
  
  
  /*! @brief 获取微信的itunes安装地址
   *
   * @return 微信的安装地址字符串。
   */
  + (NSString *)getWXAppInstallUrl;
  
  
  
  /*! @brief 获取当前微信SDK的版本号
   *
   * @return 返回当前微信SDK的版本号
   */
  + (NSString *)getApiVersion;
  
  
  
  /*! @brief 打开微信
   *
   * @return 成功返回YES,失败返回NO
   */
  + (BOOL)openWXApp;
  
  
  
  /*! @brief 发送请求到微信,等待微信返回onResp
   *
   * 函数调用后,会切换到微信的界面。第三方应用程序等待微信返回onResp。微信在异步处理完成后一定会调用onResp。支持以下类型
   * SendAuthReqSendMessageToWXReqPayReq等。
   * @param req 具体的发送请求。
   * @param completion 调用结果回调block
   */
  + (void)sendReq:(BaseReq *)req completion:(void (^ __nullable)(BOOL success))completion;
  
  /*! @brief 收到微信onReq的请求,发送对应的应答给微信,并切换到微信界面
   *
   * 函数调用后,会切换到微信的界面。第三方应用程序收到微信onReq的请求,异步处理该请求,完成后必须调用该函数。可能发送的相应有
   * GetMessageFromWXRespShowMessageFromWXResp等。
   * @param resp 具体的应答内容
   * @param completion 调用结果回调block
   */
  + (void)sendResp:(BaseResp*)resp completion:(void (^ __nullable)(BOOL success))completion;
  
  
  /*! @brief 发送Auth请求到微信,支持用户没安装微信,等待微信返回onResp
   *
   * 函数调用后,会切换到微信的界面。第三方应用程序等待微信返回onResp。微信在异步处理完成后一定会调用onResp。支持SendAuthReq类型。
   * @param req 具体的发送请求。
   * @param viewController 当前界面对象。
   * @param delegate  WXApiDelegate对象,用来接收微信触发的消息。
   * @param completion 调用结果回调block
   */
  + (void)sendAuthReq:(SendAuthReq *)req viewController:(UIViewController*)viewController delegate:(nullable id<WXApiDelegate>)delegate completion:(void (^ __nullable)(BOOL success))completion;
  
  
  /*! @brief 测试函数,用于排查当前App通过Universal Link方式分享到微信的流程
      注意1:  调用自检函数之前必须要先调用registerApp:universalLink接口, 并确认调用成功
      注意2:  自检过程中会有Log产生,可以先调用startLogByLevel函数,根据Log排查问题
      注意3:  会多次回调block
      注意4:  仅用于新接入SDK时调试使用,请勿在正式环境的调用
   *
   *  completion回调的stepWXULCheckStepFinal时,表示检测通过,Universal Link接入成功
   *  @param completion 回调Block
   */
  + (void)checkUniversalLinkReady:(nonnull WXCheckULCompletion)completion;
  
  
  /*! @brief WXApi的成员函数,接受微信的log信息。byBlock
      注意1:SDK会强引用这个block,注意不要导致内存泄漏,注意不要导致内存泄漏
      注意2:调用过一次startLog by block之后,如果再调用一次任意方式的startLoad,会释放上一次logBlock,不再回调上一个logBlock
   *
   *  @param level 打印log的级别
   *  @param logBlock 打印log的回调block
   */
  
  + (void)startLogByLevel:(WXLogLevel)level logBlock:(WXLogBolock)logBlock;
  
  /*! @brief WXApi的成员函数,接受微信的log信息。byDelegate 
      注意1:sdk会弱引用这个delegate,这里可加任意对象为代理,不需要与WXApiDelegate同一个对象
      注意2:调用过一次startLog by delegate之后,再调用一次任意方式的startLoad,不会再回调上一个logDelegate对象
   *  @param level 打印log的级别
   *  @param logDelegate 打印log的回调代理,
   */
  + (void)startLogByLevel:(WXLogLevel)level logDelegate:(id<WXApiLogDelegate>)logDelegate;
  
  /*! @brief 停止打印log,会清理block或者delegate为空,释放block
   *  @param 
   */
  + (void)stopLog;
  
  @end
  
  NS_ASSUME_NONNULL_END