Tool.php 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215
  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. }