Ei kuvausta

AlibcNetPacket.h 3.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. /*
  2. * AlibcNetPacket.h
  3. *
  4. * 阿里百川电商
  5. * 项目名称:阿里巴巴电商 AlibcTradeCommon
  6. * 版本号:3.1.1.200
  7. * 发布时间:2017-08-21
  8. * 开发团队:阿里巴巴百川商业化团队
  9. * 阿里巴巴电商SDK答疑群号:1488705339 2071154343(阿里旺旺)
  10. * Copyright (c) 2016-2019 阿里巴巴-移动事业群-百川. All rights reserved.
  11. */
  12. #import <Foundation/Foundation.h>
  13. #import "AlibcNetError.h"
  14. #ifndef AlibcNetPacket_h
  15. #define AlibcNetPacket_h
  16. //*******使用须知
  17. //函数是给子类重载用的; block是给外部调用者设置的,子类自己不要用
  18. typedef NS_ENUM(long, ALiNetPriority) {
  19. ALiNetPriorityHigh = 1, //高,马上发送
  20. ALiNetPriorityNormal, //普通,发送任务多时,可能等待200ms(等待时可以合并请求)
  21. ALiNetPriorityLow, //低,等待200ms后发送,供合并请求
  22. };
  23. typedef NS_ENUM(long, AlibcNetPacketStatus) {
  24. AlibcNetPacketStatusNormal = 1,//请求未处理
  25. AlibcNetPacketStatusSendng, //发送中
  26. AlibcNetPacketStatusSuccess, //请求成功
  27. AlibcNetPacketStatusFail, //请求失败
  28. };
  29. typedef void (^SuccessAction)(id netData); //发送成功
  30. typedef void (^ErrorAction)(AlibcNetError *error); //发送失败
  31. //mtop请求包头定义
  32. @interface AlibcNetPacketHttpHeader : NSObject
  33. @property(nonatomic, copy) NSString *cmd; //mtop命令
  34. @property(nonatomic, copy) NSString *version; //版本,默认值"1.0"
  35. @property(nonatomic, assign) BOOL needPost; //是否用post,默认是YES
  36. @property(nonatomic, assign) BOOL needLogin; //是否需要login,默认是NO
  37. @property(nonatomic, assign) BOOL needAuth; //是否需要授权,默认是NO
  38. @property(nonatomic, assign) BOOL needWua; //是否需要人机,默认是NO
  39. @property(nonatomic, copy) NSString *bizId; //组件id,默认不需要填,组件发起的才需要填
  40. - (instancetype)initWithCmd:(NSString *)cmd;
  41. @end
  42. //......
  43. @interface AlibcNetPacket<ObjectType> : NSObject
  44. @property(nonatomic, assign) NSUInteger retryTime; //发送重试次数,默认(0),不重试 最大重试5次
  45. @property(nonatomic, assign) ALiNetPriority priority; //默认值(AMPNetPriorityNormal)
  46. //****** 下面变量,是netservice维护的, ******//
  47. @property(nonatomic, assign) NSUInteger retryCount; //当前是第几次重试,网络层用..子类不要动,切忌
  48. @property(nonatomic, assign) AlibcNetPacketStatus status;
  49. //block,只供外部使用者设置,子类不要用;
  50. @property(nonatomic, copy) SuccessAction successAction;
  51. @property(nonatomic, copy) ErrorAction failAction;
  52. //**************供子类重载用的
  53. //Mtop发送相关
  54. - (AlibcNetPacketHttpHeader *)generateMtopHeader;
  55. - (NSDictionary *)generateMtopBody;
  56. //重试通知, 如果有需要在这里修改内部数据 ,否则不用管,retryCount是第几次(1开始)
  57. //retryAction时,可以改变netType,这样重试的时候,可以改变通道方式.比如第一次用accs的,重发的时候用mtop
  58. - (void)retryAction:(NSUInteger)retryCount;
  59. //剔除sendPacke中自己已经在请求中部分.如果全部剔除完,返回YES,sendPacke会被丢弃(参考AMPBatchGetUserPacket)
  60. - (BOOL)filterNewPacket:(__kindof AlibcNetPacket *)sendPack;
  61. //等待队列,请求合并..合并待发送的包,返回YES,sendPacke会被丢弃
  62. - (BOOL)conbineWaitingPacket:(__kindof AlibcNetPacket *)sendPack;
  63. //打点逻辑,如果retry时每次都要打点,重载这个..一般的成功失败打点直接successAction,failAction里挂载打点即可..
  64. - (void)trackActionSuccess:(BOOL)isSuccess error:(AlibcNetError *)error duration:(double)durationMillisecond;
  65. //**********给子类用的辅助函数
  66. //是否有效,用户切换后则无效 .没事不要重载修改
  67. - (BOOL)isValued;
  68. - (BOOL)sendPacket;
  69. @end
  70. #endif