From 727055649464f6266490bd1943d8039b25e5d184 Mon Sep 17 00:00:00 2001 From: Anyon Date: Tue, 2 Apr 2019 13:46:30 +0800 Subject: [PATCH] =?UTF-8?q?[=E6=9B=B4=E6=96=B0]=E5=8D=87=E7=BA=A7V4.0?= =?UTF-8?q?=E7=89=88=E6=9C=AC?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .gitattributes | 3 - .gitignore | 13 +- LICENSE | 20 - README.md | 143 +- admin_v3.sql | 947 - admin_v4.sql | 981 + application/.htaccess | 1 - application/admin/controller/Auth.php | 146 +- application/admin/controller/Config.php | 104 +- application/admin/controller/Index.php | 192 +- application/admin/controller/Log.php | 45 +- application/admin/controller/Login.php | 125 +- application/admin/controller/Menu.php | 159 +- application/admin/controller/Message.php | 92 + application/admin/controller/Node.php | 177 +- application/admin/controller/Plugs.php | 152 - application/admin/controller/Queue.php | 89 + application/admin/controller/User.php | 178 +- application/admin/controller/api/Message.php | 53 + application/admin/controller/api/Plugs.php | 217 + application/admin/controller/api/Update.php | 54 + application/admin/middleware/Auth.php | 71 - application/admin/queue/JobsBase.php | 122 + application/admin/service/Auth.php | 207 + .../admin/service/Log.php | 114 +- application/admin/service/Message.php | 72 + application/admin/service/Queue.php | 128 + application/admin/sys.php | 111 + .../admin/view/{ => api}/plugs/icon.html | 5 +- application/admin/view/api/plugs/message.html | 65 + application/admin/view/api/plugs/upfile.html | 432 + application/admin/view/auth/apply.html | 159 +- application/admin/view/auth/form.html | 35 +- application/admin/view/auth/index.html | 123 +- application/admin/view/auth/index_search.html | 42 + application/admin/view/config/file.html | 236 +- application/admin/view/config/file_local.html | 25 + application/admin/view/config/file_oss.html | 86 + application/admin/view/config/file_qiniu.html | 87 + application/admin/view/config/index.html | 82 - application/admin/view/config/info.html | 61 + application/admin/view/index/command.html | 8 + application/admin/view/index/index.html | 210 +- application/admin/view/index/main.html | 87 +- application/admin/view/log/index.html | 145 +- application/admin/view/log/index_search.html | 56 + application/admin/view/log/sms.html | 76 - application/admin/view/login/index.html | 109 +- application/admin/view/main.html | 11 + application/admin/view/menu/form.html | 133 +- application/admin/view/menu/index.html | 141 +- application/admin/view/message/index.html | 86 + .../admin/view/message/index_search.html | 57 + application/admin/view/node/index.html | 81 +- application/admin/view/plugs/upfile.html | 554 - application/admin/view/public/content.html | 13 - application/admin/view/public/main.html | 26 - application/admin/view/queue/index.html | 78 + .../admin/view/queue/index_search.html | 68 + application/admin/view/user/auth.html | 55 +- application/admin/view/user/form.html | 97 +- application/admin/view/user/index.html | 184 +- application/admin/view/user/index_search.html | 57 + application/admin/view/user/pass.html | 66 +- application/common.php | 110 - application/index/controller/Index.php | 18 +- application/service/controller/Config.php | 50 + application/service/controller/Index.php | 146 + application/service/controller/api/Client.php | 154 + application/service/controller/api/Push.php | 181 + application/service/handler/Publish.php | 67 + application/service/handler/Receive.php | 64 + application/service/handler/Wechat.php | 169 + application/service/logic/Build.php | 52 + application/service/logic/Wechat.php | 150 + application/service/view/config/index.html | 86 + application/service/view/index/index.html | 79 + .../service/view/index/index_search.html | 77 + application/store/command/AutoRun.php | 70 + application/store/controller/Config.php | 44 + application/store/controller/Express.php | 117 +- application/store/controller/Goods.php | 353 +- application/store/controller/GoodsBrand.php | 151 - application/store/controller/GoodsCate.php | 130 +- application/store/controller/GoodsSpec.php | 157 - application/store/controller/Member.php | 57 + application/store/controller/Message.php | 46 + application/store/controller/Order.php | 170 +- application/store/controller/Page.php | 136 + application/store/controller/api/Express.php | 37 + application/store/controller/api/Goods.php | 118 + application/store/controller/api/Member.php | 90 + application/store/controller/api/Notify.php | 71 + application/store/controller/api/Page.php | 72 + application/store/controller/api/Wechat.php | 88 + .../store/controller/api/member/Address.php | 127 + .../store/controller/api/member/Center.php | 116 + .../store/controller/api/member/Order.php | 298 + application/store/controller/wechat/Demo.php | 204 - application/store/init.php | 34 - application/store/service/Extend.php | 82 + application/store/service/Goods.php | 68 + application/store/service/GoodsService.php | 130 - application/store/service/Order.php | 71 + application/store/service/OrderService.php | 189 - application/{middleware.php => store/sys.php} | 14 +- application/store/view/config/index.html | 71 + application/store/view/express/form.html | 45 +- application/store/view/express/index.html | 164 +- .../store/view/express/index_search.html | 42 + application/store/view/goods/form.html | 635 +- application/store/view/goods/index.html | 282 +- .../store/view/goods/index_search.html | 44 + application/store/view/goods/stock.html | 88 +- application/store/view/goods_brand/form.html | 82 - application/store/view/goods_brand/index.html | 108 - application/store/view/goods_cate/form.html | 50 +- application/store/view/goods_cate/index.html | 131 +- .../store/view/goods_cate/index_search.html | 30 + application/store/view/goods_spec/form.html | 200 - application/store/view/goods_spec/index.html | 116 - application/store/view/member/index.html | 45 + .../store/view/member/index_search.html | 45 + application/store/view/message/index.html | 34 + .../store/view/message/index_search.html | 34 + application/store/view/order/address.html | 60 - application/store/view/order/express.html | 89 + .../store/view/order/express_query.html | 17 + application/store/view/order/index.html | 368 +- .../store/view/order/index_search.html | 103 + application/store/view/page/form.html | 158 + application/store/view/page/index.html | 64 + application/wechat/command/Fans.php | 137 + .../command/fans/FansAll.php} | 29 +- application/wechat/command/fans/FansBlack.php | 34 + application/wechat/command/fans/FansList.php | 35 + application/wechat/command/fans/FansTags.php | 34 + application/wechat/controller/Config.php | 116 +- application/wechat/controller/Fans.php | 196 +- application/wechat/controller/FansBlock.php | 113 - application/wechat/controller/Keys.php | 128 +- application/wechat/controller/Menu.php | 187 +- application/wechat/controller/News.php | 197 +- application/wechat/controller/Review.php | 60 - application/wechat/controller/Tags.php | 159 - application/wechat/controller/api/Js.php | 56 +- application/wechat/controller/api/Push.php | 372 +- application/wechat/controller/api/Review.php | 84 + application/wechat/controller/api/Tools.php | 183 +- application/wechat/queue/Jobs.php | 75 + application/wechat/service/Fans.php | 68 + application/wechat/service/FansService.php | 123 - application/wechat/service/Media.php | 83 + application/wechat/service/MediaService.php | 128 - application/wechat/service/TagsService.php | 69 - application/wechat/service/Wechat.php | 247 + application/wechat/sys.php | 21 + application/wechat/view/api/review/image.html | 23 + application/wechat/view/api/review/main.html | 19 + application/wechat/view/api/review/music.html | 56 + application/wechat/view/api/review/news.html | 128 + application/wechat/view/api/review/text.html | 9 + application/wechat/view/api/review/video.html | 46 + application/wechat/view/api/review/view.html | 61 + application/wechat/view/api/review/voice.html | 43 + application/wechat/view/api/script/index.js | 10 - application/wechat/view/api/tools/jssdk.html | 5 +- application/wechat/view/api/tools/oauth.html | 86 +- application/wechat/view/config/index.html | 168 - application/wechat/view/config/options.html | 41 + .../wechat/view/config/options_api.html | 69 + .../wechat/view/config/options_help.html | 39 + .../wechat/view/config/options_thr.html | 72 + application/wechat/view/config/payment.html | 98 + application/wechat/view/fans/index.html | 159 +- .../wechat/view/fans/index_search.html | 61 + application/wechat/view/fans/search_inc.html | 74 - application/wechat/view/fans/tags_inc.html | 82 - application/wechat/view/fans_block/index.html | 84 - application/wechat/view/keys/form.html | 394 +- application/wechat/view/keys/index.html | 159 +- .../wechat/view/keys/index_search.html | 56 + application/wechat/view/menu/index.html | 544 +- application/wechat/view/news/form.html | 303 +- application/wechat/view/news/image.html | 42 - application/wechat/view/news/index.html | 95 +- application/wechat/view/news/push.html | 2 +- application/wechat/view/news/select.html | 163 +- application/wechat/view/review/index.html | 177 - application/wechat/view/tags/form.html | 18 - application/wechat/view/tags/index.html | 89 - build.cmd | 4 +- build.sh | 37 - composer.json | 22 +- config/app.php | 6 +- config/cert/1332187001_20181030_cert.p12 | Bin 0 -> 6102 bytes config/cert/1332187001_20181030_cert.pem | 24 + config/cert/1332187001_20181030_key.pem | 28 + config/cookie.php | 24 + config/database.php | 10 +- config/log.php | 13 +- .../wechat/Index.php => config/queue.php | 30 +- config/session.php | 14 +- config/template.php | 19 +- config/wechat.php | 16 +- extend/controller/BasicAdmin.php | 160 - extend/controller/BasicApi.php | 65 - extend/controller/BasicWechat.php | 84 - extend/service/AlismsService.php | 177 - extend/service/DataService.php | 112 - extend/service/FileService.php | 383 - extend/service/HttpService.php | 118 - extend/service/NodeService.php | 174 - extend/service/SoapService.php | 65 - extend/service/ToolsService.php | 222 - extend/service/WechatService.php | 250 - .htaccess => public/.htaccess | 0 public/4919999519.txt | 1 + public/favicon.ico | Bin 0 -> 16958 bytes index.php => public/index.php | 15 +- route/route.php => public/router.php | 22 +- public/static/admin.js | 707 + public/static/myself/my plugs file | 0 .../static}/plugs/angular/angular.min.js | 0 public/static/plugs/awesome/fonts.css | 4 + .../plugs/awesome/fonts/FontAwesome.otf | Bin .../static/plugs/awesome/fonts/webfont.eot | Bin .../static/plugs/awesome/fonts/webfont.svg | 0 .../static/plugs/awesome/fonts/webfont.ttf | Bin .../static/plugs/awesome/fonts/webfont.woff | Bin .../static/plugs/awesome/fonts/webfont.woff2 | Bin .../static}/plugs/ckeditor/ckeditor.js | 917 +- public/static/plugs/ckeditor/config.js | 75 + .../static}/plugs/ckeditor/contents.css | 7 +- .../static}/plugs/ckeditor/lang/en.js | 0 public/static/plugs/ckeditor/lang/zh-cn.js | 5 + .../plugins/a11yhelp/dialogs/a11yhelp.js | 0 .../dialogs/lang/_translationstatus.txt | 0 .../plugins/a11yhelp/dialogs/lang/af.js | 0 .../plugins/a11yhelp/dialogs/lang/ar.js | 0 .../plugins/a11yhelp/dialogs/lang/az.js | 0 .../plugins/a11yhelp/dialogs/lang/bg.js | 11 + .../plugins/a11yhelp/dialogs/lang/ca.js | 0 .../plugins/a11yhelp/dialogs/lang/cs.js | 0 .../plugins/a11yhelp/dialogs/lang/cy.js | 0 .../plugins/a11yhelp/dialogs/lang/da.js | 0 .../plugins/a11yhelp/dialogs/lang/de-ch.js | 0 .../plugins/a11yhelp/dialogs/lang/de.js | 0 .../plugins/a11yhelp/dialogs/lang/el.js | 0 .../plugins/a11yhelp/dialogs/lang/en-au.js | 0 .../plugins/a11yhelp/dialogs/lang/en-gb.js | 0 .../plugins/a11yhelp/dialogs/lang/en.js | 0 .../plugins/a11yhelp/dialogs/lang/eo.js | 0 .../plugins/a11yhelp/dialogs/lang/es-mx.js | 0 .../plugins/a11yhelp/dialogs/lang/es.js | 0 .../plugins/a11yhelp/dialogs/lang/et.js | 4 +- .../plugins/a11yhelp/dialogs/lang/eu.js | 0 .../plugins/a11yhelp/dialogs/lang/fa.js | 4 +- .../plugins/a11yhelp/dialogs/lang/fi.js | 0 .../plugins/a11yhelp/dialogs/lang/fo.js | 0 .../plugins/a11yhelp/dialogs/lang/fr-ca.js | 0 .../plugins/a11yhelp/dialogs/lang/fr.js | 0 .../plugins/a11yhelp/dialogs/lang/gl.js | 0 .../plugins/a11yhelp/dialogs/lang/gu.js | 0 .../plugins/a11yhelp/dialogs/lang/he.js | 0 .../plugins/a11yhelp/dialogs/lang/hi.js | 0 .../plugins/a11yhelp/dialogs/lang/hr.js | 0 .../plugins/a11yhelp/dialogs/lang/hu.js | 0 .../plugins/a11yhelp/dialogs/lang/id.js | 0 .../plugins/a11yhelp/dialogs/lang/it.js | 0 .../plugins/a11yhelp/dialogs/lang/ja.js | 0 .../plugins/a11yhelp/dialogs/lang/km.js | 0 .../plugins/a11yhelp/dialogs/lang/ko.js | 0 .../plugins/a11yhelp/dialogs/lang/ku.js | 0 .../plugins/a11yhelp/dialogs/lang/lt.js | 0 .../plugins/a11yhelp/dialogs/lang/lv.js | 0 .../plugins/a11yhelp/dialogs/lang/mk.js | 0 .../plugins/a11yhelp/dialogs/lang/mn.js | 0 .../plugins/a11yhelp/dialogs/lang/nb.js | 0 .../plugins/a11yhelp/dialogs/lang/nl.js | 0 .../plugins/a11yhelp/dialogs/lang/no.js | 0 .../plugins/a11yhelp/dialogs/lang/oc.js | 0 .../plugins/a11yhelp/dialogs/lang/pl.js | 0 .../plugins/a11yhelp/dialogs/lang/pt-br.js | 0 .../plugins/a11yhelp/dialogs/lang/pt.js | 0 .../plugins/a11yhelp/dialogs/lang/ro.js | 0 .../plugins/a11yhelp/dialogs/lang/ru.js | 0 .../plugins/a11yhelp/dialogs/lang/si.js | 0 .../plugins/a11yhelp/dialogs/lang/sk.js | 0 .../plugins/a11yhelp/dialogs/lang/sl.js | 0 .../plugins/a11yhelp/dialogs/lang/sq.js | 0 .../plugins/a11yhelp/dialogs/lang/sr-latn.js | 0 .../plugins/a11yhelp/dialogs/lang/sr.js | 0 .../plugins/a11yhelp/dialogs/lang/sv.js | 0 .../plugins/a11yhelp/dialogs/lang/th.js | 0 .../plugins/a11yhelp/dialogs/lang/tr.js | 0 .../plugins/a11yhelp/dialogs/lang/tt.js | 0 .../plugins/a11yhelp/dialogs/lang/ug.js | 0 .../plugins/a11yhelp/dialogs/lang/uk.js | 0 .../plugins/a11yhelp/dialogs/lang/vi.js | 0 .../plugins/a11yhelp/dialogs/lang/zh-cn.js | 0 .../plugins/a11yhelp/dialogs/lang/zh.js | 0 .../ckeditor/plugins/about/dialogs/about.js | 0 .../about/dialogs/hidpi/logo_ckeditor.png | Bin .../plugins/about/dialogs/logo_ckeditor.png | Bin .../plugins/clipboard/dialogs/paste.js | 0 .../colordialog/dialogs/colordialog.css | 0 .../colordialog/dialogs/colordialog.js | 0 .../cursors/cursor-disabled.svg | 0 .../plugins/copyformatting/cursors/cursor.svg | 0 .../copyformatting/styles/copyformatting.css | 0 .../plugins/dialog/dialogDefinition.js | 0 .../plugs/ckeditor/plugins/div/dialogs/div.js | 0 .../ckeditor/plugins/find/dialogs/find.js | 25 + .../ckeditor/plugins/flash/dialogs/flash.js | 0 .../plugins/flash/images/placeholder.png | Bin .../ckeditor/plugins/forms/dialogs/button.js | 0 .../plugins/forms/dialogs/checkbox.js | 0 .../ckeditor/plugins/forms/dialogs/form.js | 0 .../plugins/forms/dialogs/hiddenfield.js | 0 .../ckeditor/plugins/forms/dialogs/radio.js | 0 .../ckeditor/plugins/forms/dialogs/select.js | 0 .../plugins/forms/dialogs/textarea.js | 0 .../plugins/forms/dialogs/textfield.js | 0 .../plugins/forms/images/hiddenfield.gif | Bin .../static}/plugs/ckeditor/plugins/icons.png | Bin .../plugs/ckeditor/plugins/icons_hidpi.png | Bin .../ckeditor/plugins/iframe/dialogs/iframe.js | 0 .../plugins/iframe/images/placeholder.png | Bin .../ckeditor/plugins/image/dialogs/image.js | 44 + .../ckeditor/plugins/image/images/noimage.png | Bin .../ckeditor/plugins/link/dialogs/anchor.js | 0 .../ckeditor/plugins/link/dialogs/link.js | 0 .../ckeditor/plugins/link/images/anchor.png | Bin .../plugins/link/images/hidpi/anchor.png | Bin .../plugins/liststyle/dialogs/liststyle.js | 0 .../magicline/images/hidpi/icon-rtl.png | Bin .../plugins/magicline/images/hidpi/icon.png | Bin .../plugins/magicline/images/icon-rtl.png | Bin .../plugins/magicline/images/icon.png | Bin .../plugins/pagebreak/images/pagebreak.gif | Bin .../plugins/pastefromword/filter/default.js | 0 .../ckeditor/plugins/preview/preview.html | 0 .../plugs/ckeditor/plugins/scayt/CHANGELOG.md | 0 .../plugs/ckeditor/plugins/scayt/LICENSE.md | 0 .../plugs/ckeditor/plugins/scayt/README.md | 0 .../ckeditor/plugins/scayt/dialogs/dialog.css | 0 .../ckeditor/plugins/scayt/dialogs/options.js | 32 + .../plugins/scayt/dialogs/toolbar.css | 0 .../plugins/scayt/skins/moono-lisa/scayt.css | 0 .../showblocks/images/block_address.png | Bin .../showblocks/images/block_blockquote.png | Bin .../plugins/showblocks/images/block_div.png | Bin .../plugins/showblocks/images/block_h1.png | Bin .../plugins/showblocks/images/block_h2.png | Bin .../plugins/showblocks/images/block_h3.png | Bin .../plugins/showblocks/images/block_h4.png | Bin .../plugins/showblocks/images/block_h5.png | Bin .../plugins/showblocks/images/block_h6.png | Bin .../plugins/showblocks/images/block_p.png | Bin .../plugins/showblocks/images/block_pre.png | Bin .../ckeditor/plugins/smiley/dialogs/smiley.js | 0 .../plugins/smiley/images/angel_smile.gif | Bin .../plugins/smiley/images/angel_smile.png | Bin .../plugins/smiley/images/angry_smile.gif | Bin .../plugins/smiley/images/angry_smile.png | Bin .../plugins/smiley/images/broken_heart.gif | Bin .../plugins/smiley/images/broken_heart.png | Bin .../plugins/smiley/images/confused_smile.gif | Bin .../plugins/smiley/images/confused_smile.png | Bin .../plugins/smiley/images/cry_smile.gif | Bin .../plugins/smiley/images/cry_smile.png | Bin .../plugins/smiley/images/devil_smile.gif | Bin .../plugins/smiley/images/devil_smile.png | Bin .../smiley/images/embaressed_smile.gif | Bin .../smiley/images/embarrassed_smile.gif | Bin .../smiley/images/embarrassed_smile.png | Bin .../plugins/smiley/images/envelope.gif | Bin .../plugins/smiley/images/envelope.png | Bin .../ckeditor/plugins/smiley/images/heart.gif | Bin .../ckeditor/plugins/smiley/images/heart.png | Bin .../ckeditor/plugins/smiley/images/kiss.gif | Bin .../ckeditor/plugins/smiley/images/kiss.png | Bin .../plugins/smiley/images/lightbulb.gif | Bin .../plugins/smiley/images/lightbulb.png | Bin .../plugins/smiley/images/omg_smile.gif | Bin .../plugins/smiley/images/omg_smile.png | Bin .../plugins/smiley/images/regular_smile.gif | Bin .../plugins/smiley/images/regular_smile.png | Bin .../plugins/smiley/images/sad_smile.gif | Bin .../plugins/smiley/images/sad_smile.png | Bin .../plugins/smiley/images/shades_smile.gif | Bin .../plugins/smiley/images/shades_smile.png | Bin .../plugins/smiley/images/teeth_smile.gif | Bin .../plugins/smiley/images/teeth_smile.png | Bin .../plugins/smiley/images/thumbs_down.gif | Bin .../plugins/smiley/images/thumbs_down.png | Bin .../plugins/smiley/images/thumbs_up.gif | Bin .../plugins/smiley/images/thumbs_up.png | Bin .../plugins/smiley/images/tongue_smile.gif | Bin .../plugins/smiley/images/tongue_smile.png | Bin .../plugins/smiley/images/tounge_smile.gif | Bin .../images/whatchutalkingabout_smile.gif | Bin .../images/whatchutalkingabout_smile.png | Bin .../plugins/smiley/images/wink_smile.gif | Bin .../plugins/smiley/images/wink_smile.png | Bin .../dialogs/lang/_translationstatus.txt | 0 .../plugins/specialchar/dialogs/lang/af.js | 0 .../plugins/specialchar/dialogs/lang/ar.js | 0 .../plugins/specialchar/dialogs/lang/az.js | 0 .../plugins/specialchar/dialogs/lang/bg.js | 2 +- .../plugins/specialchar/dialogs/lang/ca.js | 0 .../plugins/specialchar/dialogs/lang/cs.js | 0 .../plugins/specialchar/dialogs/lang/cy.js | 0 .../plugins/specialchar/dialogs/lang/da.js | 0 .../plugins/specialchar/dialogs/lang/de-ch.js | 0 .../plugins/specialchar/dialogs/lang/de.js | 0 .../plugins/specialchar/dialogs/lang/el.js | 0 .../plugins/specialchar/dialogs/lang/en-au.js | 0 .../plugins/specialchar/dialogs/lang/en-ca.js | 0 .../plugins/specialchar/dialogs/lang/en-gb.js | 0 .../plugins/specialchar/dialogs/lang/en.js | 0 .../plugins/specialchar/dialogs/lang/eo.js | 0 .../plugins/specialchar/dialogs/lang/es-mx.js | 0 .../plugins/specialchar/dialogs/lang/es.js | 0 .../plugins/specialchar/dialogs/lang/et.js | 0 .../plugins/specialchar/dialogs/lang/eu.js | 0 .../plugins/specialchar/dialogs/lang/fa.js | 0 .../plugins/specialchar/dialogs/lang/fi.js | 0 .../plugins/specialchar/dialogs/lang/fr-ca.js | 0 .../plugins/specialchar/dialogs/lang/fr.js | 0 .../plugins/specialchar/dialogs/lang/gl.js | 0 .../plugins/specialchar/dialogs/lang/he.js | 0 .../plugins/specialchar/dialogs/lang/hr.js | 0 .../plugins/specialchar/dialogs/lang/hu.js | 0 .../plugins/specialchar/dialogs/lang/id.js | 0 .../plugins/specialchar/dialogs/lang/it.js | 0 .../plugins/specialchar/dialogs/lang/ja.js | 0 .../plugins/specialchar/dialogs/lang/km.js | 0 .../plugins/specialchar/dialogs/lang/ko.js | 0 .../plugins/specialchar/dialogs/lang/ku.js | 0 .../plugins/specialchar/dialogs/lang/lt.js | 0 .../plugins/specialchar/dialogs/lang/lv.js | 0 .../plugins/specialchar/dialogs/lang/nb.js | 0 .../plugins/specialchar/dialogs/lang/nl.js | 0 .../plugins/specialchar/dialogs/lang/no.js | 0 .../plugins/specialchar/dialogs/lang/oc.js | 0 .../plugins/specialchar/dialogs/lang/pl.js | 0 .../plugins/specialchar/dialogs/lang/pt-br.js | 0 .../plugins/specialchar/dialogs/lang/pt.js | 0 .../plugins/specialchar/dialogs/lang/ro.js | 0 .../plugins/specialchar/dialogs/lang/ru.js | 0 .../plugins/specialchar/dialogs/lang/si.js | 0 .../plugins/specialchar/dialogs/lang/sk.js | 0 .../plugins/specialchar/dialogs/lang/sl.js | 0 .../plugins/specialchar/dialogs/lang/sq.js | 0 .../plugins/specialchar/dialogs/lang/sv.js | 0 .../plugins/specialchar/dialogs/lang/th.js | 0 .../plugins/specialchar/dialogs/lang/tr.js | 0 .../plugins/specialchar/dialogs/lang/tt.js | 0 .../plugins/specialchar/dialogs/lang/ug.js | 0 .../plugins/specialchar/dialogs/lang/uk.js | 0 .../plugins/specialchar/dialogs/lang/vi.js | 0 .../plugins/specialchar/dialogs/lang/zh-cn.js | 0 .../plugins/specialchar/dialogs/lang/zh.js | 0 .../specialchar/dialogs/specialchar.js | 0 .../ckeditor/plugins/table/dialogs/table.js | 0 .../tableselection/styles/tableselection.css | 6 - .../plugins/tabletools/dialogs/tableCell.js | 0 .../plugins/templates/dialogs/templates.css | 0 .../plugins/templates/dialogs/templates.js | 0 .../plugins/templates/templates/default.js | 0 .../templates/templates/images/template1.gif | Bin .../templates/templates/images/template2.gif | Bin .../templates/templates/images/template3.gif | Bin .../ckeditor/plugins/widget/images/handle.png | Bin .../plugs/ckeditor/plugins/wsc/LICENSE.md | 0 .../plugs/ckeditor/plugins/wsc/README.md | 0 .../ckeditor/plugins/wsc/dialogs/ciframe.html | 0 .../plugins/wsc/dialogs/tmpFrameset.html | 52 + .../ckeditor/plugins/wsc/dialogs/wsc.css | 0 .../plugs/ckeditor/plugins/wsc/dialogs/wsc.js | 91 + .../ckeditor/plugins/wsc/dialogs/wsc_ie.js | 0 .../plugins/wsc/skins/moono-lisa/wsc.css | 0 .../ckeditor/skins/moono-lisa/dialog.css | 0 .../ckeditor/skins/moono-lisa/dialog_ie.css | 0 .../ckeditor/skins/moono-lisa/dialog_ie8.css | 0 .../skins/moono-lisa/dialog_iequirks.css | 0 .../ckeditor/skins/moono-lisa/editor.css | 2 +- .../skins/moono-lisa/editor_gecko.css | 2 +- .../ckeditor/skins/moono-lisa/editor_ie.css | 2 +- .../ckeditor/skins/moono-lisa/editor_ie8.css | 2 +- .../skins/moono-lisa/editor_iequirks.css | 2 +- .../plugs/ckeditor/skins/moono-lisa/icons.png | Bin .../ckeditor/skins/moono-lisa/icons_hidpi.png | Bin .../skins/moono-lisa/images/arrow.png | Bin .../skins/moono-lisa/images/close.png | Bin .../skins/moono-lisa/images/hidpi/close.png | Bin .../moono-lisa/images/hidpi/lock-open.png | Bin .../skins/moono-lisa/images/hidpi/lock.png | Bin .../skins/moono-lisa/images/hidpi/refresh.png | Bin .../skins/moono-lisa/images/lock-open.png | Bin .../ckeditor/skins/moono-lisa/images/lock.png | Bin .../skins/moono-lisa/images/refresh.png | Bin .../skins/moono-lisa/images/spinner.gif | Bin .../plugs/ckeditor/skins/moono-lisa/readme.md | 2 +- public/static/plugs/ckeditor/styles.js | 79 + public/static/plugs/jquery/autocompleter.css | 79 + .../static/plugs/jquery/autocompleter.min.js | 9 + .../static}/plugs/jquery/base64.min.js | 0 .../static}/plugs/jquery/jquery.min.js | 0 .../static/plugs/jquery/json.min.js | 0 .../static}/plugs/jquery/masonry.min.js | 0 public/static/plugs/jquery/md5.min.js | 1 + .../static}/plugs/jquery/pace.min.js | 2 +- .../static}/plugs/jquery/pcasunzips.js | 58 +- public/static/plugs/layui/css/layui.css | 2 + .../static}/plugs/layui/css/layui.mobile.css | 2 +- .../static}/plugs/layui/css/modules/code.css | 2 +- .../css/modules/laydate/default/laydate.css | 2 +- .../css/modules/layer/default/icon-ext.png | Bin .../layui/css/modules/layer/default/icon.png | Bin .../layui/css/modules/layer/default/layer.css | 2 +- .../css/modules/layer/default/loading-0.gif | Bin .../css/modules/layer/default/loading-1.gif | Bin .../css/modules/layer/default/loading-2.gif | Bin .../static}/plugs/layui/font/iconfont.eot | Bin 40144 -> 40844 bytes .../static}/plugs/layui/font/iconfont.svg | 19 +- .../static}/plugs/layui/font/iconfont.ttf | Bin 39968 -> 40668 bytes public/static/plugs/layui/font/iconfont.woff | Bin 0 -> 26744 bytes .../static}/plugs/layui/images/face/0.gif | Bin .../static}/plugs/layui/images/face/1.gif | Bin .../static}/plugs/layui/images/face/10.gif | Bin .../static}/plugs/layui/images/face/11.gif | Bin .../static}/plugs/layui/images/face/12.gif | Bin .../static}/plugs/layui/images/face/13.gif | Bin .../static}/plugs/layui/images/face/14.gif | Bin .../static}/plugs/layui/images/face/15.gif | Bin .../static}/plugs/layui/images/face/16.gif | Bin .../static}/plugs/layui/images/face/17.gif | Bin .../static}/plugs/layui/images/face/18.gif | Bin .../static}/plugs/layui/images/face/19.gif | Bin .../static}/plugs/layui/images/face/2.gif | Bin .../static}/plugs/layui/images/face/20.gif | Bin .../static}/plugs/layui/images/face/21.gif | Bin .../static}/plugs/layui/images/face/22.gif | Bin .../static}/plugs/layui/images/face/23.gif | Bin .../static}/plugs/layui/images/face/24.gif | Bin .../static}/plugs/layui/images/face/25.gif | Bin .../static}/plugs/layui/images/face/26.gif | Bin .../static}/plugs/layui/images/face/27.gif | Bin .../static}/plugs/layui/images/face/28.gif | Bin .../static}/plugs/layui/images/face/29.gif | Bin .../static}/plugs/layui/images/face/3.gif | Bin .../static}/plugs/layui/images/face/30.gif | Bin .../static}/plugs/layui/images/face/31.gif | Bin .../static}/plugs/layui/images/face/32.gif | Bin .../static}/plugs/layui/images/face/33.gif | Bin .../static}/plugs/layui/images/face/34.gif | Bin .../static}/plugs/layui/images/face/35.gif | Bin .../static}/plugs/layui/images/face/36.gif | Bin .../static}/plugs/layui/images/face/37.gif | Bin .../static}/plugs/layui/images/face/38.gif | Bin .../static}/plugs/layui/images/face/39.gif | Bin .../static}/plugs/layui/images/face/4.gif | Bin .../static}/plugs/layui/images/face/40.gif | Bin .../static}/plugs/layui/images/face/41.gif | Bin .../static}/plugs/layui/images/face/42.gif | Bin .../static}/plugs/layui/images/face/43.gif | Bin .../static}/plugs/layui/images/face/44.gif | Bin .../static}/plugs/layui/images/face/45.gif | Bin .../static}/plugs/layui/images/face/46.gif | Bin .../static}/plugs/layui/images/face/47.gif | Bin .../static}/plugs/layui/images/face/48.gif | Bin .../static}/plugs/layui/images/face/49.gif | Bin .../static}/plugs/layui/images/face/5.gif | Bin .../static}/plugs/layui/images/face/50.gif | Bin .../static}/plugs/layui/images/face/51.gif | Bin .../static}/plugs/layui/images/face/52.gif | Bin .../static}/plugs/layui/images/face/53.gif | Bin .../static}/plugs/layui/images/face/54.gif | Bin .../static}/plugs/layui/images/face/55.gif | Bin .../static}/plugs/layui/images/face/56.gif | Bin .../static}/plugs/layui/images/face/57.gif | Bin .../static}/plugs/layui/images/face/58.gif | Bin .../static}/plugs/layui/images/face/59.gif | Bin .../static}/plugs/layui/images/face/6.gif | Bin .../static}/plugs/layui/images/face/60.gif | Bin .../static}/plugs/layui/images/face/61.gif | Bin .../static}/plugs/layui/images/face/62.gif | Bin .../static}/plugs/layui/images/face/63.gif | Bin .../static}/plugs/layui/images/face/64.gif | Bin .../static}/plugs/layui/images/face/65.gif | Bin .../static}/plugs/layui/images/face/66.gif | Bin .../static}/plugs/layui/images/face/67.gif | Bin .../static}/plugs/layui/images/face/68.gif | Bin .../static}/plugs/layui/images/face/69.gif | Bin .../static}/plugs/layui/images/face/7.gif | Bin .../static}/plugs/layui/images/face/70.gif | Bin .../static}/plugs/layui/images/face/71.gif | Bin .../static}/plugs/layui/images/face/8.gif | Bin .../static}/plugs/layui/images/face/9.gif | Bin .../plugs/layui/lay/modules/carousel.js | 2 +- .../static}/plugs/layui/lay/modules/code.js | 2 +- .../plugs/layui/lay/modules/colorpicker.js | 2 + .../plugs/layui/lay/modules/element.js | 2 +- .../static}/plugs/layui/lay/modules/flow.js | 2 +- public/static/plugs/layui/lay/modules/form.js | 2 + .../static}/plugs/layui/lay/modules/jquery.js | 2 +- .../static/plugs/layui/lay/modules/laydate.js | 2 + .../plugs/layui/lay/modules/layedit.js | 2 +- .../static/plugs/layui/lay/modules/layer.js | 2 + .../plugs/layui/lay/modules/laypage.js | 2 +- .../static}/plugs/layui/lay/modules/laytpl.js | 2 +- .../static}/plugs/layui/lay/modules/mobile.js | 2 +- .../static}/plugs/layui/lay/modules/rate.js | 2 +- .../static/plugs/layui/lay/modules/slider.js | 2 + .../static/plugs/layui/lay/modules/table.js | 2 + .../static}/plugs/layui/lay/modules/tree.js | 2 +- .../static/plugs/layui/lay/modules/upload.js | 2 + public/static/plugs/layui/lay/modules/util.js | 2 + public/static/plugs/layui/layui.all.js | 5 + public/static/plugs/layui/layui.js | 2 + public/static/plugs/plupload/Moxie.swf | Bin 0 -> 27640 bytes public/static/plugs/plupload/Moxie.xap | Bin 0 -> 65757 bytes public/static/plugs/plupload/build.js | 58 + public/static/plugs/plupload/moxie.min.js | 16 + .../plugs/plupload/plupload.full.min.js | 29 + public/static/plugs/plupload/plupload.min.js | 13 + .../static/plugs/require/css.js | 0 .../static}/plugs/require/require.js | 0 .../static}/plugs/socket/swfobject.js | 0 public/static/plugs/socket/websocket.js | 6 + .../static/plugs/socket/websocket.swf | Bin public/static/plugs/spop/spop.min.css | 5 + public/static/plugs/spop/spop.min.js | 6 + public/static/plugs/supersized/progress.gif | Bin 0 -> 5481 bytes .../plugs/supersized/supersized.3.2.7.min.js | 677 + public/static/plugs/supersized/supersized.css | 1 + .../static}/plugs/uploader/Uploader.swf | Bin .../static}/plugs/uploader/theme/bg.png | Bin .../plugs/uploader/theme/expressInstall.swf | Bin .../static}/plugs/uploader/theme/icons.png | Bin .../static}/plugs/uploader/theme/image.png | Bin .../static}/plugs/uploader/theme/progress.png | Bin .../static}/plugs/uploader/theme/success.png | Bin .../static}/plugs/uploader/theme/upload.js | 0 .../static}/plugs/uploader/theme/uploader.css | 0 .../static}/plugs/uploader/webuploader.css | 0 .../static}/plugs/uploader/webuploader.min.js | 0 .../ztree/zTreeStyle/img/diy/1_close.png | Bin .../plugs/ztree/zTreeStyle/img/diy/1_open.png | Bin .../plugs/ztree/zTreeStyle/img/diy/2.png | Bin .../plugs/ztree/zTreeStyle/img/diy/3.png | Bin .../plugs/ztree/zTreeStyle/img/diy/4.png | Bin .../plugs/ztree/zTreeStyle/img/diy/5.png | Bin .../plugs/ztree/zTreeStyle/img/diy/6.png | Bin .../plugs/ztree/zTreeStyle/img/diy/7.png | Bin .../plugs/ztree/zTreeStyle/img/diy/8.png | Bin .../plugs/ztree/zTreeStyle/img/diy/9.png | Bin .../plugs/ztree/zTreeStyle/img/line_conn.gif | Bin .../plugs/ztree/zTreeStyle/img/loading.gif | Bin .../ztree/zTreeStyle/img/zTreeStandard.gif | Bin .../ztree/zTreeStyle/img/zTreeStandard.png | Bin .../plugs/ztree/zTreeStyle/zTreeStyle.css | 0 public/static/plugs/ztree/ztree.all.min.js | 166 + public/static/theme/css/console.css | 197 + public/static/theme/css/icon/iconfont.eot | Bin 0 -> 2464 bytes public/static/theme/css/icon/iconfont.svg | 35 + public/static/theme/css/icon/iconfont.ttf | Bin 0 -> 2296 bytes public/static/theme/css/icon/iconfont.woff | Bin 0 -> 1540 bytes public/static/theme/css/login.css | 56 + public/static/theme/css/mobile.css | 30 + .../static}/theme/img/404_icon.png | Bin .../static}/theme/img/505_icon.png | Bin .../static}/theme/img/headimg.png | Bin {static => public/static}/theme/img/image.png | Bin public/static/theme/img/login/bg1.jpg | Bin 0 -> 55719 bytes public/static/theme/img/login/bg2.jpg | Bin 0 -> 67855 bytes .../static}/theme/img/wechat/index.png | Bin .../static}/theme/img/wechat/mobile_foot.png | Bin .../static}/theme/img/wechat/mobile_head.png | Bin .../static/theme/img/wechat/qrc_pay_error.jpg | Bin 0 -> 44321 bytes .../static}/theme/img/wechat/qrc_payed.jpg | Bin route/demo.php | 45 +- static/admin.js | 667 - static/app.js | 73 - static/mobile/lib/city-picker.js | 16713 ---------------- static/mobile/lib/city-picker.min.js | 5 - static/mobile/lib/fastclick.js | 842 - static/mobile/lib/fastclick.min.js | 3 - static/mobile/lib/jquery-weui.js | 6441 ------ static/mobile/lib/jquery-weui.min.js | 13 - static/mobile/lib/jquery.js | 10364 ---------- static/mobile/lib/jquery.min.js | 2 - static/mobile/lib/swiper.js | 4160 ---- static/mobile/lib/swiper.min.js | 17 - static/mobile/library.min.css | 12 - static/mobile/library.min.js | 19 - static/plugs/aui/aui-iconfont.ttf | Bin 36352 -> 0 bytes static/plugs/aui/aui.css | 3275 --- static/plugs/awesome/css/font-awesome.css | 2337 --- static/plugs/awesome/css/font-awesome.min.css | 4 - .../bootstrap-multiselect.css | 1 - .../bootstrap-multiselect.js | 1683 -- .../plugs/bootstrap/css/bootstrap-theme.css | 587 - .../bootstrap/css/bootstrap-theme.css.map | 1 - .../bootstrap/css/bootstrap-theme.min.css | 6 - .../bootstrap/css/bootstrap-theme.min.css.map | 1 - static/plugs/bootstrap/css/bootstrap.css | 6757 ------- static/plugs/bootstrap/css/bootstrap.css.map | 1 - static/plugs/bootstrap/css/bootstrap.min.css | 6 - .../plugs/bootstrap/css/bootstrap.min.css.map | 1 - .../fonts/glyphicons-halflings-regular.eot | Bin 20127 -> 0 bytes .../fonts/glyphicons-halflings-regular.svg | 288 - .../fonts/glyphicons-halflings-regular.ttf | Bin 45404 -> 0 bytes .../fonts/glyphicons-halflings-regular.woff | Bin 23424 -> 0 bytes .../fonts/glyphicons-halflings-regular.woff2 | Bin 18028 -> 0 bytes static/plugs/bootstrap/js/bootstrap.js | 2377 --- static/plugs/bootstrap/js/bootstrap.min.js | 7 - .../bootstrap/js/bootstrap3-typeahead.min.js | 1 - .../js/debug/ie-emulation-modes-warning.js | 50 - .../js/debug/ie10-viewport-bug-workaround.js | 17 - static/plugs/bootstrap/js/npm.js | 13 - static/plugs/ckeditor/config.js | 55 - static/plugs/ckeditor/lang/af.js | 5 - static/plugs/ckeditor/lang/ar.js | 5 - static/plugs/ckeditor/lang/az.js | 5 - static/plugs/ckeditor/lang/bg.js | 5 - static/plugs/ckeditor/lang/bn.js | 5 - static/plugs/ckeditor/lang/bs.js | 5 - static/plugs/ckeditor/lang/ca.js | 5 - static/plugs/ckeditor/lang/cs.js | 5 - static/plugs/ckeditor/lang/cy.js | 5 - static/plugs/ckeditor/lang/da.js | 5 - static/plugs/ckeditor/lang/de-ch.js | 5 - static/plugs/ckeditor/lang/de.js | 5 - static/plugs/ckeditor/lang/el.js | 5 - static/plugs/ckeditor/lang/en-au.js | 5 - static/plugs/ckeditor/lang/en-ca.js | 5 - static/plugs/ckeditor/lang/en-gb.js | 5 - static/plugs/ckeditor/lang/eo.js | 5 - static/plugs/ckeditor/lang/es-mx.js | 5 - static/plugs/ckeditor/lang/es.js | 5 - static/plugs/ckeditor/lang/et.js | 5 - static/plugs/ckeditor/lang/eu.js | 5 - static/plugs/ckeditor/lang/fa.js | 5 - static/plugs/ckeditor/lang/fi.js | 5 - static/plugs/ckeditor/lang/fo.js | 5 - static/plugs/ckeditor/lang/fr-ca.js | 5 - static/plugs/ckeditor/lang/fr.js | 5 - static/plugs/ckeditor/lang/gl.js | 5 - static/plugs/ckeditor/lang/gu.js | 5 - static/plugs/ckeditor/lang/he.js | 5 - static/plugs/ckeditor/lang/hi.js | 5 - static/plugs/ckeditor/lang/hr.js | 5 - static/plugs/ckeditor/lang/hu.js | 5 - static/plugs/ckeditor/lang/id.js | 5 - static/plugs/ckeditor/lang/is.js | 5 - static/plugs/ckeditor/lang/it.js | 5 - static/plugs/ckeditor/lang/ja.js | 5 - static/plugs/ckeditor/lang/ka.js | 5 - static/plugs/ckeditor/lang/km.js | 5 - static/plugs/ckeditor/lang/ko.js | 5 - static/plugs/ckeditor/lang/ku.js | 5 - static/plugs/ckeditor/lang/lt.js | 5 - static/plugs/ckeditor/lang/lv.js | 5 - static/plugs/ckeditor/lang/mk.js | 5 - static/plugs/ckeditor/lang/mn.js | 5 - static/plugs/ckeditor/lang/ms.js | 5 - static/plugs/ckeditor/lang/nb.js | 5 - static/plugs/ckeditor/lang/nl.js | 5 - static/plugs/ckeditor/lang/no.js | 5 - static/plugs/ckeditor/lang/oc.js | 5 - static/plugs/ckeditor/lang/pl.js | 5 - static/plugs/ckeditor/lang/pt-br.js | 5 - static/plugs/ckeditor/lang/pt.js | 5 - static/plugs/ckeditor/lang/ro.js | 5 - static/plugs/ckeditor/lang/ru.js | 5 - static/plugs/ckeditor/lang/si.js | 5 - static/plugs/ckeditor/lang/sk.js | 5 - static/plugs/ckeditor/lang/sl.js | 5 - static/plugs/ckeditor/lang/sq.js | 5 - static/plugs/ckeditor/lang/sr-latn.js | 5 - static/plugs/ckeditor/lang/sr.js | 5 - static/plugs/ckeditor/lang/sv.js | 5 - static/plugs/ckeditor/lang/th.js | 5 - static/plugs/ckeditor/lang/tr.js | 5 - static/plugs/ckeditor/lang/tt.js | 5 - static/plugs/ckeditor/lang/ug.js | 5 - static/plugs/ckeditor/lang/uk.js | 5 - static/plugs/ckeditor/lang/vi.js | 5 - static/plugs/ckeditor/lang/zh-cn.js | 5 - static/plugs/ckeditor/lang/zh.js | 5 - .../plugins/a11yhelp/dialogs/lang/bg.js | 11 - .../ckeditor/plugins/find/dialogs/find.js | 25 - .../ckeditor/plugins/image/dialogs/image.js | 44 - .../ckeditor/plugins/scayt/dialogs/options.js | 33 - .../plugins/wsc/dialogs/tmpFrameset.html | 61 - .../plugs/ckeditor/plugins/wsc/dialogs/wsc.js | 91 - static/plugs/ckeditor/styles.js | 137 - static/plugs/clipboard/clipboard.js | 939 - static/plugs/clipboard/clipboard.min.js | 7 - static/plugs/distpicker/distpicker.data.js | 4528 ----- static/plugs/distpicker/distpicker.js | 248 - static/plugs/jquery/jquery.PrintArea.js | 201 - static/plugs/jquery/jquery.cascade.js | 100 - static/plugs/jquery/jquery.citys.js | 249 - static/plugs/jquery/jquery.cookie.js | 118 - static/plugs/layui/css/layui.css | 2 - static/plugs/layui/font/iconfont.woff | Bin 26328 -> 0 bytes static/plugs/layui/lay/modules/form.js | 2 - static/plugs/layui/lay/modules/laydate.js | 2 - static/plugs/layui/lay/modules/layer.js | 2 - static/plugs/layui/lay/modules/table.js | 2 - static/plugs/layui/lay/modules/upload.js | 2 - static/plugs/layui/lay/modules/util.js | 2 - static/plugs/layui/layui.all.js | 5 - static/plugs/layui/layui.js | 2 - static/plugs/socket/websocket.js | 401 - static/plugs/template/template.js | 2 - static/plugs/uploader/webuploader.js | 8106 -------- static/plugs/ztree/jquery.ztree.all.min.js | 165 - static/theme/css/animate.css | 2860 --- static/theme/css/console.css | 163 - static/theme/css/login.css | 63 - static/theme/img/icon.png | Bin 2857 -> 0 bytes static/theme/img/login/bg.png | Bin 153525 -> 0 bytes static/theme/img/login/bg_form.png | Bin 67202 -> 0 bytes static/theme/img/login/cloud.png | Bin 35150 -> 0 bytes static/theme/img/login/cloud_one.png | Bin 195897 -> 0 bytes static/theme/img/login/cloud_two.png | Bin 286793 -> 0 bytes static/theme/img/login/hand.png | Bin 1061 -> 0 bytes static/theme/img/login/hand_left.png | Bin 1469 -> 0 bytes static/theme/img/login/hand_right.png | Bin 1370 -> 0 bytes static/theme/img/login/hand_tou.png | Bin 9217 -> 0 bytes think | 16 +- vendor/autoload.php | 2 +- vendor/composer/autoload_classmap.php | 58 +- vendor/composer/autoload_files.php | 4 +- vendor/composer/autoload_psr4.php | 4 +- vendor/composer/autoload_real.php | 14 +- vendor/composer/autoload_static.php | 89 +- vendor/composer/installed.json | 139 +- vendor/topthink/think-captcha/LICENSE | 32 - vendor/topthink/think-captcha/README.md | 33 - .../topthink/think-captcha/assets/bgs/1.jpg | Bin 30428 -> 0 bytes .../topthink/think-captcha/assets/bgs/2.jpg | Bin 29677 -> 0 bytes .../topthink/think-captcha/assets/bgs/3.jpg | Bin 32109 -> 0 bytes .../topthink/think-captcha/assets/bgs/4.jpg | Bin 29081 -> 0 bytes .../topthink/think-captcha/assets/bgs/5.jpg | Bin 27940 -> 0 bytes .../topthink/think-captcha/assets/bgs/6.jpg | Bin 31381 -> 0 bytes .../topthink/think-captcha/assets/bgs/7.jpg | Bin 30234 -> 0 bytes .../topthink/think-captcha/assets/bgs/8.jpg | Bin 30188 -> 0 bytes .../topthink/think-captcha/assets/ttfs/1.ttf | Bin 57520 -> 0 bytes .../topthink/think-captcha/assets/ttfs/2.ttf | Bin 28328 -> 0 bytes .../topthink/think-captcha/assets/ttfs/3.ttf | Bin 39308 -> 0 bytes .../topthink/think-captcha/assets/ttfs/4.ttf | Bin 34852 -> 0 bytes .../topthink/think-captcha/assets/ttfs/5.ttf | Bin 32664 -> 0 bytes .../topthink/think-captcha/assets/ttfs/6.ttf | Bin 28036 -> 0 bytes .../think-captcha/assets/zhttfs/1.ttf | Bin 2183628 -> 0 bytes vendor/topthink/think-captcha/src/Captcha.php | 320 - vendor/topthink/think-captcha/src/helper.php | 59 - vendor/topthink/think-helper/.gitignore | 2 + vendor/topthink/think-helper/LICENSE | 201 + vendor/topthink/think-helper/README.md | 32 + .../composer.json | 11 +- vendor/topthink/think-helper/src/Arr.php | 41 + vendor/topthink/think-helper/src/Str.php | 202 + vendor/topthink/think-helper/src/helper.php | 38 + .../{think-captcha => think-queue}/.gitignore | 3 +- vendor/topthink/think-queue/LICENSE | 201 + vendor/topthink/think-queue/README.md | 135 + vendor/topthink/think-queue/composer.json | 30 + vendor/topthink/think-queue/src/Queue.php | 49 + vendor/topthink/think-queue/src/common.php | 36 + vendor/topthink/think-queue/src/config.php | 14 + .../src/queue/CallQueuedHandler.php | 36 + .../think-queue/src/queue/Connector.php | 69 + vendor/topthink/think-queue/src/queue/Job.php | 213 + .../think-queue/src/queue/Listener.php | 164 + .../think-queue/src/queue/Queueable.php | 46 + .../src/queue/ShouldQueue.php} | 16 +- .../topthink/think-queue/src/queue/Worker.php | 119 + .../think-queue/src/queue/command/Listen.php | 60 + .../think-queue/src/queue/command/Restart.php | 31 + .../src/queue/command/Subscribe.php | 46 + .../think-queue/src/queue/command/Work.php | 210 + .../src/queue/connector/Database.php | 169 + .../think-queue/src/queue/connector/Redis.php | 236 + .../think-queue/src/queue/connector/Sync.php | 57 + .../src/queue/connector/Topthink.php | 223 + .../think-queue/src/queue/job/Database.php | 88 + .../think-queue/src/queue/job/Redis.php | 92 + .../think-queue/src/queue/job/Sync.php | 56 + .../think-queue/src/queue/job/Topthink.php | 85 + vendor/zoujingli/think-library/.gitignore | 5 + vendor/zoujingli/think-library/common.php | 229 + vendor/zoujingli/think-library/composer.json | 25 + vendor/zoujingli/think-library/readme.md | 208 + .../think-library/src/Controller.php | 175 + vendor/zoujingli/think-library/src/File.php | 197 + .../think-library/src/command/Sess.php | 45 + .../think-library/src/command/Sync.php | 230 + .../think-library/src/command/Task.php | 104 + .../think-library/src/command/sync/Admin.php | 31 + .../think-library/src/command/sync/Config.php | 31 + .../think-library/src/command/sync/Plugs.php | 31 + .../src/command/sync/Service.php | 30 + .../think-library/src/command/sync/Wechat.php | 31 + .../think-library/src/command/task/Reset.php | 45 + .../think-library/src/command/task/Start.php | 45 + .../think-library/src/command/task/State.php | 40 + .../think-library/src/command/task/Stop.php | 41 + .../think-library/src/driver/Local.php | 143 + .../think-library/src/driver/Oss.php | 201 + .../think-library/src/driver/Qiniu.php | 175 + .../think-library/src/logic/Delete.php | 96 + .../think-library/src/logic/Form.php | 114 + .../think-library/src/logic/Input.php | 94 + .../think-library/src/logic/Logic.php | 56 + .../think-library/src/logic/Page.php | 142 + .../think-library/src/logic/Query.php | 185 + .../think-library/src/logic/Save.php | 100 + .../think-library/src/tools/Cors.php | 105 + .../think-library/src/tools/Crypt.php | 84 + .../think-library/src/tools/Csrf.php | 91 + .../zoujingli/think-library/src/tools/Csv.php | 67 + .../think-library/src/tools/Data.php | 141 + .../think-library/src/tools/Express.php | 55 + .../think-library/src/tools/Http.php | 140 + .../think-library/src/tools/Node.php | 91 + .../think-library/src/tools/Options.php | 137 + vendor/zoujingli/weopen-developer/README.md | 4 +- .../weopen-developer/WeChat/Bind.php | 80 + .../weopen-developer/WeOpen/Service.php | 14 + .../weopen-developer/{Test => _test}/open.php | 0 .../{Test => _test}/wechat.sql | 0 .../zoujingli/weopen-developer/composer.json | 3 +- 939 files changed, 23018 insertions(+), 88785 deletions(-) delete mode 100644 .gitattributes delete mode 100644 LICENSE delete mode 100644 admin_v3.sql create mode 100644 admin_v4.sql delete mode 100644 application/.htaccess create mode 100644 application/admin/controller/Message.php delete mode 100644 application/admin/controller/Plugs.php create mode 100644 application/admin/controller/Queue.php create mode 100644 application/admin/controller/api/Message.php create mode 100644 application/admin/controller/api/Plugs.php create mode 100644 application/admin/controller/api/Update.php delete mode 100644 application/admin/middleware/Auth.php create mode 100644 application/admin/queue/JobsBase.php create mode 100644 application/admin/service/Auth.php rename extend/service/LogService.php => application/admin/service/Log.php (50%) create mode 100644 application/admin/service/Message.php create mode 100644 application/admin/service/Queue.php create mode 100644 application/admin/sys.php rename application/admin/view/{ => api}/plugs/icon.html (99%) create mode 100644 application/admin/view/api/plugs/message.html create mode 100644 application/admin/view/api/plugs/upfile.html create mode 100644 application/admin/view/auth/index_search.html create mode 100644 application/admin/view/config/file_local.html create mode 100644 application/admin/view/config/file_oss.html create mode 100644 application/admin/view/config/file_qiniu.html delete mode 100644 application/admin/view/config/index.html create mode 100644 application/admin/view/config/info.html create mode 100644 application/admin/view/index/command.html create mode 100644 application/admin/view/log/index_search.html delete mode 100644 application/admin/view/log/sms.html create mode 100644 application/admin/view/main.html create mode 100644 application/admin/view/message/index.html create mode 100644 application/admin/view/message/index_search.html delete mode 100644 application/admin/view/plugs/upfile.html delete mode 100644 application/admin/view/public/content.html delete mode 100644 application/admin/view/public/main.html create mode 100644 application/admin/view/queue/index.html create mode 100644 application/admin/view/queue/index_search.html create mode 100644 application/admin/view/user/index_search.html delete mode 100644 application/common.php create mode 100644 application/service/controller/Config.php create mode 100644 application/service/controller/Index.php create mode 100644 application/service/controller/api/Client.php create mode 100644 application/service/controller/api/Push.php create mode 100644 application/service/handler/Publish.php create mode 100644 application/service/handler/Receive.php create mode 100644 application/service/handler/Wechat.php create mode 100644 application/service/logic/Build.php create mode 100644 application/service/logic/Wechat.php create mode 100644 application/service/view/config/index.html create mode 100644 application/service/view/index/index.html create mode 100644 application/service/view/index/index_search.html create mode 100644 application/store/command/AutoRun.php create mode 100644 application/store/controller/Config.php delete mode 100644 application/store/controller/GoodsBrand.php delete mode 100644 application/store/controller/GoodsSpec.php create mode 100644 application/store/controller/Member.php create mode 100644 application/store/controller/Message.php create mode 100644 application/store/controller/Page.php create mode 100644 application/store/controller/api/Express.php create mode 100644 application/store/controller/api/Goods.php create mode 100644 application/store/controller/api/Member.php create mode 100644 application/store/controller/api/Notify.php create mode 100644 application/store/controller/api/Page.php create mode 100644 application/store/controller/api/Wechat.php create mode 100644 application/store/controller/api/member/Address.php create mode 100644 application/store/controller/api/member/Center.php create mode 100644 application/store/controller/api/member/Order.php delete mode 100644 application/store/controller/wechat/Demo.php delete mode 100644 application/store/init.php create mode 100644 application/store/service/Extend.php create mode 100644 application/store/service/Goods.php delete mode 100644 application/store/service/GoodsService.php create mode 100644 application/store/service/Order.php delete mode 100644 application/store/service/OrderService.php rename application/{middleware.php => store/sys.php} (72%) create mode 100644 application/store/view/config/index.html create mode 100644 application/store/view/express/index_search.html create mode 100644 application/store/view/goods/index_search.html delete mode 100644 application/store/view/goods_brand/form.html delete mode 100644 application/store/view/goods_brand/index.html create mode 100644 application/store/view/goods_cate/index_search.html delete mode 100644 application/store/view/goods_spec/form.html delete mode 100644 application/store/view/goods_spec/index.html create mode 100644 application/store/view/member/index.html create mode 100644 application/store/view/member/index_search.html create mode 100644 application/store/view/message/index.html create mode 100644 application/store/view/message/index_search.html delete mode 100644 application/store/view/order/address.html create mode 100644 application/store/view/order/express.html create mode 100644 application/store/view/order/express_query.html create mode 100644 application/store/view/order/index_search.html create mode 100644 application/store/view/page/form.html create mode 100644 application/store/view/page/index.html create mode 100644 application/wechat/command/Fans.php rename application/{store/service/MemberService.php => wechat/command/fans/FansAll.php} (54%) create mode 100644 application/wechat/command/fans/FansBlack.php create mode 100644 application/wechat/command/fans/FansList.php create mode 100644 application/wechat/command/fans/FansTags.php delete mode 100644 application/wechat/controller/FansBlock.php delete mode 100644 application/wechat/controller/Review.php delete mode 100644 application/wechat/controller/Tags.php create mode 100644 application/wechat/controller/api/Review.php create mode 100644 application/wechat/queue/Jobs.php create mode 100644 application/wechat/service/Fans.php delete mode 100644 application/wechat/service/FansService.php create mode 100644 application/wechat/service/Media.php delete mode 100644 application/wechat/service/MediaService.php delete mode 100644 application/wechat/service/TagsService.php create mode 100644 application/wechat/service/Wechat.php create mode 100644 application/wechat/sys.php create mode 100644 application/wechat/view/api/review/image.html create mode 100644 application/wechat/view/api/review/main.html create mode 100644 application/wechat/view/api/review/music.html create mode 100644 application/wechat/view/api/review/news.html create mode 100644 application/wechat/view/api/review/text.html create mode 100644 application/wechat/view/api/review/video.html create mode 100644 application/wechat/view/api/review/view.html create mode 100644 application/wechat/view/api/review/voice.html delete mode 100644 application/wechat/view/api/script/index.js delete mode 100644 application/wechat/view/config/index.html create mode 100644 application/wechat/view/config/options.html create mode 100644 application/wechat/view/config/options_api.html create mode 100644 application/wechat/view/config/options_help.html create mode 100644 application/wechat/view/config/options_thr.html create mode 100644 application/wechat/view/config/payment.html create mode 100644 application/wechat/view/fans/index_search.html delete mode 100644 application/wechat/view/fans/search_inc.html delete mode 100644 application/wechat/view/fans/tags_inc.html delete mode 100644 application/wechat/view/fans_block/index.html create mode 100644 application/wechat/view/keys/index_search.html delete mode 100644 application/wechat/view/news/image.html delete mode 100644 application/wechat/view/review/index.html delete mode 100644 application/wechat/view/tags/form.html delete mode 100644 application/wechat/view/tags/index.html delete mode 100644 build.sh create mode 100644 config/cert/1332187001_20181030_cert.p12 create mode 100644 config/cert/1332187001_20181030_cert.pem create mode 100644 config/cert/1332187001_20181030_key.pem create mode 100644 config/cookie.php rename application/store/controller/wechat/Index.php => config/queue.php (56%) delete mode 100644 extend/controller/BasicAdmin.php delete mode 100644 extend/controller/BasicApi.php delete mode 100644 extend/controller/BasicWechat.php delete mode 100644 extend/service/AlismsService.php delete mode 100644 extend/service/DataService.php delete mode 100644 extend/service/FileService.php delete mode 100644 extend/service/HttpService.php delete mode 100644 extend/service/NodeService.php delete mode 100644 extend/service/SoapService.php delete mode 100644 extend/service/ToolsService.php delete mode 100644 extend/service/WechatService.php rename .htaccess => public/.htaccess (100%) create mode 100644 public/4919999519.txt create mode 100644 public/favicon.ico rename index.php => public/index.php (62%) rename route/route.php => public/router.php (56%) create mode 100644 public/static/admin.js create mode 100644 public/static/myself/my plugs file rename {static => public/static}/plugs/angular/angular.min.js (100%) create mode 100644 public/static/plugs/awesome/fonts.css rename {static => public/static}/plugs/awesome/fonts/FontAwesome.otf (100%) rename static/plugs/awesome/fonts/fontawesome-webfont.eot => public/static/plugs/awesome/fonts/webfont.eot (100%) rename static/plugs/awesome/fonts/fontawesome-webfont.svg => public/static/plugs/awesome/fonts/webfont.svg (100%) rename static/plugs/awesome/fonts/fontawesome-webfont.ttf => public/static/plugs/awesome/fonts/webfont.ttf (100%) rename static/plugs/awesome/fonts/fontawesome-webfont.woff => public/static/plugs/awesome/fonts/webfont.woff (100%) rename static/plugs/awesome/fonts/fontawesome-webfont.woff2 => public/static/plugs/awesome/fonts/webfont.woff2 (100%) rename {static => public/static}/plugs/ckeditor/ckeditor.js (77%) create mode 100644 public/static/plugs/ckeditor/config.js rename {static => public/static}/plugs/ckeditor/contents.css (87%) rename {static => public/static}/plugs/ckeditor/lang/en.js (100%) create mode 100644 public/static/plugs/ckeditor/lang/zh-cn.js rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/a11yhelp.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/_translationstatus.txt (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/af.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ar.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/az.js (100%) create mode 100644 public/static/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/bg.js rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ca.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/cs.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/cy.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/da.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/de-ch.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/de.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/el.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/en-au.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/en-gb.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/en.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/eo.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/es-mx.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/es.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/et.js (82%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/eu.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/fa.js (72%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/fi.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/fo.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/fr-ca.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/fr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/gl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/gu.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/he.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/hi.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/hr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/hu.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/id.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/it.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ja.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/km.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ko.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ku.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/lt.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/lv.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/mk.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/mn.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/nb.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/nl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/no.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/oc.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/pl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/pt-br.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/pt.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ro.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ru.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/si.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/sk.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/sl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/sq.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/sr-latn.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/sr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/sv.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/th.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/tr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/tt.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/ug.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/uk.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/vi.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/zh-cn.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/zh.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/about/dialogs/about.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/about/dialogs/hidpi/logo_ckeditor.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/about/dialogs/logo_ckeditor.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/clipboard/dialogs/paste.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/colordialog/dialogs/colordialog.css (100%) rename {static => public/static}/plugs/ckeditor/plugins/colordialog/dialogs/colordialog.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/copyformatting/cursors/cursor-disabled.svg (100%) rename {static => public/static}/plugs/ckeditor/plugins/copyformatting/cursors/cursor.svg (100%) rename {static => public/static}/plugs/ckeditor/plugins/copyformatting/styles/copyformatting.css (100%) rename {static => public/static}/plugs/ckeditor/plugins/dialog/dialogDefinition.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/div/dialogs/div.js (100%) create mode 100644 public/static/plugs/ckeditor/plugins/find/dialogs/find.js rename {static => public/static}/plugs/ckeditor/plugins/flash/dialogs/flash.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/flash/images/placeholder.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/button.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/checkbox.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/form.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/hiddenfield.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/radio.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/select.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/textarea.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/dialogs/textfield.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/forms/images/hiddenfield.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/icons.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/icons_hidpi.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/iframe/dialogs/iframe.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/iframe/images/placeholder.png (100%) create mode 100644 public/static/plugs/ckeditor/plugins/image/dialogs/image.js rename {static => public/static}/plugs/ckeditor/plugins/image/images/noimage.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/link/dialogs/anchor.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/link/dialogs/link.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/link/images/anchor.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/link/images/hidpi/anchor.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/liststyle/dialogs/liststyle.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/magicline/images/hidpi/icon-rtl.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/magicline/images/hidpi/icon.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/magicline/images/icon-rtl.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/magicline/images/icon.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/pagebreak/images/pagebreak.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/pastefromword/filter/default.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/preview/preview.html (100%) rename {static => public/static}/plugs/ckeditor/plugins/scayt/CHANGELOG.md (100%) rename {static => public/static}/plugs/ckeditor/plugins/scayt/LICENSE.md (100%) rename {static => public/static}/plugs/ckeditor/plugins/scayt/README.md (100%) rename {static => public/static}/plugs/ckeditor/plugins/scayt/dialogs/dialog.css (100%) create mode 100644 public/static/plugs/ckeditor/plugins/scayt/dialogs/options.js rename {static => public/static}/plugs/ckeditor/plugins/scayt/dialogs/toolbar.css (100%) rename {static => public/static}/plugs/ckeditor/plugins/scayt/skins/moono-lisa/scayt.css (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_address.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_blockquote.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_div.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_h1.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_h2.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_h3.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_h4.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_h5.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_h6.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_p.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/showblocks/images/block_pre.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/dialogs/smiley.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/angel_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/angel_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/angry_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/angry_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/broken_heart.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/broken_heart.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/confused_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/confused_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/cry_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/cry_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/devil_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/devil_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/embaressed_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/embarrassed_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/embarrassed_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/envelope.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/envelope.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/heart.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/heart.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/kiss.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/kiss.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/lightbulb.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/lightbulb.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/omg_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/omg_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/regular_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/regular_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/sad_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/sad_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/shades_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/shades_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/teeth_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/teeth_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/thumbs_down.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/thumbs_down.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/thumbs_up.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/thumbs_up.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/tongue_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/tongue_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/tounge_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/whatchutalkingabout_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/whatchutalkingabout_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/wink_smile.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/smiley/images/wink_smile.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/_translationstatus.txt (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/af.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ar.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/az.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/bg.js (96%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ca.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/cs.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/cy.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/da.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/de-ch.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/de.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/el.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/en-au.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/en-ca.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/en-gb.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/en.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/eo.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/es-mx.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/es.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/et.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/eu.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/fa.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/fi.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/fr-ca.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/fr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/gl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/he.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/hr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/hu.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/id.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/it.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ja.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/km.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ko.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ku.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/lt.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/lv.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/nb.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/nl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/no.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/oc.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/pl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/pt-br.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/pt.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ro.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ru.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/si.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/sk.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/sl.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/sq.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/sv.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/th.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/tr.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/tt.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/ug.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/uk.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/vi.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/zh-cn.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/lang/zh.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/specialchar/dialogs/specialchar.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/table/dialogs/table.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/tableselection/styles/tableselection.css (74%) rename {static => public/static}/plugs/ckeditor/plugins/tabletools/dialogs/tableCell.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/templates/dialogs/templates.css (100%) rename {static => public/static}/plugs/ckeditor/plugins/templates/dialogs/templates.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/templates/templates/default.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/templates/templates/images/template1.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/templates/templates/images/template2.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/templates/templates/images/template3.gif (100%) rename {static => public/static}/plugs/ckeditor/plugins/widget/images/handle.png (100%) rename {static => public/static}/plugs/ckeditor/plugins/wsc/LICENSE.md (100%) rename {static => public/static}/plugs/ckeditor/plugins/wsc/README.md (100%) rename {static => public/static}/plugs/ckeditor/plugins/wsc/dialogs/ciframe.html (100%) create mode 100644 public/static/plugs/ckeditor/plugins/wsc/dialogs/tmpFrameset.html rename {static => public/static}/plugs/ckeditor/plugins/wsc/dialogs/wsc.css (100%) create mode 100644 public/static/plugs/ckeditor/plugins/wsc/dialogs/wsc.js rename {static => public/static}/plugs/ckeditor/plugins/wsc/dialogs/wsc_ie.js (100%) rename {static => public/static}/plugs/ckeditor/plugins/wsc/skins/moono-lisa/wsc.css (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/dialog.css (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/dialog_ie.css (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/dialog_ie8.css (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/dialog_iequirks.css (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/editor.css (75%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/editor_gecko.css (74%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/editor_ie.css (74%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/editor_ie8.css (75%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/editor_iequirks.css (75%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/icons.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/icons_hidpi.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/arrow.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/close.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/hidpi/close.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/hidpi/lock-open.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/hidpi/lock.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/hidpi/refresh.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/lock-open.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/lock.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/refresh.png (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/images/spinner.gif (100%) rename {static => public/static}/plugs/ckeditor/skins/moono-lisa/readme.md (96%) create mode 100644 public/static/plugs/ckeditor/styles.js create mode 100644 public/static/plugs/jquery/autocompleter.css create mode 100644 public/static/plugs/jquery/autocompleter.min.js rename {static => public/static}/plugs/jquery/base64.min.js (100%) rename {static => public/static}/plugs/jquery/jquery.min.js (100%) rename static/plugs/jquery/json2.min.js => public/static/plugs/jquery/json.min.js (100%) rename {static => public/static}/plugs/jquery/masonry.min.js (100%) create mode 100644 public/static/plugs/jquery/md5.min.js rename {static => public/static}/plugs/jquery/pace.min.js (99%) rename {static => public/static}/plugs/jquery/pcasunzips.js (99%) create mode 100644 public/static/plugs/layui/css/layui.css rename {static => public/static}/plugs/layui/css/layui.mobile.css (99%) rename {static => public/static}/plugs/layui/css/modules/code.css (94%) rename {static => public/static}/plugs/layui/css/modules/laydate/default/laydate.css (99%) rename {static => public/static}/plugs/layui/css/modules/layer/default/icon-ext.png (100%) rename {static => public/static}/plugs/layui/css/modules/layer/default/icon.png (100%) rename {static => public/static}/plugs/layui/css/modules/layer/default/layer.css (99%) rename {static => public/static}/plugs/layui/css/modules/layer/default/loading-0.gif (100%) rename {static => public/static}/plugs/layui/css/modules/layer/default/loading-1.gif (100%) rename {static => public/static}/plugs/layui/css/modules/layer/default/loading-2.gif (100%) rename {static => public/static}/plugs/layui/font/iconfont.eot (88%) rename {static => public/static}/plugs/layui/font/iconfont.svg (98%) rename {static => public/static}/plugs/layui/font/iconfont.ttf (88%) create mode 100644 public/static/plugs/layui/font/iconfont.woff rename {static => public/static}/plugs/layui/images/face/0.gif (100%) rename {static => public/static}/plugs/layui/images/face/1.gif (100%) rename {static => public/static}/plugs/layui/images/face/10.gif (100%) rename {static => public/static}/plugs/layui/images/face/11.gif (100%) rename {static => public/static}/plugs/layui/images/face/12.gif (100%) rename {static => public/static}/plugs/layui/images/face/13.gif (100%) rename {static => public/static}/plugs/layui/images/face/14.gif (100%) rename {static => public/static}/plugs/layui/images/face/15.gif (100%) rename {static => public/static}/plugs/layui/images/face/16.gif (100%) rename {static => public/static}/plugs/layui/images/face/17.gif (100%) rename {static => public/static}/plugs/layui/images/face/18.gif (100%) rename {static => public/static}/plugs/layui/images/face/19.gif (100%) rename {static => public/static}/plugs/layui/images/face/2.gif (100%) rename {static => public/static}/plugs/layui/images/face/20.gif (100%) rename {static => public/static}/plugs/layui/images/face/21.gif (100%) rename {static => public/static}/plugs/layui/images/face/22.gif (100%) rename {static => public/static}/plugs/layui/images/face/23.gif (100%) rename {static => public/static}/plugs/layui/images/face/24.gif (100%) rename {static => public/static}/plugs/layui/images/face/25.gif (100%) rename {static => public/static}/plugs/layui/images/face/26.gif (100%) rename {static => public/static}/plugs/layui/images/face/27.gif (100%) rename {static => public/static}/plugs/layui/images/face/28.gif (100%) rename {static => public/static}/plugs/layui/images/face/29.gif (100%) rename {static => public/static}/plugs/layui/images/face/3.gif (100%) rename {static => public/static}/plugs/layui/images/face/30.gif (100%) rename {static => public/static}/plugs/layui/images/face/31.gif (100%) rename {static => public/static}/plugs/layui/images/face/32.gif (100%) rename {static => public/static}/plugs/layui/images/face/33.gif (100%) rename {static => public/static}/plugs/layui/images/face/34.gif (100%) rename {static => public/static}/plugs/layui/images/face/35.gif (100%) rename {static => public/static}/plugs/layui/images/face/36.gif (100%) rename {static => public/static}/plugs/layui/images/face/37.gif (100%) rename {static => public/static}/plugs/layui/images/face/38.gif (100%) rename {static => public/static}/plugs/layui/images/face/39.gif (100%) rename {static => public/static}/plugs/layui/images/face/4.gif (100%) rename {static => public/static}/plugs/layui/images/face/40.gif (100%) rename {static => public/static}/plugs/layui/images/face/41.gif (100%) rename {static => public/static}/plugs/layui/images/face/42.gif (100%) rename {static => public/static}/plugs/layui/images/face/43.gif (100%) rename {static => public/static}/plugs/layui/images/face/44.gif (100%) rename {static => public/static}/plugs/layui/images/face/45.gif (100%) rename {static => public/static}/plugs/layui/images/face/46.gif (100%) rename {static => public/static}/plugs/layui/images/face/47.gif (100%) rename {static => public/static}/plugs/layui/images/face/48.gif (100%) rename {static => public/static}/plugs/layui/images/face/49.gif (100%) rename {static => public/static}/plugs/layui/images/face/5.gif (100%) rename {static => public/static}/plugs/layui/images/face/50.gif (100%) rename {static => public/static}/plugs/layui/images/face/51.gif (100%) rename {static => public/static}/plugs/layui/images/face/52.gif (100%) rename {static => public/static}/plugs/layui/images/face/53.gif (100%) rename {static => public/static}/plugs/layui/images/face/54.gif (100%) rename {static => public/static}/plugs/layui/images/face/55.gif (100%) rename {static => public/static}/plugs/layui/images/face/56.gif (100%) rename {static => public/static}/plugs/layui/images/face/57.gif (100%) rename {static => public/static}/plugs/layui/images/face/58.gif (100%) rename {static => public/static}/plugs/layui/images/face/59.gif (100%) rename {static => public/static}/plugs/layui/images/face/6.gif (100%) rename {static => public/static}/plugs/layui/images/face/60.gif (100%) rename {static => public/static}/plugs/layui/images/face/61.gif (100%) rename {static => public/static}/plugs/layui/images/face/62.gif (100%) rename {static => public/static}/plugs/layui/images/face/63.gif (100%) rename {static => public/static}/plugs/layui/images/face/64.gif (100%) rename {static => public/static}/plugs/layui/images/face/65.gif (100%) rename {static => public/static}/plugs/layui/images/face/66.gif (100%) rename {static => public/static}/plugs/layui/images/face/67.gif (100%) rename {static => public/static}/plugs/layui/images/face/68.gif (100%) rename {static => public/static}/plugs/layui/images/face/69.gif (100%) rename {static => public/static}/plugs/layui/images/face/7.gif (100%) rename {static => public/static}/plugs/layui/images/face/70.gif (100%) rename {static => public/static}/plugs/layui/images/face/71.gif (100%) rename {static => public/static}/plugs/layui/images/face/8.gif (100%) rename {static => public/static}/plugs/layui/images/face/9.gif (100%) rename {static => public/static}/plugs/layui/lay/modules/carousel.js (98%) rename {static => public/static}/plugs/layui/lay/modules/code.js (95%) create mode 100644 public/static/plugs/layui/lay/modules/colorpicker.js rename {static => public/static}/plugs/layui/lay/modules/element.js (99%) rename {static => public/static}/plugs/layui/lay/modules/flow.js (97%) create mode 100644 public/static/plugs/layui/lay/modules/form.js rename {static => public/static}/plugs/layui/lay/modules/jquery.js (99%) create mode 100644 public/static/plugs/layui/lay/modules/laydate.js rename {static => public/static}/plugs/layui/lay/modules/layedit.js (99%) create mode 100644 public/static/plugs/layui/lay/modules/layer.js rename {static => public/static}/plugs/layui/lay/modules/laypage.js (98%) rename {static => public/static}/plugs/layui/lay/modules/laytpl.js (96%) rename {static => public/static}/plugs/layui/lay/modules/mobile.js (99%) rename {static => public/static}/plugs/layui/lay/modules/rate.js (97%) create mode 100644 public/static/plugs/layui/lay/modules/slider.js create mode 100644 public/static/plugs/layui/lay/modules/table.js rename {static => public/static}/plugs/layui/lay/modules/tree.js (98%) create mode 100644 public/static/plugs/layui/lay/modules/upload.js create mode 100644 public/static/plugs/layui/lay/modules/util.js create mode 100644 public/static/plugs/layui/layui.all.js create mode 100644 public/static/plugs/layui/layui.js create mode 100644 public/static/plugs/plupload/Moxie.swf create mode 100644 public/static/plugs/plupload/Moxie.xap create mode 100644 public/static/plugs/plupload/build.js create mode 100644 public/static/plugs/plupload/moxie.min.js create mode 100644 public/static/plugs/plupload/plupload.full.min.js create mode 100644 public/static/plugs/plupload/plupload.min.js rename static/plugs/require/require.css.js => public/static/plugs/require/css.js (100%) rename {static => public/static}/plugs/require/require.js (100%) rename {static => public/static}/plugs/socket/swfobject.js (100%) create mode 100644 public/static/plugs/socket/websocket.js rename static/plugs/socket/WebSocketMain.swf => public/static/plugs/socket/websocket.swf (100%) create mode 100644 public/static/plugs/spop/spop.min.css create mode 100644 public/static/plugs/spop/spop.min.js create mode 100644 public/static/plugs/supersized/progress.gif create mode 100644 public/static/plugs/supersized/supersized.3.2.7.min.js create mode 100644 public/static/plugs/supersized/supersized.css rename {static => public/static}/plugs/uploader/Uploader.swf (100%) rename {static => public/static}/plugs/uploader/theme/bg.png (100%) rename {static => public/static}/plugs/uploader/theme/expressInstall.swf (100%) rename {static => public/static}/plugs/uploader/theme/icons.png (100%) rename {static => public/static}/plugs/uploader/theme/image.png (100%) rename {static => public/static}/plugs/uploader/theme/progress.png (100%) rename {static => public/static}/plugs/uploader/theme/success.png (100%) rename {static => public/static}/plugs/uploader/theme/upload.js (100%) rename {static => public/static}/plugs/uploader/theme/uploader.css (100%) rename {static => public/static}/plugs/uploader/webuploader.css (100%) rename {static => public/static}/plugs/uploader/webuploader.min.js (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/1_close.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/1_open.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/2.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/3.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/4.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/5.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/6.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/7.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/8.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/diy/9.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/line_conn.gif (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/loading.gif (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/zTreeStandard.gif (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/img/zTreeStandard.png (100%) rename {static => public/static}/plugs/ztree/zTreeStyle/zTreeStyle.css (100%) create mode 100644 public/static/plugs/ztree/ztree.all.min.js create mode 100644 public/static/theme/css/console.css create mode 100644 public/static/theme/css/icon/iconfont.eot create mode 100644 public/static/theme/css/icon/iconfont.svg create mode 100644 public/static/theme/css/icon/iconfont.ttf create mode 100644 public/static/theme/css/icon/iconfont.woff create mode 100644 public/static/theme/css/login.css create mode 100644 public/static/theme/css/mobile.css rename {static => public/static}/theme/img/404_icon.png (100%) rename {static => public/static}/theme/img/505_icon.png (100%) rename {static => public/static}/theme/img/headimg.png (100%) rename {static => public/static}/theme/img/image.png (100%) create mode 100644 public/static/theme/img/login/bg1.jpg create mode 100644 public/static/theme/img/login/bg2.jpg rename {static => public/static}/theme/img/wechat/index.png (100%) rename {static => public/static}/theme/img/wechat/mobile_foot.png (100%) rename {static => public/static}/theme/img/wechat/mobile_head.png (100%) create mode 100644 public/static/theme/img/wechat/qrc_pay_error.jpg rename {static => public/static}/theme/img/wechat/qrc_payed.jpg (100%) delete mode 100644 static/admin.js delete mode 100644 static/app.js delete mode 100644 static/mobile/lib/city-picker.js delete mode 100644 static/mobile/lib/city-picker.min.js delete mode 100644 static/mobile/lib/fastclick.js delete mode 100644 static/mobile/lib/fastclick.min.js delete mode 100644 static/mobile/lib/jquery-weui.js delete mode 100644 static/mobile/lib/jquery-weui.min.js delete mode 100644 static/mobile/lib/jquery.js delete mode 100644 static/mobile/lib/jquery.min.js delete mode 100644 static/mobile/lib/swiper.js delete mode 100644 static/mobile/lib/swiper.min.js delete mode 100644 static/mobile/library.min.css delete mode 100644 static/mobile/library.min.js delete mode 100644 static/plugs/aui/aui-iconfont.ttf delete mode 100644 static/plugs/aui/aui.css delete mode 100644 static/plugs/awesome/css/font-awesome.css delete mode 100644 static/plugs/awesome/css/font-awesome.min.css delete mode 100644 static/plugs/bootstrap-multiselect/bootstrap-multiselect.css delete mode 100644 static/plugs/bootstrap-multiselect/bootstrap-multiselect.js delete mode 100644 static/plugs/bootstrap/css/bootstrap-theme.css delete mode 100644 static/plugs/bootstrap/css/bootstrap-theme.css.map delete mode 100644 static/plugs/bootstrap/css/bootstrap-theme.min.css delete mode 100644 static/plugs/bootstrap/css/bootstrap-theme.min.css.map delete mode 100644 static/plugs/bootstrap/css/bootstrap.css delete mode 100644 static/plugs/bootstrap/css/bootstrap.css.map delete mode 100644 static/plugs/bootstrap/css/bootstrap.min.css delete mode 100644 static/plugs/bootstrap/css/bootstrap.min.css.map delete mode 100644 static/plugs/bootstrap/fonts/glyphicons-halflings-regular.eot delete mode 100644 static/plugs/bootstrap/fonts/glyphicons-halflings-regular.svg delete mode 100644 static/plugs/bootstrap/fonts/glyphicons-halflings-regular.ttf delete mode 100644 static/plugs/bootstrap/fonts/glyphicons-halflings-regular.woff delete mode 100644 static/plugs/bootstrap/fonts/glyphicons-halflings-regular.woff2 delete mode 100644 static/plugs/bootstrap/js/bootstrap.js delete mode 100644 static/plugs/bootstrap/js/bootstrap.min.js delete mode 100644 static/plugs/bootstrap/js/bootstrap3-typeahead.min.js delete mode 100644 static/plugs/bootstrap/js/debug/ie-emulation-modes-warning.js delete mode 100644 static/plugs/bootstrap/js/debug/ie10-viewport-bug-workaround.js delete mode 100644 static/plugs/bootstrap/js/npm.js delete mode 100644 static/plugs/ckeditor/config.js delete mode 100644 static/plugs/ckeditor/lang/af.js delete mode 100644 static/plugs/ckeditor/lang/ar.js delete mode 100644 static/plugs/ckeditor/lang/az.js delete mode 100644 static/plugs/ckeditor/lang/bg.js delete mode 100644 static/plugs/ckeditor/lang/bn.js delete mode 100644 static/plugs/ckeditor/lang/bs.js delete mode 100644 static/plugs/ckeditor/lang/ca.js delete mode 100644 static/plugs/ckeditor/lang/cs.js delete mode 100644 static/plugs/ckeditor/lang/cy.js delete mode 100644 static/plugs/ckeditor/lang/da.js delete mode 100644 static/plugs/ckeditor/lang/de-ch.js delete mode 100644 static/plugs/ckeditor/lang/de.js delete mode 100644 static/plugs/ckeditor/lang/el.js delete mode 100644 static/plugs/ckeditor/lang/en-au.js delete mode 100644 static/plugs/ckeditor/lang/en-ca.js delete mode 100644 static/plugs/ckeditor/lang/en-gb.js delete mode 100644 static/plugs/ckeditor/lang/eo.js delete mode 100644 static/plugs/ckeditor/lang/es-mx.js delete mode 100644 static/plugs/ckeditor/lang/es.js delete mode 100644 static/plugs/ckeditor/lang/et.js delete mode 100644 static/plugs/ckeditor/lang/eu.js delete mode 100644 static/plugs/ckeditor/lang/fa.js delete mode 100644 static/plugs/ckeditor/lang/fi.js delete mode 100644 static/plugs/ckeditor/lang/fo.js delete mode 100644 static/plugs/ckeditor/lang/fr-ca.js delete mode 100644 static/plugs/ckeditor/lang/fr.js delete mode 100644 static/plugs/ckeditor/lang/gl.js delete mode 100644 static/plugs/ckeditor/lang/gu.js delete mode 100644 static/plugs/ckeditor/lang/he.js delete mode 100644 static/plugs/ckeditor/lang/hi.js delete mode 100644 static/plugs/ckeditor/lang/hr.js delete mode 100644 static/plugs/ckeditor/lang/hu.js delete mode 100644 static/plugs/ckeditor/lang/id.js delete mode 100644 static/plugs/ckeditor/lang/is.js delete mode 100644 static/plugs/ckeditor/lang/it.js delete mode 100644 static/plugs/ckeditor/lang/ja.js delete mode 100644 static/plugs/ckeditor/lang/ka.js delete mode 100644 static/plugs/ckeditor/lang/km.js delete mode 100644 static/plugs/ckeditor/lang/ko.js delete mode 100644 static/plugs/ckeditor/lang/ku.js delete mode 100644 static/plugs/ckeditor/lang/lt.js delete mode 100644 static/plugs/ckeditor/lang/lv.js delete mode 100644 static/plugs/ckeditor/lang/mk.js delete mode 100644 static/plugs/ckeditor/lang/mn.js delete mode 100644 static/plugs/ckeditor/lang/ms.js delete mode 100644 static/plugs/ckeditor/lang/nb.js delete mode 100644 static/plugs/ckeditor/lang/nl.js delete mode 100644 static/plugs/ckeditor/lang/no.js delete mode 100644 static/plugs/ckeditor/lang/oc.js delete mode 100644 static/plugs/ckeditor/lang/pl.js delete mode 100644 static/plugs/ckeditor/lang/pt-br.js delete mode 100644 static/plugs/ckeditor/lang/pt.js delete mode 100644 static/plugs/ckeditor/lang/ro.js delete mode 100644 static/plugs/ckeditor/lang/ru.js delete mode 100644 static/plugs/ckeditor/lang/si.js delete mode 100644 static/plugs/ckeditor/lang/sk.js delete mode 100644 static/plugs/ckeditor/lang/sl.js delete mode 100644 static/plugs/ckeditor/lang/sq.js delete mode 100644 static/plugs/ckeditor/lang/sr-latn.js delete mode 100644 static/plugs/ckeditor/lang/sr.js delete mode 100644 static/plugs/ckeditor/lang/sv.js delete mode 100644 static/plugs/ckeditor/lang/th.js delete mode 100644 static/plugs/ckeditor/lang/tr.js delete mode 100644 static/plugs/ckeditor/lang/tt.js delete mode 100644 static/plugs/ckeditor/lang/ug.js delete mode 100644 static/plugs/ckeditor/lang/uk.js delete mode 100644 static/plugs/ckeditor/lang/vi.js delete mode 100644 static/plugs/ckeditor/lang/zh-cn.js delete mode 100644 static/plugs/ckeditor/lang/zh.js delete mode 100644 static/plugs/ckeditor/plugins/a11yhelp/dialogs/lang/bg.js delete mode 100644 static/plugs/ckeditor/plugins/find/dialogs/find.js delete mode 100644 static/plugs/ckeditor/plugins/image/dialogs/image.js delete mode 100644 static/plugs/ckeditor/plugins/scayt/dialogs/options.js delete mode 100644 static/plugs/ckeditor/plugins/wsc/dialogs/tmpFrameset.html delete mode 100644 static/plugs/ckeditor/plugins/wsc/dialogs/wsc.js delete mode 100644 static/plugs/ckeditor/styles.js delete mode 100644 static/plugs/clipboard/clipboard.js delete mode 100644 static/plugs/clipboard/clipboard.min.js delete mode 100644 static/plugs/distpicker/distpicker.data.js delete mode 100644 static/plugs/distpicker/distpicker.js delete mode 100644 static/plugs/jquery/jquery.PrintArea.js delete mode 100644 static/plugs/jquery/jquery.cascade.js delete mode 100644 static/plugs/jquery/jquery.citys.js delete mode 100644 static/plugs/jquery/jquery.cookie.js delete mode 100644 static/plugs/layui/css/layui.css delete mode 100644 static/plugs/layui/font/iconfont.woff delete mode 100644 static/plugs/layui/lay/modules/form.js delete mode 100644 static/plugs/layui/lay/modules/laydate.js delete mode 100644 static/plugs/layui/lay/modules/layer.js delete mode 100644 static/plugs/layui/lay/modules/table.js delete mode 100644 static/plugs/layui/lay/modules/upload.js delete mode 100644 static/plugs/layui/lay/modules/util.js delete mode 100644 static/plugs/layui/layui.all.js delete mode 100644 static/plugs/layui/layui.js delete mode 100644 static/plugs/socket/websocket.js delete mode 100644 static/plugs/template/template.js delete mode 100644 static/plugs/uploader/webuploader.js delete mode 100644 static/plugs/ztree/jquery.ztree.all.min.js delete mode 100644 static/theme/css/animate.css delete mode 100644 static/theme/css/console.css delete mode 100644 static/theme/css/login.css delete mode 100644 static/theme/img/icon.png delete mode 100644 static/theme/img/login/bg.png delete mode 100644 static/theme/img/login/bg_form.png delete mode 100644 static/theme/img/login/cloud.png delete mode 100644 static/theme/img/login/cloud_one.png delete mode 100644 static/theme/img/login/cloud_two.png delete mode 100644 static/theme/img/login/hand.png delete mode 100644 static/theme/img/login/hand_left.png delete mode 100644 static/theme/img/login/hand_right.png delete mode 100644 static/theme/img/login/hand_tou.png delete mode 100644 vendor/topthink/think-captcha/LICENSE delete mode 100644 vendor/topthink/think-captcha/README.md delete mode 100644 vendor/topthink/think-captcha/assets/bgs/1.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/2.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/3.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/4.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/5.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/6.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/7.jpg delete mode 100644 vendor/topthink/think-captcha/assets/bgs/8.jpg delete mode 100644 vendor/topthink/think-captcha/assets/ttfs/1.ttf delete mode 100644 vendor/topthink/think-captcha/assets/ttfs/2.ttf delete mode 100644 vendor/topthink/think-captcha/assets/ttfs/3.ttf delete mode 100644 vendor/topthink/think-captcha/assets/ttfs/4.ttf delete mode 100644 vendor/topthink/think-captcha/assets/ttfs/5.ttf delete mode 100644 vendor/topthink/think-captcha/assets/ttfs/6.ttf delete mode 100644 vendor/topthink/think-captcha/assets/zhttfs/1.ttf delete mode 100644 vendor/topthink/think-captcha/src/Captcha.php delete mode 100644 vendor/topthink/think-captcha/src/helper.php create mode 100644 vendor/topthink/think-helper/.gitignore create mode 100644 vendor/topthink/think-helper/LICENSE create mode 100644 vendor/topthink/think-helper/README.md rename vendor/topthink/{think-captcha => think-helper}/composer.json (58%) create mode 100644 vendor/topthink/think-helper/src/Arr.php create mode 100644 vendor/topthink/think-helper/src/Str.php create mode 100644 vendor/topthink/think-helper/src/helper.php rename vendor/topthink/{think-captcha => think-queue}/.gitignore (55%) create mode 100644 vendor/topthink/think-queue/LICENSE create mode 100644 vendor/topthink/think-queue/README.md create mode 100644 vendor/topthink/think-queue/composer.json create mode 100644 vendor/topthink/think-queue/src/Queue.php create mode 100644 vendor/topthink/think-queue/src/common.php create mode 100644 vendor/topthink/think-queue/src/config.php create mode 100644 vendor/topthink/think-queue/src/queue/CallQueuedHandler.php create mode 100644 vendor/topthink/think-queue/src/queue/Connector.php create mode 100644 vendor/topthink/think-queue/src/queue/Job.php create mode 100644 vendor/topthink/think-queue/src/queue/Listener.php create mode 100644 vendor/topthink/think-queue/src/queue/Queueable.php rename vendor/topthink/{think-captcha/src/CaptchaController.php => think-queue/src/queue/ShouldQueue.php} (60%) create mode 100644 vendor/topthink/think-queue/src/queue/Worker.php create mode 100644 vendor/topthink/think-queue/src/queue/command/Listen.php create mode 100644 vendor/topthink/think-queue/src/queue/command/Restart.php create mode 100644 vendor/topthink/think-queue/src/queue/command/Subscribe.php create mode 100644 vendor/topthink/think-queue/src/queue/command/Work.php create mode 100644 vendor/topthink/think-queue/src/queue/connector/Database.php create mode 100644 vendor/topthink/think-queue/src/queue/connector/Redis.php create mode 100644 vendor/topthink/think-queue/src/queue/connector/Sync.php create mode 100644 vendor/topthink/think-queue/src/queue/connector/Topthink.php create mode 100644 vendor/topthink/think-queue/src/queue/job/Database.php create mode 100644 vendor/topthink/think-queue/src/queue/job/Redis.php create mode 100644 vendor/topthink/think-queue/src/queue/job/Sync.php create mode 100644 vendor/topthink/think-queue/src/queue/job/Topthink.php create mode 100644 vendor/zoujingli/think-library/.gitignore create mode 100644 vendor/zoujingli/think-library/common.php create mode 100644 vendor/zoujingli/think-library/composer.json create mode 100644 vendor/zoujingli/think-library/readme.md create mode 100644 vendor/zoujingli/think-library/src/Controller.php create mode 100644 vendor/zoujingli/think-library/src/File.php create mode 100644 vendor/zoujingli/think-library/src/command/Sess.php create mode 100644 vendor/zoujingli/think-library/src/command/Sync.php create mode 100644 vendor/zoujingli/think-library/src/command/Task.php create mode 100644 vendor/zoujingli/think-library/src/command/sync/Admin.php create mode 100644 vendor/zoujingli/think-library/src/command/sync/Config.php create mode 100644 vendor/zoujingli/think-library/src/command/sync/Plugs.php create mode 100644 vendor/zoujingli/think-library/src/command/sync/Service.php create mode 100644 vendor/zoujingli/think-library/src/command/sync/Wechat.php create mode 100644 vendor/zoujingli/think-library/src/command/task/Reset.php create mode 100644 vendor/zoujingli/think-library/src/command/task/Start.php create mode 100644 vendor/zoujingli/think-library/src/command/task/State.php create mode 100644 vendor/zoujingli/think-library/src/command/task/Stop.php create mode 100644 vendor/zoujingli/think-library/src/driver/Local.php create mode 100644 vendor/zoujingli/think-library/src/driver/Oss.php create mode 100644 vendor/zoujingli/think-library/src/driver/Qiniu.php create mode 100644 vendor/zoujingli/think-library/src/logic/Delete.php create mode 100644 vendor/zoujingli/think-library/src/logic/Form.php create mode 100644 vendor/zoujingli/think-library/src/logic/Input.php create mode 100644 vendor/zoujingli/think-library/src/logic/Logic.php create mode 100644 vendor/zoujingli/think-library/src/logic/Page.php create mode 100644 vendor/zoujingli/think-library/src/logic/Query.php create mode 100644 vendor/zoujingli/think-library/src/logic/Save.php create mode 100644 vendor/zoujingli/think-library/src/tools/Cors.php create mode 100644 vendor/zoujingli/think-library/src/tools/Crypt.php create mode 100644 vendor/zoujingli/think-library/src/tools/Csrf.php create mode 100644 vendor/zoujingli/think-library/src/tools/Csv.php create mode 100644 vendor/zoujingli/think-library/src/tools/Data.php create mode 100644 vendor/zoujingli/think-library/src/tools/Express.php create mode 100644 vendor/zoujingli/think-library/src/tools/Http.php create mode 100644 vendor/zoujingli/think-library/src/tools/Node.php create mode 100644 vendor/zoujingli/think-library/src/tools/Options.php create mode 100644 vendor/zoujingli/weopen-developer/WeChat/Bind.php rename vendor/zoujingli/weopen-developer/{Test => _test}/open.php (100%) rename vendor/zoujingli/weopen-developer/{Test => _test}/wechat.sql (100%) diff --git a/.gitattributes b/.gitattributes deleted file mode 100644 index b748c5239..000000000 --- a/.gitattributes +++ /dev/null @@ -1,3 +0,0 @@ -*.js linguist-language=php -*.css linguist-language=php -*.html linguist-language=php diff --git a/.gitignore b/.gitignore index c0fb87220..a0a419b5c 100644 --- a/.gitignore +++ b/.gitignore @@ -1,11 +1,8 @@ -!.gitignore -!.gitattributes -*.DS_Store -*.idea -*.svn -*.git +/.git +/.svn +/.idea /runtime +/safefile /nbproject -!composer.json /composer.lock -/static/upload \ No newline at end of file +/public/upload \ No newline at end of file diff --git a/LICENSE b/LICENSE deleted file mode 100644 index 18dbe27e9..000000000 --- a/LICENSE +++ /dev/null @@ -1,20 +0,0 @@ -The MIT License (MIT) - -Copyright (c) 2017 Anyon - -Permission is hereby granted, free of charge, to any person obtaining a copy of -this software and associated documentation files (the "Software"), to deal in -the Software without restriction, including without limitation the rights to -use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of -the Software, and to permit persons to whom the Software is furnished to do so, -subject to the following conditions: - -The above copyright notice and this permission notice shall be included in all -copies or substantial portions of the Software. - -THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR -IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS -FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR -COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER -IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN -CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. \ No newline at end of file diff --git a/README.md b/README.md index 2af29deab..61846c1cd 100644 --- a/README.md +++ b/README.md @@ -1,124 +1,49 @@ -ThinkAdmin for PHP +大道至简 · 原生框架 -- -## 大道至简 · 悟在天成 +framework 是一个基于 ThinkPHP5.1 开发的后台管理系统,集成常用功能及封装。 -* ThinkAdmin 是一个基于 Thinkphp 5.1.x 开发的后台管理系统,集成后台系统常用功能。 -* 项目安装及二次开发请参考 ThinkPHP 官方文档及下面的服务环境说明,数据库 sql 文件存放于项目根目录下。 ->* 注意:项目测试请另行搭建环境并创建数据库(数据库配置 config/database.php), 切勿直接使用测试环境数据! ->* 如果系统提示“测试系统禁止操作等字样”,可以删除项目演示路由配置(route/demo.php)或清空里面的路由记录。 ->* 当前版本使用 ThinkPHP 5.1.x 版本,对PHP版本要求不低于php5.6,具体请查阅ThinkPHP官方文档。 +项目安装及二次开发可以参考 ThinkPHP 官方文档,数据库文件摆放在项目根目录下。 +#### 注意事项 +* 项目测试需要自行搭建环境导入数据库( framework.sql )并修改配置( config/database.php ); +* 若操作提示“测试系统禁止操作”等字样,需要删除演示路由配置( route/demo.php )或清空路由文件; +* 当前版本使用 ThinkPHP5.1.x,对 PHP 版本标注不低于 PHP5.6,具体请阅读 ThinkPHP 官方文档; +* 环境需开启 PATHINFO,不再支持 ThinkPHP 的 URL 兼容模式运行(源于如何优雅的展示); -Documentation +技术支持 -- -认真看看文档可能会对你的开发有所帮助哦! +开发前认真阅读 ThinkPHP 官方文档会对您有帮助哦! -文档地址:[ThinkAdmin 开发文档](https://www.kancloud.cn/zoujingli/thinkadmin/content) - - -PHP开发技术交流(QQ群 513350915) +PHP 开发技术交流( QQ 群 513350915) [![PHP微信开发群 (SDK)](http://pub.idqqimg.com/wpa/images/group.png)](http://shang.qq.com/wpa/qunwpa?idkey=ae25cf789dafbef62e50a980ffc31242f150bc61a61164458216dd98c411832a) -Repositorie +代码仓库 -- - ThinkAdmin 为开源项目,允许把它用于任何地方,不受任何约束,欢迎 fork 项目。 -* Gitee 托管地址:https://gitee.com/zoujingli/Think.Admin -* GitHub 托管地址:https://github.com/zoujingli/ThinkAdmin - -对于新版本的微信模块使用的是授权模式,需要用到 ThinkService 项目。 -* Gitee 托管地址:https://gitee.com/zoujingli/ThinkService -* GitHub 托管地址:https://github.com/zoujingli/ThinkService - -其安装与 ThinkAdmin 相似,这里就不多说了。具体可以参见微信开放平台官网 -https://open.weixin.qq.com ,ThinkService 后台具体可以配置对应参数。 - -ThinkAdmin 与 ThinkService 对接是通过 WebService 通信的,因此运行环境需要安装 Soap 模块支持。 - - -Module + framework 为 MIT 协议开源项目,安装使用或二次开发不受约束,欢迎 fork 项目。 + + 部分代码来自互联网,若有异议可以联系作者进行删除。 + + * 在线体验地址:https://framework.thinkadmin.top (体验账号和密码都是 admin ) + * Gitee仓库地址:https://gitee.com/zoujingli/ThinkAdmin + * GitHub仓库地址:https://github.com/zoujingli/ThinkAdmin + +特别感谢 -- -* 简易`RBAC`权限管理(用户、权限、节点、菜单控制) -* 自建秒传文件上载组件(本地存储、七牛云存储,阿里云OSS存储) -* 基站数据服务组件(唯一随机序号、表单更新) -* `Http`服务组件(原生`CURL`封装,兼容PHP多版本) -* 微信公众号服务组件(基于[WeChatDeveloper](https://github.com/zoujingli/WeChatDeveloper),微信网页授权获取用户信息、已关注粉丝管理、自定义菜单管理等等) -* 微信商户支付服务组件(基于[WeChatDeveloper](https://github.com/zoujingli/WeChatDeveloper),支持JSAPI支付、扫码模式一支付、扫码模式二支付) -* 更多组件开发中... +|名称|版本|描述|链接| +|---|---|---|---| +|Layui|2.4.5|UI组件库|https://github.com/sentsin/layui| +|Ckeditor|4.10.1|富文件编辑器|https://github.com/ckeditor/ckeditor-dev| +|PluPloader|3.1.2|文件上传工具1|https://github.com/fex-team/webuploader| +|WebUploader|0.1.5|文件上传工具2|https://github.com/fex-team/webuploader| +|Font-Awesome|4.7.0|字体图标库|https://github.com/FortAwesome/Font-Awesome| +|ThinkPHP|5.1.35|PHP基础框架|https://github.com/top-think/framework| +|ThinkLibrary|5.1.x-dev|ThinkPHP扩展组件|https://github.com/zoujingli/ThinkLibrary| +|WeChatDeveloper|1.2.9|微信公众号组件|https://github.com/zoujingli/WeChatDeveloper| +|WeOpenDeveloper|dev-master|微信开放平台组件|https://github.com/zoujingli/WeOpenDeveloper| - -Environment ---- ->1. PHP 版本不低于 PHP5.6,推荐使用 PHP7 以达到最优效果; ->2. 需开启 PATHINFO,不再支持 ThinkPHP 的 URL 兼容模式运行(源于如何优雅的展示)。 - -* Apache - -```xml - - Options +FollowSymlinks -Multiviews - RewriteEngine On - RewriteCond %{REQUEST_FILENAME} !-d - RewriteCond %{REQUEST_FILENAME} !-f - RewriteRule ^(.*)$ index.php/$1 [QSA,PT,L] - -``` - -* Nginx - -``` -server { - listen 80; - server_name wealth.demo.cuci.cc; - root /home/wwwroot/ThinkAdmin; - index index.php index.html index.htm; - - add_header X-Powered-Host $hostname; - fastcgi_hide_header X-Powered-By; - - if (!-e $request_filename) { - rewrite ^/(.+?\.php)/?(.*)$ /$1/$2 last; - rewrite ^/(.*)$ /index.php/$1 last; - } - - location ~ \.php($|/){ - fastcgi_index index.php; - fastcgi_pass 127.0.0.1:9000; - include fastcgi_params; - set $real_script_name $fastcgi_script_name; - if ($real_script_name ~ "^(.+?\.php)(/.+)$") { - set $real_script_name $1; - } - fastcgi_split_path_info ^(.+?\.php)(/.*)$; - fastcgi_param PATH_INFO $fastcgi_path_info; - fastcgi_param SCRIPT_NAME $real_script_name; - fastcgi_param SCRIPT_FILENAME $document_root$real_script_name; - fastcgi_param PHP_VALUE open_basedir=$document_root:/tmp/:/proc/; - access_log /home/wwwlog/domain_access.log access; - error_log /home/wwwlog/domain_error.log error; - } - - location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$ { - access_log off; - error_log off; - expires 30d; - } - - location ~ .*\.(js|css)?$ { - access_log off; - error_log off; - expires 12h; - } -} -``` - -Copyright +赞助打赏 -- -* ThinkAdmin 基于`MIT`协议发布,任何人可以用在任何地方,不受约束 -* ThinkAdmin 部分代码来自互联网,若有异议,可以联系作者进行删除 +![赞助](http://zoujingli.oschina.io/static/pay.png) - -Sponsor --- -![赞助](http://zoujingli.oschina.io/static/pay.png) \ No newline at end of file diff --git a/admin_v3.sql b/admin_v3.sql deleted file mode 100644 index 1789db95c..000000000 --- a/admin_v3.sql +++ /dev/null @@ -1,947 +0,0 @@ -/* -Navicat MySQL Data Transfer - -Source Server : server.cuci.cc -Source Server Version : 50558 -Source Host : server.cuci.cc:3306 -Source Database : admin_v3 - -Target Server Type : MYSQL -Target Server Version : 50558 -File Encoding : 65001 - -Date: 2018-05-04 11:40:19 -*/ - -SET FOREIGN_KEY_CHECKS=0; - --- ---------------------------- --- Table structure for store_express --- ---------------------------- -DROP TABLE IF EXISTS `store_express`; -CREATE TABLE `store_express` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `express_title` varchar(50) DEFAULT '' COMMENT '快递公司名称', - `express_code` varchar(50) DEFAULT '' COMMENT '快递公司代码', - `express_desc` text COMMENT '快递公司描述', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0.无效,1.有效)', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '排序', - `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB AUTO_INCREMENT=95 DEFAULT CHARSET=utf8 COMMENT='商城快递配置'; - --- ---------------------------- --- Records of store_express --- ---------------------------- -INSERT INTO `store_express` VALUES ('5', 'AAE全球专递', 'aae', '顺丰快递公司', '0', '0', '0', '2017-09-12 11:53:40'); -INSERT INTO `store_express` VALUES ('6', '安捷快递', 'anjie', '', '0', '0', '0', '2017-09-13 15:27:26'); -INSERT INTO `store_express` VALUES ('7', '安信达快递', 'anxindakuaixi', null, '0', '0', '0', '2017-09-13 16:05:19'); -INSERT INTO `store_express` VALUES ('8', '彪记快递', 'biaojikuaidi', null, '0', '0', '0', '2017-09-13 16:05:26'); -INSERT INTO `store_express` VALUES ('9', 'BHT', 'bht', '', '0', '0', '0', '2017-09-13 16:05:37'); -INSERT INTO `store_express` VALUES ('10', '百福东方国际物流', 'baifudongfang', null, '0', '0', '0', '2017-09-13 16:05:41'); -INSERT INTO `store_express` VALUES ('11', '中国东方(COE)', 'coe', null, '0', '0', '0', '2017-09-13 16:05:48'); -INSERT INTO `store_express` VALUES ('12', '长宇物流', 'changyuwuliu', null, '0', '0', '0', '2017-09-13 16:05:58'); -INSERT INTO `store_express` VALUES ('13', '大田物流', 'datianwuliu', null, '0', '0', '0', '2017-09-13 16:06:06'); -INSERT INTO `store_express` VALUES ('14', '德邦物流', 'debangwuliu', null, '1', '1', '0', '2017-09-13 16:06:14'); -INSERT INTO `store_express` VALUES ('15', 'DHL', 'dhl', null, '0', '0', '0', '2017-09-13 16:06:24'); -INSERT INTO `store_express` VALUES ('16', 'DPEX', 'dpex', null, '0', '0', '0', '2017-09-13 16:06:29'); -INSERT INTO `store_express` VALUES ('17', 'd速快递', 'dsukuaidi', null, '0', '0', '0', '2017-09-13 16:06:34'); -INSERT INTO `store_express` VALUES ('18', '递四方', 'disifang', null, '0', '0', '0', '2017-09-13 16:06:40'); -INSERT INTO `store_express` VALUES ('19', 'EMS快递', 'ems', '', '1', '0', '0', '2017-09-13 16:06:47'); -INSERT INTO `store_express` VALUES ('20', 'FEDEX(国外)', 'fedex', null, '0', '0', '0', '2017-09-13 16:06:56'); -INSERT INTO `store_express` VALUES ('21', '飞康达物流', 'feikangda', null, '0', '0', '0', '2017-09-13 16:07:03'); -INSERT INTO `store_express` VALUES ('22', '凤凰快递', 'fenghuangkuaidi', null, '0', '0', '0', '2017-09-13 16:07:10'); -INSERT INTO `store_express` VALUES ('23', '飞快达', 'feikuaida', null, '0', '0', '0', '2017-09-13 16:07:16'); -INSERT INTO `store_express` VALUES ('24', '国通快递', 'guotongkuaidi', null, '0', '0', '0', '2017-09-13 16:07:27'); -INSERT INTO `store_express` VALUES ('25', '港中能达物流', 'ganzhongnengda', null, '0', '0', '0', '2017-09-13 16:07:33'); -INSERT INTO `store_express` VALUES ('26', '广东邮政物流', 'guangdongyouzhengwuliu', null, '0', '0', '0', '2017-09-13 16:08:22'); -INSERT INTO `store_express` VALUES ('27', '共速达', 'gongsuda', null, '0', '0', '0', '2017-09-13 16:08:48'); -INSERT INTO `store_express` VALUES ('28', '汇通快运', 'huitongkuaidi', null, '0', '0', '0', '2017-09-13 16:08:56'); -INSERT INTO `store_express` VALUES ('29', '恒路物流', 'hengluwuliu', null, '0', '0', '0', '2017-09-13 16:09:02'); -INSERT INTO `store_express` VALUES ('30', '华夏龙物流', 'huaxialongwuliu', null, '0', '0', '0', '2017-09-13 16:09:12'); -INSERT INTO `store_express` VALUES ('31', '海红', 'haihongwangsong', null, '0', '0', '0', '2017-09-13 16:09:20'); -INSERT INTO `store_express` VALUES ('32', '海外环球', 'haiwaihuanqiu', null, '0', '0', '0', '2017-09-13 16:09:27'); -INSERT INTO `store_express` VALUES ('33', '佳怡物流', 'jiayiwuliu', null, '0', '0', '0', '2017-09-13 16:09:35'); -INSERT INTO `store_express` VALUES ('34', '京广速递', 'jinguangsudikuaijian', null, '0', '0', '0', '2017-09-13 16:09:42'); -INSERT INTO `store_express` VALUES ('35', '急先达', 'jixianda', null, '0', '0', '0', '2017-09-13 16:09:49'); -INSERT INTO `store_express` VALUES ('36', '佳吉物流', 'jjwl', null, '0', '0', '0', '2017-09-13 16:10:01'); -INSERT INTO `store_express` VALUES ('37', '加运美物流', 'jymwl', null, '0', '0', '0', '2017-09-13 16:10:13'); -INSERT INTO `store_express` VALUES ('38', '金大物流', 'jindawuliu', null, '0', '0', '0', '2017-09-13 16:10:22'); -INSERT INTO `store_express` VALUES ('39', '嘉里大通', 'jialidatong', null, '0', '0', '0', '2017-09-13 16:10:33'); -INSERT INTO `store_express` VALUES ('40', '晋越快递', 'jykd', null, '0', '0', '0', '2017-09-13 16:10:40'); -INSERT INTO `store_express` VALUES ('41', '快捷速递', 'kuaijiesudi', null, '0', '0', '0', '2017-09-13 16:10:49'); -INSERT INTO `store_express` VALUES ('42', '联邦快递(国内)', 'lianb', null, '0', '0', '0', '2017-09-13 16:10:58'); -INSERT INTO `store_express` VALUES ('43', '联昊通物流', 'lianhaowuliu', null, '0', '0', '0', '2017-09-13 16:11:07'); -INSERT INTO `store_express` VALUES ('44', '龙邦物流', 'longbanwuliu', null, '0', '0', '0', '2017-09-13 16:11:15'); -INSERT INTO `store_express` VALUES ('45', '立即送', 'lijisong', null, '0', '0', '0', '2017-09-13 16:11:25'); -INSERT INTO `store_express` VALUES ('46', '乐捷递', 'lejiedi', null, '0', '0', '0', '2017-09-13 16:11:36'); -INSERT INTO `store_express` VALUES ('47', '民航快递', 'minghangkuaidi', null, '0', '0', '0', '2017-09-13 16:11:45'); -INSERT INTO `store_express` VALUES ('48', '美国快递', 'meiguokuaidi', null, '0', '0', '0', '2017-09-13 16:11:53'); -INSERT INTO `store_express` VALUES ('49', '门对门', 'menduimen', null, '0', '0', '0', '2017-09-13 16:12:01'); -INSERT INTO `store_express` VALUES ('50', 'OCS', 'ocs', null, '0', '0', '0', '2017-09-13 16:12:10'); -INSERT INTO `store_express` VALUES ('51', '配思货运', 'peisihuoyunkuaidi', null, '0', '0', '0', '2017-09-13 16:12:18'); -INSERT INTO `store_express` VALUES ('52', '全晨快递', 'quanchenkuaidi', null, '0', '0', '0', '2017-09-13 16:12:26'); -INSERT INTO `store_express` VALUES ('53', '全峰快递', 'quanfengkuaidi', null, '0', '0', '0', '2017-09-13 16:12:34'); -INSERT INTO `store_express` VALUES ('54', '全际通物流', 'quanjitong', null, '0', '0', '0', '2017-09-13 16:12:41'); -INSERT INTO `store_express` VALUES ('55', '全日通快递', 'quanritongkuaidi', null, '0', '0', '0', '2017-09-13 16:12:49'); -INSERT INTO `store_express` VALUES ('56', '全一快递', 'quanyikuaidi', null, '0', '0', '0', '2017-09-13 16:12:56'); -INSERT INTO `store_express` VALUES ('57', '如风达', 'rufengda', null, '0', '0', '0', '2017-09-13 16:13:03'); -INSERT INTO `store_express` VALUES ('58', '三态速递', 'santaisudi', null, '0', '0', '0', '2017-09-13 16:13:15'); -INSERT INTO `store_express` VALUES ('59', '盛辉物流', 'shenghuiwuliu', null, '0', '0', '0', '2017-09-13 16:13:22'); -INSERT INTO `store_express` VALUES ('60', '申通', 'shentong', null, '0', '0', '0', '2017-09-13 16:13:34'); -INSERT INTO `store_express` VALUES ('61', '顺丰', 'shunfeng', '', '1', '0', '0', '2017-09-13 16:13:41'); -INSERT INTO `store_express` VALUES ('62', '速尔物流', 'sue', null, '0', '0', '0', '2017-09-13 16:13:48'); -INSERT INTO `store_express` VALUES ('63', '盛丰物流', 'shengfeng', null, '0', '0', '0', '2017-09-13 16:13:55'); -INSERT INTO `store_express` VALUES ('64', '赛澳递', 'saiaodi', null, '0', '0', '0', '2017-09-13 16:14:02'); -INSERT INTO `store_express` VALUES ('65', '天地华宇', 'tiandihuayu', null, '0', '0', '0', '2017-09-13 16:14:11'); -INSERT INTO `store_express` VALUES ('66', '天天快递', 'tiantian', null, '0', '0', '0', '2017-09-13 16:14:19'); -INSERT INTO `store_express` VALUES ('67', 'TNT', 'tnt', null, '0', '0', '0', '2017-09-13 16:14:26'); -INSERT INTO `store_express` VALUES ('68', 'UPS', 'ups', null, '0', '0', '0', '2017-09-13 16:14:29'); -INSERT INTO `store_express` VALUES ('69', '万家物流', 'wanjiawuliu', null, '0', '0', '0', '2017-09-13 16:14:37'); -INSERT INTO `store_express` VALUES ('70', '文捷航空速递', 'wenjiesudi', null, '0', '0', '0', '2017-09-13 16:14:46'); -INSERT INTO `store_express` VALUES ('71', '伍圆', 'wuyuan', null, '0', '0', '0', '2017-09-13 16:14:52'); -INSERT INTO `store_express` VALUES ('72', '万象物流', 'wxwl', null, '0', '0', '0', '2017-09-13 16:15:00'); -INSERT INTO `store_express` VALUES ('73', '新邦物流', 'xinbangwuliu', null, '0', '0', '0', '2017-09-13 16:15:06'); -INSERT INTO `store_express` VALUES ('74', '信丰物流', 'xinfengwuliu', null, '0', '0', '0', '2017-09-13 16:15:15'); -INSERT INTO `store_express` VALUES ('75', '亚风速递', 'yafengsudi', null, '0', '0', '0', '2017-09-13 16:15:23'); -INSERT INTO `store_express` VALUES ('76', '一邦速递', 'yibangwuliu', null, '0', '0', '0', '2017-09-13 16:15:30'); -INSERT INTO `store_express` VALUES ('77', '优速物流', 'youshuwuliu', null, '0', '0', '0', '2017-09-13 16:15:36'); -INSERT INTO `store_express` VALUES ('78', '邮政包裹挂号信', 'youzhengguonei', null, '0', '3', '0', '2017-09-13 16:15:44'); -INSERT INTO `store_express` VALUES ('79', '邮政国际包裹挂号信', 'youzhengguoji', null, '0', '2', '0', '2017-09-13 16:15:51'); -INSERT INTO `store_express` VALUES ('80', '远成物流', 'yuanchengwuliu', null, '0', '0', '0', '2017-09-13 16:15:57'); -INSERT INTO `store_express` VALUES ('81', '圆通速递', 'yuantong', null, '1', '1', '0', '2017-09-13 16:16:03'); -INSERT INTO `store_express` VALUES ('82', '源伟丰快递', 'yuanweifeng', null, '0', '0', '0', '2017-09-13 16:16:10'); -INSERT INTO `store_express` VALUES ('83', '元智捷诚快递', 'yuanzhijiecheng', null, '0', '0', '0', '2017-09-13 16:16:17'); -INSERT INTO `store_express` VALUES ('84', '韵达快运', 'yunda', null, '0', '0', '0', '2017-09-13 16:16:24'); -INSERT INTO `store_express` VALUES ('85', '运通快递', 'yuntongkuaidi', null, '0', '0', '0', '2017-09-13 16:16:33'); -INSERT INTO `store_express` VALUES ('86', '越丰物流', 'yuefengwuliu', null, '0', '0', '0', '2017-09-13 16:16:40'); -INSERT INTO `store_express` VALUES ('87', '源安达', 'yad', null, '0', '0', '0', '2017-09-13 16:16:47'); -INSERT INTO `store_express` VALUES ('88', '银捷速递', 'yinjiesudi', null, '0', '0', '0', '2017-09-13 16:16:56'); -INSERT INTO `store_express` VALUES ('89', '宅急送', 'zhaijisong', null, '0', '0', '0', '2017-09-13 16:17:03'); -INSERT INTO `store_express` VALUES ('90', '中铁快运', 'zhongtiekuaiyun', null, '0', '0', '0', '2017-09-13 16:17:10'); -INSERT INTO `store_express` VALUES ('91', '中通速递', 'zhongtong', '', '0', '0', '0', '2017-09-13 16:17:16'); -INSERT INTO `store_express` VALUES ('92', '中邮物流', 'zhongyouwuliu', null, '0', '0', '0', '2017-09-13 16:17:27'); -INSERT INTO `store_express` VALUES ('93', '忠信达', 'zhongxinda', null, '0', '0', '0', '2017-09-13 16:17:34'); -INSERT INTO `store_express` VALUES ('94', '芝麻开门', 'zhimakaimen', null, '0', '0', '0', '2017-09-13 16:17:41'); - --- ---------------------------- --- Table structure for store_goods --- ---------------------------- -DROP TABLE IF EXISTS `store_goods`; -CREATE TABLE `store_goods` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `brand_id` bigint(20) unsigned DEFAULT '0' COMMENT '品牌ID', - `cate_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品分类id', - `unit_id` bigint(20) DEFAULT NULL COMMENT '商品单位ID', - `spec_id` bigint(20) unsigned DEFAULT '0' COMMENT '规格ID', - `tags_id` varchar(255) DEFAULT '' COMMENT '商品标签ID', - `is_code` bigint(1) DEFAULT '1' COMMENT '是否有码商品', - `goods_title` varchar(255) DEFAULT '' COMMENT '商品标签', - `goods_content` text COMMENT '商品内容', - `goods_logo` varchar(255) DEFAULT '' COMMENT '商品LOGO', - `goods_image` text COMMENT '商品图片地址', - `goods_video` varchar(500) DEFAULT '' COMMENT '商品视频URL', - `goods_desc` varchar(500) DEFAULT '' COMMENT '商品描述', - `package_stock` bigint(20) unsigned DEFAULT '0' COMMENT '总库存数量', - `package_sale` bigint(20) unsigned DEFAULT '0' COMMENT '已销售数量', - `favorite_num` bigint(20) unsigned DEFAULT '0' COMMENT '收藏次数', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '数据排序', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品主表'; - --- ---------------------------- --- Records of store_goods --- ---------------------------- - --- ---------------------------- --- Table structure for store_goods_brand --- ---------------------------- -DROP TABLE IF EXISTS `store_goods_brand`; -CREATE TABLE `store_goods_brand` ( - `id` int(11) unsigned NOT NULL AUTO_INCREMENT, - `brand_logo` varchar(1024) DEFAULT '' COMMENT '品牌logo', - `brand_cover` varchar(1024) DEFAULT '' COMMENT '品牌封面', - `brand_title` varchar(255) DEFAULT '' COMMENT '商品品牌名称', - `brand_desc` text COMMENT '商品品牌描述', - `brand_detail` text COMMENT '品牌图文信息', - `sort` int(11) unsigned DEFAULT '0' COMMENT '商品分类排序', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='产品品牌'; - --- ---------------------------- --- Records of store_goods_brand --- ---------------------------- - --- ---------------------------- --- Table structure for store_goods_cate --- ---------------------------- -DROP TABLE IF EXISTS `store_goods_cate`; -CREATE TABLE `store_goods_cate` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `pid` bigint(20) unsigned DEFAULT '0' COMMENT '上级分类编号', - `brand_id` bigint(20) DEFAULT '0' COMMENT '品牌ID', - `cate_title` varchar(255) DEFAULT '' COMMENT '商品分类名称', - `cate_desc` text COMMENT '商品分类', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '商品分类排序', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品分类'; - --- ---------------------------- --- Records of store_goods_cate --- ---------------------------- - --- ---------------------------- --- Table structure for store_goods_list --- ---------------------------- -DROP TABLE IF EXISTS `store_goods_list`; -CREATE TABLE `store_goods_list` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `goods_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品ID', - `goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格名称', - `goods_number` bigint(20) unsigned DEFAULT '0' COMMENT '商品礼品-商品数量', - `market_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '销售价格', - `selling_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品价格', - `goods_stock` bigint(20) unsigned DEFAULT '0' COMMENT '商品库存统计', - `goods_sale` bigint(20) unsigned DEFAULT '0' COMMENT '已销售数量', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品列表'; - --- ---------------------------- --- Records of store_goods_list --- ---------------------------- - --- ---------------------------- --- Table structure for store_goods_spec --- ---------------------------- -DROP TABLE IF EXISTS `store_goods_spec`; -CREATE TABLE `store_goods_spec` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `mch_id` bigint(20) unsigned DEFAULT '0' COMMENT '商户ID', - `spec_title` varchar(255) DEFAULT '' COMMENT '商品规格名称', - `spec_param` varchar(255) DEFAULT '' COMMENT '商品规格参数', - `spec_desc` varchar(255) DEFAULT '' COMMENT '商品规格描述', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '商品规格排序', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_store_goods_spec_mch_id` (`mch_id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城商品规格'; - --- ---------------------------- --- Records of store_goods_spec --- ---------------------------- - --- ---------------------------- --- Table structure for store_member --- ---------------------------- -DROP TABLE IF EXISTS `store_member`; -CREATE TABLE `store_member` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `openid` varchar(100) DEFAULT '' COMMENT '会员微信OPENID', - `phone` varchar(16) DEFAULT '' COMMENT '会员手机号', - `password` varchar(64) NOT NULL DEFAULT '' COMMENT '登录密码', - `nickname` varchar(20) DEFAULT '' COMMENT '会员昵称', - `headimg` varchar(500) DEFAULT '' COMMENT '会员头像', - `sex` char(2) DEFAULT '' COMMENT '性别', - `level` tinyint(2) unsigned DEFAULT '1' COMMENT '会员级别', - `remark` varchar(500) DEFAULT '' COMMENT '会员个性签名', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '会员状态(1有效,0无效)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - UNIQUE KEY `index_store_member_openid` (`openid`) USING BTREE, - KEY `index_store_member_phone` (`phone`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城会员信息'; - --- ---------------------------- --- Records of store_member --- ---------------------------- - --- ---------------------------- --- Table structure for store_member_address --- ---------------------------- -DROP TABLE IF EXISTS `store_member_address`; -CREATE TABLE `store_member_address` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', - `username` varchar(20) DEFAULT '' COMMENT '收货人姓名', - `phone` varchar(16) DEFAULT '' COMMENT '收货手机号', - `province` varchar(50) DEFAULT '' COMMENT '收货地址省份', - `city` varchar(50) DEFAULT '' COMMENT '收货地址城市', - `area` varchar(255) DEFAULT '' COMMENT '收货地址区域', - `address` varchar(255) DEFAULT '' COMMENT '收货详细地址', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0无效, 1新快递)', - `is_default` tinyint(1) unsigned DEFAULT '1' COMMENT '默认收货地址', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城会员收货地址'; - --- ---------------------------- --- Records of store_member_address --- ---------------------------- - --- ---------------------------- --- Table structure for store_order --- ---------------------------- -DROP TABLE IF EXISTS `store_order`; -CREATE TABLE `store_order` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `type` tinyint(1) unsigned DEFAULT '1' COMMENT '订单类型(1普通订单,2积分订单)', - `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', - `order_no` char(10) DEFAULT '' COMMENT '订单号', - `freight_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '快递费', - `goods_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品总金额(不含快递费)', - `real_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '真实支付金额(商品金额+快递金额)', - `is_pay` tinyint(1) unsigned DEFAULT '0' COMMENT '订单支付状态(0.未支付,1.已支付)', - `pay_type` varchar(255) DEFAULT '' COMMENT '支付方式 (wechat微信支付, alipay支付宝支付)', - `pay_no` varchar(100) DEFAULT '' COMMENT '商户交易号', - `pay_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '实际支付金额', - `pay_at` datetime DEFAULT NULL COMMENT '支付时间', - `desc` text COMMENT '订单描述', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '订单状态(0.无效,1.新订单,2.待发货,3.已发货,4.已收货,5.已完成,6.已退货及退款)', - `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_store_order_order_no` (`order_no`) USING BTREE, - KEY `index_store_order_status` (`status`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单主表'; - --- ---------------------------- --- Records of store_order --- ---------------------------- - --- ---------------------------- --- Table structure for store_order_express --- ---------------------------- -DROP TABLE IF EXISTS `store_order_express`; -CREATE TABLE `store_order_express` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', - `type` tinyint(1) unsigned DEFAULT '0' COMMENT '快递类型(0.订单快递,1.退货快递)', - `order_no` char(10) DEFAULT '' COMMENT '订单编号', - `company_title` varchar(50) DEFAULT '' COMMENT '物流公司名称', - `company_code` varchar(50) DEFAULT '' COMMENT '物流公司编码', - `username` varchar(20) DEFAULT '' COMMENT '收货人姓名', - `phone` varchar(16) DEFAULT '' COMMENT '收货手机号', - `province` varchar(50) DEFAULT NULL COMMENT '收货地址省份', - `city` varchar(50) DEFAULT '' COMMENT '收货地址城市', - `area` varchar(255) DEFAULT '' COMMENT '收货地址区域', - `address` varchar(255) DEFAULT '' COMMENT '收货详细地址', - `send_no` varchar(50) DEFAULT '' COMMENT '实际物流公司单号', - `send_company_title` varchar(50) DEFAULT '' COMMENT '实际发货快递公司', - `send_company_code` varchar(50) DEFAULT '' COMMENT '实际发货快递代码', - `send_username` varchar(255) DEFAULT '' COMMENT '寄件人名称', - `send_phone` varchar(16) DEFAULT '' COMMENT '寄件人手机号', - `send_province` varchar(50) DEFAULT '' COMMENT '寄件人地址省份', - `send_city` varchar(50) DEFAULT '' COMMENT '寄件人地址城市', - `send_area` varchar(255) DEFAULT '' COMMENT '寄件人地址区域', - `send_address` varchar(255) DEFAULT '' COMMENT '寄件人详细地址', - `send_at` datetime DEFAULT NULL COMMENT '快递发货时间', - `desc` text COMMENT '发货描述', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0.无效,1.新快递,2.已签收,3.签收失败)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单快递'; - --- ---------------------------- --- Records of store_order_express --- ---------------------------- - --- ---------------------------- --- Table structure for store_order_goods --- ---------------------------- -DROP TABLE IF EXISTS `store_order_goods`; -CREATE TABLE `store_order_goods` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `mid` bigint(20) unsigned DEFAULT '0' COMMENT '会员ID', - `order_no` char(10) DEFAULT '' COMMENT '订单编号', - `goods_id` bigint(20) DEFAULT '0' COMMENT '商品ID', - `goods_title` varchar(255) DEFAULT '' COMMENT '商品标签', - `goods_spec` varchar(255) DEFAULT '' COMMENT '商品规格', - `goods_logo` varchar(255) DEFAULT '' COMMENT '商品LOGO', - `goods_image` text COMMENT '商品图片地址', - `market_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '市场价格', - `selling_price` decimal(20,2) unsigned DEFAULT '0.00' COMMENT '商品销售价格', - `price_field` varchar(20) DEFAULT 'selling_price' COMMENT '计价字段', - `number` bigint(20) unsigned DEFAULT '0' COMMENT '订单商品数量', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_store_order_list_order_no` (`order_no`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='商城订单关联商品'; - --- ---------------------------- --- Records of store_order_goods --- ---------------------------- - --- ---------------------------- --- Table structure for system_auth --- ---------------------------- -DROP TABLE IF EXISTS `system_auth`; -CREATE TABLE `system_auth` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `title` varchar(20) NOT NULL COMMENT '权限名称', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(1:禁用,2:启用)', - `sort` smallint(6) unsigned DEFAULT '0' COMMENT '排序权重', - `desc` varchar(255) DEFAULT NULL COMMENT '备注说明', - `create_by` bigint(11) unsigned DEFAULT '0' COMMENT '创建人', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - UNIQUE KEY `index_system_auth_title` (`title`) USING BTREE, - KEY `index_system_auth_status` (`status`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='系统权限表'; - --- ---------------------------- --- Records of system_auth --- ---------------------------- - --- ---------------------------- --- Table structure for system_auth_node --- ---------------------------- -DROP TABLE IF EXISTS `system_auth_node`; -CREATE TABLE `system_auth_node` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `auth` bigint(20) unsigned DEFAULT NULL COMMENT '角色ID', - `node` varchar(200) DEFAULT NULL COMMENT '节点路径', - PRIMARY KEY (`id`), - KEY `index_system_auth_auth` (`auth`) USING BTREE, - KEY `index_system_auth_node` (`node`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='系统角色与节点绑定'; - --- ---------------------------- --- Records of system_auth_node --- ---------------------------- - --- ---------------------------- --- Table structure for system_config --- ---------------------------- -DROP TABLE IF EXISTS `system_config`; -CREATE TABLE `system_config` ( - `id` int(11) unsigned NOT NULL AUTO_INCREMENT, - `name` varchar(100) DEFAULT NULL COMMENT '配置编码', - `value` varchar(500) DEFAULT NULL COMMENT '配置值', - PRIMARY KEY (`id`), - KEY `index_system_config_name` (`name`) -) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT='系统参数配置'; - --- ---------------------------- --- Records of system_config --- ---------------------------- -INSERT INTO `system_config` VALUES ('1', 'app_name', 'ThinkAdmin'); -INSERT INTO `system_config` VALUES ('2', 'site_name', 'ThinkAdmin'); -INSERT INTO `system_config` VALUES ('3', 'app_version', '3.0 dev'); -INSERT INTO `system_config` VALUES ('4', 'site_copy', '©版权所有 2014-2018 楚才科技'); -INSERT INTO `system_config` VALUES ('5', 'browser_icon', 'http://localhost/ThinkAdmin/static/upload/f47b8fe06e38ae99/08e8398da45583b9.png'); -INSERT INTO `system_config` VALUES ('6', 'tongji_baidu_key', ''); -INSERT INTO `system_config` VALUES ('7', 'miitbeian', '粤ICP备16006642号-2'); -INSERT INTO `system_config` VALUES ('8', 'storage_type', 'local'); -INSERT INTO `system_config` VALUES ('9', 'storage_local_exts', 'png,jpg,rar,doc,icon,mp4'); -INSERT INTO `system_config` VALUES ('10', 'storage_qiniu_bucket', ''); -INSERT INTO `system_config` VALUES ('11', 'storage_qiniu_domain', ''); -INSERT INTO `system_config` VALUES ('12', 'storage_qiniu_access_key', ''); -INSERT INTO `system_config` VALUES ('13', 'storage_qiniu_secret_key', ''); -INSERT INTO `system_config` VALUES ('14', 'storage_oss_bucket', 'cuci'); -INSERT INTO `system_config` VALUES ('15', 'storage_oss_endpoint', 'oss-cn-beijing.aliyuncs.com'); -INSERT INTO `system_config` VALUES ('16', 'storage_oss_domain', 'cuci.oss-cn-beijing.aliyuncs.com'); -INSERT INTO `system_config` VALUES ('17', 'storage_oss_keyid', '用你自己的吧'); -INSERT INTO `system_config` VALUES ('18', 'storage_oss_secret', '用你自己的吧'); -INSERT INTO `system_config` VALUES ('34', 'wechat_appid', 'wx60a43dd8161666d4'); -INSERT INTO `system_config` VALUES ('35', 'wechat_appkey', '9890a0d7c91801a609d151099e95b61a'); -INSERT INTO `system_config` VALUES ('36', 'storage_oss_is_https', 'http'); -INSERT INTO `system_config` VALUES ('37', 'wechat_type', 'thr'); -INSERT INTO `system_config` VALUES ('38', 'wechat_token', 'test'); -INSERT INTO `system_config` VALUES ('39', 'wechat_appsecret', 'a041bec98ed015d52b99acea5c6a16ef'); -INSERT INTO `system_config` VALUES ('40', 'wechat_encodingaeskey', 'BJIUzE0gqlWy0GxfPp4J1oPTBmOrNDIGPNav1YFH5Z5'); -INSERT INTO `system_config` VALUES ('41', 'wechat_thr_appid', 'wx60a43dd8161666d4'); -INSERT INTO `system_config` VALUES ('42', 'wechat_thr_appkey', '05db2aa335382c66ab56d69b1a9ad0ee'); - --- ---------------------------- --- Table structure for system_log --- ---------------------------- -DROP TABLE IF EXISTS `system_log`; -CREATE TABLE `system_log` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `ip` char(15) NOT NULL DEFAULT '' COMMENT '操作者IP地址', - `node` char(200) NOT NULL DEFAULT '' COMMENT '当前操作节点', - `username` varchar(32) NOT NULL DEFAULT '' COMMENT '操作人用户名', - `action` varchar(200) NOT NULL DEFAULT '' COMMENT '操作行为', - `content` text NOT NULL COMMENT '操作内容描述', - `create_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='系统操作日志表'; - --- ---------------------------- --- Records of system_log --- ---------------------------- - --- ---------------------------- --- Table structure for system_menu --- ---------------------------- -DROP TABLE IF EXISTS `system_menu`; -CREATE TABLE `system_menu` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `pid` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '父id', - `title` varchar(100) NOT NULL DEFAULT '' COMMENT '名称', - `node` varchar(200) NOT NULL DEFAULT '' COMMENT '节点代码', - `icon` varchar(100) NOT NULL DEFAULT '' COMMENT '菜单图标', - `url` varchar(400) NOT NULL DEFAULT '' COMMENT '链接', - `params` varchar(500) DEFAULT '' COMMENT '链接参数', - `target` varchar(20) NOT NULL DEFAULT '_self' COMMENT '链接打开方式', - `sort` int(11) unsigned DEFAULT '0' COMMENT '菜单排序', - `status` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '状态(0:禁用,1:启用)', - `create_by` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '创建人', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_system_menu_node` (`node`) USING BTREE -) ENGINE=InnoDB AUTO_INCREMENT=43 DEFAULT CHARSET=utf8 COMMENT='系统菜单表'; - --- ---------------------------- --- Records of system_menu --- ---------------------------- -INSERT INTO `system_menu` VALUES ('1', '0', '系统设置', '', '', '#', '', '_self', '9000', '1', '10000', '2018-01-19 15:27:00'); -INSERT INTO `system_menu` VALUES ('2', '10', '后台菜单', '', 'fa fa-leaf', 'admin/menu/index', '', '_self', '10', '1', '10000', '2018-01-19 15:27:17'); -INSERT INTO `system_menu` VALUES ('3', '10', '系统参数', '', 'fa fa-modx', 'admin/config/index', '', '_self', '20', '1', '10000', '2018-01-19 15:27:57'); -INSERT INTO `system_menu` VALUES ('4', '11', '访问授权', '', 'fa fa-group', 'admin/auth/index', '', '_self', '20', '1', '10000', '2018-01-22 11:13:02'); -INSERT INTO `system_menu` VALUES ('5', '11', '用户管理', '', 'fa fa-user', 'admin/user/index', '', '_self', '10', '1', '0', '2018-01-23 12:15:12'); -INSERT INTO `system_menu` VALUES ('6', '11', '访问节点', '', 'fa fa-fort-awesome', 'admin/node/index', '', '_self', '30', '1', '0', '2018-01-23 12:36:54'); -INSERT INTO `system_menu` VALUES ('7', '0', '后台首页', '', '', 'admin/index/main', '', '_self', '1000', '1', '0', '2018-01-23 13:42:30'); -INSERT INTO `system_menu` VALUES ('8', '16', '系统日志', '', 'fa fa-code', 'admin/log/index', '', '_self', '10', '1', '0', '2018-01-24 13:52:58'); -INSERT INTO `system_menu` VALUES ('9', '10', '文件存储', '', 'fa fa-stop-circle', 'admin/config/file', '', '_self', '30', '1', '0', '2018-01-25 10:54:28'); -INSERT INTO `system_menu` VALUES ('10', '1', '系统管理', '', '', '#', '', '_self', '200', '1', '0', '2018-01-25 18:14:28'); -INSERT INTO `system_menu` VALUES ('11', '1', '访问权限', '', '', '#', '', '_self', '300', '1', '0', '2018-01-25 18:15:08'); -INSERT INTO `system_menu` VALUES ('16', '1', '日志管理', '', '', '#', '', '_self', '400', '1', '0', '2018-02-10 16:31:15'); -INSERT INTO `system_menu` VALUES ('17', '0', '微信管理', '', '', '#', '', '_self', '8000', '1', '0', '2018-03-06 14:42:49'); -INSERT INTO `system_menu` VALUES ('18', '17', '公众号配置', '', '', '#', '', '_self', '0', '1', '0', '2018-03-06 14:43:05'); -INSERT INTO `system_menu` VALUES ('19', '18', '微信授权绑定', '', 'fa fa-cog', 'wechat/config/index', '', '_self', '0', '1', '0', '2018-03-06 14:43:26'); -INSERT INTO `system_menu` VALUES ('20', '18', '关注默认回复', '', 'fa fa-comment-o', 'wechat/keys/subscribe', '', '_self', '0', '1', '0', '2018-03-06 14:44:45'); -INSERT INTO `system_menu` VALUES ('21', '18', '无反馈默认回复', '', 'fa fa-commenting', 'wechat/keys/defaults', '', '_self', '0', '1', '0', '2018-03-06 14:45:55'); -INSERT INTO `system_menu` VALUES ('22', '18', '微信关键字管理', '', 'fa fa-hashtag', 'wechat/keys/index', '', '_self', '0', '1', '0', '2018-03-06 14:46:23'); -INSERT INTO `system_menu` VALUES ('23', '17', '微信服务定制', '', '', '#', '', '_self', '0', '1', '0', '2018-03-06 14:47:11'); -INSERT INTO `system_menu` VALUES ('24', '23', '微信菜单管理', '', 'fa fa-gg-circle', 'wechat/menu/index', '', '_self', '0', '1', '0', '2018-03-06 14:47:39'); -INSERT INTO `system_menu` VALUES ('25', '23', '微信图文管理', '', 'fa fa-map-o', 'wechat/news/index', '', '_self', '0', '1', '0', '2018-03-06 14:48:14'); -INSERT INTO `system_menu` VALUES ('26', '17', '微信粉丝管理', '', 'fa fa-user', '#', '', '_self', '0', '1', '0', '2018-03-06 14:48:33'); -INSERT INTO `system_menu` VALUES ('27', '26', '微信粉丝列表', '', 'fa fa-users', 'wechat/fans/index', '', '_self', '20', '1', '0', '2018-03-06 14:49:04'); -INSERT INTO `system_menu` VALUES ('28', '26', '微信黑名单管理', '', 'fa fa-user-times', 'wechat/fans_block/index', '', '_self', '30', '1', '0', '2018-03-06 14:49:22'); -INSERT INTO `system_menu` VALUES ('29', '26', '微信标签管理', '', 'fa fa-tags', 'wechat/tags/index', '', '_self', '10', '1', '0', '2018-03-06 14:49:39'); -INSERT INTO `system_menu` VALUES ('32', '0', '商城管理', '', '', '#', '', '_self', '2000', '1', '0', '2018-03-20 16:46:07'); -INSERT INTO `system_menu` VALUES ('33', '32', '商品管理', '', '', '#', '', '_self', '0', '1', '0', '2018-03-20 16:46:21'); -INSERT INTO `system_menu` VALUES ('34', '33', '产品管理', '', 'fa fa-modx', 'store/goods/index', '', '_self', '0', '1', '0', '2018-03-20 16:46:45'); -INSERT INTO `system_menu` VALUES ('35', '33', '规格管理', '', 'fa fa-hashtag', 'store/goods_spec/index', '', '_self', '0', '1', '0', '2018-03-20 16:47:08'); -INSERT INTO `system_menu` VALUES ('36', '33', '分类管理', '', 'fa fa-product-hunt', 'store/goods_cate/index', '', '_self', '0', '1', '0', '2018-03-20 16:47:50'); -INSERT INTO `system_menu` VALUES ('37', '33', '品牌管理', '', 'fa fa-scribd', 'store/goods_brand/index', '', '_self', '0', '1', '0', '2018-03-20 16:48:05'); -INSERT INTO `system_menu` VALUES ('38', '32', '订单管理', '', '', '#', '', '_self', '0', '1', '0', '2018-04-21 15:07:36'); -INSERT INTO `system_menu` VALUES ('39', '38', '订单列表', '', 'fa fa-adjust', 'store/order/index', '', '_self', '0', '1', '0', '2018-04-21 15:07:54'); -INSERT INTO `system_menu` VALUES ('40', '32', '商城配置', '', '', '#', '', '_self', '0', '1', '0', '2018-04-21 15:08:17'); -INSERT INTO `system_menu` VALUES ('41', '40', '参数管理', '', '', '#', '', '_self', '0', '0', '0', '2018-04-21 15:08:25'); -INSERT INTO `system_menu` VALUES ('42', '40', '快递公司', '', 'fa fa-mixcloud', 'store/express/index', '', '_self', '0', '1', '0', '2018-04-21 15:08:50'); - --- ---------------------------- --- Table structure for system_node --- ---------------------------- -DROP TABLE IF EXISTS `system_node`; -CREATE TABLE `system_node` ( - `id` int(11) unsigned NOT NULL AUTO_INCREMENT, - `node` varchar(100) DEFAULT NULL COMMENT '节点代码', - `title` varchar(500) DEFAULT NULL COMMENT '节点标题', - `is_menu` tinyint(1) unsigned DEFAULT '0' COMMENT '是否可设置为菜单', - `is_auth` tinyint(1) unsigned DEFAULT '1' COMMENT '是否启动RBAC权限控制', - `is_login` tinyint(1) unsigned DEFAULT '1' COMMENT '是否启动登录控制', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_system_node_node` (`node`) -) ENGINE=InnoDB AUTO_INCREMENT=145 DEFAULT CHARSET=utf8 COMMENT='系统节点表'; - --- ---------------------------- --- Records of system_node --- ---------------------------- -INSERT INTO `system_node` VALUES ('13', 'admin', '系统设置', '0', '1', '1', '2018-05-04 11:02:34'); -INSERT INTO `system_node` VALUES ('14', 'admin/auth', '权限管理', '0', '1', '1', '2018-05-04 11:06:55'); -INSERT INTO `system_node` VALUES ('15', 'admin/auth/index', '权限列表', '1', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('16', 'admin/auth/apply', '权限配置', '0', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('17', 'admin/auth/add', '添加权限', '0', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('18', 'admin/auth/edit', '编辑权限', '0', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('19', 'admin/auth/forbid', '禁用权限', '0', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('20', 'admin/auth/resume', '启用权限', '0', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('21', 'admin/auth/del', '删除权限', '0', '1', '1', '2018-05-04 11:06:56'); -INSERT INTO `system_node` VALUES ('22', 'admin/config', '系统配置', '0', '1', '1', '2018-05-04 11:08:18'); -INSERT INTO `system_node` VALUES ('23', 'admin/config/index', '系统参数', '1', '1', '1', '2018-05-04 11:08:25'); -INSERT INTO `system_node` VALUES ('24', 'admin/config/file', '文件存储', '1', '1', '1', '2018-05-04 11:08:27'); -INSERT INTO `system_node` VALUES ('25', 'admin/log', '日志管理', '0', '1', '1', '2018-05-04 11:08:43'); -INSERT INTO `system_node` VALUES ('26', 'admin/log/index', '日志管理', '1', '1', '1', '2018-05-04 11:08:43'); -INSERT INTO `system_node` VALUES ('28', 'admin/log/del', '日志删除', '0', '1', '1', '2018-05-04 11:08:43'); -INSERT INTO `system_node` VALUES ('29', 'admin/menu', '系统菜单', '0', '1', '1', '2018-05-04 11:09:54'); -INSERT INTO `system_node` VALUES ('30', 'admin/menu/index', '菜单列表', '1', '1', '1', '2018-05-04 11:09:54'); -INSERT INTO `system_node` VALUES ('31', 'admin/menu/add', '添加菜单', '0', '1', '1', '2018-05-04 11:09:55'); -INSERT INTO `system_node` VALUES ('32', 'admin/menu/edit', '编辑菜单', '0', '1', '1', '2018-05-04 11:09:55'); -INSERT INTO `system_node` VALUES ('33', 'admin/menu/del', '删除菜单', '0', '1', '1', '2018-05-04 11:09:55'); -INSERT INTO `system_node` VALUES ('34', 'admin/menu/forbid', '禁用菜单', '0', '1', '1', '2018-05-04 11:09:55'); -INSERT INTO `system_node` VALUES ('35', 'admin/menu/resume', '启用菜单', '0', '1', '1', '2018-05-04 11:09:55'); -INSERT INTO `system_node` VALUES ('36', 'admin/node', '节点管理', '0', '1', '1', '2018-05-04 11:10:20'); -INSERT INTO `system_node` VALUES ('37', 'admin/node/index', '节点列表', '1', '1', '1', '2018-05-04 11:10:20'); -INSERT INTO `system_node` VALUES ('38', 'admin/node/clear', '清理节点', '0', '1', '1', '2018-05-04 11:10:21'); -INSERT INTO `system_node` VALUES ('39', 'admin/node/save', '更新节点', '0', '1', '1', '2018-05-04 11:10:21'); -INSERT INTO `system_node` VALUES ('40', 'admin/user', '系统用户', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('41', 'admin/user/index', '用户列表', '1', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('42', 'admin/user/auth', '用户授权', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('43', 'admin/user/add', '添加用户', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('44', 'admin/user/edit', '编辑用户', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('45', 'admin/user/pass', '修改密码', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('46', 'admin/user/del', '删除用户', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('47', 'admin/user/forbid', '禁用启用', '0', '1', '1', '2018-05-04 11:10:43'); -INSERT INTO `system_node` VALUES ('48', 'admin/user/resume', '启用用户', '0', '1', '1', '2018-05-04 11:10:44'); -INSERT INTO `system_node` VALUES ('49', 'store', '商城管理', '0', '1', '1', '2018-05-04 11:11:28'); -INSERT INTO `system_node` VALUES ('50', 'store/express', '快递公司管理', '0', '1', '1', '2018-05-04 11:11:39'); -INSERT INTO `system_node` VALUES ('51', 'store/express/index', '快递公司列表', '1', '1', '1', '2018-05-04 11:11:39'); -INSERT INTO `system_node` VALUES ('52', 'store/express/add', '添加快递公司', '0', '1', '1', '2018-05-04 11:11:39'); -INSERT INTO `system_node` VALUES ('53', 'store/express/edit', '编辑快递公司', '0', '1', '1', '2018-05-04 11:11:39'); -INSERT INTO `system_node` VALUES ('54', 'store/express/del', '删除快递公司', '0', '1', '1', '2018-05-04 11:11:39'); -INSERT INTO `system_node` VALUES ('55', 'store/express/forbid', '禁用快递公司', '0', '1', '1', '2018-05-04 11:11:39'); -INSERT INTO `system_node` VALUES ('56', 'store/express/resume', '启用快递公司', '0', '1', '1', '2018-05-04 11:11:40'); -INSERT INTO `system_node` VALUES ('57', 'store/order', '订单管理', '0', '1', '1', '2018-05-04 11:12:14'); -INSERT INTO `system_node` VALUES ('58', 'store/order/index', '订单列表', '1', '1', '1', '2018-05-04 11:12:17'); -INSERT INTO `system_node` VALUES ('59', 'store/order/address', '修改地址', '0', '1', '1', '2018-05-04 11:12:19'); -INSERT INTO `system_node` VALUES ('76', 'wechat', '微信管理', '0', '1', '1', '2018-05-04 11:14:59'); -INSERT INTO `system_node` VALUES ('78', 'wechat/config', '微信对接管理', '0', '1', '1', '2018-05-04 11:16:20'); -INSERT INTO `system_node` VALUES ('79', 'wechat/config/index', '微信对接配置', '1', '1', '1', '2018-05-04 11:16:23'); -INSERT INTO `system_node` VALUES ('80', 'wechat/fans', '微信粉丝管理', '0', '1', '1', '2018-05-04 11:16:31'); -INSERT INTO `system_node` VALUES ('81', 'wechat/fans/index', '微信粉丝列表', '1', '1', '1', '2018-05-04 11:16:32'); -INSERT INTO `system_node` VALUES ('82', 'wechat/fans/backadd', '微信粉丝拉黑', '0', '1', '1', '2018-05-04 11:16:32'); -INSERT INTO `system_node` VALUES ('83', 'wechat/fans/tagset', '设置粉丝标签', '0', '1', '1', '2018-05-04 11:16:32'); -INSERT INTO `system_node` VALUES ('84', 'wechat/fans/tagadd', '添加粉丝标签', '0', '1', '1', '2018-05-04 11:16:32'); -INSERT INTO `system_node` VALUES ('85', 'wechat/fans/tagdel', '删除粉丝标签', '0', '1', '1', '2018-05-04 11:16:32'); -INSERT INTO `system_node` VALUES ('86', 'wechat/fans/sync', '同步粉丝列表', '0', '1', '1', '2018-05-04 11:16:32'); -INSERT INTO `system_node` VALUES ('87', 'wechat/fans_block', '粉丝黑名单管理', '0', '1', '1', '2018-05-04 11:17:25'); -INSERT INTO `system_node` VALUES ('88', 'wechat/fans_block/index', '粉丝黑名单列表', '1', '1', '1', '2018-05-04 11:17:50'); -INSERT INTO `system_node` VALUES ('89', 'wechat/fans_block/backdel', '移除粉丝黑名单', '0', '1', '1', '2018-05-04 11:17:51'); -INSERT INTO `system_node` VALUES ('90', 'wechat/keys', '微信关键字', '0', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('91', 'wechat/keys/index', '关键字列表', '1', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('92', 'wechat/keys/add', '添加关键字', '0', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('93', 'wechat/keys/edit', '编辑关键字', '0', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('94', 'wechat/keys/del', '删除关键字', '0', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('95', 'wechat/keys/forbid', '禁用关键字', '0', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('96', 'wechat/keys/resume', '启用关键字', '0', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('97', 'wechat/keys/subscribe', '关注回复', '1', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('98', 'wechat/keys/defaults', '默认回复', '1', '1', '1', '2018-05-04 11:18:09'); -INSERT INTO `system_node` VALUES ('99', 'wechat/menu', '微信菜单管理', '0', '1', '1', '2018-05-04 11:18:57'); -INSERT INTO `system_node` VALUES ('100', 'wechat/menu/index', '微信菜单展示', '1', '1', '1', '2018-05-04 11:19:10'); -INSERT INTO `system_node` VALUES ('101', 'wechat/menu/edit', '编辑微信菜单', '0', '1', '1', '2018-05-04 11:19:22'); -INSERT INTO `system_node` VALUES ('102', 'wechat/menu/cancel', '取消微信菜单', '0', '1', '1', '2018-05-04 11:19:26'); -INSERT INTO `system_node` VALUES ('103', 'wechat/news/index', '微信图文列表', '1', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('104', 'wechat/news/select', '微信图文选择', '0', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('105', 'wechat/news/image', '微信图片选择', '0', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('106', 'wechat/news/add', '添加微信图文', '0', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('107', 'wechat/news/edit', '编辑微信图文', '0', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('108', 'wechat/news/del', '删除微信图文', '0', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('109', 'wechat/news/push', '推送微信图文', '0', '1', '1', '2018-05-04 11:19:28'); -INSERT INTO `system_node` VALUES ('110', 'wechat/news', '微信图文管理', '0', '1', '1', '2018-05-04 11:19:35'); -INSERT INTO `system_node` VALUES ('111', 'wechat/tags', '微信粉丝标签管理', '0', '1', '1', '2018-05-04 11:20:28'); -INSERT INTO `system_node` VALUES ('112', 'wechat/tags/index', '粉丝标签列表', '1', '1', '1', '2018-05-04 11:20:28'); -INSERT INTO `system_node` VALUES ('113', 'wechat/tags/add', '添加粉丝标签', '0', '1', '1', '2018-05-04 11:20:28'); -INSERT INTO `system_node` VALUES ('114', 'wechat/tags/edit', '编辑粉丝标签', '0', '1', '1', '2018-05-04 11:20:29'); -INSERT INTO `system_node` VALUES ('115', 'wechat/tags/del', '删除粉丝标签', '0', '1', '1', '2018-05-04 11:20:29'); -INSERT INTO `system_node` VALUES ('116', 'wechat/tags/sync', '同步粉丝标签', '0', '1', '1', '2018-05-04 11:20:29'); -INSERT INTO `system_node` VALUES ('117', 'store/goods', '商品管理', '0', '1', '1', '2018-05-04 11:29:55'); -INSERT INTO `system_node` VALUES ('118', 'store/goods/index', '商品列表', '1', '1', '1', '2018-05-04 11:29:56'); -INSERT INTO `system_node` VALUES ('119', 'store/goods/add', '添加商品', '0', '1', '1', '2018-05-04 11:29:56'); -INSERT INTO `system_node` VALUES ('120', 'store/goods/edit', '编辑商品', '0', '1', '1', '2018-05-04 11:29:56'); -INSERT INTO `system_node` VALUES ('121', 'store/goods/del', '删除商品', '0', '1', '1', '2018-05-04 11:29:56'); -INSERT INTO `system_node` VALUES ('122', 'store/goods/forbid', '下架商品', '0', '1', '1', '2018-05-04 11:29:56'); -INSERT INTO `system_node` VALUES ('123', 'store/goods/resume', '上架商品', '0', '1', '1', '2018-05-04 11:29:57'); -INSERT INTO `system_node` VALUES ('124', 'store/goods_brand', '商品品牌管理', '0', '1', '1', '2018-05-04 11:30:44'); -INSERT INTO `system_node` VALUES ('125', 'store/goods_brand/index', '商品品牌列表', '1', '1', '1', '2018-05-04 11:30:52'); -INSERT INTO `system_node` VALUES ('126', 'store/goods_brand/add', '添加商品品牌', '0', '1', '1', '2018-05-04 11:30:55'); -INSERT INTO `system_node` VALUES ('127', 'store/goods_brand/edit', '编辑商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); -INSERT INTO `system_node` VALUES ('128', 'store/goods_brand/del', '删除商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); -INSERT INTO `system_node` VALUES ('129', 'store/goods_brand/forbid', '禁用商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); -INSERT INTO `system_node` VALUES ('130', 'store/goods_brand/resume', '启用商品品牌', '0', '1', '1', '2018-05-04 11:30:56'); -INSERT INTO `system_node` VALUES ('131', 'store/goods_cate', '商品分类管理', '0', '1', '1', '2018-05-04 11:31:19'); -INSERT INTO `system_node` VALUES ('132', 'store/goods_cate/index', '商品分类列表', '1', '1', '1', '2018-05-04 11:31:23'); -INSERT INTO `system_node` VALUES ('133', 'store/goods_cate/add', '添加商品分类', '0', '1', '1', '2018-05-04 11:31:23'); -INSERT INTO `system_node` VALUES ('134', 'store/goods_cate/edit', '编辑商品分类', '0', '1', '1', '2018-05-04 11:31:23'); -INSERT INTO `system_node` VALUES ('135', 'store/goods_cate/del', '删除商品分类', '0', '1', '1', '2018-05-04 11:31:24'); -INSERT INTO `system_node` VALUES ('136', 'store/goods_cate/forbid', '禁用商品分类', '0', '1', '1', '2018-05-04 11:31:24'); -INSERT INTO `system_node` VALUES ('137', 'store/goods_cate/resume', '启用商品分类', '0', '1', '1', '2018-05-04 11:31:24'); -INSERT INTO `system_node` VALUES ('138', 'store/goods_spec', '商品规格管理', '0', '1', '1', '2018-05-04 11:31:47'); -INSERT INTO `system_node` VALUES ('139', 'store/goods_spec/index', '商品规格列表', '1', '1', '1', '2018-05-04 11:31:47'); -INSERT INTO `system_node` VALUES ('140', 'store/goods_spec/add', '添加商品规格', '0', '1', '1', '2018-05-04 11:31:47'); -INSERT INTO `system_node` VALUES ('141', 'store/goods_spec/edit', '编辑商品规格', '0', '1', '1', '2018-05-04 11:31:48'); -INSERT INTO `system_node` VALUES ('142', 'store/goods_spec/del', '删除商品规格', '0', '1', '1', '2018-05-04 11:31:48'); -INSERT INTO `system_node` VALUES ('143', 'store/goods_spec/forbid', '禁用商品规格', '0', '1', '1', '2018-05-04 11:31:48'); -INSERT INTO `system_node` VALUES ('144', 'store/goods_spec/resume', '启用商品规格', '0', '1', '1', '2018-05-04 11:31:48'); - --- ---------------------------- --- Table structure for system_sequence --- ---------------------------- -DROP TABLE IF EXISTS `system_sequence`; -CREATE TABLE `system_sequence` ( - `id` bigint(20) NOT NULL AUTO_INCREMENT, - `type` varchar(20) DEFAULT NULL COMMENT '序号类型', - `sequence` char(50) NOT NULL COMMENT '序号值', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP, - PRIMARY KEY (`id`), - UNIQUE KEY `index_system_sequence_unique` (`type`,`sequence`) USING BTREE, - KEY `index_system_sequence_type` (`type`), - KEY `index_system_sequence_number` (`sequence`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='系统序号表'; - --- ---------------------------- --- Records of system_sequence --- ---------------------------- - --- ---------------------------- --- Table structure for system_user --- ---------------------------- -DROP TABLE IF EXISTS `system_user`; -CREATE TABLE `system_user` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `username` varchar(50) NOT NULL DEFAULT '' COMMENT '用户登录名', - `password` char(32) NOT NULL DEFAULT '' COMMENT '用户登录密码', - `qq` varchar(16) DEFAULT NULL COMMENT '联系QQ', - `mail` varchar(32) DEFAULT NULL COMMENT '联系邮箱', - `phone` varchar(16) DEFAULT NULL COMMENT '联系手机号', - `desc` varchar(255) DEFAULT '' COMMENT '备注说明', - `login_num` bigint(20) unsigned DEFAULT '0' COMMENT '登录次数', - `login_at` datetime DEFAULT NULL, - `status` tinyint(1) unsigned NOT NULL DEFAULT '1' COMMENT '状态(0:禁用,1:启用)', - `authorize` varchar(255) DEFAULT NULL, - `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '删除状态(1:删除,0:未删)', - `create_by` bigint(20) unsigned DEFAULT NULL COMMENT '创建人', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - UNIQUE KEY `index_system_user_username` (`username`) USING BTREE -) ENGINE=InnoDB AUTO_INCREMENT=10001 DEFAULT CHARSET=utf8 COMMENT='系统用户表'; - --- ---------------------------- --- Records of system_user --- ---------------------------- -INSERT INTO `system_user` VALUES ('10000', 'admin', '21232f297a57a5a743894a0e4a801fc3', '22222222', '', '', '', '22973', '2018-03-26 17:06:48', '1', '2,4', '0', null, '2015-11-13 15:14:22'); - --- ---------------------------- --- Table structure for wechat_fans --- ---------------------------- -DROP TABLE IF EXISTS `wechat_fans`; -CREATE TABLE `wechat_fans` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `appid` char(50) DEFAULT '' COMMENT '公众号Appid', - `unionid` char(100) DEFAULT '' COMMENT 'unionid', - `openid` char(100) DEFAULT '' COMMENT '用户的标识,对当前公众号唯一', - `spread_openid` char(100) DEFAULT '' COMMENT '推荐人OPENID', - `spread_at` datetime DEFAULT NULL COMMENT '推荐时间', - `tagid_list` varchar(100) DEFAULT '' COMMENT '标签id', - `is_black` tinyint(1) unsigned DEFAULT '0' COMMENT '是否为黑名单用户', - `subscribe` tinyint(1) unsigned DEFAULT '0' COMMENT '用户是否关注该公众号(0:未关注, 1:已关注)', - `nickname` varchar(200) DEFAULT '' COMMENT '用户的昵称', - `sex` tinyint(1) unsigned DEFAULT NULL COMMENT '用户的性别,值为1时是男性,值为2时是女性,值为0时是未知', - `country` varchar(50) DEFAULT '' COMMENT '用户所在国家', - `province` varchar(50) DEFAULT '' COMMENT '用户所在省份', - `city` varchar(50) DEFAULT '' COMMENT '用户所在城市', - `language` varchar(50) DEFAULT '' COMMENT '用户的语言,简体中文为zh_CN', - `headimgurl` varchar(500) DEFAULT '' COMMENT '用户头像', - `subscribe_time` bigint(20) unsigned DEFAULT '0' COMMENT '用户关注时间', - `subscribe_at` datetime DEFAULT NULL COMMENT '关注时间', - `remark` varchar(50) DEFAULT '' COMMENT '备注', - `expires_in` bigint(20) unsigned DEFAULT '0' COMMENT '有效时间', - `refresh_token` varchar(200) DEFAULT '' COMMENT '刷新token', - `access_token` varchar(200) DEFAULT '' COMMENT '访问token', - `subscribe_scene` varchar(200) DEFAULT '' COMMENT '扫码关注场景', - `qr_scene` varchar(100) DEFAULT '' COMMENT '二维码场景值', - `qr_scene_str` varchar(200) DEFAULT '' COMMENT '二维码场景内容', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_wechat_fans_spread_openid` (`spread_openid`) USING BTREE, - KEY `index_wechat_fans_openid` (`openid`) USING BTREE, - KEY `index_wechat_fans_unionid` (`unionid`), - KEY `index_wechat_fans_is_back` (`is_black`), - KEY `index_wechat_fans_subscribe` (`subscribe`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信粉丝'; - --- ---------------------------- --- Records of wechat_fans --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_fans_tags --- ---------------------------- -DROP TABLE IF EXISTS `wechat_fans_tags`; -CREATE TABLE `wechat_fans_tags` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT COMMENT '标签ID', - `appid` char(50) DEFAULT NULL COMMENT '公众号APPID', - `name` varchar(35) DEFAULT NULL COMMENT '标签名称', - `count` int(11) unsigned DEFAULT NULL COMMENT '总数', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建日期', - KEY `index_wechat_fans_tags_id` (`id`) USING BTREE, - KEY `index_wechat_fans_tags_appid` (`appid`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信会员标签'; - --- ---------------------------- --- Records of wechat_fans_tags --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_keys --- ---------------------------- -DROP TABLE IF EXISTS `wechat_keys`; -CREATE TABLE `wechat_keys` ( - `id` bigint(20) NOT NULL AUTO_INCREMENT, - `appid` char(100) DEFAULT '' COMMENT '公众号APPID', - `type` varchar(20) DEFAULT '' COMMENT '类型,text 文件消息,image 图片消息,news 图文消息', - `keys` varchar(100) DEFAULT NULL COMMENT '关键字', - `content` text COMMENT '文本内容', - `image_url` varchar(255) DEFAULT '' COMMENT '图片链接', - `voice_url` varchar(255) DEFAULT '' COMMENT '语音链接', - `music_title` varchar(100) DEFAULT '' COMMENT '音乐标题', - `music_url` varchar(255) DEFAULT '' COMMENT '音乐链接', - `music_image` varchar(255) DEFAULT '' COMMENT '音乐缩略图链接', - `music_desc` varchar(255) DEFAULT '' COMMENT '音乐描述', - `video_title` varchar(100) DEFAULT '' COMMENT '视频标题', - `video_url` varchar(255) DEFAULT '' COMMENT '视频URL', - `video_desc` varchar(255) DEFAULT '' COMMENT '视频描述', - `news_id` bigint(20) unsigned DEFAULT NULL COMMENT '图文ID', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '排序字段', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '0 禁用,1 启用', - `create_by` bigint(20) unsigned DEFAULT NULL COMMENT '创建人', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_wechat_keys_appid` (`appid`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信关键字'; - --- ---------------------------- --- Records of wechat_keys --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_menu --- ---------------------------- -DROP TABLE IF EXISTS `wechat_menu`; -CREATE TABLE `wechat_menu` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `index` bigint(20) DEFAULT NULL, - `pindex` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '父id', - `type` varchar(24) NOT NULL DEFAULT '' COMMENT '菜单类型 null主菜单 link链接 keys关键字', - `name` varchar(256) NOT NULL DEFAULT '' COMMENT '菜单名称', - `content` text NOT NULL COMMENT '文字内容', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '排序', - `status` tinyint(1) unsigned DEFAULT '1' COMMENT '状态(0禁用1启用)', - `create_by` bigint(20) unsigned NOT NULL DEFAULT '0' COMMENT '创建人', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_wechat_menu_pindex` (`pindex`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信菜单配置'; - --- ---------------------------- --- Records of wechat_menu --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_news --- ---------------------------- -DROP TABLE IF EXISTS `wechat_news`; -CREATE TABLE `wechat_news` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `media_id` varchar(100) DEFAULT '' COMMENT '永久素材MediaID', - `local_url` varchar(300) DEFAULT '' COMMENT '永久素材显示URL', - `article_id` varchar(60) DEFAULT '' COMMENT '关联图文ID,用,号做分割', - `is_deleted` tinyint(1) unsigned DEFAULT '0' COMMENT '是否删除', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - `create_by` bigint(20) DEFAULT NULL COMMENT '创建人', - PRIMARY KEY (`id`), - KEY `index_wechat_news_artcle_id` (`article_id`) USING BTREE -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信图文表'; - --- ---------------------------- --- Records of wechat_news --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_news_article --- ---------------------------- -DROP TABLE IF EXISTS `wechat_news_article`; -CREATE TABLE `wechat_news_article` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `title` varchar(50) DEFAULT '' COMMENT '素材标题', - `local_url` varchar(300) DEFAULT '' COMMENT '永久素材显示URL', - `show_cover_pic` tinyint(4) unsigned DEFAULT '0' COMMENT '是否显示封面 0不显示,1 显示', - `author` varchar(20) DEFAULT '' COMMENT '作者', - `digest` varchar(300) DEFAULT '' COMMENT '摘要内容', - `content` longtext COMMENT '图文内容', - `content_source_url` varchar(200) DEFAULT '' COMMENT '图文消息原文地址', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - `create_by` bigint(20) DEFAULT NULL COMMENT '创建人', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信素材表'; - --- ---------------------------- --- Records of wechat_news_article --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_news_image --- ---------------------------- -DROP TABLE IF EXISTS `wechat_news_image`; -CREATE TABLE `wechat_news_image` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `md5` varchar(32) DEFAULT '' COMMENT '文件md5', - `local_url` varchar(300) DEFAULT '' COMMENT '本地文件链接', - `media_url` varchar(300) DEFAULT '' COMMENT '远程图片链接', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`), - KEY `index_wechat_news_image_md5` (`md5`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信服务器图片'; - --- ---------------------------- --- Records of wechat_news_image --- ---------------------------- - --- ---------------------------- --- Table structure for wechat_news_media --- ---------------------------- -DROP TABLE IF EXISTS `wechat_news_media`; -CREATE TABLE `wechat_news_media` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `appid` varchar(100) DEFAULT '' COMMENT '公众号ID', - `md5` varchar(32) DEFAULT '' COMMENT '文件md5', - `type` varchar(20) DEFAULT '' COMMENT '媒体类型', - `media_id` varchar(100) DEFAULT '' COMMENT '永久素材MediaID', - `local_url` varchar(300) DEFAULT '' COMMENT '本地文件链接', - `media_url` varchar(300) DEFAULT '' COMMENT '远程图片链接', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB DEFAULT CHARSET=utf8 COMMENT='微信素材表'; - - --- ---------------------------- --- Table structure for store_goods_stock --- ---------------------------- -DROP TABLE IF EXISTS `store_goods_stock`; -CREATE TABLE `store_goods_stock` ( - `id` bigint(20) unsigned NOT NULL AUTO_INCREMENT, - `goods_id` bigint(20) unsigned DEFAULT '0' COMMENT '商品ID', - `goods_spec` varchar(255) DEFAULT '' COMMENT '商品属性', - `goods_stock` bigint(20) unsigned DEFAULT '0' COMMENT '商品库存', - `stock_desc` varchar(255) DEFAULT '' COMMENT '商品库存描述', - `sort` bigint(20) unsigned DEFAULT '0' COMMENT '数据排序', - `status` bigint(1) unsigned DEFAULT '1' COMMENT '商品状态(1有效,0无效)', - `is_deleted` bigint(1) unsigned DEFAULT '0' COMMENT '删除状态(1删除,0未删除)', - `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', - PRIMARY KEY (`id`) -) ENGINE=InnoDB AUTO_INCREMENT=36 DEFAULT CHARSET=utf8 COMMENT='商城商品库存'; - --- ---------------------------- --- Records of wechat_news_media --- ---------------------------- diff --git a/admin_v4.sql b/admin_v4.sql new file mode 100644 index 000000000..76599609e --- /dev/null +++ b/admin_v4.sql @@ -0,0 +1,981 @@ +/* + Navicat Premium Data Transfer + + Source Server : ctolog.com + Source Server Type : MySQL + Source Server Version : 50562 + Source Host : 127.0.0.1:3306 + Source Schema : admin_v4 + + Target Server Type : MySQL + Target Server Version : 50562 + File Encoding : 65001 + + Date: 02/04/2019 13:45:37 +*/ + +SET NAMES utf8mb4; +SET FOREIGN_KEY_CHECKS = 0; + +-- ---------------------------- +-- Table structure for store_express +-- ---------------------------- +DROP TABLE IF EXISTS `store_express`; +CREATE TABLE `store_express` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `express_title` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '快递公司名称', + `express_code` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '快递公司代码', + `express_desc` varchar(512) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '快递公司描述', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '状态(0.无效,1.有效)', + `sort` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '排序权重', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '删除状态(1删除,0未删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_express_code`(`express_code`) USING BTREE, + INDEX `index_store_express_status`(`status`) USING BTREE, + INDEX `index_store_express_deleted`(`is_deleted`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 97 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '商城-快递' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Records of store_express +-- ---------------------------- +INSERT INTO `store_express` VALUES (5, 'AAE全球专递', 'aae', NULL, 0, 0, 0, '2017-09-12 11:53:40'); +INSERT INTO `store_express` VALUES (6, '安捷快递', 'anjie', '', 0, 0, 0, '2017-09-13 15:27:26'); +INSERT INTO `store_express` VALUES (7, '安信达快递', 'anxindakuaixi', NULL, 0, 0, 0, '2017-09-13 16:05:19'); +INSERT INTO `store_express` VALUES (8, '彪记快递', 'biaojikuaidi', NULL, 0, 0, 0, '2017-09-13 16:05:26'); +INSERT INTO `store_express` VALUES (9, 'BHT', 'bht', '', 0, 0, 0, '2017-09-13 16:05:37'); +INSERT INTO `store_express` VALUES (10, '百福东方国际物流', 'baifudongfang', NULL, 0, 0, 0, '2017-09-13 16:05:41'); +INSERT INTO `store_express` VALUES (11, '中国东方(COE)', 'coe', NULL, 0, 0, 0, '2017-09-13 16:05:48'); +INSERT INTO `store_express` VALUES (12, '长宇物流', 'changyuwuliu', NULL, 0, 0, 0, '2017-09-13 16:05:58'); +INSERT INTO `store_express` VALUES (13, '大田物流', 'datianwuliu', NULL, 0, 0, 0, '2017-09-13 16:06:06'); +INSERT INTO `store_express` VALUES (14, '德邦物流', 'debangwuliu', NULL, 1, 1, 0, '2017-09-13 16:06:14'); +INSERT INTO `store_express` VALUES (15, 'DHL', 'dhl', NULL, 0, 0, 0, '2017-09-13 16:06:24'); +INSERT INTO `store_express` VALUES (16, 'DPEX', 'dpex', NULL, 0, 0, 0, '2017-09-13 16:06:29'); +INSERT INTO `store_express` VALUES (17, 'd速快递', 'dsukuaidi', NULL, 0, 0, 0, '2017-09-13 16:06:34'); +INSERT INTO `store_express` VALUES (18, '递四方', 'disifang', NULL, 0, 0, 0, '2017-09-13 16:06:40'); +INSERT INTO `store_express` VALUES (19, 'EMS快递', 'ems', '', 1, 0, 0, '2017-09-13 16:06:47'); +INSERT INTO `store_express` VALUES (20, 'FEDEX(国外)', 'fedex', NULL, 0, 0, 0, '2017-09-13 16:06:56'); +INSERT INTO `store_express` VALUES (21, '飞康达物流', 'feikangda', NULL, 0, 0, 0, '2017-09-13 16:07:03'); +INSERT INTO `store_express` VALUES (22, '凤凰快递', 'fenghuangkuaidi', NULL, 0, 0, 0, '2017-09-13 16:07:10'); +INSERT INTO `store_express` VALUES (23, '飞快达', 'feikuaida', NULL, 0, 0, 0, '2017-09-13 16:07:16'); +INSERT INTO `store_express` VALUES (24, '国通快递', 'guotongkuaidi', NULL, 0, 0, 0, '2017-09-13 16:07:27'); +INSERT INTO `store_express` VALUES (25, '港中能达物流', 'ganzhongnengda', NULL, 0, 0, 0, '2017-09-13 16:07:33'); +INSERT INTO `store_express` VALUES (26, '广东邮政物流', 'guangdongyouzhengwuliu', NULL, 0, 0, 0, '2017-09-13 16:08:22'); +INSERT INTO `store_express` VALUES (27, '共速达', 'gongsuda', NULL, 0, 0, 0, '2017-09-13 16:08:48'); +INSERT INTO `store_express` VALUES (28, '汇通快运', 'huitongkuaidi', NULL, 1, 0, 0, '2017-09-13 16:08:56'); +INSERT INTO `store_express` VALUES (29, '恒路物流', 'hengluwuliu', NULL, 0, 0, 0, '2017-09-13 16:09:02'); +INSERT INTO `store_express` VALUES (30, '华夏龙物流', 'huaxialongwuliu', NULL, 0, 0, 0, '2017-09-13 16:09:12'); +INSERT INTO `store_express` VALUES (31, '海红', 'haihongwangsong', NULL, 0, 0, 0, '2017-09-13 16:09:20'); +INSERT INTO `store_express` VALUES (32, '海外环球', 'haiwaihuanqiu', NULL, 0, 0, 0, '2017-09-13 16:09:27'); +INSERT INTO `store_express` VALUES (33, '佳怡物流', 'jiayiwuliu', NULL, 0, 0, 0, '2017-09-13 16:09:35'); +INSERT INTO `store_express` VALUES (34, '京广速递', 'jinguangsudikuaijian', NULL, 0, 0, 0, '2017-09-13 16:09:42'); +INSERT INTO `store_express` VALUES (35, '急先达', 'jixianda', NULL, 0, 0, 0, '2017-09-13 16:09:49'); +INSERT INTO `store_express` VALUES (36, '佳吉物流', 'jjwl', NULL, 0, 0, 0, '2017-09-13 16:10:01'); +INSERT INTO `store_express` VALUES (37, '加运美物流', 'jymwl', NULL, 0, 0, 0, '2017-09-13 16:10:13'); +INSERT INTO `store_express` VALUES (38, '金大物流', 'jindawuliu', NULL, 0, 0, 0, '2017-09-13 16:10:22'); +INSERT INTO `store_express` VALUES (39, '嘉里大通', 'jialidatong', NULL, 0, 0, 0, '2017-09-13 16:10:33'); +INSERT INTO `store_express` VALUES (40, '晋越快递', 'jykd', NULL, 0, 0, 0, '2017-09-13 16:10:40'); +INSERT INTO `store_express` VALUES (41, '快捷速递', 'kuaijiesudi', NULL, 0, 0, 0, '2017-09-13 16:10:49'); +INSERT INTO `store_express` VALUES (42, '联邦快递(国内)', 'lianb', NULL, 0, 0, 0, '2017-09-13 16:10:58'); +INSERT INTO `store_express` VALUES (43, '联昊通物流', 'lianhaowuliu', NULL, 0, 0, 0, '2017-09-13 16:11:07'); +INSERT INTO `store_express` VALUES (44, '龙邦物流', 'longbanwuliu', NULL, 0, 0, 0, '2017-09-13 16:11:15'); +INSERT INTO `store_express` VALUES (45, '立即送', 'lijisong', NULL, 0, 0, 0, '2017-09-13 16:11:25'); +INSERT INTO `store_express` VALUES (46, '乐捷递', 'lejiedi', NULL, 0, 0, 0, '2017-09-13 16:11:36'); +INSERT INTO `store_express` VALUES (47, '民航快递', 'minghangkuaidi', NULL, 0, 0, 0, '2017-09-13 16:11:45'); +INSERT INTO `store_express` VALUES (48, '美国快递', 'meiguokuaidi', NULL, 0, 0, 0, '2017-09-13 16:11:53'); +INSERT INTO `store_express` VALUES (49, '门对门', 'menduimen', NULL, 0, 0, 0, '2017-09-13 16:12:01'); +INSERT INTO `store_express` VALUES (50, 'OCS', 'ocs', NULL, 0, 0, 0, '2017-09-13 16:12:10'); +INSERT INTO `store_express` VALUES (51, '配思货运', 'peisihuoyunkuaidi', NULL, 0, 0, 0, '2017-09-13 16:12:18'); +INSERT INTO `store_express` VALUES (52, '全晨快递', 'quanchenkuaidi', NULL, 0, 0, 0, '2017-09-13 16:12:26'); +INSERT INTO `store_express` VALUES (53, '全峰快递', 'quanfengkuaidi', NULL, 0, 0, 0, '2017-09-13 16:12:34'); +INSERT INTO `store_express` VALUES (54, '全际通物流', 'quanjitong', NULL, 0, 0, 0, '2017-09-13 16:12:41'); +INSERT INTO `store_express` VALUES (55, '全日通快递', 'quanritongkuaidi', NULL, 0, 0, 0, '2017-09-13 16:12:49'); +INSERT INTO `store_express` VALUES (56, '全一快递', 'quanyikuaidi', NULL, 0, 0, 0, '2017-09-13 16:12:56'); +INSERT INTO `store_express` VALUES (57, '如风达', 'rufengda', NULL, 0, 0, 0, '2017-09-13 16:13:03'); +INSERT INTO `store_express` VALUES (58, '三态速递', 'santaisudi', NULL, 0, 0, 0, '2017-09-13 16:13:15'); +INSERT INTO `store_express` VALUES (59, '盛辉物流', 'shenghuiwuliu', NULL, 0, 0, 0, '2017-09-13 16:13:22'); +INSERT INTO `store_express` VALUES (60, '申通', 'shentong', NULL, 1, 0, 0, '2017-09-13 16:13:34'); +INSERT INTO `store_express` VALUES (61, '顺丰', 'shunfeng', '', 0, 0, 0, '2017-09-13 16:13:41'); +INSERT INTO `store_express` VALUES (62, '速尔物流', 'sue', NULL, 1, 0, 0, '2017-09-13 16:13:48'); +INSERT INTO `store_express` VALUES (63, '盛丰物流', 'shengfeng', NULL, 0, 0, 0, '2017-09-13 16:13:55'); +INSERT INTO `store_express` VALUES (64, '赛澳递', 'saiaodi', NULL, 0, 0, 0, '2017-09-13 16:14:02'); +INSERT INTO `store_express` VALUES (65, '天地华宇', 'tiandihuayu', NULL, 0, 0, 0, '2017-09-13 16:14:11'); +INSERT INTO `store_express` VALUES (66, '天天快递', 'tiantian', NULL, 1, 0, 0, '2017-09-13 16:14:19'); +INSERT INTO `store_express` VALUES (67, 'TNT', 'tnt', NULL, 0, 0, 0, '2017-09-13 16:14:26'); +INSERT INTO `store_express` VALUES (68, 'UPS', 'ups', NULL, 0, 0, 0, '2017-09-13 16:14:29'); +INSERT INTO `store_express` VALUES (69, '万家物流', 'wanjiawuliu', NULL, 0, 0, 0, '2017-09-13 16:14:37'); +INSERT INTO `store_express` VALUES (70, '文捷航空速递', 'wenjiesudi', NULL, 0, 0, 0, '2017-09-13 16:14:46'); +INSERT INTO `store_express` VALUES (71, '伍圆', 'wuyuan', NULL, 0, 0, 0, '2017-09-13 16:14:52'); +INSERT INTO `store_express` VALUES (72, '万象物流', 'wxwl', NULL, 0, 0, 0, '2017-09-13 16:15:00'); +INSERT INTO `store_express` VALUES (73, '新邦物流', 'xinbangwuliu', NULL, 0, 0, 0, '2017-09-13 16:15:06'); +INSERT INTO `store_express` VALUES (74, '信丰物流', 'xinfengwuliu', NULL, 0, 0, 0, '2017-09-13 16:15:15'); +INSERT INTO `store_express` VALUES (75, '亚风速递', 'yafengsudi', NULL, 0, 0, 0, '2017-09-13 16:15:23'); +INSERT INTO `store_express` VALUES (76, '一邦速递', 'yibangwuliu', NULL, 0, 0, 0, '2017-09-13 16:15:30'); +INSERT INTO `store_express` VALUES (77, '优速物流', 'youshuwuliu', NULL, 0, 0, 0, '2017-09-13 16:15:36'); +INSERT INTO `store_express` VALUES (78, '邮政包裹挂号信', 'youzhengguonei', NULL, 0, 3, 0, '2017-09-13 16:15:44'); +INSERT INTO `store_express` VALUES (79, '邮政国际包裹挂号信', 'youzhengguoji', NULL, 1, 2, 0, '2017-09-13 16:15:51'); +INSERT INTO `store_express` VALUES (80, '远成物流', 'yuanchengwuliu', NULL, 0, 0, 0, '2017-09-13 16:15:57'); +INSERT INTO `store_express` VALUES (81, '圆通速递', 'yuantong', NULL, 1, 1, 0, '2017-09-13 16:16:03'); +INSERT INTO `store_express` VALUES (82, '源伟丰快递', 'yuanweifeng', NULL, 0, 0, 0, '2017-09-13 16:16:10'); +INSERT INTO `store_express` VALUES (83, '元智捷诚快递', 'yuanzhijiecheng', NULL, 0, 0, 0, '2017-09-13 16:16:17'); +INSERT INTO `store_express` VALUES (84, '韵达快运', 'yunda', NULL, 1, 0, 0, '2017-09-13 16:16:24'); +INSERT INTO `store_express` VALUES (85, '运通快递', 'yuntongkuaidi', NULL, 0, 0, 0, '2017-09-13 16:16:33'); +INSERT INTO `store_express` VALUES (86, '越丰物流', 'yuefengwuliu', NULL, 0, 0, 0, '2017-09-13 16:16:40'); +INSERT INTO `store_express` VALUES (87, '源安达', 'yad', NULL, 0, 0, 0, '2017-09-13 16:16:47'); +INSERT INTO `store_express` VALUES (88, '银捷速递', 'yinjiesudi', NULL, 0, 0, 0, '2017-09-13 16:16:56'); +INSERT INTO `store_express` VALUES (89, '宅急送', 'zhaijisong', NULL, 0, 0, 0, '2017-09-13 16:17:03'); +INSERT INTO `store_express` VALUES (90, '中铁快运', 'zhongtiekuaiyun', NULL, 0, 0, 0, '2017-09-13 16:17:10'); +INSERT INTO `store_express` VALUES (91, '中通速递', 'zhongtong', '', 1, 0, 0, '2017-09-13 16:17:16'); +INSERT INTO `store_express` VALUES (92, '中邮物流', 'zhongyouwuliu', NULL, 0, 0, 0, '2017-09-13 16:17:27'); +INSERT INTO `store_express` VALUES (93, '忠信达', 'zhongxinda', NULL, 0, 0, 0, '2017-09-13 16:17:34'); +INSERT INTO `store_express` VALUES (94, '芝麻开门', 'zhimakaimen', NULL, 1, 0, 1, '2017-09-13 16:17:41'); +INSERT INTO `store_express` VALUES (95, '中通快运', 'zhongtongkuaiyun', '', 1, 0, 0, '2019-03-28 15:04:41'); +INSERT INTO `store_express` VALUES (96, '德邦快递', 'debangkuaidi', '', 1, 0, 0, '2019-03-28 15:05:30'); + +-- ---------------------------- +-- Table structure for store_goods +-- ---------------------------- +DROP TABLE IF EXISTS `store_goods`; +CREATE TABLE `store_goods` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `cate_id` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '商品分类', + `title` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '商品标题', + `logo` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '商品图标', + `specs` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '商品规格JSON', + `lists` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '商品列表JSON', + `image` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '商品图片', + `content` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '商品内容', + `number_sales` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '销售数量', + `number_stock` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '库库数量', + `price_rate` decimal(20, 4) UNSIGNED NULL DEFAULT 0.0000 COMMENT '返利比例', + `price_express` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '统一运费', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '销售状态', + `sort` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '排序权重', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '删除状态', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_goods_status`(`status`) USING BTREE, + INDEX `index_store_goods_cate_id`(`cate_id`) USING BTREE, + INDEX `index_store_goods_is_deleted`(`is_deleted`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '商品-记录' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_goods_cate +-- ---------------------------- +DROP TABLE IF EXISTS `store_goods_cate`; +CREATE TABLE `store_goods_cate` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `logo` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '分类图标', + `title` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '分类名称', + `desc` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '分类描述', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '销售状态', + `sort` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '排序权重', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '删除状态', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_goods_cate_is_deleted`(`is_deleted`) USING BTREE, + INDEX `index_store_goods_cate_status`(`status`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '商品-分类' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_goods_list +-- ---------------------------- +DROP TABLE IF EXISTS `store_goods_list`; +CREATE TABLE `store_goods_list` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `goods_id` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '商品ID', + `goods_spec` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '商品规格', + `price_market` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '商品标价', + `price_selling` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '商品售价', + `number_sales` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '销售数量', + `number_stock` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '商品库存', + `number_virtual` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '虚拟销量', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '商品状态', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_goods_list_id`(`goods_id`) USING BTREE, + INDEX `index_store_goods_list_spec`(`goods_spec`) USING BTREE, + INDEX `index_store_goods_list_status`(`status`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '商品-详情' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_goods_stock +-- ---------------------------- +DROP TABLE IF EXISTS `store_goods_stock`; +CREATE TABLE `store_goods_stock` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `goods_id` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '商品ID', + `goods_spec` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '商品规格', + `number_stock` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '商品库存', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_goods_stock_gid`(`goods_id`) USING BTREE, + INDEX `index_store_goods_stock_spec`(`goods_spec`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '商品-入库' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_member +-- ---------------------------- +DROP TABLE IF EXISTS `store_member`; +CREATE TABLE `store_member` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `openid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '微信OPENID', + `headimg` varchar(512) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '头像地址', + `nickname` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '微信昵称', + `phone` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '联系手机', + `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '真实姓名', + `vip_level` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '会员级别(0游客,1为临时,2为VIP1,3为VIP2)', + `vip_date` date NULL DEFAULT NULL COMMENT '保级日期', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_member_openid`(`openid`) USING BTREE, + INDEX `index_store_member_phone`(`phone`) USING BTREE, + INDEX `index_store_member_vip_level`(`vip_level`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '会员-记录' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_member_address +-- ---------------------------- +DROP TABLE IF EXISTS `store_member_address`; +CREATE TABLE `store_member_address` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '会员ID', + `name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货姓名', + `phone` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货手机', + `province` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '地址-省份', + `city` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '地址-城市', + `area` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '地址-区域', + `address` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '地址-详情', + `is_default` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '默认地址', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_member_address_mid`(`mid`) USING BTREE, + INDEX `index_store_member_address_is_default`(`is_default`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '会员-收货地址' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_member_sms_history +-- ---------------------------- +DROP TABLE IF EXISTS `store_member_sms_history`; +CREATE TABLE `store_member_sms_history` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '会员ID', + `phone` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '目标手机', + `content` varchar(512) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '短信内容', + `result` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '返回结果', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_member_sms_history_phone`(`phone`) USING BTREE, + INDEX `index_store_member_sms_history_mid`(`mid`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '会员-短信' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_order +-- ---------------------------- +DROP TABLE IF EXISTS `store_order`; +CREATE TABLE `store_order` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '会员ID', + `order_no` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '订单单号', + `from_mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '推荐会员ID', + `price_total` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '待付金额统计', + `price_goods` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '商品费用统计', + `price_express` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '快递费用统计', + `price_rate_amount` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '返利金额统计', + `pay_state` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '支付状态(0未支付,1已支付)', + `pay_type` varchar(10) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '支付方式', + `pay_price` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '支付金额', + `pay_no` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '支付单号', + `pay_at` datetime NULL DEFAULT NULL COMMENT '支付时间', + `cancel_state` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '取消状态', + `cancel_at` datetime NULL DEFAULT NULL COMMENT '取消时间', + `cancel_desc` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '取消描述', + `refund_state` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '退款状态(0未退款,1待退款,2已退款)', + `refund_at` datetime NULL DEFAULT NULL COMMENT '退款时间', + `refund_no` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '退款单号', + `refund_price` decimal(20, 2) NULL DEFAULT 0.00 COMMENT '退款金额', + `refund_desc` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '退款描述', + `express_state` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '发货状态(0未发货,1已发货,2已签收)', + `express_company_code` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '发货快递公司编码', + `express_company_title` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '发货快递公司名称', + `express_send_no` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '发货单号', + `express_send_at` datetime NULL DEFAULT NULL COMMENT '发货时间', + `express_address_id` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '收货地址ID', + `express_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货人姓名', + `express_phone` varchar(11) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货人手机', + `express_province` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货地址省份', + `express_city` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货地址城市', + `express_area` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货地址区域', + `express_address` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '收货详细地址', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '订单状态(0已取消,1预订单待补全,2新订单待支付,3已支付待发货,4已发货待签收,5已完成)', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '删除状态', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_groups_order_mid`(`mid`) USING BTREE, + INDEX `index_store_groups_order_order_no`(`order_no`) USING BTREE, + INDEX `index_store_groups_order_pay_state`(`pay_state`) USING BTREE, + INDEX `index_store_groups_order_cancel_state`(`cancel_state`) USING BTREE, + INDEX `index_store_groups_order_refund_state`(`refund_state`) USING BTREE, + INDEX `index_store_groups_order_status`(`status`) USING BTREE, + INDEX `index_store_groups_order_pay_no`(`pay_no`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '订单-记录' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_order_list +-- ---------------------------- +DROP TABLE IF EXISTS `store_order_list`; +CREATE TABLE `store_order_list` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '会员ID', + `from_id` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '推荐会员', + `order_no` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '订单单号', + `number` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '交易数量', + `goods_id` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '商品标识', + `goods_title` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '商品标题', + `goods_logo` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '商品图标', + `goods_spec` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '商品规格', + `price_real` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '交易金额', + `price_selling` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '销售价格', + `price_market` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '市场价格', + `price_express` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '快递费用', + `price_rate` decimal(20, 4) UNSIGNED NULL DEFAULT 0.0000 COMMENT '分成比例', + `price_rate_amount` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '分成金额', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_goods_list_id`(`goods_id`) USING BTREE, + INDEX `index_store_goods_list_spec`(`goods_spec`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '订单-详情' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_profit_record +-- ---------------------------- +DROP TABLE IF EXISTS `store_profit_record`; +CREATE TABLE `store_profit_record` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `from_mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '来源会员ID', + `order_no` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '订单单号', + `order_mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '订单会员ID', + `order_price` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '订单金额', + `profit_price` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '拥金金额', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_member_phone`(`profit_price`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '拥金-记录' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for store_profit_used +-- ---------------------------- +DROP TABLE IF EXISTS `store_profit_used`; +CREATE TABLE `store_profit_used` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `mid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '会员ID', + `appid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号APPID', + `openid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '微信OPENID', + `trs_no` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '订单号', + `pay_no` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '交易号', + `pay_desc` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '提现描述', + `pay_price` decimal(20, 2) UNSIGNED NULL DEFAULT 0.00 COMMENT '提现金额', + `pay_at` datetime NULL DEFAULT NULL COMMENT '打款时间', + `last_at` datetime NULL DEFAULT NULL COMMENT '最后处理时间', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '提现状态(0失败,1待打款,2已完成)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_store_profit_used_openid`(`openid`) USING BTREE, + INDEX `index_store_profit_used_mid`(`mid`) USING BTREE, + INDEX `index_store_profit_used_appid`(`appid`) USING BTREE, + INDEX `index_store_profit_used_status`(`status`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '拥金-提现' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_auth +-- ---------------------------- +DROP TABLE IF EXISTS `system_auth`; +CREATE TABLE `system_auth` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `title` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '权限名称', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '权限状态', + `sort` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '排序权重', + `desc` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '备注说明', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_auth_status`(`status`) USING BTREE, + INDEX `index_system_auth_title`(`title`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-权限' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_auth_node +-- ---------------------------- +DROP TABLE IF EXISTS `system_auth_node`; +CREATE TABLE `system_auth_node` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `auth` bigint(20) UNSIGNED NULL DEFAULT NULL COMMENT '角色', + `node` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '节点', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_auth_auth`(`auth`) USING BTREE, + INDEX `index_system_auth_node`(`node`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-权限-授权' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_config +-- ---------------------------- +DROP TABLE IF EXISTS `system_config`; +CREATE TABLE `system_config` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '配置名', + `value` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '配置值', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_config_name`(`name`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 70 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-配置' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Records of system_config +-- ---------------------------- +INSERT INTO `system_config` VALUES (1, 'app_name', 'ThinkAdmin'); +INSERT INTO `system_config` VALUES (2, 'site_name', 'ThinkAdmin'); +INSERT INTO `system_config` VALUES (3, 'app_version', 'v4.0'); +INSERT INTO `system_config` VALUES (4, 'site_copy', '©版权所有 2014-2018 楚才科技'); +INSERT INTO `system_config` VALUES (5, 'site_icon', 'http://127.0.0.1:8000/upload/f47b8fe06e38ae99/08e8398da45583b9.png'); +INSERT INTO `system_config` VALUES (7, 'miitbeian', '粤ICP备16006642号-2'); +INSERT INTO `system_config` VALUES (8, 'storage_type', 'local'); +INSERT INTO `system_config` VALUES (9, 'storage_local_exts', 'doc,gif,icon,jpg,mp3,mp4,p12,pem,png,rar'); +INSERT INTO `system_config` VALUES (10, 'storage_qiniu_bucket', 'https'); +INSERT INTO `system_config` VALUES (11, 'storage_qiniu_domain', '用你自己的吧'); +INSERT INTO `system_config` VALUES (12, 'storage_qiniu_access_key', '用你自己的吧'); +INSERT INTO `system_config` VALUES (13, 'storage_qiniu_secret_key', '用你自己的吧'); +INSERT INTO `system_config` VALUES (14, 'storage_oss_bucket', 'cuci-mytest'); +INSERT INTO `system_config` VALUES (15, 'storage_oss_endpoint', 'oss-cn-hangzhou.aliyuncs.com'); +INSERT INTO `system_config` VALUES (16, 'storage_oss_domain', '用你自己的吧'); +INSERT INTO `system_config` VALUES (17, 'storage_oss_keyid', '用你自己的吧'); +INSERT INTO `system_config` VALUES (18, 'storage_oss_secret', '用你自己的吧'); +INSERT INTO `system_config` VALUES (36, 'storage_oss_is_https', 'http'); +INSERT INTO `system_config` VALUES (43, 'storage_qiniu_region', '华东'); +INSERT INTO `system_config` VALUES (44, 'storage_qiniu_is_https', 'https'); +INSERT INTO `system_config` VALUES (45, 'wechat_mch_id', '1332187001'); +INSERT INTO `system_config` VALUES (46, 'wechat_mch_key', 'A82DC5BD1F3359081049C568D8502BC5'); +INSERT INTO `system_config` VALUES (47, 'wechat_mch_ssl_type', 'p12'); +INSERT INTO `system_config` VALUES (48, 'wechat_mch_ssl_p12', '65b8e4f56718182d/1bc857ee646aa15d.p12'); +INSERT INTO `system_config` VALUES (49, 'wechat_mch_ssl_key', ''); +INSERT INTO `system_config` VALUES (50, 'wechat_mch_ssl_cer', ''); +INSERT INTO `system_config` VALUES (51, 'wechat_token', 'mytoken'); +INSERT INTO `system_config` VALUES (52, 'wechat_appid', 'wx60a43dd8161666d4'); +INSERT INTO `system_config` VALUES (53, 'wechat_appsecret', '9978422e0e431643d4b42868d183d60b'); +INSERT INTO `system_config` VALUES (54, 'wechat_encodingaeskey', ''); +INSERT INTO `system_config` VALUES (55, 'wechat_push_url', '消息推送地址:http://127.0.0.1:8000/wechat/api.push'); +INSERT INTO `system_config` VALUES (56, 'wechat_type', 'thr'); +INSERT INTO `system_config` VALUES (57, 'wechat_thr_appid', 'wx60a43dd8161666d4'); +INSERT INTO `system_config` VALUES (58, 'wechat_thr_appkey', '8007da35fd45afe88f2ccc05fe22324d'); +INSERT INTO `system_config` VALUES (60, 'wechat_thr_appurl', '消息推送地址:http://127.0.0.1:8000/wechat/api.push'); +INSERT INTO `system_config` VALUES (61, 'component_appid', 'wx1b8278fa121d8dc6'); +INSERT INTO `system_config` VALUES (62, 'component_appsecret', 'cf5af39408fb3b977584a40d399d298c'); +INSERT INTO `system_config` VALUES (63, 'component_token', 'P8QHTIxpBEq88IrxatqhgpBm2OAQROkI'); +INSERT INTO `system_config` VALUES (64, 'component_encodingaeskey', 'L5uFIa0U6KLalPyXckyqoVIJYLhsfrg8k9YzybZIHsx'); +INSERT INTO `system_config` VALUES (65, 'system_message_state', '0'); +INSERT INTO `system_config` VALUES (66, 'sms_zt_username', '可以找CUCI申请'); +INSERT INTO `system_config` VALUES (67, 'sms_zt_password', '可以找CUCI申请'); +INSERT INTO `system_config` VALUES (68, 'sms_reg_template', '您的验证码为{code},请在十分钟内完成操作!'); +INSERT INTO `system_config` VALUES (69, 'sms_secure', '可以找CUCI申请'); + +-- ---------------------------- +-- Table structure for system_data +-- ---------------------------- +DROP TABLE IF EXISTS `system_data`; +CREATE TABLE `system_data` ( + `id` bigint(11) UNSIGNED NOT NULL AUTO_INCREMENT, + `name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '配置名', + `value` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '配置值', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_data_name`(`name`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 2 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-数据' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Records of system_data +-- ---------------------------- +INSERT INTO `system_data` VALUES (1, 'menudata', '[{\"name\":\"请输入名称\",\"type\":\"view\",\"url\":\"3252\"}]'); + +-- ---------------------------- +-- Table structure for system_jobs +-- ---------------------------- +DROP TABLE IF EXISTS `system_jobs`; +CREATE TABLE `system_jobs` ( + `id` int(11) NOT NULL AUTO_INCREMENT, + `queue` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, + `payload` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL, + `attempts` bigint(20) UNSIGNED NOT NULL DEFAULT 0, + `reserved` bigint(20) UNSIGNED NOT NULL DEFAULT 0, + `reserved_at` int(10) UNSIGNED NULL DEFAULT NULL, + `available_at` int(10) UNSIGNED NOT NULL, + `created_at` int(10) UNSIGNED NOT NULL, + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_jobs_reserved`(`reserved`) USING BTREE, + INDEX `index_system_jobs_attempts`(`attempts`) USING BTREE, + INDEX `index_system_jobs_reserved_at`(`reserved_at`) USING BTREE, + INDEX `index_system_jobs_available_at`(`available_at`) USING BTREE, + INDEX `index_system_jobs_create_at`(`created_at`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-任务' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_jobs_log +-- ---------------------------- +DROP TABLE IF EXISTS `system_jobs_log`; +CREATE TABLE `system_jobs_log` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '任务名称', + `uri` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '任务对象', + `later` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '任务延时', + `data` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '任务数据', + `desc` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '任务描述', + `double` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '任务多开', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '任务状态(1新任务,2任务进行中,3任务成功,4任务失败)', + `status_at` datetime NULL DEFAULT NULL COMMENT '任务状态时间', + `status_desc` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '任务状态描述', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_jobs_log_status`(`status`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-任务-日志' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_log +-- ---------------------------- +DROP TABLE IF EXISTS `system_log`; +CREATE TABLE `system_log` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `node` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '当前操作节点', + `geoip` varchar(15) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '操作者IP地址', + `action` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '操作行为名称', + `content` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '操作内容描述', + `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NOT NULL DEFAULT '' COMMENT '操作人用户名', + `create_at` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-日志' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_menu +-- ---------------------------- +DROP TABLE IF EXISTS `system_menu`; +CREATE TABLE `system_menu` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `pid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '父ID', + `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '名称', + `node` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '节点代码', + `icon` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '菜单图标', + `url` varchar(400) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '链接', + `params` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '链接参数', + `target` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '_self' COMMENT '打开方式', + `sort` int(11) UNSIGNED NULL DEFAULT 0 COMMENT '菜单排序', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '状态(0:禁用,1:启用)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_menu_node`(`node`) USING BTREE, + INDEX `index_system_menu_status`(`status`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 51 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-菜单' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Records of system_menu +-- ---------------------------- +INSERT INTO `system_menu` VALUES (1, 0, '后台首页', '', '', 'admin/index/main', '', '_self', 100, 1, '2018-09-05 17:59:38'); +INSERT INTO `system_menu` VALUES (2, 0, '系统管理', '', '', '#', '', '_self', 300, 1, '2018-09-05 18:04:52'); +INSERT INTO `system_menu` VALUES (3, 12, '系统菜单', '', 'layui-icon layui-icon-layouts', 'admin/menu/index', '', '_self', 3, 1, '2018-09-05 18:05:26'); +INSERT INTO `system_menu` VALUES (4, 2, '系统配置', '', '', '#', '', '_self', 10, 1, '2018-09-05 18:07:17'); +INSERT INTO `system_menu` VALUES (5, 12, '用户管理', '', 'layui-icon layui-icon-username', 'admin/user/index', '', '_self', 4, 1, '2018-09-06 11:10:42'); +INSERT INTO `system_menu` VALUES (6, 12, '节点管理', '', 'layui-icon layui-icon-template', 'admin/node/index', '', '_self', 1, 1, '2018-09-06 14:16:13'); +INSERT INTO `system_menu` VALUES (7, 12, '权限管理', '', 'layui-icon layui-icon-vercode', 'admin/auth/index', '', '_self', 2, 1, '2018-09-06 15:17:14'); +INSERT INTO `system_menu` VALUES (10, 4, '文件存储', '', 'layui-icon layui-icon-template-1', 'admin/config/file', '', '_self', 2, 1, '2018-09-06 16:43:19'); +INSERT INTO `system_menu` VALUES (11, 4, '系统参数', '', 'layui-icon layui-icon-set', 'admin/config/info', '', '_self', 1, 1, '2018-09-06 16:43:47'); +INSERT INTO `system_menu` VALUES (12, 2, '权限管理', '', '', '#', '', '_self', 20, 1, '2018-09-06 18:01:31'); +INSERT INTO `system_menu` VALUES (13, 0, '商城管理', '', '', '#', '', '_self', 200, 1, '2018-10-12 13:56:29'); +INSERT INTO `system_menu` VALUES (14, 48, '商品管理', '', 'layui-icon layui-icon-component', 'store/goods/index', '', '_self', 30, 1, '2018-10-12 13:56:48'); +INSERT INTO `system_menu` VALUES (16, 0, '微信管理', '', '', '#', '', '_self', 210, 1, '2018-10-31 15:15:27'); +INSERT INTO `system_menu` VALUES (17, 16, '微信管理', '', '', '#', '', '_self', 10, 1, '2018-10-31 15:16:46'); +INSERT INTO `system_menu` VALUES (18, 17, '微信配置', '', 'layui-icon layui-icon-set', 'wechat/config/options', '', '_self', 1, 1, '2018-10-31 15:17:11'); +INSERT INTO `system_menu` VALUES (19, 17, '支付配置', '', 'layui-icon layui-icon-rmb', 'wechat/config/payment', '', '_self', 2, 1, '2018-10-31 18:28:09'); +INSERT INTO `system_menu` VALUES (20, 16, '微信定制', '', '', '#', '', '_self', 20, 1, '2018-11-13 11:46:27'); +INSERT INTO `system_menu` VALUES (21, 20, '图文管理', '', 'layui-icon layui-icon-template', 'wechat/news/index', '', '_self', 1, 1, '2018-11-13 11:46:55'); +INSERT INTO `system_menu` VALUES (22, 20, '粉丝管理', '', 'layui-icon layui-icon-user', 'wechat/fans/index', '', '_self', 2, 1, '2018-11-15 09:51:13'); +INSERT INTO `system_menu` VALUES (23, 20, '回复规则', '', 'layui-icon layui-icon-engine', 'wechat/keys/index', '', '_self', 3, 1, '2018-11-22 11:29:08'); +INSERT INTO `system_menu` VALUES (24, 20, '关注回复', '', 'layui-icon layui-icon-senior', 'wechat/keys/subscribe', '', '_self', 4, 1, '2018-11-27 11:45:28'); +INSERT INTO `system_menu` VALUES (25, 20, '默认回复', '', 'layui-icon layui-icon-survey', 'wechat/keys/defaults', '', '_self', 5, 1, '2018-11-27 11:45:58'); +INSERT INTO `system_menu` VALUES (26, 20, '微信菜单', '', 'layui-icon layui-icon-cellphone', 'wechat/menu/index', '', '_self', 6, 1, '2018-11-27 17:56:56'); +INSERT INTO `system_menu` VALUES (27, 4, '任务管理', '', 'layui-icon layui-icon-log', 'admin/queue/index', '', '_self', 3, 1, '2018-11-29 11:13:34'); +INSERT INTO `system_menu` VALUES (35, 4, '消息管理', '', 'layui-icon layui-icon-notice', 'admin/message/index', '', '_self', 4, 1, '2018-12-24 14:03:52'); +INSERT INTO `system_menu` VALUES (37, 0, '开放平台', '', '', '#', '', '_self', 220, 1, '2018-12-28 13:29:25'); +INSERT INTO `system_menu` VALUES (38, 40, '开放平台配置', '', 'layui-icon layui-icon-set', 'service/config/index', '', '_self', 0, 1, '2018-12-28 13:29:44'); +INSERT INTO `system_menu` VALUES (39, 40, '公众授权管理', '', 'layui-icon layui-icon-template-1', 'service/index/index', '', '_self', 0, 1, '2018-12-28 13:30:07'); +INSERT INTO `system_menu` VALUES (40, 37, '开放平台管理', '', '', '#', '', '_self', 0, 1, '2018-12-28 16:05:46'); +INSERT INTO `system_menu` VALUES (42, 48, '会员管理', '', 'layui-icon layui-icon-username', 'store/member/index', '', '_self', 50, 1, '2019-01-22 14:24:23'); +INSERT INTO `system_menu` VALUES (43, 48, '订单管理', '', 'layui-icon layui-icon-template-1', 'store/order/index', '', '_self', 40, 1, '2019-01-22 14:46:22'); +INSERT INTO `system_menu` VALUES (44, 48, '商品分类', '', 'layui-icon layui-icon-app', 'store/goods_cate/index', '', '_self', 20, 1, '2019-01-23 10:41:06'); +INSERT INTO `system_menu` VALUES (45, 47, '商城配置', '', 'layui-icon layui-icon-set', 'store/config/index', '', '_self', 10, 1, '2019-01-24 16:47:33'); +INSERT INTO `system_menu` VALUES (46, 47, '短信记录', '', 'layui-icon layui-icon-tabs', 'store/message/index', '', '_self', 30, 1, '2019-01-24 18:09:58'); +INSERT INTO `system_menu` VALUES (47, 13, '商城配置', '', '', '#', '', '_self', 10, 1, '2019-01-25 16:47:49'); +INSERT INTO `system_menu` VALUES (48, 13, '数据管理', '', '', '#', '', '_self', 20, 1, '2019-01-25 16:48:35'); +INSERT INTO `system_menu` VALUES (49, 4, '系统日志', '', 'layui-icon layui-icon-form', 'admin/log/index', '', '_self', 5, 1, '2019-02-18 12:56:56'); +INSERT INTO `system_menu` VALUES (50, 47, '快递管理', '', 'layui-icon layui-icon-release', 'store/express/index', '', '_self', 40, 1, '2019-04-01 17:10:59'); + +-- ---------------------------- +-- Table structure for system_message +-- ---------------------------- +DROP TABLE IF EXISTS `system_message`; +CREATE TABLE `system_message` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `code` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '消息编号', + `title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '消息名称', + `url` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '跳转地址', + `desc` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '消息描述', + `node` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '消息授权', + `read_state` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '读取状态', + `read_uid` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '读取用户', + `read_at` datetime NULL DEFAULT NULL COMMENT '读取时间', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '消息状态', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_message_code`(`code`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-消息' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for system_node +-- ---------------------------- +DROP TABLE IF EXISTS `system_node`; +CREATE TABLE `system_node` ( + `id` int(11) UNSIGNED NOT NULL AUTO_INCREMENT, + `node` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '节点代码', + `title` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '节点标题', + `is_menu` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '是否可设置为菜单', + `is_auth` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '是否启动RBAC权限控制', + `is_login` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '是否启动登录控制', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_system_node_node`(`node`) USING BTREE, + INDEX `index_system_node_is_menu`(`is_menu`) USING BTREE, + INDEX `index_system_node_is_auth`(`is_auth`) USING BTREE, + INDEX `index_system_node_is_login`(`is_login`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 187 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-节点' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Records of system_node +-- ---------------------------- +INSERT INTO `system_node` VALUES (1, 'admin', '系统管理', 0, 1, 1, '2018-09-06 14:20:42'); +INSERT INTO `system_node` VALUES (2, 'admin/menu', '菜单管理', 0, 1, 1, '2018-09-06 14:23:01'); +INSERT INTO `system_node` VALUES (3, 'admin/menu/index', '菜单列表', 1, 1, 1, '2018-09-06 14:23:01'); +INSERT INTO `system_node` VALUES (4, 'admin/menu/edit', '编辑菜单', 0, 1, 1, '2018-09-06 14:23:01'); +INSERT INTO `system_node` VALUES (5, 'admin/menu/add', '添加菜单', 0, 1, 1, '2018-09-06 14:23:01'); +INSERT INTO `system_node` VALUES (6, 'admin/menu/resume', '启用菜单', 0, 1, 1, '2018-09-06 14:23:01'); +INSERT INTO `system_node` VALUES (7, 'admin/menu/forbid', '禁用菜单', 0, 1, 1, '2018-09-06 14:23:02'); +INSERT INTO `system_node` VALUES (8, 'admin/menu/del', '删除菜单', 0, 1, 1, '2018-09-06 14:23:02'); +INSERT INTO `system_node` VALUES (9, 'admin/node/index', '节点列表', 1, 1, 1, '2018-09-06 14:24:20'); +INSERT INTO `system_node` VALUES (10, 'admin/node/clear', '清理节点', 0, 1, 1, '2018-09-06 14:24:20'); +INSERT INTO `system_node` VALUES (11, 'admin/node/save', '更新节点', 0, 1, 1, '2018-09-06 14:24:20'); +INSERT INTO `system_node` VALUES (12, 'admin/user/index', '用户列表', 1, 1, 1, '2018-09-06 14:24:21'); +INSERT INTO `system_node` VALUES (13, 'admin/user/auth', '用户授权', 0, 1, 1, '2018-09-06 14:24:21'); +INSERT INTO `system_node` VALUES (14, 'admin/user/add', '添加用户', 0, 1, 1, '2018-09-06 14:24:21'); +INSERT INTO `system_node` VALUES (15, 'admin/user/edit', '编辑用户', 0, 1, 1, '2018-09-06 14:24:21'); +INSERT INTO `system_node` VALUES (16, 'admin/user/pass', '修改密码', 0, 1, 1, '2018-09-06 14:24:22'); +INSERT INTO `system_node` VALUES (17, 'admin/user/del', '删除用户', 0, 1, 1, '2018-09-06 14:24:22'); +INSERT INTO `system_node` VALUES (18, 'admin/user/forbid', '禁用用户', 0, 1, 1, '2018-09-06 14:24:22'); +INSERT INTO `system_node` VALUES (19, 'admin/user/resume', '启用用户', 0, 1, 1, '2018-09-06 14:24:22'); +INSERT INTO `system_node` VALUES (20, 'admin/node', '节点管理', 0, 1, 1, '2018-09-06 14:35:36'); +INSERT INTO `system_node` VALUES (21, 'admin/user', '用户管理', 0, 1, 1, '2018-09-06 14:36:09'); +INSERT INTO `system_node` VALUES (22, 'admin/auth', '权限管理', 0, 1, 1, '2018-09-06 15:16:10'); +INSERT INTO `system_node` VALUES (23, 'admin/auth/index', '权限列表', 1, 1, 1, '2018-09-06 15:16:10'); +INSERT INTO `system_node` VALUES (24, 'admin/auth/apply', '节点授权', 0, 1, 1, '2018-09-06 15:16:10'); +INSERT INTO `system_node` VALUES (25, 'admin/auth/add', '添加授权', 0, 1, 1, '2018-09-06 15:16:10'); +INSERT INTO `system_node` VALUES (26, 'admin/auth/edit', '编辑权限', 0, 1, 1, '2018-09-06 15:16:10'); +INSERT INTO `system_node` VALUES (27, 'admin/auth/forbid', '禁用权限', 0, 1, 1, '2018-09-06 15:16:11'); +INSERT INTO `system_node` VALUES (28, 'admin/auth/resume', '启用权限', 0, 1, 1, '2018-09-06 15:16:11'); +INSERT INTO `system_node` VALUES (29, 'admin/auth/del', '删除权限', 0, 1, 1, '2018-09-06 15:16:11'); +INSERT INTO `system_node` VALUES (30, 'admin/config', '参数配置', 0, 1, 1, '2018-09-06 16:41:18'); +INSERT INTO `system_node` VALUES (32, 'admin/config/file', '文件存储', 1, 1, 1, '2018-09-06 16:41:19'); +INSERT INTO `system_node` VALUES (34, 'admin/config/info', '系统信息', 1, 1, 1, '2018-09-06 16:42:10'); +INSERT INTO `system_node` VALUES (36, 'store/goods/index', '商品列表', 1, 1, 1, '2018-10-12 13:54:45'); +INSERT INTO `system_node` VALUES (37, 'store/goods/add', '添加商品', 0, 1, 1, '2018-10-12 13:54:45'); +INSERT INTO `system_node` VALUES (38, 'store/goods/edit', '编辑商品', 0, 1, 1, '2018-10-12 13:54:46'); +INSERT INTO `system_node` VALUES (39, 'store', '商城管理', 0, 1, 1, '2018-10-12 13:54:53'); +INSERT INTO `system_node` VALUES (40, 'store/goods', '商品管理', 0, 1, 1, '2018-10-12 13:55:20'); +INSERT INTO `system_node` VALUES (41, 'store/goods/forbid', '禁用商品', 0, 1, 1, '2018-10-12 16:49:02'); +INSERT INTO `system_node` VALUES (42, 'store/goods/resume', '启用商品', 0, 1, 1, '2018-10-16 18:31:42'); +INSERT INTO `system_node` VALUES (43, 'store/goods/del', '删除商品', 0, 1, 1, '2018-10-16 18:31:50'); +INSERT INTO `system_node` VALUES (44, 'store/goods/stock', '商品入库', 0, 1, 1, '2018-10-22 17:58:37'); +INSERT INTO `system_node` VALUES (45, 'wechat', '微信模块', 0, 1, 1, '2018-10-31 15:13:55'); +INSERT INTO `system_node` VALUES (46, 'wechat/config', '微信配置', 0, 1, 1, '2018-10-31 15:14:00'); +INSERT INTO `system_node` VALUES (51, 'wechat/config/payment', '微信支付', 1, 1, 1, '2018-11-01 11:19:37'); +INSERT INTO `system_node` VALUES (53, 'wechat/config/options', '授权配置', 1, 1, 1, '2018-11-01 11:27:55'); +INSERT INTO `system_node` VALUES (54, 'wechat/news/index', '图文列表', 1, 1, 1, '2018-11-13 11:45:46'); +INSERT INTO `system_node` VALUES (56, 'wechat/news/select', '选择图文', 0, 1, 1, '2018-11-13 11:45:46'); +INSERT INTO `system_node` VALUES (57, 'wechat/news/add', '添加图文', 0, 1, 1, '2018-11-13 11:45:47'); +INSERT INTO `system_node` VALUES (58, 'wechat/news/edit', '编辑图文', 0, 1, 1, '2018-11-13 11:45:47'); +INSERT INTO `system_node` VALUES (59, 'wechat/news/del', '删除图文', 0, 1, 1, '2018-11-13 11:45:47'); +INSERT INTO `system_node` VALUES (61, 'wechat/fans/index', '粉丝列表', 1, 1, 1, '2018-11-15 09:50:28'); +INSERT INTO `system_node` VALUES (62, 'wechat/fans', '微信粉丝', 0, 1, 1, '2018-11-15 09:50:34'); +INSERT INTO `system_node` VALUES (63, 'wechat/news', '微信图文', 0, 1, 1, '2018-11-15 11:31:16'); +INSERT INTO `system_node` VALUES (64, 'wechat/fans/sync', '同步粉丝', 0, 1, 1, '2018-11-22 11:27:26'); +INSERT INTO `system_node` VALUES (65, 'wechat/keys/index', '回复规则列表', 1, 1, 1, '2018-11-22 11:27:27'); +INSERT INTO `system_node` VALUES (66, 'wechat/keys/add', '添加回复规则', 0, 1, 1, '2018-11-22 11:27:27'); +INSERT INTO `system_node` VALUES (67, 'wechat/keys/edit', '编辑回复规则', 0, 1, 1, '2018-11-22 11:27:27'); +INSERT INTO `system_node` VALUES (68, 'wechat/keys/del', '删除回复规则', 0, 1, 1, '2018-11-22 11:27:27'); +INSERT INTO `system_node` VALUES (69, 'wechat/keys/forbid', '禁用回复规则', 0, 1, 1, '2018-11-22 11:27:27'); +INSERT INTO `system_node` VALUES (70, 'wechat/keys/resume', '启用回复规则', 0, 1, 1, '2018-11-22 11:27:28'); +INSERT INTO `system_node` VALUES (71, 'wechat/keys', '回复规则管理', 0, 1, 1, '2018-11-23 10:26:06'); +INSERT INTO `system_node` VALUES (72, 'wechat/keys/subscribe', '关注回复规则', 1, 1, 1, '2018-11-27 11:43:27'); +INSERT INTO `system_node` VALUES (73, 'wechat/keys/defaults', '默认回复规则', 1, 1, 1, '2018-11-27 11:43:27'); +INSERT INTO `system_node` VALUES (74, 'wechat/fans/setblack', '拉黑粉丝', 0, 1, 1, '2018-11-27 16:23:21'); +INSERT INTO `system_node` VALUES (75, 'wechat/fans/delblack', '取消拉黑', 0, 1, 1, '2018-11-27 16:23:21'); +INSERT INTO `system_node` VALUES (76, 'wechat/menu/index', '微信菜单显示', 1, 1, 1, '2018-11-27 17:56:28'); +INSERT INTO `system_node` VALUES (77, 'wechat/menu/edit', '更新微信菜单', 0, 1, 1, '2018-11-27 17:56:28'); +INSERT INTO `system_node` VALUES (78, 'wechat/menu/cancel', '取消微信菜单', 0, 1, 1, '2018-11-27 17:56:29'); +INSERT INTO `system_node` VALUES (79, 'wechat/menu', '微信菜单管理', 0, 1, 1, '2018-11-28 16:03:03'); +INSERT INTO `system_node` VALUES (80, 'admin/queue/index', '任务列表', 1, 1, 1, '2018-11-29 11:12:54'); +INSERT INTO `system_node` VALUES (81, 'admin/queue', '任务管理', 0, 1, 1, '2018-11-29 11:13:05'); +INSERT INTO `system_node` VALUES (82, 'admin/queue/redo', '重启任务', 0, 1, 1, '2018-11-29 15:17:43'); +INSERT INTO `system_node` VALUES (83, 'admin/queue/del', '删除任务', 0, 1, 1, '2018-12-04 15:16:59'); +INSERT INTO `system_node` VALUES (114, 'admin/message/index', '消息管理', 1, 1, 1, '2018-12-24 14:03:09'); +INSERT INTO `system_node` VALUES (115, 'admin/message', '消息管理', 0, 1, 1, '2018-12-24 14:03:14'); +INSERT INTO `system_node` VALUES (116, 'admin/message/state', '消息状态', 0, 1, 1, '2018-12-24 18:41:37'); +INSERT INTO `system_node` VALUES (117, 'admin/message/del', '删除消息', 0, 1, 1, '2018-12-24 18:41:37'); +INSERT INTO `system_node` VALUES (118, 'service', '开放平台', 0, 1, 1, '2018-12-28 13:27:38'); +INSERT INTO `system_node` VALUES (119, 'service/config', '开放平台', 0, 1, 1, '2018-12-28 13:27:41'); +INSERT INTO `system_node` VALUES (120, 'service/config/index', '开放平台配置', 1, 1, 1, '2018-12-28 13:27:42'); +INSERT INTO `system_node` VALUES (121, 'service/index/index', '公众号授权列表', 1, 1, 1, '2018-12-28 13:27:42'); +INSERT INTO `system_node` VALUES (122, 'service/index/sync', '同步公众号授权', 0, 1, 1, '2018-12-28 13:27:42'); +INSERT INTO `system_node` VALUES (123, 'service/index/syncall', '公众号所有授权', 0, 1, 1, '2018-12-28 13:27:43'); +INSERT INTO `system_node` VALUES (124, 'service/index/del', '删除公众号授权', 0, 1, 1, '2018-12-28 13:27:43'); +INSERT INTO `system_node` VALUES (125, 'service/index/forbid', '禁用公众号授权', 0, 1, 1, '2018-12-28 13:27:43'); +INSERT INTO `system_node` VALUES (126, 'service/index/resume', '启用公众号授权', 0, 1, 1, '2018-12-28 13:27:43'); +INSERT INTO `system_node` VALUES (127, 'service/index', '公众号授权管理', 0, 1, 1, '2018-12-28 13:27:59'); +INSERT INTO `system_node` VALUES (147, 'admin/message/clear', '清理消息', 0, 1, 1, '2019-01-05 13:23:49'); +INSERT INTO `system_node` VALUES (148, 'admin/message/onoff', '消息开关', 0, 1, 1, '2019-01-05 13:23:49'); +INSERT INTO `system_node` VALUES (149, 'store/page/index', '页面管理', 1, 1, 1, '2019-01-18 09:58:00'); +INSERT INTO `system_node` VALUES (150, 'store/page/add', '添加页面', 0, 1, 1, '2019-01-18 09:58:00'); +INSERT INTO `system_node` VALUES (151, 'store/page/edit', '编辑页面', 0, 1, 1, '2019-01-18 09:58:00'); +INSERT INTO `system_node` VALUES (152, 'store/page/forbid', '禁用页面', 0, 1, 1, '2019-01-18 09:58:00'); +INSERT INTO `system_node` VALUES (153, 'store/page/resume', '启用页面', 0, 1, 1, '2019-01-18 09:58:01'); +INSERT INTO `system_node` VALUES (154, 'store/page/del', '删除页面', 0, 1, 1, '2019-01-18 09:58:01'); +INSERT INTO `system_node` VALUES (155, 'store/page', '页面管理', 0, 1, 1, '2019-01-18 09:58:07'); +INSERT INTO `system_node` VALUES (156, 'store/member/index', '商城会员管理', 1, 1, 1, '2019-01-22 14:23:55'); +INSERT INTO `system_node` VALUES (157, 'store/member', '商城会员管理', 0, 1, 1, '2019-01-22 14:24:02'); +INSERT INTO `system_node` VALUES (158, 'store/order/index', '商城订单管理', 1, 1, 1, '2019-01-22 14:45:52'); +INSERT INTO `system_node` VALUES (159, 'store/order', '商城订单管理', 0, 1, 1, '2019-01-22 14:45:59'); +INSERT INTO `system_node` VALUES (160, 'store/goods_cate/index', '商品分类管理', 1, 1, 1, '2019-01-23 10:39:54'); +INSERT INTO `system_node` VALUES (161, 'store/goods_cate/add', '添加商品分类', 0, 1, 1, '2019-01-23 10:39:54'); +INSERT INTO `system_node` VALUES (162, 'store/goods_cate/edit', '编辑商品分类', 0, 1, 1, '2019-01-23 10:39:54'); +INSERT INTO `system_node` VALUES (163, 'store/goods_cate/forbid', '禁用商品分类', 0, 1, 1, '2019-01-23 10:39:55'); +INSERT INTO `system_node` VALUES (164, 'store/goods_cate/resume', '启用商品分类', 0, 1, 1, '2019-01-23 10:39:55'); +INSERT INTO `system_node` VALUES (165, 'store/goods_cate/del', '删除商品分类', 0, 1, 1, '2019-01-23 10:39:55'); +INSERT INTO `system_node` VALUES (166, 'store/goods_cate', '商品分类', 0, 1, 1, '2019-01-23 10:40:01'); +INSERT INTO `system_node` VALUES (167, 'store/config/index', '商城配置', 1, 1, 1, '2019-01-24 16:47:01'); +INSERT INTO `system_node` VALUES (168, 'store/config', '商城配置', 0, 1, 1, '2019-01-24 16:47:09'); +INSERT INTO `system_node` VALUES (169, 'store/message/index', '短信消息', 1, 1, 1, '2019-01-24 18:09:05'); +INSERT INTO `system_node` VALUES (170, 'store/message', '短信消息', 0, 1, 1, '2019-01-24 18:09:12'); +INSERT INTO `system_node` VALUES (171, 'admin/log/index', '日志管理列表', 1, 1, 1, '2019-02-18 12:56:07'); +INSERT INTO `system_node` VALUES (172, 'admin/log/del', '删除日志管理', 0, 1, 1, '2019-02-18 12:56:07'); +INSERT INTO `system_node` VALUES (173, 'admin/log', '系统日志管理', 0, 1, 1, '2019-02-18 12:56:15'); +INSERT INTO `system_node` VALUES (176, 'wechat/fans/del', '删除粉丝', 0, 1, 1, '2019-03-18 10:58:10'); +INSERT INTO `system_node` VALUES (177, 'service/index/clearquota', '清空调用次数', 0, 1, 1, '2019-03-30 16:39:17'); +INSERT INTO `system_node` VALUES (178, 'store/express/index', '快递公司管理', 1, 1, 1, '2019-04-01 17:09:27'); +INSERT INTO `system_node` VALUES (179, 'store/express/add', '添加快递公司', 0, 1, 1, '2019-04-01 17:09:27'); +INSERT INTO `system_node` VALUES (180, 'store/express/edit', '编辑快递公司', 0, 1, 1, '2019-04-01 17:09:27'); +INSERT INTO `system_node` VALUES (181, 'store/express/forbid', '禁用快递公司', 0, 1, 1, '2019-04-01 17:09:27'); +INSERT INTO `system_node` VALUES (182, 'store/express/resume', '启用快递公司', 0, 1, 1, '2019-04-01 17:09:28'); +INSERT INTO `system_node` VALUES (183, 'store/express/del', '删除快递公司', 0, 1, 1, '2019-04-01 17:09:28'); +INSERT INTO `system_node` VALUES (184, 'store/order/express', '商城订单发货', 0, 1, 1, '2019-04-01 17:09:30'); +INSERT INTO `system_node` VALUES (185, 'store/order/expressquery', '商城快递查询', 0, 1, 1, '2019-04-01 17:09:30'); +INSERT INTO `system_node` VALUES (186, 'store/express', '快递公司管理', 0, 1, 1, '2019-04-01 17:09:55'); + +-- ---------------------------- +-- Table structure for system_user +-- ---------------------------- +DROP TABLE IF EXISTS `system_user`; +CREATE TABLE `system_user` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `username` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户账号', + `password` char(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户密码', + `qq` varchar(16) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '联系QQ', + `mail` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '联系邮箱', + `phone` varchar(16) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '联系手机号', + `login_at` datetime NULL DEFAULT NULL COMMENT '登录时间', + `login_ip` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '登录IP', + `login_num` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '登录次数', + `authorize` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '权限授权', + `desc` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '备注说明', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '状态(0:禁用,1:启用)', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '删除(1:删除,0:未删)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + UNIQUE INDEX `index_system_user_username`(`username`) USING BTREE, + INDEX `index_system_user_status`(`status`) USING BTREE, + INDEX `index_system_user_deleted`(`is_deleted`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 10001 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '系统-用户' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Records of system_user +-- ---------------------------- +INSERT INTO `system_user` VALUES (10000, 'admin', '21232f297a57a5a743894a0e4a801fc3', '22222222', '', '', '2019-04-01 16:55:15', '127.0.0.1', 500, '', '', 1, 0, '2015-11-13 15:14:22'); + +-- ---------------------------- +-- Table structure for wechat_fans +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_fans`; +CREATE TABLE `wechat_fans` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `appid` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号APPID', + `unionid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '粉丝unionid', + `openid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '粉丝openid', + `tagid_list` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '粉丝标签id', + `is_black` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '是否为黑名单状态', + `subscribe` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '关注状态(0未关注,1已关注)', + `nickname` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户昵称', + `sex` tinyint(1) UNSIGNED NULL DEFAULT NULL COMMENT '用户性别(1男性,2女性,0未知)', + `country` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户所在国家', + `province` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户所在省份', + `city` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户所在城市', + `language` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户的语言(zh_CN)', + `headimgurl` varchar(500) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '用户头像', + `subscribe_time` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '关注时间', + `subscribe_at` datetime NULL DEFAULT NULL COMMENT '关注时间', + `remark` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '备注', + `subscribe_scene` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '扫码关注场景', + `qr_scene` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '二维码场景值', + `qr_scene_str` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '二维码场景内容', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_wechat_fans_openid`(`openid`) USING BTREE, + INDEX `index_wechat_fans_unionid`(`unionid`) USING BTREE, + INDEX `index_wechat_fans_is_back`(`is_black`) USING BTREE, + INDEX `index_wechat_fans_subscribe`(`subscribe`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-粉丝' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for wechat_fans_tags +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_fans_tags`; +CREATE TABLE `wechat_fans_tags` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT COMMENT '标签ID', + `appid` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号APPID', + `name` varchar(35) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '标签名称', + `count` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '总数', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建日期', + INDEX `index_wechat_fans_tags_id`(`id`) USING BTREE, + INDEX `index_wechat_fans_tags_appid`(`appid`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-粉丝-标签' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for wechat_keys +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_keys`; +CREATE TABLE `wechat_keys` ( + `id` bigint(20) NOT NULL AUTO_INCREMENT, + `appid` char(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号APPID', + `type` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '类型,text 文件消息,image 图片消息,news 图文消息', + `keys` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT NULL COMMENT '关键字', + `content` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '文本内容', + `image_url` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '图片链接', + `voice_url` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '语音链接', + `music_title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '音乐标题', + `music_url` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '音乐链接', + `music_image` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '音乐缩略图链接', + `music_desc` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '音乐描述', + `video_title` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '视频标题', + `video_url` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '视频URL', + `video_desc` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '视频描述', + `news_id` bigint(20) UNSIGNED NULL DEFAULT NULL COMMENT '图文ID', + `sort` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '排序字段', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '0 禁用,1 启用', + `create_by` bigint(20) UNSIGNED NULL DEFAULT NULL COMMENT '创建人', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_wechat_keys_appid`(`appid`) USING BTREE, + INDEX `index_wechat_keys_type`(`type`) USING BTREE, + INDEX `index_wechat_keys_keys`(`keys`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-关键字' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for wechat_media +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_media`; +CREATE TABLE `wechat_media` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `appid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号ID', + `md5` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '文件md5', + `type` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '媒体类型', + `media_id` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '永久素材MediaID', + `local_url` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '本地文件链接', + `media_url` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '远程图片链接', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_wechat_media_appid`(`appid`) USING BTREE, + INDEX `index_wechat_media_md5`(`md5`) USING BTREE, + INDEX `index_wechat_media_type`(`type`) USING BTREE, + INDEX `index_wechat_media_media_id`(`media_id`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-素材' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for wechat_news +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_news`; +CREATE TABLE `wechat_news` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `media_id` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '永久素材MediaID', + `local_url` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '永久素材显示URL', + `article_id` varchar(60) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '关联图文ID,用,号做分割', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '是否删除', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + `create_by` bigint(20) NULL DEFAULT NULL COMMENT '创建人', + PRIMARY KEY (`id`) USING BTREE, + INDEX `index_wechat_news_artcle_id`(`article_id`) USING BTREE, + INDEX `index_wechat_news_media_id`(`media_id`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-图文' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for wechat_news_article +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_news_article`; +CREATE TABLE `wechat_news_article` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `title` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '素材标题', + `local_url` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '永久素材显示URL', + `show_cover_pic` tinyint(4) UNSIGNED NULL DEFAULT 0 COMMENT '显示封面(0 不显示, 1 显示)', + `author` varchar(20) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '作者', + `digest` varchar(300) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '摘要内容', + `content` longtext CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '图文内容', + `content_source_url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '原文地址', + `read_num` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '阅读量', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-图文-文章' ROW_FORMAT = Compact; + +-- ---------------------------- +-- Table structure for wechat_service_config +-- ---------------------------- +DROP TABLE IF EXISTS `wechat_service_config`; +CREATE TABLE `wechat_service_config` ( + `id` bigint(20) UNSIGNED NOT NULL AUTO_INCREMENT, + `authorizer_appid` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号APPID', + `authorizer_access_token` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号授权Token', + `authorizer_refresh_token` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号刷新Token', + `func_info` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号集权', + `nick_name` varchar(50) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号昵称', + `head_img` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号头像', + `expires_in` bigint(20) NULL DEFAULT NULL COMMENT 'Token有效时间', + `service_type` tinyint(2) NULL DEFAULT NULL COMMENT '微信类型(0代表订阅号,2代表服务号,3代表小程序)', + `service_type_info` tinyint(2) NULL DEFAULT NULL COMMENT '公众号实际类型', + `verify_type` tinyint(2) NULL DEFAULT NULL COMMENT '公众号认证类型(-1代表未认证, 0代表微信认证)', + `verify_type_info` tinyint(2) NULL DEFAULT NULL COMMENT '公众号实际认证类型', + `user_name` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '众众号原始账号', + `alias` varchar(100) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号别名', + `qrcode_url` varchar(200) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公众号二维码', + `business_info` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '', + `principal_name` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '公司名称', + `miniprograminfo` varchar(1024) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '小程序JSON', + `idc` tinyint(1) UNSIGNED NULL DEFAULT NULL, + `signature` text CHARACTER SET utf8 COLLATE utf8_general_ci NULL COMMENT '小程序的描述', + `total` bigint(20) UNSIGNED NULL DEFAULT 0 COMMENT '统计调用次数', + `appkey` varchar(32) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '应用接口KEY', + `appuri` varchar(255) CHARACTER SET utf8 COLLATE utf8_general_ci NULL DEFAULT '' COMMENT '应用接口URI', + `status` tinyint(1) UNSIGNED NULL DEFAULT 1 COMMENT '状态(1正常授权,0取消授权)', + `is_deleted` tinyint(1) UNSIGNED NULL DEFAULT 0 COMMENT '删除状态(0未删除,1已删除)', + `create_at` timestamp NULL DEFAULT CURRENT_TIMESTAMP COMMENT '创建时间', + PRIMARY KEY (`id`) USING BTREE, + UNIQUE INDEX `index_wechat_service_config_authorizer_appid`(`authorizer_appid`) USING BTREE, + INDEX `index_wechat_service_config_status`(`status`) USING BTREE, + INDEX `index_wechat_service_config_is_deleted`(`is_deleted`) USING BTREE +) ENGINE = InnoDB AUTO_INCREMENT = 1 CHARACTER SET = utf8 COLLATE = utf8_general_ci COMMENT = '微信-授权' ROW_FORMAT = Compact; + +SET FOREIGN_KEY_CHECKS = 1; diff --git a/application/.htaccess b/application/.htaccess deleted file mode 100644 index 3418e55a6..000000000 --- a/application/.htaccess +++ /dev/null @@ -1 +0,0 @@ -deny from all \ No newline at end of file diff --git a/application/admin/controller/Auth.php b/application/admin/controller/Auth.php index b9beb8adb..196261b11 100644 --- a/application/admin/controller/Auth.php +++ b/application/admin/controller/Auth.php @@ -1,11 +1,11 @@ - * @date 2017/02/15 18:13 */ -class Auth extends BasicAdmin +class Auth extends Controller { - /** * 默认数据模型 * @var string @@ -38,81 +32,56 @@ class Auth extends BasicAdmin /** * 权限列表 - * @return array|string * @throws \think\Exception * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException + * @throws \think\exception\PDOException */ public function index() { $this->title = '系统权限管理'; - return parent::_list($this->table); + $this->_query($this->table)->dateBetween('create_at')->like('title,desc')->equal('status')->order('sort asc,id desc')->page(); } /** - * 权限授权 - * @return string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception - */ - public function apply() - { - $this->title = '节点授权'; - $auth_id = $this->request->get('id', '0'); - $method = '_apply_' . strtolower($this->request->get('action', '0')); - if (method_exists($this, $method)) { - return $this->$method($auth_id); - } - return $this->_form($this->table, 'apply'); - } - - /** - * 读取授权节点 - * @param string $auth - */ - protected function _apply_getnode($auth) - { - $nodes = NodeService::get(); - $checked = Db::name('SystemAuthNode')->where(['auth' => $auth])->column('node'); - foreach ($nodes as &$node) { - $node['checked'] = in_array($node['node'], $checked); - } - $all = $this->_apply_filter(ToolsService::arr2tree($nodes, 'node', 'pnode', '_sub_')); - $this->success('获取节点成功!', '', $all); - } - - /** - * 保存授权节点 - * @param string $auth + * 权限授权节点 + * @return mixed * @throws \think\Exception * @throws \think\exception\PDOException */ - protected function _apply_save($auth) + public function apply() { - list($data, $post) = [[], $this->request->post()]; - foreach (isset($post['nodes']) ? $post['nodes'] : [] as $node) { - $data[] = ['auth' => $auth, 'node' => $node]; + $this->title = '权限授权配置'; + $auth = $this->request->post('id', '0'); + switch (strtolower($this->request->post('action'))) { + case 'get': // 获取权限配置 + $nodes = \app\admin\service\Auth::get(); + $checked = Db::name('SystemAuthNode')->where(['auth' => $auth])->column('node'); + foreach ($nodes as &$node) $node['checked'] = in_array($node['node'], $checked); + $data = $this->_apply_filter(\library\tools\Data::arr2tree($nodes, 'node', 'pnode', '_sub_')); + return $this->success('获取权限配置成功!', $data); + case 'save': // 保存权限配置 + list($post, $data) = [$this->request->post(), []]; + foreach (isset($post['nodes']) ? $post['nodes'] : [] as $node) $data[] = ['auth' => $auth, 'node' => $node]; + Db::name('SystemAuthNode')->where(['auth' => $auth])->delete(); + Db::name('SystemAuthNode')->insertAll($data); + return $this->success('权限授权配置更新成功!'); + default: + return $this->_form($this->table, 'apply'); } - Db::name('SystemAuthNode')->where(['auth' => $auth])->delete(); - Db::name('SystemAuthNode')->insertAll($data); - $this->success('节点授权更新成功!', ''); } /** * 节点数据拼装 * @param array $nodes - * @param int $level + * @param integer $level * @return array */ - protected function _apply_filter($nodes, $level = 1) + private function _apply_filter($nodes, $level = 1) { - foreach ($nodes as $key => $node) { - if (!empty($node['_sub_']) && is_array($node['_sub_'])) { - $node[$key]['_sub_'] = $this->_apply_filter($node['_sub_'], $level + 1); - } + foreach ($nodes as $key => $node) if (!empty($node['_sub_']) && is_array($node['_sub_'])) { + $node[$key]['_sub_'] = $this->_apply_filter($node['_sub_'], $level + 1); } return $nodes; } @@ -120,68 +89,65 @@ class Auth extends BasicAdmin /** * 权限添加 * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception */ public function add() { - return $this->_form($this->table, 'form'); + $this->applyCsrfToken(); + $this->_form($this->table, 'form'); } /** * 权限编辑 * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception */ public function edit() { - return $this->_form($this->table, 'form'); + $this->applyCsrfToken(); + $this->_form($this->table, 'form'); } /** * 权限禁用 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function forbid() { - if (DataService::update($this->table)) { - $this->success("权限禁用成功!", ''); - } - $this->error("权限禁用失败,请稍候再试!"); + $this->applyCsrfToken(); + $this->_save($this->table, ['status' => '0']); } /** * 权限恢复 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function resume() { - if (DataService::update($this->table)) { - $this->success("权限启用成功!", ''); - } - $this->error("权限启用失败,请稍候再试!"); + $this->applyCsrfToken(); + $this->_save($this->table, ['status' => '1']); } /** * 权限删除 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function del() { - if (DataService::update($this->table)) { + $this->applyCsrfToken(); + $this->_delete($this->table); + } + + /** + * 删除结果处理 + * @param boolean $result + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + protected function _del_delete_result($result) + { + if ($result) { $where = ['auth' => $this->request->post('id')]; Db::name('SystemAuthNode')->where($where)->delete(); $this->success("权限删除成功!", ''); + } else { + $this->error("权限删除失败,请稍候再试!"); } - $this->error("权限删除失败,请稍候再试!"); } -} +} \ No newline at end of file diff --git a/application/admin/controller/Config.php b/application/admin/controller/Config.php index 2d4022100..dcccc4831 100644 --- a/application/admin/controller/Config.php +++ b/application/admin/controller/Config.php @@ -1,11 +1,11 @@ - * @date 2017/02/15 18:05 */ -class Config extends BasicAdmin +class Config extends Controller { - /** - * 当前默认数据模型 + * 默认数据模型 * @var string */ - public $table = 'SystemConfig'; + protected $table = 'SystemConfig'; /** - * 当前页面标题 - * @var string - */ - public $title = '系统参数配置'; - - /** - * 显示系统常规配置 - * @return string + * 系统参数配置 + * @return mixed * @throws \think\Exception * @throws \think\exception\PDOException */ - public function index() + public function info() { - if ($this->request->isGet()) { - return $this->fetch('', ['title' => $this->title]); - } - if ($this->request->isPost()) { - foreach ($this->request->post() as $key => $vo) { - sysconf($key, $vo); - } - LogService::write('系统管理', '系统参数配置成功'); - $this->success('系统参数配置成功!', ''); - } + $this->applyCsrfToken(); + $this->title = '系统参数配置'; + if ($this->request->isGet()) return $this->fetch(); + foreach ($this->request->post() as $k => $v) sysconf($k, $v); + $this->success('系统参数配置保存成功!'); } /** @@ -68,8 +52,58 @@ class Config extends BasicAdmin */ public function file() { - $this->title = '文件存储配置'; - return $this->index(); + $this->applyCsrfToken(); + if ($this->request->isGet()) { + $this->fetch('file', [ + 'title' => '文件存储配置', + 'point' => [ + 'oss-cn-hangzhou.aliyuncs.com' => '华东 1 杭州', + 'oss-cn-shanghai.aliyuncs.com' => '华东 2 上海', + 'oss-cn-qingdao.aliyuncs.com' => '华北 1 青岛', + 'oss-cn-beijing.aliyuncs.com' => '华北 2 北京', + 'oss-cn-zhangjiakou.aliyuncs.com' => '华北 3 张家口', + 'oss-cn-huhehaote.aliyuncs.com' => '华北 5 呼和浩特', + 'oss-cn-shenzhen.aliyuncs.com' => '华南 1 深圳', + 'oss-cn-hongkong.aliyuncs.com' => '香港 1', + 'oss-us-west-1.aliyuncs.com' => '美国西部 1 硅谷', + 'oss-us-east-1.aliyuncs.com' => '美国东部 1 弗吉尼亚', + 'oss-ap-southeast-1.aliyuncs.com' => '亚太东南 1 新加坡', + 'oss-ap-southeast-2.aliyuncs.com' => '亚太东南 2 悉尼', + 'oss-ap-southeast-3.aliyuncs.com' => '亚太东南 3 吉隆坡', + 'oss-ap-southeast-5.aliyuncs.com' => '亚太东南 5 雅加达', + 'oss-ap-northeast-1.aliyuncs.com' => '亚太东北 1 日本', + 'oss-ap-south-1.aliyuncs.com' => '亚太南部 1 孟买', + 'oss-eu-central-1.aliyuncs.com' => '欧洲中部 1 法兰克福', + 'oss-eu-west-1.aliyuncs.com' => '英国 1 伦敦', + 'oss-me-east-1.aliyuncs.com' => '中东东部 1 迪拜', + ], + ]); + } else { + $post = $this->request->post(); + if (isset($post['storage_type']) && $post['storage_type'] === 'local') { + $exts = array_unique(explode(',', $post['storage_local_exts'])); + if (in_array('php', $exts)) $this->error('禁止上传可执行文件到本地服务器!'); + $post['storage_local_exts'] = join(',', $exts); + } + foreach ($post as $key => $value) sysconf($key, $value); + if (isset($post['storage_type']) && $post['storage_type'] === 'oss') { + try { + $local = sysconf('storage_oss_domain'); + $bucket = $this->request->post('storage_oss_bucket'); + $domain = \library\File::instance('oss')->setBucket($bucket); + if (empty($local) || stripos($local, '.aliyuncs.com') !== false) { + sysconf('storage_oss_domain', $domain); + } + $this->success('阿里云OSS存储动态配置成功!'); + } catch (\think\exception\HttpResponseException $exception) { + throw $exception; + } catch (\Exception $e) { + $this->error("阿里云OSS存储配置失效,{$e->getMessage()}"); + } + } else { + $this->success('文件存储配置保存成功!'); + } + } } -} +} \ No newline at end of file diff --git a/application/admin/controller/Index.php b/application/admin/controller/Index.php index 9658264b3..ea6bff2ef 100644 --- a/application/admin/controller/Index.php +++ b/application/admin/controller/Index.php @@ -1,11 +1,11 @@ - * @date 2017/02/15 10:41 */ -class Index extends BasicAdmin +class Index extends Controller { /** - * 后台框架布局 + * 显示后台首页 * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException */ public function index() { - NodeService::applyAuthNode(); - $list = (array)Db::name('SystemMenu')->where(['status' => '1'])->order('sort asc,id asc')->select(); - $menus = $this->buildMenuData(ToolsService::arr2tree($list), NodeService::get(), !!session('user')); - if (empty($menus) && !session('user.id')) { + $this->title = '系统管理后台'; + $this->menus = \app\admin\service\Auth::getAuthMenu(); + if (empty($this->menus) && !session('user.id')) { $this->redirect('@admin/login'); + } else { + $this->fetch(); } - return $this->fetch('', ['title' => '系统管理', 'menus' => $menus]); } /** - * 后台主菜单权限过滤 - * @param array $menus 当前菜单列表 - * @param array $nodes 系统权限节点数据 - * @param bool $isLogin 是否已经登录 - * @return array - */ - private function buildMenuData($menus, $nodes, $isLogin) - { - foreach ($menus as $key => &$menu) { - !empty($menu['sub']) && $menu['sub'] = $this->buildMenuData($menu['sub'], $nodes, $isLogin); - if (!empty($menu['sub'])) { - $menu['url'] = '#'; - } elseif (preg_match('/^https?\:/i', $menu['url'])) { - continue; - } elseif ($menu['url'] !== '#') { - $node = join('/', array_slice(explode('/', preg_replace('/[\W]/', '/', $menu['url'])), 0, 3)); - $menu['url'] = url($menu['url']) . (empty($menu['params']) ? '' : "?{$menu['params']}"); - if (isset($nodes[$node]) && $nodes[$node]['is_login'] && empty($isLogin)) { - unset($menus[$key]); - } elseif (isset($nodes[$node]) && $nodes[$node]['is_auth'] && $isLogin && !auth($node)) { - unset($menus[$key]); - } - } else { - unset($menus[$key]); - } - } - return $menus; - } - - /** - * 主机信息显示 - * @return string + * 后台环境信息 + * @return mixed */ public function main() { - $_version = Db::query('select version() as ver'); - return $this->fetch('', [ - 'title' => '后台首页', - 'think_ver' => App::VERSION, - 'mysql_ver' => array_pop($_version)['ver'], - ]); + $this->title = '后台首页'; + $this->think_ver = \think\App::VERSION; + $this->mysql_ver = Db::query('select version() as ver')[0]['ver']; + $this->fetch(); + } + + /** + * 清理系统运行缓存 + */ + public function clearRuntime() + { + if (!\app\admin\service\Auth::isLogin()) { + $this->error('需要登录才能操作哦!'); + } + $this->list = [ + [ + 'title' => 'Clean up running cached files', + 'message' => nl2br(Console::call('clear')->fetch()), + ], [ + 'title' => 'Clean up invalid session files', + 'message' => nl2br(Console::call('xclean:session')->fetch()), + ], + ]; + $this->fetch('admin@index/command'); + } + + /** + * 压缩发布系统 + */ + public function buildOptimize() + { + if (!\app\admin\service\Auth::isLogin()) { + $this->error('需要登录才能操作哦!'); + } + $this->list = [ + [ + 'title' => 'Build route cache', + 'message' => nl2br(Console::call('optimize:route')->fetch()), + ], [ + 'title' => 'Build database schema cache', + 'message' => nl2br(Console::call('optimize:schema')->fetch()), + ], [ + 'title' => 'Optimizes PSR0 and PSR4 packages', + 'message' => nl2br(Console::call('optimize:autoload')->fetch()), + ], [ + 'title' => 'Build config and common file cache', + 'message' => nl2br(Console::call('optimize:config')->fetch()), + ], + ]; + $this->fetch('admin@index/command'); } /** * 修改密码 - * @return array|string + * @param integer $id * @throws \think\Exception * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException * @throws \think\exception\PDOException */ - public function pass() + public function pass($id) { - if (intval($this->request->request('id')) !== intval(session('user.id'))) { + $this->applyCsrfToken(); + if (intval($id) !== intval(session('user.id'))) { $this->error('只能修改当前用户的密码!'); } if ($this->request->isGet()) { - $this->assign('verify', true); - return $this->_form('SystemUser', 'user/pass'); + $this->verify = true; + $this->_form('SystemUser', 'admin@user/pass', 'id', [], ['id' => $id]); + } else { + $data = $this->_input([ + 'password' => $this->request->post('password'), + 'repassword' => $this->request->post('repassword'), + 'oldpassword' => $this->request->post('oldpassword'), + ], [ + 'oldpassword' => 'require', + 'password' => 'require|min:4', + 'repassword' => 'require|confirm:password', + ], [ + 'oldpassword.require' => '旧密码不能为空!', + 'password.require' => '登录密码不能为空!', + 'password.min' => '登录密码长度不能少于4位有效字符!', + 'repassword.require' => '重复密码不能为空!', + 'repassword.confirm' => '重复密码与登录密码不匹配,请重新输入!', + ]); + $user = Db::name('SystemUser')->where(['id' => $id])->find(); + if (md5($data['oldpassword']) !== $user['password']) { + $this->error('旧密码验证失败,请重新输入!'); + } + $result = \app\admin\service\Auth::checkPassword($data['password']); + if (empty($result['code'])) $this->error($result['msg']); + if (Data::save('SystemUser', ['id' => $user['id'], 'password' => md5($data['password'])])) { + $this->success('密码修改成功,下次请使用新密码登录!', ''); + } else { + $this->error('密码修改失败,请稍候再试!'); + } } - $data = $this->request->post(); - if ($data['password'] !== $data['repassword']) { - $this->error('两次输入的密码不一致,请重新输入!'); - } - $user = Db::name('SystemUser')->where('id', session('user.id'))->find(); - if (md5($data['oldpassword']) !== $user['password']) { - $this->error('旧密码验证失败,请重新输入!'); - } - if (DataService::save('SystemUser', ['id' => session('user.id'), 'password' => md5($data['password'])])) { - $this->success('密码修改成功,下次请使用新密码登录!', ''); - } - $this->error('密码修改失败,请稍候再试!'); } /** - * 修改资料 - * @return array|string - * @throws \think\Exception - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException + * 修改用户资料 + * @param integer $id 会员ID */ - public function info() + public function info($id = 0) { - if (intval($this->request->request('id')) === intval(session('user.id'))) { - return $this->_form('SystemUser', 'user/form'); + $this->applyCsrfToken(); + if (intval($id) === intval(session('user.id'))) { + $this->_form('SystemUser', 'user/form', 'id', [], ['id' => $id]); + } else { + $this->error('只能修改登录用户的资料!'); } - $this->error('只能修改当前用户的资料!'); } -} +} \ No newline at end of file diff --git a/application/admin/controller/Log.php b/application/admin/controller/Log.php index d9ae070dd..f29c10d50 100644 --- a/application/admin/controller/Log.php +++ b/application/admin/controller/Log.php @@ -1,11 +1,11 @@ - * @date 2017/02/15 18:12 */ -class Log extends BasicAdmin +class Log extends Controller { /** @@ -36,7 +32,6 @@ class Log extends BasicAdmin /** * 日志列表 - * @return array|string * @throws \think\Exception * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException @@ -44,20 +39,8 @@ class Log extends BasicAdmin */ public function index() { - // 日志行为类别 - $actions = Db::name($this->table)->group('action')->column('action'); - $this->assign('actions', $actions); - // 日志数据库对象 - list($this->title, $get) = ['系统操作日志', $this->request->get()]; - $db = Db::name($this->table)->order('id desc'); - foreach (['action', 'content', 'username'] as $key) { - (isset($get[$key]) && $get[$key] !== '') && $db->whereLike($key, "%{$get[$key]}%"); - } - if (isset($get['create_at']) && $get['create_at'] !== '') { - list($start, $end) = explode(' - ', $get['create_at']); - $db->whereBetween('create_at', ["{$start} 00:00:00", "{$end} 23:59:59"]); - } - return parent::_list($db); + $this->title = '系统操作日志'; + $this->_query($this->table)->like('action,node,content,username,geoip')->dateBetween('create_at')->order('id desc')->page(); } /** @@ -65,11 +48,11 @@ class Log extends BasicAdmin * @param array $data * @throws \Exception */ - protected function _index_data_filter(&$data) + protected function _index_page_filter(&$data) { $ip = new \Ip2Region(); foreach ($data as &$vo) { - $result = $ip->btreeSearch($vo['ip']); + $result = $ip->btreeSearch($vo['geoip']); $vo['isp'] = isset($result['region']) ? $result['region'] : ''; $vo['isp'] = str_replace(['内网IP', '0', '|'], '', $vo['isp']); } @@ -77,15 +60,11 @@ class Log extends BasicAdmin /** * 日志删除操作 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function del() { - if (DataService::update($this->table)) { - $this->success("日志删除成功!", ''); - } - $this->error("日志删除失败, 请稍候再试!"); + $this->applyCsrfToken(); + $this->_delete($this->table); } -} +} \ No newline at end of file diff --git a/application/admin/controller/Login.php b/application/admin/controller/Login.php index 6e61de34d..e8565db93 100644 --- a/application/admin/controller/Login.php +++ b/application/admin/controller/Login.php @@ -1,11 +1,11 @@ - * @date 2017/02/10 13:59 */ -class Login extends BasicAdmin +class Login extends Controller { - /** - * 控制器基础方法 + * 设置页面标题 + * @var string */ - public function initialize() - { - if (session('user.id') && $this->request->action() !== 'out') { - $this->redirect('@admin'); - } - } + public $title = '管理登录'; /** * 用户登录 - * @return string * @throws \think\Exception * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException @@ -52,38 +40,64 @@ class Login extends BasicAdmin */ public function index() { + $this->applyCsrfToken(); if ($this->request->isGet()) { - return $this->fetch('', ['title' => '用户登录']); + session('loginskey', $this->skey = session('loginskey') ? session('loginskey') : uniqid()); + $this->fetch(); + } else { + $data = $this->_input([ + 'username' => $this->request->post('username'), + 'password' => $this->request->post('password'), + ], [ + 'username' => 'require|min:4', + 'password' => 'require|min:4', + ], [ + 'username.require' => '登录账号不能为空!', + 'password.require' => '登录密码不能为空!', + 'username.min' => '登录账号长度不能少于4位有效字符!', + 'password.min' => '登录密码长度不能少于4位有效字符!', + ]); + // 用户信息验证 + $map = ['is_deleted' => '0', 'username' => $data['username']]; + $user = Db::name('SystemUser')->where($map)->find(); + if (empty($user)) $this->error('登录账号或密码错误,请重新输入!'); + if (empty($user['status'])) $this->error('账号已经被禁用,请联系管理!'); + // 账号锁定消息 + $cache = cache('user_login_' . $user['username']); + if (is_array($cache) && !empty($cache['number']) && !empty($cache['time'])) { + if ($cache['number'] >= 10 && ($diff = $cache['time'] + 3600 - time()) > 0) { + list($m, $s, $info) = [floor($diff / 60), floor($diff % 60), '']; + if ($m > 0) $info = "{$m} 分"; + $this->error("抱歉,该账号已经被锁定!

连续 10 次登录错误,请 {$info} {$s} 秒后再登录!

"); + } + } + if (md5($user['password'] . session('loginskey')) !== $data['password']) { + if (empty($cache) || empty($cache['time']) || empty($cache['number']) || $cache['time'] + 3600 < time()) { + $cache = ['time' => time(), 'number' => 1, 'geoip' => $this->request->ip()]; + } elseif ($cache['number'] + 1 <= 10) { + $cache = ['time' => time(), 'number' => $cache['number'] + 1, 'geoip' => $this->request->ip()]; + } + cache('user_login_' . $user['username'], $cache); + if (($diff = 10 - $cache['number']) > 0) { + $this->error("登录账号或密码错误!

还有 {$diff} 次尝试机会,将锁定一小时内禁止登录!

"); + } else { + _syslog('系统管理', "账号{$user['username']}连续10次登录密码错误,请注意账号安全!"); + $this->error("登录账号或密码错误!

尝试次数达到上限,锁定一小时内禁止登录!

"); + } + } + // 登录成功并更新账号 + cache('user_login_' . $user['username'], null); + Db::name('SystemUser')->where(['id' => $user['id']])->update([ + 'login_at' => Db::raw('now()'), + 'login_ip' => $this->request->ip(), + 'login_num' => Db::raw('login_num+1'), + ]); + session('user', $user); + session('loginskey', null); + empty($user['authorize']) || \app\admin\service\Auth::applyNode(); + _syslog('系统管理', '用户登录系统成功'); + $this->success('登录成功,正在进入系统...', url('@admin')); } - // 输入数据效验 - $validate = Validate::make([ - 'username' => 'require|min:4', - 'password' => 'require|min:4', - ], [ - 'username.require' => '登录账号不能为空!', - 'username.min' => '登录账号长度不能少于4位有效字符!', - 'password.require' => '登录密码不能为空!', - 'password.min' => '登录密码长度不能少于4位有效字符!', - ]); - $data = [ - 'username' => $this->request->post('username', ''), - 'password' => $this->request->post('password', ''), - ]; - $validate->check($data) || $this->error($validate->getError()); - // 用户信息验证 - $user = Db::name('SystemUser')->where(['username' => $data['username'], 'is_deleted' => '0'])->find(); - empty($user) && $this->error('登录账号不存在,请重新输入!'); - empty($user['status']) && $this->error('账号已经被禁用,请联系管理员!'); - $user['password'] !== md5($data['password']) && $this->error('登录密码错误,请重新输入!'); - // 更新登录信息 - Db::name('SystemUser')->where(['id' => $user['id']])->update([ - 'login_at' => Db::raw('now()'), - 'login_num' => Db::raw('login_num+1'), - ]); - session('user', $user); - !empty($user['authorize']) && NodeService::applyAuthNode(); - LogService::write('系统管理', '用户登录系统成功'); - $this->success('登录成功,正在进入系统...', '@admin'); } /** @@ -91,10 +105,9 @@ class Login extends BasicAdmin */ public function out() { - session('user') && LogService::write('系统管理', '用户退出系统成功'); - !empty($_SESSION) && $_SESSION = []; + if ($_SESSION) $_SESSION = []; [session_unset(), session_destroy()]; - $this->success('退出登录成功!', '@admin/login'); + $this->success('退出登录成功!', url('@admin/login')); } -} +} \ No newline at end of file diff --git a/application/admin/controller/Menu.php b/application/admin/controller/Menu.php index 69fa9e63a..e928cd66a 100644 --- a/application/admin/controller/Menu.php +++ b/application/admin/controller/Menu.php @@ -1,11 +1,11 @@ - * @date 2017/02/15 */ -class Menu extends BasicAdmin +class Menu extends Controller { /** - * 绑定操作模型 + * 当前操作数据库 * @var string */ - public $table = 'SystemMenu'; + protected $table = 'SystemMenu'; /** - * 菜单列表 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception + * 系统菜单显示 */ public function index() { - $this->title = '后台菜单管理'; - $db = Db::name($this->table)->order('sort asc,id asc'); - return parent::_list($db, false); + $this->title = '系统菜单管理'; + $this->_page($this->table, false); } /** * 列表数据处理 * @param array $data */ - protected function _index_data_filter(&$data) + protected function _index_page_filter(&$data) { foreach ($data as &$vo) { if ($vo['url'] !== '#') { $vo['url'] = url($vo['url']) . (empty($vo['params']) ? '' : "?{$vo['params']}"); } - $vo['ids'] = join(',', ToolsService::getArrSubIds($data, $vo['id'])); + $vo['ids'] = join(',', Data::getArrSubIds($data, $vo['id'])); } - $data = ToolsService::arr2table($data); - } - - /** - * 添加菜单 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception - */ - public function add() - { - return $this->_form($this->table, 'form'); + $data = Data::arr2table($data); } /** * 编辑菜单 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception */ public function edit() { - return $this->_form($this->table, 'form'); + $this->applyCsrfToken(); + $this->_form($this->table, 'form'); } /** - * 表单数据前缀方法 + * 添加菜单 + */ + public function add() + { + $this->applyCsrfToken(); + $this->_form($this->table, 'form'); + } + + /** + * 表单数据 * @param array $vo * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException @@ -105,72 +87,47 @@ class Menu extends BasicAdmin // 上级菜单处理 $_menus = Db::name($this->table)->where(['status' => '1'])->order('sort asc,id asc')->select(); $_menus[] = ['title' => '顶级菜单', 'id' => '0', 'pid' => '-1']; - $menus = ToolsService::arr2table($_menus); - foreach ($menus as $key => &$menu) { - if (substr_count($menu['path'], '-') > 3) { - unset($menus[$key]); - continue; - } - if (isset($vo['pid'])) { - $current_path = "-{$vo['pid']}-{$vo['id']}"; - if ($vo['pid'] !== '' && (stripos("{$menu['path']}-", "{$current_path}-") !== false || $menu['path'] === $current_path)) { - unset($menus[$key]); - continue; - } - } - } + $menus = Data::arr2table($_menus); + foreach ($menus as $key => &$menu) if (substr_count($menu['path'], '-') > 3) unset($menus[$key]); # 移除三级以下的菜单 + elseif (isset($vo['pid']) && $vo['pid'] !== '' && $cur = "-{$vo['pid']}-{$vo['id']}") + if (stripos("{$menu['path']}-", "{$cur}-") !== false || $menu['path'] === $cur) unset($menus[$key]); # 移除与自己相关联的菜单 + // 选择自己的上级菜单 + if (!isset($vo['pid']) && $this->request->get('pid', '0')) $vo['pid'] = $this->request->get('pid', '0'); // 读取系统功能节点 - $nodes = NodeService::get(); + $nodes = \app\admin\service\Auth::get(); foreach ($nodes as $key => $node) { - if (empty($node['is_menu'])) { - unset($nodes[$key]); - } + if (empty($node['is_menu'])) unset($nodes[$key]); + unset($nodes[$key]['pnode'], $nodes[$key]['is_login'], $nodes[$key]['is_menu'], $nodes[$key]['is_auth']); } - // 设置上级菜单 - if (!isset($vo['pid']) && $this->request->get('pid', '0')) { - $vo['pid'] = $this->request->get('pid', '0'); - } - $this->assign(['nodes' => array_column($nodes, 'node'), 'menus' => $menus]); + list($this->menus, $this->nodes) = [$menus, array_values($nodes)]; } } + /** + * 启用菜单 + */ + public function resume() + { + $this->applyCsrfToken(); + $this->_save($this->table, ['status' => '1']); + } + + /** + * 禁用菜单 + */ + public function forbid() + { + $this->applyCsrfToken(); + $this->_save($this->table, ['status' => '0']); + } + /** * 删除菜单 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function del() { - if (DataService::update($this->table)) { - $this->success("菜单删除成功!", ''); - } - $this->error("菜单删除失败, 请稍候再试!"); + $this->applyCsrfToken(); + $this->_delete($this->table); } - /** - * 菜单禁用 - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - public function forbid() - { - if (DataService::update($this->table)) { - $this->success("菜单禁用成功!", ''); - } - $this->error("菜单禁用失败, 请稍候再试!"); - } - - /** - * 菜单禁用 - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - public function resume() - { - if (DataService::update($this->table)) { - $this->success("菜单启用成功!", ''); - } - $this->error("菜单启用失败, 请稍候再试!"); - } - -} +} \ No newline at end of file diff --git a/application/admin/controller/Message.php b/application/admin/controller/Message.php new file mode 100644 index 000000000..97b1bb531 --- /dev/null +++ b/application/admin/controller/Message.php @@ -0,0 +1,92 @@ +title = '系统消息管理'; + $this->_query($this->table)->like('title,desc')->equal('read_state')->dateBetween('create_at,read_at')->order('id desc')->page(); + } + + /** + * 消息状态 + */ + public function state() + { + $this->_save($this->table, ['read_state' => '1', 'read_at' => date('Y-m-d H:i:s')]); + } + + /** + * 删除消息 + */ + public function del() + { + $this->_delete($this->table); + } + + /** + * 清理所有消息 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function clear() + { + if (Db::name($this->table)->whereRaw('1=1')->delete() !== false) { + $this->success('系统消息清理成功!'); + } else { + $this->error('系统消息清理失败,请稍候再试!'); + } + } + + /** + * 系统消息开关处理 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function onoff() + { + sysconf('system_message_state', sysconf('system_message_state') ? 0 : 1); + if (sysconf('system_message_state')) { + $this->success('系统消息提示开启成功!'); + } else { + $this->success('系统消息提示关闭成功!'); + } + } + +} \ No newline at end of file diff --git a/application/admin/controller/Node.php b/application/admin/controller/Node.php index 8e3d6e6bb..f44951989 100644 --- a/application/admin/controller/Node.php +++ b/application/admin/controller/Node.php @@ -1,92 +1,85 @@ - - * @date 2017/02/15 18:13 - */ -class Node extends BasicAdmin -{ - - /** - * 指定当前默认模型 - * @var string - */ - public $table = 'SystemNode'; - - /** - * 显示节点列表 - * @return string - */ - public function index() - { - $nodes = ToolsService::arr2table(NodeService::get(), 'node', 'pnode'); - $groups = []; - foreach ($nodes as $node) { - $pnode = explode('/', $node['node'])[0]; - if ($node['node'] === $pnode) { - $groups[$pnode]['node'] = $node; - } - $groups[$pnode]['list'][] = $node; - } - return $this->fetch('', ['title' => '系统节点管理', 'nodes' => $nodes, 'groups' => $groups]); - } - - /** - * 清理无效的节点记录 - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - public function clear() - { - $nodes = array_keys(NodeService::get()); - if (false !== Db::name($this->table)->whereNotIn('node', $nodes)->delete()) { - $this->success('清理无效节点记录成功!', ''); - } - $this->error('清理无效记录失败,请稍候再试!'); - } - - /** - * 保存节点变更 - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - public function save() - { - if ($this->request->isPost()) { - list($post, $data) = [$this->request->post(), []]; - foreach ($post['list'] as $vo) { - if (!empty($vo['node'])) { - $data['node'] = $vo['node']; - $data[$vo['name']] = $vo['value']; - } - } - !empty($data) && DataService::save($this->table, $data, 'node'); - $this->success('参数保存成功!', ''); - } - $this->error('访问异常,请重新进入...'); - } - -} +title = '系统节点管理'; + list($nodes, $groups) = [\app\admin\service\Auth::get(), []]; + $this->nodes = Data::arr2table($nodes, 'node', 'pnode'); + foreach ($this->nodes as $node) { + $pnode = explode('/', $node['node'])[0]; + if ($node['node'] === $pnode) $groups[$pnode]['node'] = $node; + $groups[$pnode]['list'][] = $node; + } + $this->groups = $groups; + $this->fetch(); + } + + /** + * 清理无效的节点数据 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function clear() + { + $nodes = array_unique(array_column(\app\admin\service\Auth::get(), 'node')); + if (false !== Db::name($this->table)->whereNotIn('node', $nodes)->delete()) { + $this->success('清理无效的节点配置成功!', ''); + } + $this->error('清理无效的节点配置,请稍候再试!'); + } + + /** + * 更新数据记录 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function save() + { + if ($this->request->isPost()) { + list($post, $data) = [$this->request->post(), []]; + foreach ($post['list'] as $vo) if (!empty($vo['node'])) { + $data['node'] = $vo['node']; + $data[$vo['name']] = $vo['value']; + } + empty($data) || data_save($this->table, $data, 'node'); + $this->success('节点配置保存成功!', ''); + } + $this->error('访问异常,请重新进入...'); + } + +} \ No newline at end of file diff --git a/application/admin/controller/Plugs.php b/application/admin/controller/Plugs.php deleted file mode 100644 index 9a894d9b8..000000000 --- a/application/admin/controller/Plugs.php +++ /dev/null @@ -1,152 +0,0 @@ - - * @date 2017/02/21 - */ -class Plugs extends BasicAdmin -{ - - /** - * 文件上传 - * @return mixed - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - public function upfile() - { - $uptype = $this->request->get('uptype'); - if (!in_array($uptype, ['local', 'qiniu', 'oss'])) { - $uptype = sysconf('storage_type'); - } - $mode = $this->request->get('mode', 'one'); - $types = $this->request->get('type', 'jpg,png'); - $this->assign('mimes', FileService::getFileMine($types)); - $this->assign('field', $this->request->get('field', 'file')); - return $this->fetch('', ['mode' => $mode, 'types' => $types, 'uptype' => $uptype]); - } - - /** - * 通用文件上传 - * @return \think\response\Json - * @throws \think\Exception - * @throws \think\exception\PDOException - * @throws \OSS\Core\OssException - */ - public function upload() - { - $file = $this->request->file('file'); - if (!$file->checkExt(strtolower(sysconf('storage_local_exts')))) { - return json(['code' => 'ERROR', 'msg' => '文件上传类型受限']); - } - $names = str_split($this->request->post('md5'), 16); - $ext = strtolower(pathinfo($file->getInfo('name'), 4)); - $ext = $ext ? $ext : 'tmp'; - $filename = "{$names[0]}/{$names[1]}.{$ext}"; - // 文件上传Token验证 - if ($this->request->post('token') !== md5($filename . session_id())) { - return json(['code' => 'ERROR', 'msg' => '文件上传验证失败']); - } - // 文件上传处理 - if (($info = $file->move("static/upload/{$names[0]}", "{$names[1]}.{$ext}", true))) { - if (($site_url = FileService::getFileUrl($filename, 'local'))) { - return json(['data' => ['site_url' => $site_url], 'code' => 'SUCCESS', 'msg' => '文件上传成功']); - } - } - return json(['code' => 'ERROR', 'msg' => '文件上传失败']); - } - - /** - * 文件状态检查 - * @throws \OSS\Core\OssException - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - public function upstate() - { - $post = $this->request->post(); - $ext = strtolower(pathinfo($post['filename'], 4)); - $filename = join('/', str_split($post['md5'], 16)) . '.' . ($ext ? $ext : 'tmp'); - // 检查文件是否已上传 - if (($site_url = FileService::getFileUrl($filename))) { - return json(['data' => ['site_url' => $site_url], 'code' => "IS_FOUND"]); - } - // 需要上传文件,生成上传配置参数 - $data = ['uptype' => $post['uptype'], 'file_url' => $filename]; - switch (strtolower($post['uptype'])) { - case 'local': - $data['token'] = md5($filename . session_id()); - $data['server'] = FileService::getUploadLocalUrl(); - break; - case 'qiniu': - $data['token'] = $this->_getQiniuToken($filename); - $data['server'] = FileService::getUploadQiniuUrl(true); - break; - case 'oss': - $time = time() + 3600; - $policyText = [ - 'expiration' => date('Y-m-d', $time) . 'T' . date('H:i:s', $time) . '.000Z', - 'conditions' => [['content-length-range', 0, 1048576000]], - ]; - $data['server'] = FileService::getUploadOssUrl(); - $data['policy'] = base64_encode(json_encode($policyText)); - $data['site_url'] = FileService::getBaseUriOss() . $filename; - $data['signature'] = base64_encode(hash_hmac('sha1', $data['policy'], sysconf('storage_oss_secret'), true)); - $data['OSSAccessKeyId'] = sysconf('storage_oss_keyid'); - break; - } - return json(['data' => $data, 'code' => "NOT_FOUND"]); - } - - /** - * 生成七牛文件上传Token - * @param string $key - * @return string - * @throws \think\Exception - * @throws \think\exception\PDOException - */ - protected function _getQiniuToken($key) - { - $baseUrl = FileService::getBaseUriQiniu(); - $bucket = sysconf('storage_qiniu_bucket'); - $accessKey = sysconf('storage_qiniu_access_key'); - $secretKey = sysconf('storage_qiniu_secret_key'); - $params = [ - "scope" => "{$bucket}:{$key}", "deadline" => 3600 + time(), - "returnBody" => "{\"data\":{\"site_url\":\"{$baseUrl}/$(key)\",\"file_url\":\"$(key)\"}, \"code\": \"SUCCESS\"}", - ]; - $data = str_replace(['+', '/'], ['-', '_'], base64_encode(json_encode($params))); - return $accessKey . ':' . str_replace(['+', '/'], ['-', '_'], base64_encode(hash_hmac('sha1', $data, $secretKey, true))) . ':' . $data; - } - - /** - * 字体图标选择器 - * @return \think\response\View - */ - public function icon() - { - $field = $this->request->get('field', 'icon'); - return $this->fetch('', ['field' => $field]); - } - -} diff --git a/application/admin/controller/Queue.php b/application/admin/controller/Queue.php new file mode 100644 index 000000000..cb8034aea --- /dev/null +++ b/application/admin/controller/Queue.php @@ -0,0 +1,89 @@ +title = '消息任务管理'; + $this->uris = Db::name($this->table)->distinct(true)->column('uri'); + $this->cmd = 'php ' . env('root_path') . 'think xtask:start'; + $this->message = Console::call('xtask:state')->fetch(); + $this->_query($this->table)->equal('status,title,uri')->dateBetween('create_at,status_at')->order('id desc')->page(); + } + + /** + * 重置失败的任务 + */ + public function redo() + { + try { + $where = ['id' => $this->request->post('id')]; + $info = Db::name($this->table)->where($where)->find(); + if (empty($info)) $this->error('需要重置的任务获取异常!'); + $data = isset($info['data']) ? json_decode($info['data'], true) : '[]'; + \app\admin\service\Queue::add($info['title'], $info['uri'], $info['later'], $data, $info['double'], $info['desc']); + $this->success('任务重置成功!', url('@admin') . '#' . url('@admin/queue/index')); + } catch (\think\exception\HttpResponseException $exception) { + throw $exception; + } catch (\Exception $e) { + $this->error("任务重置失败,请稍候再试!
{$e->getMessage()}"); + } + } + + /** + * 删除消息任务 + */ + public function del() + { + try { + $isNot = false; + foreach (explode(',', $this->request->post('id', '0')) as $id) { + if (!\app\admin\service\Queue::del($id)) $isNot = true; + } + if (empty($isNot)) $this->_delete($this->table); + $this->success($isNot ? '部分任务删除成功!' : '任务删除成功!'); + } catch (\think\exception\HttpResponseException $exception) { + throw $exception; + } catch (\Exception $e) { + $this->error("任务删除失败,请稍候再试!
{$e->getMessage()}"); + } + } + +} \ No newline at end of file diff --git a/application/admin/controller/User.php b/application/admin/controller/User.php index 2510c4094..11be336c6 100644 --- a/application/admin/controller/User.php +++ b/application/admin/controller/User.php @@ -1,11 +1,11 @@ * @date 2017/02/15 18:12 */ -class User extends BasicAdmin +class User extends Controller { /** @@ -36,89 +36,74 @@ class User extends BasicAdmin /** * 用户列表 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception - */ - public function index() - { - $this->title = '系统用户管理'; - list($get, $db) = [$this->request->get(), Db::name($this->table)]; - foreach (['username', 'phone', 'mail'] as $key) { - (isset($get[$key]) && $get[$key] !== '') && $db->whereLike($key, "%{$get[$key]}%"); - } - if (isset($get['date']) && $get['date'] !== '') { - list($start, $end) = explode(' - ', $get['date']); - $db->whereBetween('login_at', ["{$start} 00:00:00", "{$end} 23:59:59"]); - } - return parent::_list($db->where(['is_deleted' => '0'])); - } - - /** - * 授权管理 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception - */ - public function auth() - { - return $this->_form($this->table, 'auth'); - } - - /** - * 用户添加 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception - */ - public function add() - { - return $this->_form($this->table, 'form'); - } - - /** - * 用户编辑 - * @return array|string - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - * @throws \think\Exception - */ - public function edit() - { - return $this->_form($this->table, 'form'); - } - - /** - * 用户密码修改 - * @return array|string * @throws \think\Exception * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\ModelNotFoundException * @throws \think\exception\DbException * @throws \think\exception\PDOException */ + public function index() + { + $this->title = '系统用户管理'; + $this->_query($this->table)->where(['is_deleted' => '0'])->like('username,phone,mail')->dateBetween('login_at')->equal('status')->page(); + } + + /** + * 授权管理 + * @return mixed + */ + public function auth() + { + $this->applyCsrfToken(); + $this->_form($this->table, 'auth'); + } + + /** + * 用户添加 + * @return mixed + */ + public function add() + { + $this->applyCsrfToken(); + $this->_form($this->table, 'form'); + } + + /** + * 用户编辑 + * @return mixed + */ + public function edit() + { + $this->applyCsrfToken(); + $this->_form($this->table, 'form'); + } + + /** + * 用户密码修改 + * @return mixed + * @throws \think\Exception + * @throws \think\exception\PDOException + */ public function pass() { + $this->applyCsrfToken(); if ($this->request->isGet()) { - $this->assign('verify', false); - return $this->_form($this->table, 'pass'); + $this->verify = false; + $this->_form($this->table, 'pass'); + } else { + $post = $this->request->post(); + if ($post['password'] !== $post['repassword']) { + $this->error('两次输入的密码不一致!'); + } + $result = \app\admin\service\Auth::checkPassword($post['password']); + if (empty($result['code'])) $this->error($result['msg']); + $data = ['id' => $post['id'], 'password' => md5($post['password'])]; + if (Data::save($this->table, $data, 'id')) { + $this->success('密码修改成功,下次请使用新密码登录!', ''); + } else { + $this->error('密码修改失败,请稍候再试!'); + } } - $post = $this->request->post(); - if ($post['password'] !== $post['repassword']) { - $this->error('两次输入的密码不一致!'); - } - $data = ['id' => $post['id'], 'password' => md5($post['password'])]; - if (DataService::save($this->table, $data, 'id')) { - $this->success('密码修改成功,下次请使用新密码登录!', ''); - } - $this->error('密码修改失败,请稍候再试!'); } /** @@ -131,14 +116,9 @@ class User extends BasicAdmin public function _form_filter(&$data) { if ($this->request->isPost()) { - if (isset($data['authorize']) && is_array($data['authorize'])) { - $data['authorize'] = join(',', $data['authorize']); - } else { - $data['authorize'] = ''; - } - if (isset($data['id'])) { - unset($data['username']); - } elseif (Db::name($this->table)->where(['username' => $data['username']])->count() > 0) { + $data['authorize'] = (isset($data['authorize']) && is_array($data['authorize'])) ? join(',', $data['authorize']) : ''; + if (isset($data['id'])) unset($data['username']); + elseif (Db::name($this->table)->where(['username' => $data['username']])->count() > 0) { $this->error('用户账号已经存在,请使用其它账号!'); } } else { @@ -149,47 +129,35 @@ class User extends BasicAdmin /** * 删除用户 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function del() { if (in_array('10000', explode(',', $this->request->post('id')))) { $this->error('系统超级账号禁止删除!'); } - if (DataService::update($this->table)) { - $this->success("用户删除成功!", ''); - } - $this->error("用户删除失败,请稍候再试!"); + $this->applyCsrfToken(); + $this->_delete($this->table); } /** * 用户禁用 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function forbid() { if (in_array('10000', explode(',', $this->request->post('id')))) { $this->error('系统超级账号禁止操作!'); } - if (DataService::update($this->table)) { - $this->success("用户禁用成功!", ''); - } - $this->error("用户禁用失败,请稍候再试!"); + $this->applyCsrfToken(); + $this->_save($this->table, ['status' => '0']); } /** * 用户禁用 - * @throws \think\Exception - * @throws \think\exception\PDOException */ public function resume() { - if (DataService::update($this->table)) { - $this->success("用户启用成功!", ''); - } - $this->error("用户启用失败,请稍候再试!"); + $this->applyCsrfToken(); + $this->_save($this->table, ['status' => '1']); } } diff --git a/application/admin/controller/api/Message.php b/application/admin/controller/api/Message.php new file mode 100644 index 000000000..6541539cf --- /dev/null +++ b/application/admin/controller/api/Message.php @@ -0,0 +1,53 @@ +success('获取系统消息成功!', $list); + } + + /** + * 系统消息状态更新 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function set() + { + $code = $this->request->post('code'); + if (\app\admin\service\Message::set($code)) { + $this->success('系统消息状态更新成功!'); + } else { + $this->error('系统消息状态更新失败,请稍候再试!'); + } + } + +} \ No newline at end of file diff --git a/application/admin/controller/api/Plugs.php b/application/admin/controller/api/Plugs.php new file mode 100644 index 000000000..7dda37fd3 --- /dev/null +++ b/application/admin/controller/api/Plugs.php @@ -0,0 +1,217 @@ +error('访问授权失败,请重新登录授权再试!'); + } + } + + /** + * 文件状态检查 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function upstate() + { + $ext = strtolower(pathinfo($this->request->post('filename', ''), PATHINFO_EXTENSION)); + $name = File::name($this->request->post('md5'), $ext, '', 'strtolower'); + // 检查文件是否已上传 + $this->safe = $this->getUploadSafe(); + if (is_string($siteUrl = File::url($name))) { + $this->success('检测到该文件已经存在,无需再次上传!', [ + 'site_url' => $this->safe ? $name : $siteUrl, + ]); + } + // 文件驱动 + $file = File::instance($this->getUploadType()); + // 生成上传授权参数 + $param = [ + 'file_url' => $name, 'uptype' => $this->uptype, 'token' => md5($name . session_id()), + 'site_url' => $file->base($name), 'server' => $file->upload(), 'safe' => $this->safe, + ]; + if (strtolower($this->uptype) === 'qiniu') { + $auth = new \Qiniu\Auth(sysconf('storage_qiniu_access_key'), sysconf('storage_qiniu_secret_key')); + $param['token'] = $auth->uploadToken(sysconf('storage_qiniu_bucket'), $name, 3600, [ + 'returnBody' => json_encode(['code' => 1, 'data' => ['site_url' => $file->base($name)]], JSON_UNESCAPED_UNICODE), + ]); + } elseif (strtolower($this->uptype) === 'oss') { + $param['OSSAccessKeyId'] = sysconf('storage_oss_keyid'); + $param['policy'] = base64_encode(json_encode(['conditions' => [['content-length-range', 0, 1048576000]], 'expiration' => gmdate("Y-m-d\TH:i:s\Z", time() + 3600)])); + $param['signature'] = base64_encode(hash_hmac('sha1', $param['policy'], sysconf('storage_oss_secret'), true)); + } + $this->error('未检测到文件,需要上传完整的文件!', $param); + } + + /** + * 文件上传 + * @return mixed + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function upfile() + { + $this->safe = $this->getUploadSafe(); + $this->uptype = $this->getUploadType(); + $this->mode = $this->request->get('mode', 'one'); + $this->field = $this->request->get('field', 'file'); + $this->types = $this->request->get('type', 'jpg,png'); + $this->mimes = File::mine($this->types); + $this->fetch(); + } + + /** + * WebUpload 文件上传 + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function upload() + { + // 文件接收 + if (!($file = $this->getUploadFile()) || empty($file)) { + $this->error('文件上传异常,文件可能过大或未上传!'); + } + if (!$file->checkExt(strtolower(sysconf('storage_local_exts')))) { + $this->error('文件上传类型受限,请在后台配置!'); + } + if ($file->checkExt('php')) { + $this->error('可执行文件禁止上传到本地服务器!'); + } + // 唯一名称 + $ext = strtolower(pathinfo($file->getInfo('name'), PATHINFO_EXTENSION)); + $name = File::name($this->request->post('md5'), $ext, '', 'strtolower'); + // Token 验证 + if ($this->request->post('token') !== md5($name . session_id())) { + $this->error('文件上传验证失败,请刷新页面重新上传!'); + } + $this->safe = $this->getUploadSafe(); + $pathinfo = pathinfo(File::instance('local')->path($name, $this->safe)); + if ($file->move($pathinfo['dirname'], $pathinfo['basename'], true)) { + if (is_array($info = File::instance('local')->info($name, $this->safe)) && isset($info['url'])) { + $this->success('文件上传成功!', ['site_url' => $this->safe ? $name : $info['url']]); + } + } + $this->error('文件上传失败,请稍候再试!'); + } + + /** + * Plupload 插件上传文件 + * @return \think\response\Json + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public function plupload() + { + if (!($file = $this->getUploadFile()) || empty($file)) { + return json(['uploaded' => false, 'error' => ['message' => '文件上传异常,文件可能过大或未上传']]); + } + if (!$file->checkExt(strtolower(sysconf('storage_local_exts')))) { + return json(['uploaded' => false, 'error' => ['message' => '文件上传类型受限,请在后台配置']]); + } + if ($file->checkExt('php')) { + return json(['uploaded' => false, 'error' => ['message' => '可执行文件禁止上传到本地服务器']]); + } + $this->safe = $this->getUploadSafe(); + $this->uptype = $this->getUploadType(); + $this->ext = pathinfo($file->getInfo('name'), PATHINFO_EXTENSION); + $name = File::name($file->getPathname(), $this->ext, '', 'md5_file'); + $info = File::instance($this->uptype)->save($name, file_get_contents($file->getRealPath()), $this->safe); + if (is_array($info) && isset($info['url'])) { + return json(['uploaded' => true, 'filename' => $name, 'url' => $this->safe ? $name : $info['url']]); + } + return json(['uploaded' => false, 'error' => ['message' => '文件处理失败,请稍候再试!']]); + } + + /** + * 获取文件上传方式 + * @return string + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + private function getUploadType() + { + $this->uptype = input('uptype'); + if (!in_array($this->uptype, ['local', 'oss', 'qiniu'])) { + $this->uptype = sysconf('storage_type'); + } + return $this->uptype; + } + + /** + * 获取上传安全模式 + * @return boolean + */ + private function getUploadSafe() + { + return $this->safe = boolval(input('safe')); + } + + /** + * 获取本地文件对象 + * @return \think\File + */ + private function getUploadFile() + { + try { + return $this->request->file('file'); + } catch (\Exception $e) { + $this->error(lang($e->getMessage())); + } + } + + /** + * 系统选择器图标 + * @return mixed + */ + public function icon() + { + $this->title = '图标选择器'; + $this->field = input('field', 'icon'); + $this->fetch(); + } + + /** + * 系统消息展示 + * @return mixed + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public function message() + { + $this->title = '系统消息'; + $this->list = Db::name('SystemMessage')->where(['read_state' => '0'])->order('id desc')->select(); + $this->fetch(); + } + +} \ No newline at end of file diff --git a/application/admin/controller/api/Update.php b/application/admin/controller/api/Update.php new file mode 100644 index 000000000..45868bc7a --- /dev/null +++ b/application/admin/controller/api/Update.php @@ -0,0 +1,54 @@ +success('获取当前文件列表成功!', UpdateLogic::build()); + } + + /** + * 读取线上文件数据 + * @param string $encode + */ + public function read($encode) + { + $file = env('root_path') . decode($encode); + if (!file_exists($file)) $this->error('获取文件内容失败!'); + $this->success('获取文件内容成功!', [ + 'format' => 'base64', 'content' => base64_encode(file_get_contents($file)), + ]); + } + +} \ No newline at end of file diff --git a/application/admin/middleware/Auth.php b/application/admin/middleware/Auth.php deleted file mode 100644 index 8dd0a3d1f..000000000 --- a/application/admin/middleware/Auth.php +++ /dev/null @@ -1,71 +0,0 @@ -module(), $request->controller(), $request->action()]; - $access = $this->buildAuth($node = NodeService::parseNodeStr("{$module}/{$controller}/{$action}")); - // 登录状态检查 - if (!empty($access['is_login']) && !session('user')) { - $msg = ['code' => 0, 'msg' => '抱歉,您还没有登录获取访问权限!', 'url' => url('@admin/login')]; - return $request->isAjax() ? json($msg) : redirect($msg['url']); - } - // 访问权限检查 - if (!empty($access['is_auth']) && !auth($node)) { - return json(['code' => 0, 'msg' => '抱歉,您没有访问该模块的权限!']); - } - // 模板常量声明 - app('view')->init(config('template.'))->assign(['classuri' => NodeService::parseNodeStr("{$module}/{$controller}")]); - return $next($request); - } - - /** - * 根据节点获取对应权限配置 - * @param string $node 权限节点 - * @return array - * @throws \think\db\exception\DataNotFoundException - * @throws \think\db\exception\ModelNotFoundException - * @throws \think\exception\DbException - */ - private function buildAuth($node) - { - $info = Db::name('SystemNode')->cache(true, 30)->where(['node' => $node])->find(); - return [ - 'is_menu' => intval(!empty($info['is_menu'])), - 'is_auth' => intval(!empty($info['is_auth'])), - 'is_login' => empty($info['is_auth']) ? intval(!empty($info['is_login'])) : 1, - ]; - } -} diff --git a/application/admin/queue/JobsBase.php b/application/admin/queue/JobsBase.php new file mode 100644 index 000000000..658eb53cd --- /dev/null +++ b/application/admin/queue/JobsBase.php @@ -0,0 +1,122 @@ +data = $data; + $this->output = new \think\console\Output(); + $this->id = isset($data['_job_id_']) ? $data['_job_id_'] : ''; + $this->title = isset($data['_job_title_']) ? $data['_job_title_'] : ''; + $this->output->newLine(); + $this->output->writeln(" system task {$this->id} execution start"); + $this->output->writeln('---------------------------------------------'); + Queue::status($this->id, self::STATUS_PROC, $this->statusDesc); + if ($this->execute()) { + $this->output->writeln('---------------------------------------------'); + $this->output->info(" successful"); + $this->status = self::STATUS_COMP; + } else { + $this->output->writeln('---------------------------------------------'); + $this->output->error(" failure"); + $this->status = self::STATUS_FAIL; + } + $job->delete(); + Queue::status($this->id, $this->status, $this->statusDesc); + $this->output->writeln('---------------------------------------------'); + $this->output->newLine(); + } + + /** + * 执行任务 + * @return boolean + */ + protected function execute() + { + return true; + } + +} \ No newline at end of file diff --git a/application/admin/service/Auth.php b/application/admin/service/Auth.php new file mode 100644 index 000000000..94ecbab11 --- /dev/null +++ b/application/admin/service/Auth.php @@ -0,0 +1,207 @@ +get('messagecode')) > 0) Message::set($code); + // 节点忽略跳过 + $node = Node::current(); + foreach (self::getIgnore() as $str) if (stripos($node, $str) === 0) return $next($request); + // 节点权限查询 + $auth = Db::name('SystemNode')->cache(true, 60)->field('is_auth,is_login')->where(['node' => $node])->find(); + $info = ['is_auth' => $auth['is_auth'], 'is_login' => $auth['is_auth'] ? 1 : $auth['is_login']]; + // 登录状态检查 + if (!empty($info['is_login']) && !self::isLogin()) { + $message = ['code' => 0, 'msg' => '抱歉,您还没有登录获取访问权限!', 'url' => url('@admin/login')]; + return $request->isAjax() ? json($message) : redirect($message['url']); + } + // 访问权限检查 + if (!empty($info['is_auth']) && !self::checkAuthNode($node)) { + return json(['code' => 0, 'msg' => '抱歉,您没有访问该模块的权限!']); + } + return $next($request); + } + + /** + * 权限节点忽略规则 + * @return array + */ + public static function getIgnore() + { + return ['index', 'admin/login', 'admin/index']; + } + + /** + * 获取系统代码节点 + * @param array $nodes + * @return array + */ + public static function get($nodes = []) + { + $ignore = self::getIgnore(); + $alias = Db::name('SystemNode')->column('node,is_menu,is_auth,is_login,title'); + foreach (Node::getTree(env('app_path')) as $thr) { + foreach ($ignore as $str) if (stripos($thr, $str) === 0) continue 2; + $tmp = explode('/', $thr); + list($one, $two) = ["{$tmp[0]}", "{$tmp[0]}/{$tmp[1]}"]; + $nodes[$one] = array_merge(isset($alias[$one]) ? $alias[$one] : ['node' => $one, 'title' => '', 'is_menu' => 0, 'is_auth' => 0, 'is_login' => 0], ['pnode' => '']); + $nodes[$two] = array_merge(isset($alias[$two]) ? $alias[$two] : ['node' => $two, 'title' => '', 'is_menu' => 0, 'is_auth' => 0, 'is_login' => 0], ['pnode' => $one]); + $nodes[$thr] = array_merge(isset($alias[$thr]) ? $alias[$thr] : ['node' => $thr, 'title' => '', 'is_menu' => 0, 'is_auth' => 0, 'is_login' => 0], ['pnode' => $two]); + } + foreach ($nodes as &$node) list($node['is_auth'], $node['is_menu'], $node['is_login']) = [intval($node['is_auth']), intval($node['is_menu']), empty($node['is_auth']) ? intval($node['is_login']) : 1]; + return $nodes; + } + + /** + * 检查用户节点权限 + * @param string $node 节点 + * @return boolean + */ + public static function checkAuthNode($node) + { + list($module, $controller, $action) = explode('/', str_replace(['?', '=', '&'], '/', "{$node}///")); + $current = Node::parseString("{$module}/{$controller}") . strtolower("/{$action}"); + // 后台入口无需要验证权限 + if (stripos($node, 'admin/index') === 0) return true; + // 超级管理员无需要验证权限 + if (session('user.username') === 'admin') return true; + // 未配置权限的节点默认放行 + if (!in_array($current, self::getAuthNode())) return true; + // 用户指定角色授权放行 + return in_array($current, (array)session('user.nodes')); + } + + /** + * 获取授权节点 + * @return array + */ + public static function getAuthNode() + { + $nodes = cache('need_access_node'); + if (empty($nodes)) { + $nodes = Db::name('SystemNode')->where(['is_auth' => '1'])->column('node'); + cache('need_access_node', $nodes); + } + return $nodes; + } + + /** + * 应用用户权限节点 + * @return bool + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public static function applyNode() + { + cache('need_access_node', null); + if (($uid = session('user.id'))) session('user', Db::name('SystemUser')->where('id', $uid)->find()); + if (session('user.authorize') && ($ids = explode(',', session('user.authorize')))) { + $auths = Db::name('SystemAuth')->whereIn('id', $ids)->where('status', '1')->column('id'); + if (empty($auths)) return session('user.nodes', []); + return session('user.nodes', Db::name('SystemAuthNode')->whereIn('auth', $auths)->column('node')); + } + return false; + } + + /** + * 判断用户登录状态 + * @return boolean + */ + public static function isLogin() + { + return !!session('user'); + } + + /** + * 获取授权后的菜单 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public static function getAuthMenu() + { + self::applyNode(); + $list = Db::name('SystemMenu')->where('status', '1')->order('sort asc,id asc')->select(); + return self::buildMenuData(Data::arr2tree($list), self::get(), self::isLogin()); + } + + /** + * 后台主菜单权限过滤 + * @param array $menus 当前菜单列表 + * @param array $nodes 系统权限节点数据 + * @param bool $isLogin 是否已经登录 + * @return array + */ + private static function buildMenuData($menus, $nodes, $isLogin) + { + foreach ($menus as $key => &$menu) { + if (!empty($menu['sub'])) $menu['sub'] = self::buildMenuData($menu['sub'], $nodes, $isLogin); + if (!empty($menu['sub'])) $menu['url'] = '#'; + elseif (preg_match('/^https?\:/i', $menu['url'])) continue; + elseif ($menu['url'] !== '#') { + $node = join('/', array_slice(explode('/', preg_replace('/[\W]/', '/', $menu['url'])), 0, 3)); + $menu['url'] = url($menu['url']) . (empty($menu['params']) ? '' : "?{$menu['params']}"); + if (isset($nodes[$node]) && $nodes[$node]['is_login'] && empty($isLogin)) unset($menus[$key]); + elseif (isset($nodes[$node]) && $nodes[$node]['is_auth'] && $isLogin && !self::checkAuthNode($node)) unset($menus[$key]); + } else unset($menus[$key]); + } + return $menus; + } + + /** + * 检查密码是否合法 + * @param string $password + * @return array + */ + public static function checkPassword($password) + { + $password = trim($password); + if (!strlen($password) >= 6) { + return ['code' => 0, 'msg' => '密码必须大于6字符!']; + } + if (!preg_match("/^(?![\d]+$)(?![a-zA-Z]+$)(?![^\da-zA-Z]+$).{6,32}$/", $password)) { + return ['code' => 0, 'msg' => '密码必需包含大小写字母、数字、符号任意两者组合!']; + } + return ['code' => 1, 'msg' => '密码复杂度通过验证!']; + } + +} diff --git a/extend/service/LogService.php b/application/admin/service/Log.php similarity index 50% rename from extend/service/LogService.php rename to application/admin/service/Log.php index 700c1303c..66785be4e 100644 --- a/extend/service/LogService.php +++ b/application/admin/service/Log.php @@ -1,59 +1,55 @@ - - * @date 2017/03/24 13:25 - */ -class LogService -{ - - /** - * 获取数据操作对象 - * @return Query - */ - protected static function db() - { - return Db::name('SystemLog'); - } - - /** - * 写入操作日志 - * @param string $action - * @param string $content - * @return bool - */ - public static function write($action = '行为', $content = "内容描述") - { - $request = app('request'); - $node = strtolower(join('/', [$request->module(), $request->controller(), $request->action()])); - $data = [ - 'ip' => $request->ip(), - 'node' => $node, - 'action' => $action, - 'content' => $content, - 'username' => session('user.username') . '', - ]; - return self::db()->insert($data) !== false; - } - -} + Node::current(), + 'geoip' => PHP_SAPI === 'cli' ? '127.0.0.1' : request()->ip(), + 'action' => $action, + 'content' => $content, + 'username' => PHP_SAPI === 'cli' ? 'cli' : session('user.username'), + ]; + return Db::name('SystemLog')->insert($data) !== false; + } + + /** + * 清理系统日志数据 + * @return boolean + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public static function clear() + { + return Db::name('SystemLog')->where('1=1')->delete() !== false; + } +} \ No newline at end of file diff --git a/application/admin/service/Message.php b/application/admin/service/Message.php new file mode 100644 index 000000000..9a0d41eef --- /dev/null +++ b/application/admin/service/Message.php @@ -0,0 +1,72 @@ + $title, 'desc' => $desc, 'url' => $url, 'code' => $code, 'node' => $node]; + return Db::name('SystemMessage')->insert($data) !== false; + } + + /** + * 系统消息状态更新 + * @param integer $code + * @return boolean + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public static function set($code) + { + $result = Db::name('SystemMessage')->where(['code' => $code, 'read_state' => '0'])->update([ + 'read_state' => '1', 'read_at' => date('Y-m-d H:i:s'), 'read_uid' => session('user.id'), + ]); + return $result !== false; + } + + /** + * 获取消息列表成功 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public static function gets() + { + $where = ['read_state' => '0']; + $list = Db::name('SystemMessage')->where($where)->order('id desc')->select(); + foreach ($list as $key => $vo) if (!empty($vo['node']) && !auth($vo['node'])) unset($list[$key]); + return $list; + } + +} \ No newline at end of file diff --git a/application/admin/service/Queue.php b/application/admin/service/Queue.php new file mode 100644 index 000000000..4dd5466a0 --- /dev/null +++ b/application/admin/service/Queue.php @@ -0,0 +1,128 @@ +insertGetId([ + 'title' => $title, 'later' => $later, 'uri' => $uri, 'double' => intval($double), + 'data' => json_encode($data, 256), 'desc' => $desc, 'status_at' => date('Y-m-d H:i:s'), + ]); + $data['_job_id_'] = $jobId; + $data['_job_title_'] = $title; + \think\Queue::later($later, $uri, $data); + } + + /** + * 更新任务状态 + * @param integer $jobId + * @param integer $status + * @param string $statusDesc + * @return boolean + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public static function status($jobId, $status = self::STATUS_PEND, $statusDesc = '') + { + $result = Db::name('SystemJobsLog')->where(['id' => $jobId])->update([ + 'status' => $status, 'status_desc' => $statusDesc, 'status_at' => date('Y-m-d H:i:s'), + ]); + return $result !== false; + } + + /** + * 检查任务是否存在 + * @param string $title + * @return boolean + */ + public static function exists($title) + { + $where = [['title', 'eq', $title], ['status', 'in', [1, 2]]]; + return Db::name('SystemJobsLog')->where($where)->count() > 0; + } + + /** + * 获取任务数据 + * @param integer $jobId + * @return array|null + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\ModelNotFoundException + * @throws \think\exception\DbException + */ + public static function get($jobId) + { + return Db::name('SystemJobsLog')->where(['id' => $jobId])->find(); + } + + /** + * 删除任务数据 + * @param integer $jobId + * @return boolean + * @throws \think\Exception + * @throws \think\exception\PDOException + */ + public static function del($jobId) + { + $where = [['id', 'eq', $jobId], ['status', 'in', [1, 3, 4]]]; + if (Db::name('SystemJobsLog')->where($where)->delete() > 0) { + Db::name('SystemJobs')->whereLike('payload', '%"_job_id_":"' . $jobId . '"%')->delete(); + return true; + } + return false; + } + +} \ No newline at end of file diff --git a/application/admin/sys.php b/application/admin/sys.php new file mode 100644 index 000000000..9d8656b3c --- /dev/null +++ b/application/admin/sys.php @@ -0,0 +1,111 @@ +where('name', $name)->value('value'), true); + return empty($data) ? [] : $data; + } + return data_save('SystemData', ['name' => $name, 'value' => json_encode($value, 256)], 'name'); + } +} + +if (!function_exists('_sysmsg')) { + /** + * 增加系统消息 + * @param string $title 消息标题 + * @param string $desc 消息描述 + * @param string $url 访问链接 + * @param string $node 权限节点 + * @return boolean + */ + function _sysmsg($title, $desc, $url, $node) + { + return \app\admin\service\Message::add($title, $desc, $url, $node); + } +} + +if (!function_exists('_syslog')) { + /** + * 写入系统日志 + * @param string $action 日志行为 + * @param string $content 日志内容 + * @return boolean + */ + function _syslog($action, $content) + { + return \app\admin\service\Log::write($action, $content); + } +} + +if (!function_exists('local_image')) { + /** + * 下载远程文件到本地 + * @param string $url 远程图片地址 + * @return string + */ + function local_image($url) + { + $result = \library\File::down($url); + if (isset($result['url'])) return $result['url']; + return $url; + } +} + +if (!function_exists('base64_image')) { + /** + * base64 图片上传接口 + * @param string $content + * @param string $predir + * @return string + */ + function base64_image($content, $predir = 'base64/') + { + try { + if (preg_match('|^data:image/(.*?);base64,|i', $content)) { + list($ext, $base) = explode('|||', preg_replace('|^data:image/(.*?);base64,|i', '$1|||', $content)); + $info = \library\File::save($predir . md5($base) . '.' . (empty($ext) ? 'tmp' : $ext), base64_decode($base)); + return $info['url']; + } + return $content; + } catch (\Exception $e) { + return $content; + } + } +} + +// 注册中间键 +\think\facade\Middleware::add('app\admin\service\Auth'); \ No newline at end of file diff --git a/application/admin/view/plugs/icon.html b/application/admin/view/api/plugs/icon.html similarity index 99% rename from application/admin/view/plugs/icon.html rename to application/admin/view/api/plugs/icon.html index b743fb1bf..f5e691282 100644 --- a/application/admin/view/plugs/icon.html +++ b/application/admin/view/api/plugs/icon.html @@ -9,7 +9,7 @@ - + - + - - {/foreach} - - + - -
- -{/block} \ No newline at end of file + +
+
+
    +
  • +
+ {foreach $menus as $oneMenu} + {notempty name='oneMenu.sub'} + + {/notempty} + {/foreach} +
+
+ + + +
{block name='content'}{/block}
+ + + +{/block} + + + +{block name='script'}{/block} +{if session('user.id') and sysconf('system_message_state')} + +{/if} + + + \ No newline at end of file diff --git a/application/admin/view/index/main.html b/application/admin/view/index/main.html index d5e62ca14..aa6e6c171 100644 --- a/application/admin/view/index/main.html +++ b/application/admin/view/index/main.html @@ -1,7 +1,6 @@ -{extend name='admin@public/content'} - -{block name="content"} +{extend name='main'} +{block name='content'} @@ -17,66 +16,66 @@ - - - - + + + + - - - - - - - - - - + + + - - - - + + + - - - - - - - - - - + + + - - - - + + + + - - - - + + + + + + + + + + + + + + + +
ThinkAdmin 版本{:sysconf('app_version')}产品名称ThinkAdmin 管理框架framework 版本{:sysconf('app_version')}产品名称framework
ThinkPHP 版本{$think_ver}产品名称ThinkAdmin 管理框架
服务器操作系统{:php_uname('s')}产品DEMO体验 - http://demo.thinkadmin.top + ThinkPHP 版本{$think_ver}在线体验 + http://framework.thinkadmin.top
WEB运行环境{:php_sapi_name()}官方QQ群 + 服务器操作系统{:php_uname('s')}官方QQ群
MySQL数据库版本{$mysql_ver}BUG反馈 - - https://github.com/zoujingli/ThinkAdmin/issues - -
运行PHP版本{$Think.PHP_VERSION}项目地址 + WEB运行环境{:php_sapi_name()}项目地址 https://github.com/zoujingli/ThinkAdmin
上传大小限制{:ini_get('upload_max_filesize')}公司官网http://www.cuci.ccMySQL数据库版本{$mysql_ver}BUG反馈 + + https://github.com/zoujingli/ThinkAdmin/issues + +
POST大小限制{:ini_get('post_max_size')}公司地址广州市天河区东圃一横路东泷商贸中心C座316运行PHP版本{$Think.PHP_VERSION}开发团队广州楚才信息科技有限公司
上传大小限制{:ini_get('upload_max_filesize')}团队官网http://www.cuci.cc
POST大小限制{:ini_get('post_max_size')}办公地址广州市天河区东圃一横路东泷商贸中心C座316
diff --git a/application/admin/view/log/index.html b/application/admin/view/log/index.html index 7c3afffe9..89288e2ef 100644 --- a/application/admin/view/log/index.html +++ b/application/admin/view/log/index.html @@ -1,100 +1,61 @@ -{extend name='admin@public/content'} +{extend name='main'} {block name="button"} - - - + +{if auth("admin/log/del")} + +{/if} + {/block} {block name="content"} + + + {notempty name='list'} + + + + + + + + + + + + + + + + + + + + + + + {/notempty} +
{include file='log/index_search'}
+ + 操作权限位置操作时间
+ + + 行为:{$vo.action|default='--'}
+ 描述:{$vo.content|default='--'} +
+ 账号:{$vo.username|default='--'}
+ 节点:{$vo.node|default='--'} +
+ 地址:{$vo.geoip|default='--'}
+ 位置:{$vo.isp|default='--'} +
+ 日期:{$vo.create_at|format_datetime|str_replace=' ','
时间:',###|raw} +
+ {if auth("admin/log/del")} + 删 除 + {/if} +
- - - - - -
- -

没 有 记 录 哦!

- - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - 操作账号权限节点操作行为操作内容操作位置操作时间
- - {$vo.username}{$vo.node}{$vo.action}{$vo.content}{$vo.isp|default=$vo.ip}{$vo.create_at|format_datetime}
- {if isset($page)}

{$page|raw}

{/if} - -
{/block} \ No newline at end of file diff --git a/application/admin/view/log/index_search.html b/application/admin/view/log/index_search.html new file mode 100644 index 000000000..265e38001 --- /dev/null +++ b/application/admin/view/log/index_search.html @@ -0,0 +1,56 @@ +
+ + 条件搜索 + + + +
+ + \ No newline at end of file diff --git a/application/admin/view/log/sms.html b/application/admin/view/log/sms.html deleted file mode 100644 index 6d99c46d3..000000000 --- a/application/admin/view/log/sms.html +++ /dev/null @@ -1,76 +0,0 @@ -{extend name='admin@public/content'} - -{block name="content"} - - - - - -
- - - - - - - - - - - - - {foreach $list as $key=>$vo} - - - - - - - - {/foreach} - -
- - 手机号短信内容返回结果发送时间
- - {$vo.phone}{$vo.content}{$vo.result}{$vo.create_at|format_datetime}
- {if isset($page)}

{$page}

{/if} - -
-{/block} \ No newline at end of file diff --git a/application/admin/view/login/index.html b/application/admin/view/login/index.html index bf83d4606..22823bc47 100644 --- a/application/admin/view/login/index.html +++ b/application/admin/view/login/index.html @@ -1,82 +1,49 @@ -{extend name="admin@public/main"} - -{block name="style"} - -{/block} +{extend name="admin@index/index"} {block name="body"} -