Tool.php 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463
  1. <?php
  2. namespace Agent\Lib;
  3. use Dever;
  4. class Tool
  5. {
  6. public function __construct()
  7. {
  8. Dever::load('manage/auth.init');
  9. }
  10. # 更换权益
  11. public function setGoods_api()
  12. {
  13. # 权益类型
  14. $type = Dever::input('type', 1);
  15. # 权益类型id
  16. $type_id = Dever::input('type_id', 1);
  17. # 替换的权益类型
  18. $set_type = Dever::input('set_type', 1);
  19. # 替换权益类型id
  20. $set_type_id = Dever::input('set_type_id', 1);
  21. $mid = Dever::input('mid');
  22. $where['type'] = $type;
  23. $where['type_id'] = $type_id;
  24. if ($mid) {
  25. $where['mid'] = $mid;
  26. }
  27. $data = Dever::db('agent/member_goods')->getAll($where);
  28. if ($data) {
  29. $desc = '更换权益';
  30. foreach ($data as $k => $v) {
  31. if ($v['num'] > 0) {
  32. # 生成新的权益
  33. $mid = $v['mid'];
  34. $total = $v['num'];
  35. $w = array();
  36. $w['type'] = $set_type;
  37. $w['type_id'] = $set_type_id;
  38. $w['sku_id'] = -1;
  39. $w['mid'] = $v['mid'];
  40. $w['clear'] = true;
  41. $cash = $price = 0;
  42. if ($set_type == 1) {
  43. $goods_info = Dever::load('goods/lib/info')->getInfoBySku($w['type_id'], $w['sku_id']);
  44. $price = $goods_info['price'];
  45. $cash = $goods_info['price'] * $total;
  46. if (isset($goods_info['sku'])) {
  47. $sku = '-' . $goods_info['sku']['string'];
  48. } else {
  49. $sku = '';
  50. }
  51. $name = $goods_info['name'] . $sku;
  52. } elseif ($set_type == 2) {
  53. # 体验卡
  54. $card = Dever::db('card/info')->find($w['type_id']);
  55. if (!$card) {
  56. continue;
  57. }
  58. $name = $card['name'];
  59. if ($card['create_type'] == 2) {
  60. $cash = $price = $card['value'] * $total;
  61. $total = 1;
  62. $w['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $mid, -1, $cash);
  63. if (!$w['sku_id']) {
  64. continue;
  65. }
  66. } else {
  67. if ($card['create_type'] == 3 && isset($v['price']) && $v['price'] > 0) {
  68. $card['value'] = $v['price'];
  69. }
  70. $cash = $price = $card['value'];
  71. for($i=0; $i<$total;$i++) {
  72. $w['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $mid, -1, $cash);
  73. if ($w['sku_id']) {
  74. $w['total_num'] = 1;
  75. $w['cash'] = $cash;
  76. $w['price'] = $price;
  77. $w['name'] = $name;
  78. $state = Dever::db('agent/member_goods')->insert($w);
  79. if ($state) {
  80. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], 1, 0, 1, $name, $desc);
  81. }
  82. }
  83. }
  84. Dever::db('agent/member_goods')->update(array('where_id' => $v['id'], 'state' => 2));
  85. $name = $v['name'] ? $v['name'] : Dever::load("agent/lib/manage.getGoods#name", $v['type'], $v['type_id'], $v['sku_id']);
  86. Dever::load('agent/lib/member_set')->log($v['mid'], '', $v['type'], $v['type_id'], $v['sku_id'], -1*$v['num'], $v['num'], 0, $name, '[系统删除]');
  87. continue;
  88. }
  89. } elseif ($set_type == 3) {
  90. $prize = Dever::db('setting/prize')->find($w['type_id']);
  91. $price = $prize['price'];
  92. $cash = $prize['price'] * $total;
  93. $name = $prize['name'];
  94. }
  95. $info = Dever::db('agent/member_goods')->one($w);
  96. $w['total_num'] = $total;
  97. $w['cash'] = $cash;
  98. $w['price'] = $price;
  99. $w['name'] = $name;
  100. if (!$info) {
  101. $state = Dever::db('agent/member_goods')->insert($w);
  102. if ($state) {
  103. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $total, 0, $w['total_num'], $name, $desc);
  104. }
  105. } else {
  106. $w['total_num'] += $info['sell_num'];
  107. $w['where_id'] = $info['id'];
  108. $w['state'] = 1;
  109. $state = Dever::db('agent/member_goods')->update($w);
  110. $num = $w['total_num']-$info['total_num'];
  111. if ($state && $num != 0) {
  112. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $num, $info['total_num'], $w['total_num'], $name, $desc);
  113. }
  114. }
  115. Dever::db('agent/member_goods')->update(array('where_id' => $v['id'], 'state' => 2));
  116. $name = $v['name'] ? $v['name'] : Dever::load("agent/lib/manage.getGoods#name", $v['type'], $v['type_id'], $v['sku_id']);
  117. Dever::load('agent/lib/member_set')->log($v['mid'], '', $v['type'], $v['type_id'], $v['sku_id'], -1*$v['num'], $v['num'], 0, $name, '[系统删除]');
  118. }
  119. }
  120. }
  121. return 'ok';
  122. }
  123. # 取消代理区域
  124. public function area_api()
  125. {
  126. $test = Dever::input('test');
  127. $mobile = '18530054871,16605286862,18603236913,18267572300,17339190899,13302105400,15392667687,15535102666,13070153282,15311806333,18562581185,13733182976,13903405064,13593186699,15835600655,13474801073,13968955672,13269293070,19905895812,18758763808,13587727119,13732008755,18833970950,15258885602,13653566218,18233577755,18103359826,13127066008,15311620979,13930976511,13345678902,15940583331,13039838326,17390633673,13701363729,15863077599,13906483281,18311405976,15686412913,15810225848,13693396201,13182546876,18612793519,18614233834,13521993918,18513595858,13522952687,15699998313,13901300871,13552581319,18611800266,13925311308,13761550119,18611413455,18911648247,18920105885,18303130831,18653382233,18896315717,18635500023,18147163713,18653393378,15381751155,18329008565,13398689683,13520576733,13811440645,18324207877,18267887877,15383860716,13903556488,18071026836,13910975422,18510243728,13698667092,15600283143,13601287566,13381052675,13691483981,13935550019,18653248558,13311108964,18535588333,17703641798,19832665255,13654500007,13835634365,18730869116,15101189418,13404729300,17543809562,13701031362,15110027725,18618339730,18911552718,13911004319,18663921509,13501101775,13522819239,13701292198,15048416210';
  128. $mobile = explode(',', $mobile);
  129. foreach ($mobile as $k => $v) {
  130. $member = Dever::db('agent/member')->find(array('mobile' => $v));
  131. if ($member && $member['area']) {
  132. Dever::db('agent/member')->update(array('where_id' => $member['id'], 'set_area' => 'null'));
  133. $area = Dever::db('agent/member_area')->find(array('mid' => $member['id'], 'area' => $member['area']));
  134. if ($area) {
  135. $role = Dever::db('setting/role')->find($member['role']);
  136. if ($role['type'] == 2) {
  137. Dever::db('agent/member_area')->update(array('where_id' => $area['id'], 'state' => 2));
  138. if ($role['area'] == 2) {
  139. # 区县
  140. $area['area'] = explode(',', $area['area']);
  141. if (isset($area['area'][2])) {
  142. $info = Dever::db('area/county')->find($area['area'][2]);
  143. if ($info) {
  144. Dever::db('area/county')->update(array('where_id' => $info['id'], 'status' => 1));
  145. }
  146. }
  147. } elseif ($role['area'] == 3) {
  148. # 街道
  149. $area['area'] = explode(',', $area['area']);
  150. if (isset($area['area'][3])) {
  151. $info = Dever::db('area/town')->find($area['area'][3]);
  152. if ($info) {
  153. Dever::db('area/town')->update(array('where_id' => $info['id'], 'status' => 1));
  154. }
  155. }
  156. }
  157. }
  158. }
  159. }
  160. }
  161. return 'ok';
  162. }
  163. # 清理已经发放的礼品卡
  164. public function delcard_api()
  165. {
  166. $mobile = '18686032888,13505877257,15389816039,18963514040,13701398869,13995284681,18035269709,15906403868,13819150072,13707879708,15010031036,13426388637,18010413226,15903121007,13806542331,13121372131,18978913842,13314784666,15968782828,15306356510,18932836531,13858571516,17301053918,13513082066,13501208132,19548950377,13757703050,13706775618,13604704911,13480478948,18048392626,18730903308,15930256609,18042108978,13261761736,15988701547,19910329911,15712843384,13206630972,16619866672,13651396081,13121187907,13501125380,13311001230,18123659695,15705797947,13977049319,13833954079,18351721593,13703202291,13311361478,15867731102,13716237788,13331025856,18612741793,13337185814,17743596029,17367180051,13716024983,13674755670';
  167. $mobile = explode(',', $mobile);
  168. foreach ($mobile as $k => $v) {
  169. $member = Dever::db('agent/member')->find(array('mobile' => $v));
  170. if ($member) {
  171. $goods = Dever::db('agent/member_goods')->getAll(array('mid' => $member['id']));
  172. if ($goods) {
  173. foreach ($goods as $k1 => $v1) {
  174. if ($v1['type'] == 2 && $v1['sku_id'] > 0) {
  175. $code = Dever::db('card/code')->find($v1['sku_id']);
  176. if ($code) {
  177. Dever::db('card/code')->update(array('where_id' => $code['id'], 'state' => 2));
  178. Dever::db('agent/member_goods')->update(array('where_id' => $v1['id'], 'state' => 2));
  179. $name = $v1['name'] ? $v1['name'] : Dever::load("agent/lib/manage.getGoods#name", $v1['type'], $v1['type_id'], $v1['sku_id']);
  180. Dever::load('agent/lib/member_set')->log($v1['mid'], '', $v1['type'], $v1['type_id'], $v1['sku_id'], -1*$v1['num'], $v1['num'], 0, $name, '[系统删除]');
  181. }
  182. }
  183. }
  184. }
  185. }
  186. }
  187. return 'ok';
  188. }
  189. # 发放礼品卡 从客满云来的
  190. public function pushcard_api()
  191. {
  192. $mobile = '13896716319|396.5,13354896599|799,13896714411|799,13964467368|799,17857041943|799,13904713949|799,13948128992|799,15023905779|711.3,15831605511|799,15924411773|799,13384713795|799,18696719568|456.6,13609468556|514.2,13996764705|136.54,13057922789|2214,13626430903|799,13811412976|799,17311333929|799,18280086198|264.4,17358503715|273.2,13606755900|799,18368852657|799,13853387568|32.9,17702360918|458.74,13998415597|799,15925878191|799,18053357079|799,17369603422|799,15542344331|799,13644277557|799,18523625865|373.2,15661053408|799,13801381206|799,13309866562|799,18642899311|676,13478542548|809,13308259951|799,18004285088|799,13132353939|979.9,13250885707|799,13904281296|799,13132363123|7.78,15810156842|376.3,13996753098|1287.54,13656522922|799,13309841160|799,13621243273|448.6,13008063508|344,13387871873|730.7,15524845373|799,15542414113|799,13245473269|560.5,13816374828|799,13001739273|698.3,13607801107|1598,13817487679|799,15734111277|799,15524652835|799,13661664667|799,13939292227|799,13581983958|799,13918552843|799,13071197982|203.1,13848118039|1,13644241151|799,13812853977|76.3,18862460056|13.4,13913660726|41.4,15851602369|10.4,18540345578|14.9,13644968293|200,15940848432|806.1,15391122046|201.7,13426388637|1000,16726766313|30.6,13591777189|8.6,18751168759|200,13801569738|200,13889676999|400,13591103339|200,13352291520|200,13050576828|6.8,13478755955|0.4,13327128187|0.6,17704881758|1207.8,13962250709|135.3,18247161616|26.34,15397618175|2.7,19804717968|456.3,15734189938|500,15158761331|10,15928573979|2.3,18614289414|100.8,15393565789|112.8,17703451471|174.94,13587632081|200,13084728781|2000,18104856142|98';
  193. //$mobile = '15098236683|100.3,15098236682|220.4,15098236681|33';
  194. $mobile = explode(',', $mobile);
  195. $yes = array();
  196. $error = array();
  197. $no = array();
  198. $card_id = Dever::input('card', 8);
  199. $total = 1;
  200. $desc = '新增权益';
  201. foreach ($mobile as $k => $v) {
  202. $temp = explode('|', $v);
  203. $v = $temp[0];
  204. $cash = $temp[1];
  205. $member = Dever::db('agent/member')->find(array('mobile' => $v));
  206. if ($member) {
  207. $yes[] = $v;
  208. $mid = $member['id'];
  209. $goods = Dever::db('agent/member_goods')->find(array('mid' => $member['id'], 'type' => 2, 'type_id' => $card_id));
  210. if (!$goods) {
  211. $w = array();
  212. $w['type'] = 2;
  213. $w['type_id'] = $card_id;
  214. $w['sku_id'] = -1;
  215. $w['mid'] = $mid;
  216. $w['clear'] = true;
  217. # 体验卡
  218. $card = Dever::db('card/info')->find($card_id);
  219. if (!$card) {
  220. $error[] = $v;
  221. continue;
  222. }
  223. $name = $card['name'];
  224. $w['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $mid, -1, $cash);
  225. if (!$w['sku_id']) {
  226. $error[] = $v;
  227. continue;
  228. }
  229. $info = Dever::db('agent/member_goods')->one($w);
  230. $w['total_num'] = $total;
  231. $w['cash'] = $cash;
  232. $w['price'] = $cash;
  233. $w['name'] = $name;
  234. if (!$info) {
  235. $state = Dever::db('agent/member_goods')->insert($w);
  236. if ($state) {
  237. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $total, 0, $w['total_num'], $name, $desc);
  238. }
  239. } else {
  240. $w['total_num'] += $info['sell_num'];
  241. $w['where_id'] = $info['id'];
  242. $w['state'] = 1;
  243. $state = Dever::db('agent/member_goods')->update($w);
  244. $num = $w['total_num']-$info['total_num'];
  245. if ($state && $num != 0) {
  246. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $num, $info['total_num'], $w['total_num'], $name, $desc);
  247. }
  248. }
  249. }
  250. } else {
  251. $no[] = $v;
  252. }
  253. }
  254. return array($yes, $error, $no);
  255. }
  256. # 发放礼品卡,从旧系统来的
  257. public function pushcard_old_api()
  258. {
  259. Dever::config('base')->hook = true;
  260. include('/share/lib/php/dever_package/excel/src/PHPExcel.php');
  261. $file = '/www/churen/data/oldcard.xlsx';
  262. $num = Dever::input('num', 0);
  263. $data = Dever::excelImport($file, $num, 5, 'excel');
  264. if ($data) {
  265. if ($num <= 1) {
  266. foreach ($data as $k => $v) {
  267. if ($k > 0 && isset($v['B']) && $v['B']) {
  268. $mobile = $v['B'];
  269. $member = Dever::db('agent/member')->find(array('mobile' => $mobile));
  270. if ($member) {
  271. $type_id = $v['D'];
  272. if ($type_id) {
  273. $type = 1;
  274. } else {
  275. $type = 2;
  276. }
  277. $name = $v['C'];
  278. $time = Dever::maketime($v['E']);
  279. $this->createGoods($member, 1, $type, $type_id, -1, $time, $name);
  280. }
  281. }
  282. }
  283. }
  284. if ($num == 2) {
  285. foreach ($data as $k => $v) {
  286. if ($k > 0 && isset($v['A']) && $v['A']) {
  287. $mobile = $v['A'];
  288. $member = Dever::db('agent/member')->find(array('mobile' => $mobile));
  289. if ($member) {
  290. $type = 2;
  291. $type_id = 2;
  292. $name = '199面值';
  293. $price = $v['E'];
  294. $time = Dever::maketime($v['C']);
  295. $this->createGoods($member, 1, $type, $type_id, -1, $time, $name, $price);
  296. }
  297. }
  298. }
  299. }
  300. if ($num == 3) {
  301. foreach ($data as $k => $v) {
  302. if ($k > 0 && isset($v['B']) && $v['B']) {
  303. $mobile = $v['B'];
  304. $member = Dever::db('agent/member')->find(array('mobile' => $mobile));
  305. if ($member) {
  306. $type = 2;
  307. $type_id = 4;
  308. $name = '1299面值';
  309. $price = $v['D'];
  310. $time = Dever::maketime($v['E']);
  311. $this->createGoods($member, 1, $type, $type_id, -1, $time, $name, $price);
  312. }
  313. }
  314. }
  315. }
  316. }
  317. return 'ok';
  318. }
  319. # 生成权益
  320. private function createGoods($member, $num, $type, $type_id, $sku_id, $time = '', $name = '', $price = 0)
  321. {
  322. # 生成新的权益
  323. $desc = '发放权益';
  324. $mid = $member['id'];
  325. $total = $num;
  326. $w = array();
  327. $w['type'] = $type;
  328. if ($type == 2) {
  329. if ($name == '厨人易料菜品通用卡(799面值)') {
  330. $type_id = 3;
  331. }
  332. if ($name == '厨人易料菜品通用卡(999面值)') {
  333. $type_id = 7;
  334. }
  335. if ($name == '199面值') {
  336. $type_id = 2;
  337. }
  338. if ($name == '1299面值') {
  339. $type_id = 4;
  340. }
  341. }
  342. $w['type_id'] = $type_id;
  343. $w['sku_id'] = $sku_id;
  344. $w['mid'] = $mid;
  345. $w['clear'] = true;
  346. $cash = $price = 0;
  347. if ($type == 1) {
  348. $goods_info = Dever::load('goods/lib/info')->getInfoBySku($w['type_id'], $w['sku_id']);
  349. $price = $goods_info['price'];
  350. $cash = $goods_info['price'] * $total;
  351. if (isset($goods_info['sku'])) {
  352. $sku = '-' . $goods_info['sku']['string'];
  353. } else {
  354. $sku = '';
  355. }
  356. $name = $goods_info['name'] . $sku;
  357. } elseif ($type == 2) {
  358. # 体验卡
  359. $card = Dever::db('card/info')->find($w['type_id']);
  360. if (!$card) {
  361. return;
  362. }
  363. if ($price > 0) {
  364. $card['value'] = $price;
  365. }
  366. $name = $card['name'];
  367. if ($card['create_type'] == 2) {
  368. $cash = $price = $card['value'] * $total;
  369. $total = 1;
  370. $w['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $mid, -1, $cash, $time);
  371. if (!$w['sku_id']) {
  372. return;
  373. }
  374. } else {
  375. $cash = $price = $card['value'];
  376. for($i=0; $i<$total;$i++) {
  377. $w['sku_id'] = Dever::load('card/lib/code')->create($card, 2, $mid, -1, $cash, $time);
  378. if ($w['sku_id']) {
  379. $w['total_num'] = 1;
  380. $w['cash'] = $cash;
  381. $w['price'] = $price;
  382. $w['name'] = $name;
  383. $w['cdate'] = $time;
  384. $state = Dever::db('agent/member_goods')->insert($w);
  385. if ($state) {
  386. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], 1, 0, 1, $name, $desc);
  387. }
  388. }
  389. }
  390. return;
  391. }
  392. } elseif ($type == 3) {
  393. $prize = Dever::db('setting/prize')->find($w['type_id']);
  394. $price = $prize['price'];
  395. $cash = $prize['price'] * $total;
  396. $name = $prize['name'];
  397. }
  398. $info = Dever::db('agent/member_goods')->one($w);
  399. $w['total_num'] = $total;
  400. $w['cash'] = $cash;
  401. $w['price'] = $price;
  402. $w['name'] = $name;
  403. $w['cdate'] = $time;
  404. if (!$info) {
  405. $state = Dever::db('agent/member_goods')->insert($w);
  406. if ($state) {
  407. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $total, 0, $w['total_num'], $name, $desc);
  408. }
  409. } else {
  410. $w['total_num'] += $info['total_num'];
  411. $w['where_id'] = $info['id'];
  412. $w['state'] = 1;
  413. $state = Dever::db('agent/member_goods')->update($w);
  414. $num = $w['total_num']-$info['total_num'];
  415. if ($state && $num != 0) {
  416. Dever::load('agent/lib/member_set')->log($w['mid'], '', $w['type'], $w['type_id'], $w['sku_id'], $num, $info['total_num'], $w['total_num'], $name, $desc);
  417. }
  418. }
  419. }
  420. }