Center.php 65 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512
  1. <?php
  2. namespace app\data\controller\api\auth;
  3. use app\data\controller\api\Auth;
  4. use app\data\controller\api\Data;
  5. use app\data\model\BaseUserMessage;
  6. use app\data\model\BaseUserMessageRead;
  7. use app\data\model\BaseUserPayment;
  8. use app\data\model\BaseUserUpgrade;
  9. use app\data\model\DataBestKnowledge;
  10. use app\data\model\DataCollectionLog;
  11. use app\data\model\DataFeedback;
  12. use app\data\model\DataMaintenance;
  13. use app\data\model\DataMerchants;
  14. use app\data\model\DataPoolTalent;
  15. use app\data\model\DataPoolTalentChild;
  16. use app\data\model\DataShipyard;
  17. use app\data\model\DataTeachingKnowledge;
  18. use app\data\model\DataUser;
  19. use app\data\model\DataUserAcceptance;
  20. use app\data\model\DataUserApplyJobInfo;
  21. use app\data\model\DataUserApplyJobInfoChild;
  22. use app\data\model\DataUserBankCard;
  23. use app\data\model\DataUserLeaveMessage;
  24. use app\data\model\DataUserMoneyLog;
  25. use app\data\model\DataUserPurchaseAcceptance;
  26. use app\data\model\DataUserRepair;
  27. use app\data\model\DataUserRepairOffer;
  28. use app\data\model\DataUserVipOrder;
  29. use app\data\model\DataUserWithdraw;
  30. use app\data\model\DataZhicheng;
  31. use app\data\model\ShopCoordination;
  32. use app\data\model\ShopFavourite;
  33. use app\data\model\ShopOcean;
  34. use app\data\model\ShopProduction;
  35. use app\data\model\ShopPurchase;
  36. use app\data\service\payment\WechatPaymentService;
  37. use app\data\service\PaymentService;
  38. use app\data\service\UserAdminService;
  39. use app\data\service\UserUpgradeService;
  40. use think\admin\Storage;
  41. use think\db\Query;
  42. use think\exception\HttpResponseException;
  43. use think\admin\Controller;
  44. use hg\apidoc\annotation\Title;
  45. use hg\apidoc\annotation\Method;
  46. use hg\apidoc\annotation\Param;
  47. use hg\apidoc\annotation\Header;
  48. use hg\apidoc\annotation\Returned;
  49. use think\facade\Db;
  50. use think\facade\Validate;
  51. use WePay\Order;
  52. /**
  53. * @Title("个人中心")
  54. */
  55. class Center extends Auth
  56. {
  57. protected $noNeedLogin=['upload','image','uploadmore'];
  58. /**
  59. * @Title("获取用户资料")
  60. * @Method("post")
  61. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  62. * @Header("api-token",type="string",require=1,default="",desc="token")
  63. * @Returned("token.token",desc="token")
  64. * @Returned("pooltalent",desc="提交的人才库信息,为空则未提交")
  65. * @Returned("pooltalent.audit",desc="人才库审核状态1:待审核 2:审核通过 3:审核不通过")
  66. * @Returned("pooltalent.why",desc="人才库审核不通过原因")
  67. * @Returned("maintenance",desc="提交的维修工申请,为空则未提交")
  68. * @Returned("maintenance.audit",desc="维修工申请审核状态1:待审核 2:审核通过 3:审核不通过")
  69. * @Returned("maintenance.why",desc="维修工申请审核不通过原因")
  70. * @Returned("shipyard",desc="提交的入驻船厂申请,为空则未提交")
  71. * @Returned("shipyard.audit",desc="入驻船厂申请审核状态1:待审核 2:审核通过 3:审核不通过")
  72. * @Returned("shipyard.why",desc="入驻船厂申请审核不通过原因")
  73. * @Returned("merchants",desc="提交的入驻商家申请,为空则未提交")
  74. * @Returned("merchants.audit",desc="入驻商家申请审核状态1:待审核 2:审核通过 3:审核不通过")
  75. * @Returned("merchants.why",desc="入驻商家申请审核不通过原因")
  76. * @Returned("collection_count",desc="收藏数量")
  77. */
  78. public function get()
  79. {
  80. $user = $this->getUser();
  81. $user['collection_count'] = DataCollectionLog::mk()->where('uuid',$this->uuid)->where('cate',1)->whereNotIn('type',[3,4])->count();
  82. $this->success('获取用户资料', $user);
  83. }
  84. /**
  85. * @Title("平台规则")
  86. * @Method("post")
  87. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  88. * @Header("api-token",type="string",require=1,default="",desc="token")
  89. *
  90. * @Returned("platform_rules",desc="平台规则")
  91. */
  92. public function getplatformrules(){
  93. $info= [
  94. 'platform_rules'=>sysconf('platform.platform_rules'),
  95. ];
  96. $this->success('成功',$info);
  97. }
  98. /**
  99. * @Title("Base64图片上传")
  100. * @Method("post")
  101. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  102. * @Header("api-token",type="string",require=0,default="",desc="token")
  103. * @Returned("url",desc="图片地址")
  104. */
  105. public function image()
  106. {
  107. try {
  108. $data = $this->_vali(['base64.require' => '图片内容不为空!']);
  109. if (preg_match($preg = '|^data:image/(.*?);base64,|i', $data['base64'])) {
  110. [$ext, $img] = explode('|||', preg_replace($preg, '$1|||', $data['base64']));
  111. if (empty($ext) || !in_array(strtolower($ext), ['png', 'jpg', 'jpeg'])) {
  112. $this->error('图片格式异常!');
  113. }
  114. $name = Storage::name($img, $ext, 'image/');
  115. $info = Storage::instance()->set($name, base64_decode($img));
  116. $this->success('图片上传成功!', ['url' => $info['url']]);
  117. } else {
  118. $this->error('解析内容失败!');
  119. }
  120. } catch (HttpResponseException $exception) {
  121. throw $exception;
  122. } catch (\Exception $exception) {
  123. trace_file($exception);
  124. $this->error($exception->getMessage());
  125. }
  126. }
  127. /**
  128. * @Title("二进制图片、文件上传")
  129. * @Method("post")
  130. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  131. * @Header("api-token",type="string",require=0,default="",desc="token")
  132. * @Param("file",type="file",require=1,default="",desc="文件")
  133. * @Returned("url",desc="图片地址")
  134. */
  135. public function upload()
  136. {
  137. ini_set ("memory_limit","-1");
  138. $file = $this->request->file('file');
  139. if (empty($file)) $this->error('文件上传异常!');
  140. $extension = strtolower($file->getOriginalExtension());
  141. if (in_array($extension, ['php', 'sh'])) $this->error('禁止上传此类文件!');
  142. $bina = file_get_contents($file->getRealPath());
  143. $name = Storage::name($file->getPathname(), $extension, '', 'md5_file');
  144. $info = Storage::instance()->set($name, $bina, false, $file->getOriginalName());
  145. if (is_array($info) && isset($info['url'])) {
  146. $this->success('文件上传成功!', $info);
  147. } else {
  148. $this->error('文件上传失败!');
  149. }
  150. }
  151. /**
  152. * @Title("二进制图片、文件上传多个")
  153. * @Method("post")
  154. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  155. * @Header("api-token",type="string",require=0,default="",desc="token")
  156. * @Param("file[]",type="file",require=1,default="",desc="文件")
  157. * @Returned("url",desc="图片地址")
  158. */
  159. public function uploadmore()
  160. {
  161. ini_set ("memory_limit","-1");
  162. $file = $this->request->file('file');
  163. if (empty($file)) $this->error('文件上传异常!');
  164. $array = [];
  165. foreach ($file as $file){
  166. $extension = strtolower($file->getOriginalExtension());
  167. if (in_array($extension, ['php', 'sh'])) $this->error('禁止上传此类文件!');
  168. $bina = file_get_contents($file->getRealPath());
  169. $name = Storage::name($file->getPathname(), $extension, '', 'md5_file');
  170. $info = Storage::instance()->set($name, $bina, false, $file->getOriginalName());
  171. array_push($array,$info);
  172. }
  173. $this->success('文件上传成功!', $array);
  174. }
  175. /**
  176. * @Title("更新用户资料")
  177. * @Method("post")
  178. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  179. * @Header("api-token",type="string",require=1,default="",desc="token")
  180. * @Param("headimg",type="string",require=0,default="",desc="头像")
  181. * @Param("nickname",type="string",require=0,default="",desc="昵称")
  182. * @Param("email",type="string",require=0,default="",desc="邮箱")
  183. * @Param("base_sex",type="string",require=0,default="",desc="性别")
  184. */
  185. public function set()
  186. {
  187. $data = $this->_vali([
  188. 'headimg.default' => '',
  189. 'nickname.default' => '',
  190. 'email.default' => '',
  191. 'base_sex.default' => '',
  192. ]);
  193. foreach ($data as $key => $vo) if ($vo === '') unset($data[$key]);
  194. if (empty($data)) $this->error('没有修改的数据!');
  195. if (DataUser::mk()->where(['id' => $this->uuid])->update($data) !== false) {
  196. $this->success('更新资料成功!', $this->getUser());
  197. } else {
  198. $this->error('更新资料失败!');
  199. }
  200. }
  201. /**
  202. * @Title("修改密码")
  203. * @Method("post")
  204. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  205. * @Header("api-token",type="string",require=1,default="",desc="token")
  206. * @Param("password",type="string",require=0,default="",desc="原密码")
  207. * @Param("newpassword",type="string",require=0,default="",desc="新密码")
  208. */
  209. public function uppass()
  210. {
  211. $data = $this->_vali([
  212. 'password.require'=>'原密码必须',
  213. 'newpassword.require'=>'新密码必须'
  214. ]);
  215. if ($data['password']==$data['newpassword']) $this->error('原密码与新密码一样');
  216. $pass = DataUser::mk()->where('id',$this->uuid)->value('password');
  217. if (md5($data['password'])!=$pass) $this->error('原密码验证错误');
  218. if (DataUser::mk()->where(['id' => $this->uuid])->update(['password'=>md5($data['newpassword'])]) !== false) {
  219. $this->success('更新密码成功!', $this->getUser());
  220. } else {
  221. $this->error('更新密码失败!');
  222. }
  223. }
  224. /**
  225. * @Title("获取开通vip配置信息")
  226. * @Method("post")
  227. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  228. * @Header("api-token",type="string",require=1,default="",desc="token")
  229. *
  230. * @Returned("price",desc="价格")
  231. * @Returned("user_vip_des",desc="会员权益说明")
  232. * @Returned("user_vip_agreement",desc="会员服务协议")
  233. */
  234. public function getvipinfo(){
  235. $info= [
  236. 'price'=>sysconf('user_vip.price'),
  237. 'user_vip_des'=>sysconf('user_vip.user_vip_des'),
  238. 'user_vip_agreement'=>sysconf('user_vip.user_vip_agreement'),
  239. ];
  240. $this->success('成功',$info);
  241. }
  242. /**
  243. * @Title("获取支付方式")
  244. * @Method("post")
  245. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  246. * @Header("api-token",type="string",require=1,default="",desc="token")
  247. *
  248. * @Param("type",type="string",require=1,default="",desc="1:开通会员vip 2:商城、充值")
  249. * @Param("from",type="string",require=1,default="",desc="1:微信小程序 2:APP")
  250. */
  251. public function channel()
  252. {
  253. $data = $this->_vali([
  254. 'type.require|in:1,2'=>'type有误',
  255. 'from.require|in:1,2'=>'来源有误'
  256. ]);
  257. $type = $data['type'];
  258. $from = $data['from'];
  259. // 读取支付通道配置
  260. $query = BaseUserPayment::mk()->where(['status' => 1, 'deleted' => 0])
  261. ->when($type,function ($query) use ($type){
  262. if ($type==2){
  263. $query->where('type','<>','balance');
  264. }
  265. })->where(function ($query) use ($from){
  266. if ($from==1){
  267. $query->whereNotIn('type',['wechat_app','alipay_app']);
  268. }else{
  269. $query->where('type','<>','wechat_xcx');
  270. }
  271. });
  272. //$query->whereIn('code', str2arr($payments))->whereIn('type', PaymentService::getTypeApi($this->type));
  273. $result = $query->order('sort desc,id desc')->column('type,code,name,cover,content,remark', 'code');
  274. foreach ($result as &$vo) $vo['content'] = ['voucher_qrcode' => json_decode($vo['content'])->voucher_qrcode ?? ''];
  275. $this->success('获取支付参数数据', array_values($result));
  276. }
  277. /**
  278. * @Title("开通会员")
  279. * @Method("post")
  280. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  281. * @Header("api-token",type="string",require=1,default="",desc="token")
  282. * @Param("pay_code",type="string",require=1,default="",desc="支付方式code")
  283. * @Param("difference_pay_code",type="string",require=0,default="",desc="余额支付时,差价支付方式code")
  284. *
  285. */
  286. public function openvip(){
  287. $user = $this->getUser();
  288. $data = $this->_vali([
  289. 'pay_code.require'=>'支付code有误',
  290. 'difference_pay_code.default'=>''
  291. ]);
  292. $code = $data['pay_code'];
  293. $difference_pay_code = $data['difference_pay_code'];
  294. $pay_type = BaseUserPayment::mk()->where(['status' => 1, 'deleted' => 0,'code'=>$code])->value('type') ? : $this->error('支付找不到');
  295. $all_price = sysconf('user_vip.price');
  296. $order_no = setorderno($this->uuid);
  297. $insert = [
  298. 'uuid'=>$this->uuid,
  299. 'order_no'=>$order_no,
  300. 'all_price'=>$all_price,
  301. 'pay_type'=>$pay_type
  302. ];
  303. $error = 1;
  304. Db::startTrans();
  305. $retrun_data = [];
  306. try {
  307. if ($pay_type=='balance'){
  308. if ($user['money']<$all_price){
  309. if (empty($difference_pay_code) || !isset($difference_pay_code)){
  310. $error = 0;
  311. $errorinfo = '差价支付方式错误';
  312. }else{
  313. $difference_pay_type = BaseUserPayment::mk()->where(['status' => 1, 'deleted' => 0,'code'=>$difference_pay_code])->value('type');
  314. if (!$difference_pay_type){
  315. $error = 0;
  316. $errorinfo = '差价支付找不到';
  317. }else{
  318. $all_price = bcsub($all_price,$user['money'],2);
  319. $insert['yue_price'] = $user['money'];
  320. $insert['difference_money'] = $all_price;
  321. $insert['difference_pay_type'] = $difference_pay_type;
  322. $code = $difference_pay_code;
  323. $pay_type = $difference_pay_type;
  324. }
  325. }
  326. }
  327. }
  328. $order_id = DataUserVipOrder::mk()->insertGetId($insert);
  329. if (stripos($pay_type, 'alipay_') === 0) {
  330. $notify_name = 'opvipzfb';
  331. } elseif (stripos($pay_type, 'wechat_') === 0) {
  332. $notify_name = 'opvipwx';
  333. } else{
  334. $notify_name = 'opvip';
  335. }
  336. $notify_url = sysuri("@data/api.notify/{$notify_name}/scene/order/param/{$code}", [], false, true);
  337. echo $notify_url;die;
  338. $parm = ['uuid'=>$this->uuid,'order_id'=>$order_id];
  339. $pay =PaymentService::instance($code)->create($user['openid1'],$order_no,$all_price,'开通vip','开通vip','','',$notify_url,$parm);
  340. $retrun_data['order_no'] = $order_no;
  341. $pay['packages'] = isset($pay['package']) ? $pay['package'] : '';
  342. $retrun_data['pay'] = $pay;
  343. $retrun_data['success'] = isset($pay['result']) && $pay['result']=='success' ? 1 : 0;
  344. Db::commit();
  345. } catch (\Exception $e) {
  346. dump($e);
  347. // 回滚事务
  348. Db::rollback();
  349. $error = 0;
  350. $errorinfo = '未知错误';
  351. }
  352. if ($error){
  353. $this->success('成功',$retrun_data);
  354. }
  355. $this->error($errorinfo);
  356. }
  357. /**
  358. * @Title("人才库职称列表")
  359. * @Method("post")
  360. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  361. * @Header("api-token",type="string",require=1,default="",desc="token")
  362. */
  363. public function zclist()
  364. {
  365. $list = DataZhicheng::Show()->select();
  366. $this->success('成功',$list);
  367. }
  368. /**
  369. * @Title("加入人才库/编辑人才库")
  370. * @Method("post")
  371. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  372. * @Header("api-token",type="string",require=1,default="",desc="token")
  373. * @Param("name",type="string",require=1,default="",desc="姓名")
  374. * @Param("sex",type="string",require=1,default="",desc="性别")
  375. * @Param("age",type="string",require=1,default="",desc="年龄")
  376. * @Param("jg",type="string",require=1,default="",desc="籍贯")
  377. * @Param("phone",type="string",require=1,default="",desc="手机号")
  378. * @Param("email",type="string",require=1,default="",desc="邮箱")
  379. * @Param("province",type="string",require=1,default="",desc="省")
  380. * @Param("city",type="string",require=1,default="",desc="市")
  381. * @Param("area",type="string",require=1,default="",desc="区/镇")
  382. * @Param("address",type="string",require=1,default="",desc="详细地址")
  383. * @Param("graduate_school",type="string",require=1,default="",desc="毕业院校")
  384. * @Param("xl",type="string",require=1,default="",desc="学历")
  385. * @Param("major",type="string",require=1,default="",desc="专业")
  386. * @Param("working_life",type="string",require=1,default="",desc="工作年限")
  387. * @Param("tc",type="string",require=1,default="",desc="特长")
  388. * @Param("jn",type="string",require=1,default="",desc="技能")
  389. * @Param("zc_id",type="string",require=1,default="",desc="职称ID")
  390. * @Param("zz_imgs",type="string",require=1,default="",desc="资质证书,多个以逗号隔开")
  391. * @Param("pxjl",type="string",require=1,default="",desc="培训经历")
  392. * @Param("id",type="string",require=0,default="",desc="审核失败,修改,则必传之前提交的ID")
  393. */
  394. public function adduppooltalent()
  395. {
  396. $data = $this->_vali([
  397. 'uuid.default'=>$this->uuid,
  398. 'name.require'=>'姓名必须',
  399. 'sex.require'=>'性别必须',
  400. 'age.require|number|between:1,120'=>'年龄必须,1-120',
  401. 'jg.require'=>'籍贯必须',
  402. 'phone.require'=>'手机号必须',
  403. 'email.require'=>'邮箱必须',
  404. 'province.require'=>'省必须',
  405. 'city.require'=>'市必须',
  406. 'area.require'=>'区/镇必须',
  407. 'address.require'=>'详细地址必须',
  408. 'graduate_school.require'=>'毕业院校必须',
  409. 'xl.require'=>'学历必须',
  410. 'working_life.require'=>'工作年限必须',
  411. 'major.require'=>'专业必须',
  412. 'tc.require'=>'特长必须',
  413. 'jn.require'=>'技能必须',
  414. 'zc_id.require|number'=>'职称必须',
  415. 'zz_imgs.require'=>'资质证书必须',
  416. 'pxjl.require'=>'培训经历必须',
  417. ],'post');
  418. $id = input('id');
  419. if (!Validate::regex($data['phone'], "^1\d{10}$")) {
  420. $this->error('手机号格式错误');
  421. }
  422. DataZhicheng::mk()->where('id',$data['zc_id'])->where('is_del',1)->count() ? : $this->error('职称不存在');
  423. empty($id) ? $id = DataUserAcceptance::mk()->where('uuid',$this->uuid)->value('id') : $data['update_at']=date('Y-m-d H:i:s');
  424. DataPoolTalent::mk()->where('uuid',$this->uuid)->value('audit') == 3 ? $data['audit'] =1 : '';
  425. if (empty($id) ? DataPoolTalent::mk()->insert($data) : DataPoolTalent::mk()->where('id',$id)->update($data)){
  426. $this->success('提交成功');
  427. }
  428. $this->error('提交失败,请稍后重试');
  429. }
  430. /**
  431. * @Title("添加人才库工作经历/编辑人才库工作经历")
  432. * @Method("post")
  433. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  434. * @Header("api-token",type="string",require=1,default="",desc="token")
  435. * @Param("id",type="string",require=1,default="",desc="工作经历ID,编辑时穿")
  436. * @Param("content",type="json",require=0,default="",desc="工作经历json,(company_name:公司名称,position_name:职位名称,on_job_start:在职时间开始,on_job_end:在职时间结束,job_description:工作内容)")
  437. */
  438. public function adduppooltalentchild()
  439. {
  440. $data = $this->_vali([
  441. 'id.default'=>'',
  442. 'content.require'=>'作经历必须',
  443. ]);
  444. $info_id = DataPoolTalent::mk()->where('uuid',$this->uuid)->value('id') ? : DataPoolTalent::mk()->insertGetId(['uuid'=>$this->uuid]);
  445. $child_id = $data['id'];
  446. $child_array = [
  447. 'info_id'=>$info_id,
  448. 'content'=>$data['content']
  449. ];
  450. !empty($child_id) ? $child_array['update_at'] = date('Y-m-d H:i:s') : '';
  451. if (!empty($child_id) ? DataPoolTalentChild::mk()->where('id',$child_id)->update($child_array) : DataPoolTalentChild::mk()->insert($child_array)){
  452. $this->success('成功');
  453. }
  454. $this->error('失败');
  455. }
  456. /**
  457. * @Title("人才库工作经历删除")
  458. * @Method("post")
  459. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  460. * @Header("api-token",type="string",require=1,default="",desc="token")
  461. * @Param("id",type="string",require=1,default="",desc="ID")
  462. */
  463. public function delpooltalentchild(){
  464. $data = $this->_vali([
  465. 'id.require'=>'id必须',
  466. ]);
  467. if (DataPoolTalentChild::mk()->where('id',$data['id'])->delete()){
  468. $this->success('成功');
  469. }
  470. $this->error('失败');
  471. }
  472. /**
  473. * @Title("申请维修工/编辑维修工")
  474. * @Method("post")
  475. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  476. * @Header("api-token",type="string",require=1,default="",desc="token")
  477. * @Param("name",type="string",require=1,default="",desc="姓名")
  478. * @Param("id_card",type="string",require=1,default="",desc="身份证号")
  479. * @Param("email",type="string",require=1,default="",desc="邮箱")
  480. * @Param("province",type="string",require=1,default="",desc="省")
  481. * @Param("city",type="string",require=1,default="",desc="市")
  482. * @Param("area",type="string",require=1,default="",desc="区/镇")
  483. * @Param("address",type="string",require=1,default="",desc="详细地址")
  484. * @Param("id_card_img1",type="string",require=1,default="",desc="身份证人面照片")
  485. * @Param("id_card_img2",type="string",require=1,default="",desc="身份证国徽面照片")
  486. * @Param("business_img",type="string",require=1,default="",desc="营业执照图片")
  487. * @Param("authorization_img",type="string",require=0,default="",desc="厂家授权图片")
  488. * @Param("results",type="string",require=1,default="",desc="以往业绩")
  489. * @Param("id",type="string",require=0,default="",desc="审核失败,修改,则必传之前提交的ID")
  490. */
  491. public function addupmaintenance()
  492. {
  493. $data = $this->_vali([
  494. 'uuid.default'=>$this->uuid,
  495. 'name.require'=>'姓名必须',
  496. 'id_card.require'=>'身份证号必须',
  497. 'email.require'=>'邮箱必须',
  498. 'province.require'=>'省必须',
  499. 'city.require'=>'市必须',
  500. 'area.require'=>'区/镇必须',
  501. 'address.require'=>'详细地址必须',
  502. 'id_card_img1.require'=>'身份证人面照片必须',
  503. 'id_card_img2.require'=>'身份证国徽面照片必须',
  504. 'business_img.require'=>'营业执照图片必须',
  505. 'authorization_img.default'=>'',
  506. 'results.require'=>'以往业绩必须',
  507. ]);
  508. if (!check_idcard($data['id_card'])) $this->error('身份证号格式错误');
  509. $id = input('id');
  510. !empty($id) ? : (DataMaintenance::mk()->where('uuid',$this->uuid)->count() ? $this->error('已经提交过') : '' );
  511. empty($id) ? : $data['update_at']=date('Y-m-d H:i:s');
  512. DataMaintenance::mk()->where('uuid',$this->uuid)->value('audit') == 3 ? $data['audit'] =1 : '';
  513. if (empty($id) ? DataMaintenance::mk()->insert($data) : DataMaintenance::mk()->where('id',$id)->update($data)){
  514. $this->success('提交成功');
  515. }
  516. $this->error('提交失败,请稍后重试');
  517. }
  518. /**
  519. * @Title("申请船厂/编辑船厂")
  520. * @Method("post")
  521. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  522. * @Header("api-token",type="string",require=1,default="",desc="token")
  523. * @Param("name",type="string",require=1,default="",desc="船厂名称")
  524. * @Param("head_img",type="string",require=1,default="",desc="船厂头像")
  525. * @Param("province",type="string",require=1,default="",desc="省")
  526. * @Param("city",type="string",require=1,default="",desc="市")
  527. * @Param("area",type="string",require=1,default="",desc="区/镇")
  528. * @Param("address",type="string",require=1,default="",desc="详细地址")
  529. * @Param("contact_name",type="string",require=1,default="",desc="联系人")
  530. * @Param("contact_phone",type="string",require=1,default="",desc="联系电话")
  531. * @Param("intro",type="string",require=1,default="",desc="船厂简介")
  532. * @Param("longitude",type="string",require=1,default="",desc="经度")
  533. * @Param("latitude",type="string",require=1,default="",desc="维度")
  534. * @Param("environment_imgs",type="string",require=1,default="",desc="船厂环境,多个以英文逗号隔开")
  535. * @Param("product_intro",type="string",require=1,default="",desc="产品简介")
  536. * @Param("business_img",type="string",require=1,default="",desc="营业执照")
  537. * @Param("num_staff",type="string",require=1,default="",desc="员工人数")
  538. * @Param("id",type="string",require=0,default="",desc="审核失败,修改,则必传之前提交的ID")
  539. */
  540. public function addupshipyard()
  541. {
  542. $data = $this->_vali([
  543. 'uuid.default'=>$this->uuid,
  544. 'name.require'=>'船厂名称必须',
  545. 'longitude.require'=>'经纬度必须',
  546. 'longitude.float'=>'经纬度有误',
  547. 'latitude.require'=>'经纬度必须',
  548. 'latitude.float'=>'经纬度有误',
  549. 'head_img.require'=>'船厂头像必须',
  550. 'province.require'=>'省必须',
  551. 'city.require'=>'市必须',
  552. 'area.require'=>'区/镇必须',
  553. 'address.require'=>'详细地址必须',
  554. 'contact_name.require'=>'联系人必须',
  555. 'contact_phone.require'=>'联系电话必须',
  556. 'intro.require'=>'船厂简介必须',
  557. 'environment_imgs.require'=>'船厂环境必须',
  558. 'product_intro.require'=>'产品简介必须',
  559. 'business_img.require'=>'营业执照必须',
  560. 'num_staff.require'=>'人数必须',
  561. ]);
  562. $id = input('id');
  563. !empty($id) ? : (DataShipyard::mk()->where('uuid',$this->uuid)->count() ? $this->error('已经提交过') : '' );
  564. empty($id) ? : $data['update_at']=date('Y-m-d H:i:s');
  565. DataShipyard::mk()->where('uuid',$this->uuid)->value('audit') == 3 ? $data['audit'] =1 : '';
  566. if (empty($id) ? DataShipyard::mk()->insert($data) : DataShipyard::mk()->where('id',$id)->update($data)){
  567. $this->success('提交成功');
  568. }
  569. $this->error('提交失败,请稍后重试');
  570. }
  571. /**
  572. * @Title("申请商家/编辑商家")
  573. * @Method("post")
  574. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  575. * @Header("api-token",type="string",require=1,default="",desc="token")
  576. * @Param("name",type="string",require=1,default="",desc="商家名称")
  577. * @Param("head_img",type="string",require=1,default="",desc="商家头像")
  578. * @Param("province",type="string",require=1,default="",desc="省")
  579. * @Param("city",type="string",require=1,default="",desc="市")
  580. * @Param("area",type="string",require=1,default="",desc="区/镇")
  581. * @Param("address",type="string",require=1,default="",desc="详细地址")
  582. * @Param("longitude",type="string",require=1,default="",desc="经度")
  583. * @Param("latitude",type="string",require=1,default="",desc="纬度")
  584. * @Param("address",type="string",require=1,default="",desc="详细地址")
  585. * @Param("contact_name",type="string",require=1,default="",desc="联系人")
  586. * @Param("contact_phone",type="string",require=1,default="",desc="联系电话")
  587. * @Param("intro",type="string",require=1,default="",desc="商家简介")
  588. * @Param("imgs_videos",type="string",require=1,default="",desc="图片及视频,以英文逗号隔开")
  589. * @Param("business_img",type="string",require=1,default="",desc="营业执照")
  590. * @Param("id",type="string",require=0,default="",desc="审核失败,修改,则必传之前提交的ID")
  591. */
  592. public function addupmerchants()
  593. {
  594. $data = $this->_vali([
  595. 'uuid.default'=>$this->uuid,
  596. 'name.require'=>'商家名称必须',
  597. 'head_img.require'=>'商家头像必须',
  598. 'province.require'=>'省必须',
  599. 'city.require'=>'市必须',
  600. 'area.require'=>'区/镇必须',
  601. 'address.require'=>'详细地址必须',
  602. 'longitude.require'=>'经纬度必须',
  603. 'latitude.require'=>'经纬度必须',
  604. 'contact_name.require'=>'联系人必须',
  605. 'contact_phone.require'=>'联系电话必须',
  606. 'intro.require'=>'商家简介必须',
  607. 'imgs_videos.require'=>'图片及视频必须',
  608. 'business_img.require'=>'营业执照必须',
  609. ]);
  610. $id = input('id');
  611. !empty($id) ? : (DataMerchants::mk()->where('uuid',$this->uuid)->count() ? $this->error('已经提交过') : '' );
  612. empty($id) ? : $data['update_at']=date('Y-m-d H:i:s');
  613. DataMerchants::mk()->where('uuid',$this->uuid)->value('audit') == 3 ? $data['audit'] =1 : '';
  614. if (empty($id) ? DataMerchants::mk()->insert($data) : DataMerchants::mk()->where('id',$id)->update($data)){
  615. $this->success('提交成功');
  616. }
  617. $this->error('提交失败,请稍后重试');
  618. }
  619. /**
  620. * @Title("实名认证")
  621. * @Method("post")
  622. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  623. * @Header("api-token",type="string",require=1,default="",desc="token")
  624. * @Param("username",type="string",require=1,default="",desc="真实姓名")
  625. * @Param("id_card",type="string",require=1,default="",desc="身份证号")
  626. */
  627. public function userCertification()
  628. {
  629. $user = $this->getUser();
  630. if ($user['is_auth']) $this->error('已实名认证');
  631. $data = $this->_vali([
  632. 'username.require'=>'真实姓名必须',
  633. 'id_card.require'=>'身份证号必须',
  634. 'is_auth.default'=>1
  635. ]);
  636. if (!isCreditNo($data['id_card'])) $this->error('身份证号格式错误');
  637. DataUser::mk()->where('id_card',$data['id_card'])->count() ? $this->error('身份证号已认证过') : '';
  638. $data['real_name']=$data['username'];
  639. unset($data['username']);
  640. if (DataUser::mk()->where(['id' => $this->uuid])->update($data) !== false) {
  641. $this->success('实名认证成功!');
  642. } else {
  643. $this->error('实名认证失败!');
  644. }
  645. }
  646. /**
  647. * @Title("钱包-我的余额")
  648. * @Method("post")
  649. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  650. * @Header("api-token",type="string",require=1,default="",desc="token")
  651. */
  652. public function moneylog(){
  653. $user = $this->getUser();
  654. $list = DataUserMoneyLog::Show($this->uuid)->paginate();
  655. $money = $user['money'];
  656. $bank_count = DataUserBankCard::Show($this->uuid)->count();
  657. $this->success('成功',compact('money','bank_count','list'));
  658. }
  659. /**
  660. * @Title("钱包-我的银行卡列表")
  661. * @Method("post")
  662. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  663. * @Header("api-token",type="string",require=1,default="",desc="token")
  664. */
  665. public function mybanklist(){
  666. $list = DataUserBankCard::Show($this->uuid)->select();
  667. $this->success('成功',$list);
  668. }
  669. /**
  670. * @Title("绑定银行卡")
  671. * @Method("post")
  672. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  673. * @Header("api-token",type="string",require=1,default="",desc="token")
  674. * @Param("name",type="string",require=1,default="",desc="姓名")
  675. * @Param("id_card",type="string",require=1,default="",desc="银行卡号")
  676. * @Param("id",type="string",require=0,default="",desc="修改,则必传之前提交的ID")
  677. */
  678. public function bind_bank(){
  679. $data = $this->_vali([
  680. 'uuid'=>$this->uuid,
  681. 'name.require'=>'姓名必须',
  682. 'id_card.require'=>'卡号必须',
  683. ]);
  684. !checkbank($data['id_card']) ? $this->error('卡号不正确') : '';
  685. $bank_name = bankInfo($data['id_card']);
  686. empty($bank_name) ? $this->error('卡号不正确或未录入') : '';
  687. $data['card_name'] = $bank_name;
  688. $id = input('id');
  689. DataUserBankCard::Show($this->uuid,$data['id_card'],$id)->count() ? $this->error('卡号已存在') : '';
  690. empty($id) ? : $data['update_at']=date('Y-m-d H:i:s');
  691. if (empty($id) ? DataUserBankCard::mk()->insert($data) : DataUserBankCard::mk()->where('id',$id)->update($data)){
  692. $this->success('提交成功');
  693. }
  694. $this->error('提交失败,请稍后重试');
  695. }
  696. /**
  697. * @Title("删除银行卡")
  698. * @Method("post")
  699. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  700. * @Header("api-token",type="string",require=1,default="",desc="token")
  701. * @Param("id",type="string",require=0,default="",desc="修改,则必传之前提交的ID")
  702. */
  703. public function delbank(){
  704. $data = $this->_vali([
  705. 'id.require'=>'id必须',
  706. ]);
  707. if (DataUserBankCard::mk()->where('id',$data['id'])->update(['is_del'=>0,'update_at'=>date('Y-m-d H:i:s')])){
  708. $this->success('删除成功');
  709. }
  710. $this->error('删除失败,请稍后重试');
  711. }
  712. /**
  713. * @Title("获取提现信息")
  714. * @Method("post")
  715. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  716. * @Header("api-token",type="string",require=1,default="",desc="token")
  717. *
  718. * @Returned("withdraw_min_price",desc="最低提现金额")
  719. * @Returned("withdraw_max_price",desc="最大提现金额")
  720. * @Returned("poundage_proportion",desc="手续费百分比")
  721. * @Returned("money",desc="用户可提现余额")
  722. */
  723. public function getwithinfo(){
  724. $user = $this->getUser();
  725. $info= [
  726. 'withdraw_min_price'=>sysconf('user.withdraw_min_price'),
  727. 'withdraw_max_price'=>sysconf('user.withdraw_max_price'),
  728. 'poundage_proportion'=>sysconf('user.poundage_proportion'),
  729. 'money'=>$user['money']
  730. ];
  731. $this->success('成功',$info);
  732. }
  733. /**
  734. * @Title("提现")
  735. * @Method("post")
  736. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  737. * @Header("api-token",type="string",require=1,default="",desc="token")
  738. * @Param("money",type="string",require=1,default="",desc="提现金额")
  739. * @Param("bind_id",type="string",require=0,default="",desc="绑定的银行卡记录ID")
  740. */
  741. public function withdraw(){
  742. $user=$this->getUser();
  743. $data = $this->_vali([
  744. 'money.require'=>'金额必须',
  745. 'bind_id.require'=>'绑定的记录ID必须',
  746. ]);
  747. $money = $data['money'];
  748. isAmount($money) ? : $this->error('金额错误');
  749. $user['money']<$money ? $this->error('余额不足') : '';
  750. $bank = DataUserBankCard::mk()->where('id',$data['bind_id'])->where('uuid',$this->uuid)->where('is_del',1)->findOrEmpty();
  751. if ($bank->isEmpty()) $this->error('绑定记录不存在');
  752. $withdraw_min_price = sysconf('user.withdraw_min_price'); //最小提现金额
  753. $withdraw_max_price = sysconf('user.withdraw_max_price'); //最大提现金额
  754. $poundage_proportion = sysconf('user.poundage_proportion'); //手续费百分比
  755. $money < $withdraw_min_price ? $this->error('最低提现'.$withdraw_min_price.'元') : '';
  756. $money > $withdraw_max_price ? $this->error('最大提现'.$withdraw_min_price.'元') : '';
  757. $error = 1;
  758. Db::startTrans();
  759. try {
  760. $proportion = sprintf("%.2f", $money*($poundage_proportion/100)); //四舍五入保留两位小数点
  761. $real_money = bcsub($money,$proportion,2);
  762. $inset = [
  763. 'uuid'=>$this->uuid,
  764. 'order_no'=>setorderno($this->uuid),
  765. 'bink_id'=>$data['bind_id'],
  766. 'card_name'=>$bank['card_name'],
  767. 'name'=>$bank['name'],
  768. 'bank_id_card'=>$bank['id_card'],
  769. 'price'=>$money,
  770. 'poundage_proportion'=>$poundage_proportion,
  771. 'proportion'=>$proportion,
  772. 'real_money'=>$real_money
  773. ];
  774. $id = DataUserWithdraw::mk()->insertGetId($inset);
  775. //余额提现
  776. $res = userMoneyChange($money,1,$this->uuid,'余额提现',0,$id);
  777. if (!$res){
  778. $error = 0;
  779. $errorinfo = '提现失败';
  780. Db::rollback();
  781. }
  782. Db::commit();
  783. } catch (\Exception $e) {
  784. // 回滚事务
  785. Db::rollback();
  786. $error = 0;
  787. $errorinfo = '未知错误';
  788. }
  789. if ($error){
  790. $this->success('提现成功,等待审核');
  791. }
  792. $this->error($errorinfo);
  793. }
  794. /**
  795. * @Title("意见反馈列表")
  796. * @Method("post")
  797. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  798. * @Header("api-token",type="string",require=1,default="",desc="token")
  799. * @Param("page&limit",type="string",require=0,default="",desc="分页")
  800. */
  801. public function feedbacklist(){
  802. $list = DataFeedback::Show($this->uuid)->with(['reply'])->paginate();
  803. $this->success('成功',$list);
  804. }
  805. /**
  806. * @Title("意见反馈提交")
  807. * @Method("post")
  808. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  809. * @Header("api-token",type="string",require=1,default="",desc="token")
  810. * @Param("content",type="string",require=1,default="",desc="反馈内容")
  811. * @Param("imgs",type="string",require=0,default="",desc="图片,以逗号隔开")
  812. * @Param("phone",type="string",require=0,default="",desc="手机号")
  813. * @Param("id",type="string",require=0,default="",desc="修改,则必传之前提交的ID,只有未回复的能修改")
  814. */
  815. public function subfeedback(){
  816. $data = $this->_vali([
  817. 'uuid'=>$this->uuid,
  818. 'content.require'=>'反馈内容必须',
  819. 'imgs.default'=>'',
  820. 'phone.default'=>''
  821. ]);
  822. empty($id) ? : $data['update_at']=date('Y-m-d H:i:s');
  823. if (empty($id) ? DataFeedback::mk()->insert($data) : DataFeedback::mk()->where('id',$id)->update($data)){
  824. $this->success('提交成功');
  825. }
  826. $this->error('提交失败,请稍后重试');
  827. }
  828. /**
  829. * @Title("意见反馈删除")
  830. * @Method("post")
  831. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  832. * @Header("api-token",type="string",require=1,default="",desc="token")
  833. * @Param("id",type="string",require=1,default="",desc="反馈ID")
  834. */
  835. public function delfeedback(){
  836. $data = $this->_vali([
  837. 'id.require'=>'ID必须',
  838. 'is_del.default'=>'0',
  839. ]);
  840. $id = $data['id'];
  841. unset($data['id']);
  842. DataFeedback::Show($this->uuid,$id)->count() ? '' : $this->error('信息不存在');
  843. if (DataFeedback::mk()->where('id',$id)->update($data)){
  844. $this->success('删除成功');
  845. }
  846. $this->error('删除失败,请稍后重试');
  847. }
  848. /**
  849. * @Title("我的收藏列表")
  850. * @Method("post")
  851. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  852. * @Header("api-token",type="string",require=1,default="",desc="token")
  853. * @Param("type",type="string",require=1,default="",desc="1:知识教学2:百知文库3:采购订单4应聘信息,5:船厂")
  854. * @Param("longitude",type="string",require=1,default="",desc="经度,船厂必须")
  855. * @Param("latitude",type="string",require=1,default="",desc="纬度,船厂必须")
  856. * @Returned("shipyard",desc="船厂对象")
  857. * @Returned("shipyard.distance",desc="船厂距离你的距离km")
  858. */
  859. public function mycollection(){
  860. $data = $this->_vali([
  861. 'type.require|in:1,2,3,4,5'=>'type有误'
  862. ]);
  863. switch ($data['type']){
  864. case 1:
  865. $list = DataCollectionLog::mk()
  866. ->hasWhere('knowledge',function (Query $query){
  867. $query->where('is_del',1);
  868. })
  869. ->where('data_collection_log.uuid',$this->uuid)
  870. ->where('cate',1)
  871. ->where('data_collection_log.type',1)
  872. ->with(['knowledge'=>function($query){
  873. $query->with(['user'=>function($query){
  874. $query->field('id,nickname,headimg,is_auth,is_vip');
  875. }]);
  876. }])
  877. ->order('id desc')
  878. ->paginate();
  879. break;
  880. case 2:
  881. $list = DataCollectionLog::mk()
  882. ->hasWhere('knowledge',function (Query $query){
  883. $query->where('is_del',1);
  884. })
  885. ->where('data_collection_log.uuid',$this->uuid)
  886. ->where('cate',1)
  887. ->where('data_collection_log.type',2)
  888. ->with(['knowledge'=>function($query){
  889. $query->with(['user'=>function($query){
  890. $query->field('id,nickname,headimg,is_auth,is_vip');
  891. }]);
  892. }])
  893. ->order('id desc')
  894. ->paginate();
  895. break;
  896. case 3:
  897. $this->uuid = '46';
  898. $list = ShopFavourite::mk()
  899. ->where('user_id',$this->uuid)
  900. ->order('id desc')
  901. ->paginate()
  902. ->toArray();
  903. foreach ($list['data'] as &$v){
  904. switch ($v['target_type']){
  905. case 'shop_purchase':
  906. $v['info'] = ShopPurchase::mk()
  907. ->where('id',$v['target_id'])
  908. ->with(['items','merchant'])
  909. ->findOrFail();
  910. break;
  911. case 'shop_production':
  912. $v['info'] = ShopProduction::mk()
  913. ->where('id',$v['target_id'])
  914. ->with(['items','merchant'])
  915. ->findOrFail();
  916. break;
  917. case 'shop_coordination':
  918. $v['info'] = ShopCoordination::mk()
  919. ->where('id',$v['target_id'])
  920. ->with(['items','merchant'])
  921. ->findOrFail();
  922. break;
  923. case 'shop_ocean':
  924. $v['info'] = ShopOcean::mk()
  925. ->where('id',$v['target_id'])
  926. ->with(['items','merchant'])
  927. ->findOrFail();
  928. break;
  929. }
  930. }
  931. break;
  932. case 4:
  933. $list = [];
  934. break;
  935. case 5:
  936. $data = $this->_vali([
  937. 'longitude.require'=>'经度必须',
  938. 'longitude.float'=>'经纬度必须是数字',
  939. 'latitude.require'=>'纬度必须',
  940. 'latitude.float'=>'经纬度必须是数字',
  941. ]);
  942. $list = DataCollectionLog::hasShipyard()
  943. ->where('uuid',$this->uuid)
  944. ->with(['shipyard'])
  945. ->paginate();
  946. foreach ($list as $item){
  947. $item['shipyard']->makeDistance($data['longitude'],$data['latitude']);
  948. }
  949. break;
  950. }
  951. $this->success('成功',$list);
  952. }
  953. /**
  954. * @Title("我的发布列表")
  955. * @Method("post")
  956. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  957. * @Header("api-token",type="string",require=1,default="",desc="token")
  958. * @Param("type",type="string",require=1,default="",desc="1:知识教学2:百知文库3:应聘信息")
  959. * @Returned("audit",desc="1:待审核2:审核成功3:审核失败")
  960. * @Returned("why",desc="审核失败原因")
  961. */
  962. public function myrelease(){
  963. $data = $this->_vali([
  964. 'type.require|in:1,2,3'=>'type有误'
  965. ]);
  966. switch ($data['type']){
  967. case 1:
  968. $list = DataTeachingKnowledge::mk()
  969. ->where('uuid',$this->uuid)
  970. ->where('is_del',1)
  971. ->with(['user'=>function($query){
  972. $query->field('id,headimg,nickname');
  973. }])
  974. ->order('id desc')
  975. ->paginate();
  976. break;
  977. case 2:
  978. $list = DataBestKnowledge::mk()
  979. ->where('uuid',$this->uuid)
  980. ->where('is_del',1)
  981. ->with(['user'=>function($query){
  982. $query->field('id,headimg,nickname');
  983. },'classTo'])
  984. ->paginate();
  985. break;
  986. case 3:
  987. $list = DataUserApplyJobInfo::mk()
  988. ->where('uuid',$this->uuid)
  989. ->with(['workexperience','professionalskills','certificate'])
  990. ->findOrEmpty();
  991. if (!isset($list['id'])) $list = null;
  992. break;
  993. }
  994. $this->success('成功',$list);
  995. }
  996. /**
  997. * @Title("应聘信息隐藏,取消隐藏")
  998. * @Method("post")
  999. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1000. * @Header("api-token",type="string",require=1,default="",desc="token")
  1001. * @Param("hidden",type="string",require=1,default="",desc="0:隐藏 1:显示")
  1002. */
  1003. public function canhidden(){
  1004. $data = $this->_vali([
  1005. 'hidden.require|in:0,1'=>'字段有误',
  1006. 'update_at.default'=>date('Y-m-d H:i:s')
  1007. ]);
  1008. DataUserApplyJobInfo::mk()->where('uuid',$this->uuid)->findOrEmpty() ? : $this->error('未提交') ;
  1009. if (DataUserApplyJobInfo::mk()->where('uuid',$this->uuid)->update($data)){
  1010. $this->success('成功');
  1011. }
  1012. $this->error('失败');
  1013. }
  1014. /**
  1015. * @Title("我的需求")
  1016. * @Method("post")
  1017. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1018. * @Header("api-token",type="string",require=1,default="",desc="token")
  1019. * @Param("type",type="string",require=1,default="",desc="1:采购接单需求2:船机修理接单需求")
  1020. */
  1021. public function myneed(){
  1022. $data = $this->_vali([
  1023. 'type.require|in:1,2'=>'字段有误',
  1024. ]);
  1025. switch ($data['type']){
  1026. case 1:
  1027. $info = DataUserPurchaseAcceptance::mk()
  1028. ->where('uuid',$this->uuid)
  1029. ->findOrEmpty();
  1030. if (!isset($info['id'])) $info = null;
  1031. break;
  1032. case 2:
  1033. $info = DataUserAcceptance::mk()
  1034. ->where('uuid',$this->uuid)
  1035. ->findOrEmpty();
  1036. break;
  1037. }
  1038. $this->success('成功',$info);
  1039. }
  1040. /**
  1041. * @Title("发布、修改采购接单需求")
  1042. * @Method("post")
  1043. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1044. * @Header("api-token",type="string",require=1,default="",desc="token")
  1045. * @Param("description",type="string",require=1,default="",desc="需求说明")
  1046. * @Param("business_img",type="string",require=1,default="",desc="营业执照或身份证照")
  1047. * @Param("imgs",type="string",require=1,default="",desc="图片及资质证件图片,多个以英文逗号隔开")
  1048. * @Param("hidden",type="string",require=0,default="1",desc="是否隐藏1:不隐藏 2:隐藏")
  1049. * @Param("province",type="string",require=1,default="",desc="定位-省")
  1050. * @Param("city",type="string",require=1,default="",desc="定位-市")
  1051. * @Param("area",type="string",require=1,default="",desc="定位-区")
  1052. * @Param("id",type="string",require=0,default="",desc="修改时,传ID")
  1053. */
  1054. public function subpurchaseacceptance(){
  1055. $data = $this->_vali([
  1056. 'uuid.default'=>$this->uuid,
  1057. 'description.require'=>'需求说明必须',
  1058. 'business_img.require'=>'营业执照或身份证照必须',
  1059. 'imgs.require'=>'图片及资质证件图片必须',
  1060. 'province.require'=>'定位-省',
  1061. 'city.require'=>'定位-市',
  1062. 'area.require'=>'定位-区',
  1063. 'hidden.default'=>1
  1064. ]);
  1065. $id = input('id');
  1066. empty($id) ? $id = DataUserPurchaseAcceptance::mk()->where('uuid',$this->uuid)->value('id') : '' ;
  1067. empty($id) ? : $data['update_at']=date('Y-m-d H:i:s');
  1068. empty($id) ? : $data['create_at']=date('Y-m-d H:i:s');
  1069. if (empty($id) ? DataUserPurchaseAcceptance::mk()->insert($data) : DataUserPurchaseAcceptance::mk()->where('id',$id)->update($data)){
  1070. $this->success('提交成功');
  1071. }
  1072. $this->error('提交失败,请稍后重试');
  1073. }
  1074. /**
  1075. * @Title("维修订单")
  1076. * @Method("post")
  1077. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1078. * @Header("api-token",type="string",require=1,default="",desc="token")
  1079. * @Param("type",type="string",require=1,default="",desc="1:我是船老板2:我是维修工")
  1080. * @Param("status",type="string",require=1,default="",desc="1:未报价2:已报价3:已匹配")
  1081. */
  1082. public function repair(){
  1083. $data = $this->_vali([
  1084. 'type.require|in:1,2'=>'字段有误',
  1085. 'status.require|in:1,2,3'=>'字段有误',
  1086. ]);
  1087. switch ($data['type']){
  1088. case 1:
  1089. $list = DataUserRepair::mk()
  1090. ->where('uuid',$this->uuid)
  1091. ->where('status',$data['status'])
  1092. ->where('is_del',1)
  1093. ->paginate();
  1094. break;
  1095. case 2:
  1096. $status = $data['status'];
  1097. $list = DataUserRepairOffer::mk()
  1098. ->hasWhere('repair',function (Query $query){
  1099. $query->where('is_del',1);
  1100. })
  1101. ->with(['repair'=>function($query){
  1102. $query->withoutField('is_del,update_at');
  1103. }])
  1104. ->where('offer_id',$this->uuid)
  1105. ->where(function ($query) use ($status){
  1106. $repair_ids = DataUserRepairOffer::mk()
  1107. ->where('offer_id',$this->uuid)
  1108. ->where('price','>',0)
  1109. ->group('repair_id')
  1110. ->column('repair_id');
  1111. switch ($status){
  1112. case 1:
  1113. $query->whereNotIn('repair_id',$repair_ids)->where('is_deal',0)->where('status',2);
  1114. break;
  1115. case 2:
  1116. $query->whereIn('repair_id',$repair_ids)->where('is_deal',0)->where('status',2);
  1117. break;
  1118. case 3:
  1119. $query->where('is_deal',1)->where('status',3);
  1120. break;
  1121. }
  1122. })
  1123. ->field('data_user_repair_offer.id,repair_id,offer_id')
  1124. ->order('id desc')
  1125. ->group('repair_id')
  1126. ->paginate();
  1127. $list = $list->toArray();
  1128. foreach ($list['data'] as &$v){
  1129. $in = DataUserRepairOffer::mk()
  1130. ->where('repair_id',$v['repair_id'])
  1131. ->where('offer_id',$v['offer_id'])
  1132. ->order('id desc')
  1133. ->limit(1)
  1134. ->field('id,price')->find();
  1135. $v['price'] = $in->price;
  1136. }
  1137. break;
  1138. }
  1139. $this->success('成功',$list);
  1140. }
  1141. /**
  1142. * @Title("维修订单删除(只有维修订单未报价和已报价可以删除)")
  1143. * @Method("post")
  1144. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1145. * @Header("api-token",type="string",require=1,default="",desc="token")
  1146. * @Param("id",type="string",require=1,default="",desc="type为1时:维修单ID type为2时报价记录ID")
  1147. */
  1148. public function repairdel(){
  1149. $data = $this->_vali([
  1150. 'id.require'=>'id有误',
  1151. ]);
  1152. if (DataUserRepair::mk()->where('id',$data['id'])->where('uuid',$this->uuid)->update(['is_del'=>0])){
  1153. $this->success('成功');
  1154. }
  1155. $this->error('失败');
  1156. }
  1157. /**
  1158. * @Title("维修订单详情页")
  1159. * @Method("post")
  1160. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1161. * @Header("api-token",type="string",require=1,default="",desc="token")
  1162. * @Param("type",type="string",require=1,default="",desc="1:我是船老板2:我是维修工")
  1163. * @Param("id",type="string",require=1,default="",desc="type为1时:维修单ID type为2时报价记录ID")
  1164. */
  1165. public function repairdetail(){
  1166. $data = $this->_vali([
  1167. 'type.require|in:1,2'=>'字段有误',
  1168. 'id.require'=>'id有误',
  1169. ]);
  1170. switch ($data['type']){
  1171. case 1:
  1172. $info = DataUserRepair::mk()
  1173. ->where('uuid',$this->uuid)
  1174. ->where('is_del',1)
  1175. ->where('id',$data['id'])
  1176. ->with(['user'=>function($query){
  1177. $query->field('id,nickname,headimg,phone');
  1178. },'offer'=>function($query){
  1179. $query->field('id,repair_id,offer_id,price,imgs')->group('offer_id')
  1180. ->with(['user'=>function($query){
  1181. $query->field('id,nickname,headimg,phone');
  1182. }]);
  1183. },'success'=>function($query){
  1184. $query->field('id,nickname,headimg,phone');
  1185. }])
  1186. ->find()->toArray();
  1187. foreach ($info['offer'] as &$v){
  1188. $in = DataUserRepairOffer::mk()
  1189. ->where('repair_id',$data['id'])
  1190. ->where('offer_id',$v['offer_id'])
  1191. ->order('id desc')
  1192. ->limit(1)
  1193. ->field('id,price')->find();
  1194. $v['id'] = $in->id;
  1195. $v['price'] = $in->price;
  1196. }
  1197. break;
  1198. case 2:
  1199. $info = DataUserRepairOffer::mk()
  1200. ->where('id',$data['id'])
  1201. ->with(['user'=>function($query){
  1202. $query->field('id,nickname,headimg,phone');
  1203. },'repair'=>function($query){
  1204. $query->with(['user'=>function($query){
  1205. $query->field('id,nickname,headimg,phone');
  1206. }]);
  1207. }])
  1208. ->find()->toArray();
  1209. $in = DataUserRepairOffer::mk()
  1210. ->where('repair_id',$info['repair_id'])
  1211. ->where('offer_id',$info['offer_id'])
  1212. ->order('id desc')
  1213. ->limit(1)
  1214. ->field('id,price')->find();
  1215. $info['price'] = $in['price'];
  1216. break;
  1217. }
  1218. $this->success('成功',$info);
  1219. }
  1220. /**
  1221. * @Title("维修订单确认匹配")
  1222. * @Method("post")
  1223. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1224. * @Header("api-token",type="string",require=1,default="",desc="token")
  1225. * @Param("id",type="string",require=1,default="",desc="维修单ID")
  1226. * @Param("offer_id",type="string",require=1,default="",desc="匹配的记录ID")
  1227. */
  1228. public function repairoffer(){
  1229. $data = $this->_vali([
  1230. 'id.require'=>'id有误',
  1231. 'offer_id.require'=>'offer_id有误',
  1232. ]);
  1233. DataUserRepair::mk()->where('id',$data['id'])->value('status') == 3 ? $this->error('订单已经匹配成功') : '';
  1234. $offer = DataUserRepairOffer::mk()->where('id',$data['offer_id'])->find();
  1235. if (DataUserRepair::mk()->where('id',$data['id'])->update(['status'=>3,'success_uuid'=>$offer->offer_id,'success_price'=>$offer->price,'success_at'=>date('Y-m-d H:i:s')])
  1236. &&
  1237. DataUserRepairOffer::mk()->where('id',$data['offer_id'])->update(['is_deal'=>1,'deal_at'=>date('Y-m-d H:i:s')])){
  1238. $this->success('成功');
  1239. }
  1240. $this->error('失败');
  1241. }
  1242. /**
  1243. * @Title("维修订单详情页用户报价列表点击查看详情")
  1244. * @Method("post")
  1245. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1246. * @Header("api-token",type="string",require=1,default="",desc="token")
  1247. * @Param("id",type="string",require=1,default="",desc="维修单ID")
  1248. * @Param("offer_id",type="string",require=1,default="",desc="匹配的记录ID")
  1249. */
  1250. public function userofferinfo(){
  1251. $data = $this->_vali([
  1252. 'id.require'=>'id有误',
  1253. 'offer_id.require'=>'offer_id有误',
  1254. ]);
  1255. $offer_id = $data['offer_id'];
  1256. $list = DataUserRepairOffer::mk()
  1257. ->where('repair_id',$data['id'])
  1258. ->where(function ($query) use ($offer_id){
  1259. $query->where('offer_id',$offer_id);
  1260. })
  1261. ->field('id,price')
  1262. ->select();
  1263. $imgs = array_filter(explode(',',DataUserRepairOffer::mk()->where('repair_id',$data['id'])
  1264. ->where('offer_id',$this->uuid)
  1265. ->order('id desc')
  1266. ->limit(1)
  1267. ->value('imgs')));
  1268. $messagelist = DataUserLeaveMessage::mk()
  1269. ->where('type',1)
  1270. ->where('link_id',$data['id'])
  1271. ->with(['user'=>function($query){
  1272. $query->field('id,nickname,headimg');
  1273. }])
  1274. ->field('id,uuid,uuid2,content,create_at')
  1275. ->select();
  1276. $this->success('成功',compact('list','imgs','messagelist'));
  1277. }
  1278. /**
  1279. * @Title("维修订单留言")
  1280. * @Method("post")
  1281. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1282. * @Header("api-token",type="string",require=1,default="",desc="token")
  1283. * @Param("id",type="string",require=1,default="",desc="维修单ID")
  1284. * @Param("offer_id",type="string",require=1,default="",desc="匹配的记录ID")
  1285. * @Param("content",type="string",require=1,default="",desc="内容")
  1286. */
  1287. public function subleavemessage(){
  1288. $data = $this->_vali([
  1289. 'id.require'=>'id有误',
  1290. 'offer_id.require'=>'offer_id有误',
  1291. 'content.require'=>'内容必须',
  1292. ]);
  1293. $offer = DataUserRepairOffer::mk()->where('id',$data['offer_id'])->findOrEmpty();
  1294. $array = [
  1295. 'uuid'=>$this->uuid,
  1296. 'uuid2'=>$offer->offer_id,
  1297. 'content'=>$data['content'],
  1298. 'type'=>1,
  1299. 'link_id'=>$data['id'],
  1300. ];
  1301. if (DataUserLeaveMessage::mk()->insert($array)){
  1302. $this->success('成功');
  1303. }
  1304. $this->error('失败');
  1305. }
  1306. /**
  1307. * @Title("维修订单维修工回复留言")
  1308. * @Method("post")
  1309. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1310. * @Header("api-token",type="string",require=1,default="",desc="token")
  1311. * @Param("id",type="string",require=1,default="",desc="维修单ID")
  1312. * @Param("content",type="string",require=1,default="",desc="内容")
  1313. */
  1314. public function subofferleavemessage(){
  1315. $data = $this->_vali([
  1316. 'id.require'=>'id有误',
  1317. 'content.require'=>'内容必须',
  1318. ]);
  1319. $repair = DataUserRepair::mk()->where('id',$data['id'])->findOrEmpty();
  1320. $array = [
  1321. 'uuid'=>$this->uuid,
  1322. 'uuid2'=>$repair->uuid,
  1323. 'content'=>$data['content'],
  1324. 'type'=>1,
  1325. 'link_id'=>$data['id'],
  1326. ];
  1327. if (DataUserLeaveMessage::mk()->insert($array)){
  1328. $this->success('成功');
  1329. }
  1330. $this->error('失败');
  1331. }
  1332. /**
  1333. * @Title("维修订单维修工查看留言列表")
  1334. * @Method("post")
  1335. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1336. * @Header("api-token",type="string",require=1,default="",desc="token")
  1337. * @Param("id",type="string",require=1,default="",desc="维修单ID")
  1338. */
  1339. public function suboffermessagelist(){
  1340. $data = $this->_vali([
  1341. 'id.require'=>'id有误',
  1342. ]);
  1343. $messagelist = DataUserLeaveMessage::mk()
  1344. ->where('type',1)
  1345. ->where('link_id',$data['id'])
  1346. ->with(['user'=>function($query){
  1347. $query->field('id,nickname,headimg');
  1348. }])
  1349. ->field('id,uuid,uuid2,content,create_at')
  1350. ->select();
  1351. $this->success('成功',$messagelist);
  1352. }
  1353. /**
  1354. * @Title("消息")
  1355. * @Method("post")
  1356. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1357. * @Header("api-token",type="string",require=1,default="",desc="token")
  1358. * @Param("type",type="string",require=1,default="",desc="message:后台消息 notice:系统通知")
  1359. * @Returned("is_read",desc="1:已读 0:未读")
  1360. */
  1361. public function messagelist(){
  1362. $data = $this->_vali([
  1363. 'type.require'=>'type有误',
  1364. ]);
  1365. $type = $data['type'];
  1366. $messagelist = BaseUserMessage::mk()
  1367. ->where('type',$data['type'])
  1368. ->when($type,function ($query) use ($type){
  1369. if ($type=='notice'){
  1370. $query->where('uuid',$this->uuid);
  1371. }
  1372. })
  1373. ->where('status',1)
  1374. ->where('deleted',0)
  1375. ->withoutField('deleted,sort,num_read,status')
  1376. ->order('id desc')
  1377. ->paginate()->toArray();
  1378. foreach ($messagelist['data'] as &$v){
  1379. $v['is_read'] = BaseUserMessageRead::mk()->where('uuid',$this->uuid)->where('message_id',$v['id'])->count() ? 1 : 0;
  1380. }
  1381. $this->success('成功',$messagelist);
  1382. }
  1383. /**
  1384. * @Title("点击消息")
  1385. * @Method("post")
  1386. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1387. * @Header("api-token",type="string",require=1,default="",desc="token")
  1388. * @Param("id",type="string",require=1,default="",desc="消息ID")
  1389. */
  1390. public function readmessage(){
  1391. $data = $this->_vali([
  1392. 'id.require'=>'id有误',
  1393. ]);
  1394. BaseUserMessageRead::mk()->where('uuid',$this->uuid)->where('message_id',$data['id'])->count() ? :
  1395. BaseUserMessageRead::mk()->insert(['message_id'=>$data['id'],'uuid'=>$this->uuid]);
  1396. $this->success('成功');
  1397. }
  1398. /**
  1399. * @Title("获取安卓版本")
  1400. * @Method("post")
  1401. * @Header("api-name",type="string",require=1,default="",desc="访问类型")
  1402. * @Header("api-token",type="string",require=1,default="",desc="token")
  1403. *
  1404. * @Returned("version",desc="当前版本")
  1405. * @Returned("name",desc="版本名")
  1406. * @Returned("title",desc="更新标题")
  1407. * @Returned("isCompel",desc="1:强制更新 0:不强制更新")
  1408. * @Returned("content",desc="更新内容")
  1409. * @Returned("download_url",desc="下载地址")
  1410. */
  1411. public function getandroidversion(){
  1412. $info= [
  1413. 'version'=>(int)sysconf('android.version'),
  1414. 'name'=>sysconf('android.name'),
  1415. 'title'=>sysconf('android.title'),
  1416. 'isCompel'=>(int)sysconf('android.isCompel'),
  1417. 'content'=>sysconf('android.content'),
  1418. 'download_url'=>sysconf('android.download_url'),
  1419. ];
  1420. $this->success('成功',$info);
  1421. }
  1422. }