mm_os 2.8.9 → 2.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/cache/sys/main/config.json +1 -0
- package/cache/user/main/config.json +1 -0
- package/core/com/sql/drive.js +6 -6
- package/core/com/static/drive.js +22 -18
- package/core/com/static/index.js +1 -1
- package/demo/app/dev/LICENSE +201 -0
- package/demo/app/dev/README.md +1 -0
- package/demo/app/dev/app.js +147 -0
- package/demo/app/dev/app.json +12 -0
- package/demo/app/dev/event_api/client/event.json +10 -0
- package/demo/app/dev/event_api/client/main.js +17 -0
- package/demo/app/dev/plugin/main/api_dev_client/api/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/api/index.js +54 -0
- package/demo/app/dev/plugin/main/api_dev_client/api/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/com.js +348 -0
- package/demo/app/dev/plugin/main/api_dev_client/event/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/event/index.js +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/event/param.json +31 -0
- package/demo/app/sys/.gitmodules +3 -0
- package/demo/app/sys/LICENSE +201 -0
- package/demo/app/sys/README.md +1 -0
- package/demo/app/sys/app.js +148 -0
- package/demo/app/sys/app.json +10 -0
- package/demo/app/sys/event_api/api/after.js +12 -0
- package/demo/app/sys/event_api/api/before.js +78 -0
- package/demo/app/sys/event_api/api/check.js +56 -0
- package/demo/app/sys/event_api/api/event.json +41 -0
- package/demo/app/sys/event_api/api/main.js +17 -0
- package/demo/app/sys/event_api/apis/before.js +76 -0
- package/demo/app/sys/event_api/apis/event.json +21 -0
- package/demo/app/sys/event_api/apis/main.js +17 -0
- package/demo/app/sys/event_api/client/event.json +10 -0
- package/demo/app/sys/event_api/client/main.js +15 -0
- package/demo/app/sys/event_api/manage/event.json +10 -0
- package/demo/app/sys/event_api/manage/main.js +15 -0
- package/demo/app/sys/event_api/upload/event.json +10 -0
- package/demo/app/sys/event_api/upload/main.js +15 -0
- package/demo/app/sys/event_api/web/check.js +34 -0
- package/demo/app/sys/event_api/web/event.json +39 -0
- package/demo/app/sys/event_api/web/main.js +36 -0
- package/demo/app/sys/event_api/ws/event.json +10 -0
- package/demo/app/sys/event_api/ws/main.js +15 -0
- package/demo/app/sys/plugin/main/api_client/activation/api.json +29 -0
- package/demo/app/sys/plugin/main/api_client/activation/index.js +185 -0
- package/demo/app/sys/plugin/main/api_client/activation/param.json +56 -0
- package/demo/app/sys/plugin/main/api_client/app_balance/api.json +18 -0
- package/demo/app/sys/plugin/main/api_client/app_balance/index.js +61 -0
- package/demo/app/sys/plugin/main/api_client/app_balance/param.json +36 -0
- package/demo/app/sys/plugin/main/api_client/app_pay/api.json +23 -0
- package/demo/app/sys/plugin/main/api_client/app_pay/index.js +65 -0
- package/demo/app/sys/plugin/main/api_client/app_pay/param.json +61 -0
- package/demo/app/sys/plugin/main/api_client/app_state/api.json +27 -0
- package/demo/app/sys/plugin/main/api_client/app_state/index.js +46 -0
- package/demo/app/sys/plugin/main/api_client/app_state/param.json +36 -0
- package/demo/app/sys/plugin/main/api_client/component/api.json +27 -0
- package/demo/app/sys/plugin/main/api_client/component/index.js +331 -0
- package/demo/app/sys/plugin/main/api_client/config/api.json +37 -0
- package/demo/app/sys/plugin/main/api_client/config/index.js +36 -0
- package/demo/app/sys/plugin/main/api_client/config/param.json +27 -0
- package/demo/app/sys/plugin/main/api_client/download/api.json +37 -0
- package/demo/app/sys/plugin/main/api_client/download/index.js +60 -0
- package/demo/app/sys/plugin/main/api_client/download/param.json +34 -0
- package/demo/app/sys/plugin/main/api_client/install/api.json +24 -0
- package/demo/app/sys/plugin/main/api_client/install/index.js +216 -0
- package/demo/app/sys/plugin/main/api_client/install/param.json +64 -0
- package/demo/app/sys/plugin/main/api_client/nav/api.json +15 -0
- package/demo/app/sys/plugin/main/api_client/nav/index.js +37 -0
- package/demo/app/sys/plugin/main/api_client/nav/param.json +87 -0
- package/demo/app/sys/plugin/main/api_client/overview/api.json +24 -0
- package/demo/app/sys/plugin/main/api_client/overview/index.js +29 -0
- package/demo/app/sys/plugin/main/api_client/overview/param.json +130 -0
- package/demo/app/sys/plugin/main/api_client/overview/sql.json +70 -0
- package/demo/app/sys/plugin/main/api_client/query/api.json +35 -0
- package/demo/app/sys/plugin/main/api_client/query/index.js +48 -0
- package/demo/app/sys/plugin/main/api_client/theme/api.json +37 -0
- package/demo/app/sys/plugin/main/api_client/theme/index.js +30 -0
- package/demo/app/sys/plugin/main/api_client/theme/param.json +31 -0
- package/demo/app/sys/plugin/main/api_client/version/api.json +29 -0
- package/demo/app/sys/plugin/main/api_client/version/index.js +132 -0
- package/demo/app/sys/plugin/main/api_client/version/param.json +130 -0
- package/demo/app/sys/plugin/main/api_client/zip/api.json +31 -0
- package/demo/app/sys/plugin/main/api_client/zip/index.js +29 -0
- package/demo/app/sys/plugin/main/api_client/zip/param.json +48 -0
- package/demo/app/sys/plugin/main/api_sys_client/count/api.json +27 -0
- package/demo/app/sys/plugin/main/api_sys_client/count/index.js +73 -0
- package/demo/app/sys/plugin/main/api_sys_client/lang/api.json +37 -0
- package/demo/app/sys/plugin/main/api_sys_client/lang/index.js +28 -0
- package/demo/app/sys/plugin/main/api_sys_client/lang/param.json +22 -0
- package/demo/app/sys/plugin/main/api_sys_client/log/api.json +29 -0
- package/demo/app/sys/plugin/main/api_sys_client/log/index.js +42 -0
- package/demo/app/sys/plugin/main/api_sys_client/log/param.json +130 -0
- package/demo/app/sys/plugin/main/api_sys_client/options/api.json +30 -0
- package/demo/app/sys/plugin/main/api_sys_client/options/index.js +28 -0
- package/demo/app/sys/plugin/main/api_sys_client/options/param.json +130 -0
- package/demo/app/sys/plugin/main/api_sys_client/query/api.json +35 -0
- package/demo/app/sys/plugin/main/api_sys_client/query/index.js +48 -0
- package/demo/app/sys/plugin/main/api_sys_client/theme/api.json +37 -0
- package/demo/app/sys/plugin/main/api_sys_client/theme/index.js +30 -0
- package/demo/app/sys/plugin/main/api_sys_client/theme/param.json +31 -0
- package/demo/app/sys/plugin/main/api_sys_web/index/api.json +37 -0
- package/demo/app/sys/plugin/main/api_sys_web/index/index.js +26 -0
- package/demo/app/sys/plugin/main/api_upload/chunk/api.json +29 -0
- package/demo/app/sys/plugin/main/api_upload/chunk/index.js +38 -0
- package/demo/app/sys/plugin/main/api_upload/chunk/param.json +27 -0
- package/demo/app/sys/plugin/main/api_upload/delete/api.json +29 -0
- package/demo/app/sys/plugin/main/api_upload/delete/index.js +38 -0
- package/demo/app/sys/plugin/main/api_upload/delete/param.json +27 -0
- package/demo/app/sys/plugin/main/api_upload/file/api.json +15 -0
- package/demo/app/sys/plugin/main/api_upload/file/index.js +114 -0
- package/demo/app/sys/plugin/main/api_upload/file/param.json +9 -0
- package/demo/app/sys/plugin/main/api_upload/image/api.json +16 -0
- package/demo/app/sys/plugin/main/api_upload/image/index.js +45 -0
- package/demo/app/sys/plugin/main/api_upload/image/param.json +9 -0
- package/demo/app/sys/plugin/main/api_upload/merge/api.json +29 -0
- package/demo/app/sys/plugin/main/api_upload/merge/index.js +38 -0
- package/demo/app/sys/plugin/main/api_upload/merge/param.json +27 -0
- package/demo/app/sys/plugin/main/api_upload/video/api.json +29 -0
- package/demo/app/sys/plugin/main/api_upload/video/index.js +48 -0
- package/demo/app/sys/plugin/main/api_upload/video/param.json +25 -0
- package/demo/app/sys/plugin/main/index.js +127 -0
- package/demo/app/sys/plugin/main/plugin.json +19 -0
- package/demo/app/sys/plugin/main/static/article_list.vue +488 -0
- package/demo/app/sys/plugin/main/static/img/logo.png +0 -0
- package/demo/app/sys/plugin/main/static/static.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_client/ad/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/ad/param.json +685 -0
- package/demo/app/sys/plugin/server/api_sys_client/ad/sql.json +114 -0
- package/demo/app/sys/plugin/server/api_sys_client/address_province/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/address_province/param.json +156 -0
- package/demo/app/sys/plugin/server/api_sys_client/address_province/sql.json +25 -0
- package/demo/app/sys/plugin/server/api_sys_client/app/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/app/param.json +437 -0
- package/demo/app/sys/plugin/server/api_sys_client/app/sql.json +71 -0
- package/demo/app/sys/plugin/server/api_sys_client/app_refresh/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/app_refresh/param.json +158 -0
- package/demo/app/sys/plugin/server/api_sys_client/app_refresh/sql.json +28 -0
- package/demo/app/sys/plugin/server/api_sys_client/block/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/block/param.json +318 -0
- package/demo/app/sys/plugin/server/api_sys_client/block/sql.json +48 -0
- package/demo/app/sys/plugin/server/api_sys_client/config/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/config/param.json +259 -0
- package/demo/app/sys/plugin/server/api_sys_client/config/sql.json +93 -0
- package/demo/app/sys/plugin/server/api_sys_client/file/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/file/param.json +268 -0
- package/demo/app/sys/plugin/server/api_sys_client/file/sql.json +30 -0
- package/demo/app/sys/plugin/server/api_sys_client/lang/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/lang/param.json +175 -0
- package/demo/app/sys/plugin/server/api_sys_client/lang/sql.json +40 -0
- package/demo/app/sys/plugin/server/api_sys_client/message/api.json +13 -0
- package/demo/app/sys/plugin/server/api_sys_client/message/index.js +31 -0
- package/demo/app/sys/plugin/server/api_sys_client/message/param.json +147 -0
- package/demo/app/sys/plugin/server/api_sys_client/message/sql.json +24 -0
- package/demo/app/sys/plugin/server/api_sys_client/nav/api.json +13 -0
- package/demo/app/sys/plugin/server/api_sys_client/nav/index.js +52 -0
- package/demo/app/sys/plugin/server/api_sys_client/nav/param.json +295 -0
- package/demo/app/sys/plugin/server/api_sys_client/nav/sql.json +63 -0
- package/demo/app/sys/plugin/server/api_sys_client/pay/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/pay/param.json +391 -0
- package/demo/app/sys/plugin/server/api_sys_client/pay/sql.json +76 -0
- package/demo/app/sys/plugin/server/api_sys_client/pay_type/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/pay_type/param.json +242 -0
- package/demo/app/sys/plugin/server/api_sys_client/pay_type/sql.json +74 -0
- package/demo/app/sys/plugin/server/api_sys_client/project/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/project/param.json +796 -0
- package/demo/app/sys/plugin/server/api_sys_client/project/sql.json +163 -0
- package/demo/app/sys/plugin/server/api_sys_client/recharge/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/recharge/param.json +311 -0
- package/demo/app/sys/plugin/server/api_sys_client/recharge/sql.json +102 -0
- package/demo/app/sys/plugin/server/api_sys_client/scene/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/scene/param.json +226 -0
- package/demo/app/sys/plugin/server/api_sys_client/scene/sql.json +49 -0
- package/demo/app/sys/plugin/server/api_sys_client/seo/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/seo/param.json +145 -0
- package/demo/app/sys/plugin/server/api_sys_client/seo/sql.json +49 -0
- package/demo/app/sys/plugin/server/api_sys_client/withdrawal/api.json +12 -0
- package/demo/app/sys/plugin/server/api_sys_client/withdrawal/param.json +378 -0
- package/demo/app/sys/plugin/server/api_sys_client/withdrawal/sql.json +92 -0
- package/demo/app/sys/plugin/server/api_sys_manage/ad/api.json +19 -0
- package/demo/app/sys/plugin/server/api_sys_manage/ad/index.js +27 -0
- package/demo/app/sys/plugin/server/api_sys_manage/ad/param.json +685 -0
- package/demo/app/sys/plugin/server/api_sys_manage/ad/sql.json +111 -0
- package/demo/app/sys/plugin/server/api_sys_manage/address_province/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/address_province/param.json +156 -0
- package/demo/app/sys/plugin/server/api_sys_manage/address_province/sql.json +23 -0
- package/demo/app/sys/plugin/server/api_sys_manage/app/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/app/param.json +437 -0
- package/demo/app/sys/plugin/server/api_sys_manage/app/sql.json +69 -0
- package/demo/app/sys/plugin/server/api_sys_manage/app_refresh/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/app_refresh/param.json +158 -0
- package/demo/app/sys/plugin/server/api_sys_manage/app_refresh/sql.json +27 -0
- package/demo/app/sys/plugin/server/api_sys_manage/block/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/block/param.json +318 -0
- package/demo/app/sys/plugin/server/api_sys_manage/block/sql.json +47 -0
- package/demo/app/sys/plugin/server/api_sys_manage/config/api.json +19 -0
- package/demo/app/sys/plugin/server/api_sys_manage/config/index.js +35 -0
- package/demo/app/sys/plugin/server/api_sys_manage/config/param.json +261 -0
- package/demo/app/sys/plugin/server/api_sys_manage/config/sql.json +92 -0
- package/demo/app/sys/plugin/server/api_sys_manage/file/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/file/param.json +268 -0
- package/demo/app/sys/plugin/server/api_sys_manage/file/sql.json +29 -0
- package/demo/app/sys/plugin/server/api_sys_manage/lang/api.json +19 -0
- package/demo/app/sys/plugin/server/api_sys_manage/lang/index.js +27 -0
- package/demo/app/sys/plugin/server/api_sys_manage/lang/param.json +175 -0
- package/demo/app/sys/plugin/server/api_sys_manage/lang/sql.json +40 -0
- package/demo/app/sys/plugin/server/api_sys_manage/message/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/message/param.json +152 -0
- package/demo/app/sys/plugin/server/api_sys_manage/message/sql.json +21 -0
- package/demo/app/sys/plugin/server/api_sys_manage/nav/api.json +19 -0
- package/demo/app/sys/plugin/server/api_sys_manage/nav/index.js +27 -0
- package/demo/app/sys/plugin/server/api_sys_manage/nav/param.json +295 -0
- package/demo/app/sys/plugin/server/api_sys_manage/nav/sql.json +61 -0
- package/demo/app/sys/plugin/server/api_sys_manage/pay/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/pay/param.json +391 -0
- package/demo/app/sys/plugin/server/api_sys_manage/pay/sql.json +75 -0
- package/demo/app/sys/plugin/server/api_sys_manage/pay_type/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/pay_type/param.json +242 -0
- package/demo/app/sys/plugin/server/api_sys_manage/pay_type/sql.json +73 -0
- package/demo/app/sys/plugin/server/api_sys_manage/project/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/project/param.json +796 -0
- package/demo/app/sys/plugin/server/api_sys_manage/project/sql.json +162 -0
- package/demo/app/sys/plugin/server/api_sys_manage/recharge/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/recharge/param.json +311 -0
- package/demo/app/sys/plugin/server/api_sys_manage/recharge/sql.json +101 -0
- package/demo/app/sys/plugin/server/api_sys_manage/scene/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/scene/param.json +226 -0
- package/demo/app/sys/plugin/server/api_sys_manage/scene/sql.json +48 -0
- package/demo/app/sys/plugin/server/api_sys_manage/seo/api.json +19 -0
- package/demo/app/sys/plugin/server/api_sys_manage/seo/index.js +26 -0
- package/demo/app/sys/plugin/server/api_sys_manage/seo/param.json +145 -0
- package/demo/app/sys/plugin/server/api_sys_manage/seo/sql.json +48 -0
- package/demo/app/sys/plugin/server/api_sys_manage/withdrawal/api.json +18 -0
- package/demo/app/sys/plugin/server/api_sys_manage/withdrawal/param.json +378 -0
- package/demo/app/sys/plugin/server/api_sys_manage/withdrawal/sql.json +91 -0
- package/demo/app/sys/plugin/server/db/ad.db.json +622 -0
- package/demo/app/sys/plugin/server/db/address_province.db.json +82 -0
- package/demo/app/sys/plugin/server/db/app.db.json +369 -0
- package/demo/app/sys/plugin/server/db/app_refresh.db.json +117 -0
- package/demo/app/sys/plugin/server/db/block.db.json +352 -0
- package/demo/app/sys/plugin/server/db/config.db.json +226 -0
- package/demo/app/sys/plugin/server/db/file.db.json +172 -0
- package/demo/app/sys/plugin/server/db/lang.db.json +208 -0
- package/demo/app/sys/plugin/server/db/message.db.json +99 -0
- package/demo/app/sys/plugin/server/db/nav.db.json +298 -0
- package/demo/app/sys/plugin/server/db/pay.db.json +316 -0
- package/demo/app/sys/plugin/server/db/pay_type.db.json +226 -0
- package/demo/app/sys/plugin/server/db/project.db.json +622 -0
- package/demo/app/sys/plugin/server/db/recharge.db.json +226 -0
- package/demo/app/sys/plugin/server/db/scene.db.json +208 -0
- package/demo/app/sys/plugin/server/db/seo.db.json +136 -0
- package/demo/app/sys/plugin/server/db/withdrawal.db.json +298 -0
- package/demo/app/user/LICENSE +201 -0
- package/demo/app/user/app.js +144 -0
- package/demo/app/user/app.json +10 -0
- package/demo/app/user/event_api/client/event.json +10 -0
- package/demo/app/user/event_api/client/main.js +17 -0
- package/demo/app/user/event_api/manage/event.json +10 -0
- package/demo/app/user/event_api/manage/main.js +17 -0
- package/demo/app/user/event_api/web/event.json +20 -0
- package/demo/app/user/event_api/web/main.js +39 -0
- package/demo/app/user/plugin/main/api_user_client/account/api.json +41 -0
- package/demo/app/user/plugin/main/api_user_client/account/index.js +54 -0
- package/demo/app/user/plugin/main/api_user_client/account/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_client/account/sql.json +70 -0
- package/demo/app/user/plugin/main/api_user_client/address_login/api.json +27 -0
- package/demo/app/user/plugin/main/api_user_client/address_login/index.js +35 -0
- package/demo/app/user/plugin/main/api_user_client/address_login/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_client/base/api.json +27 -0
- package/demo/app/user/plugin/main/api_user_client/base/index.js +92 -0
- package/demo/app/user/plugin/main/api_user_client/base/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_client/count/api.json +27 -0
- package/demo/app/user/plugin/main/api_user_client/count/chongzhi.js +103 -0
- package/demo/app/user/plugin/main/api_user_client/count/index.js +24 -0
- package/demo/app/user/plugin/main/api_user_client/count/param.json +40 -0
- package/demo/app/user/plugin/main/api_user_client/count/sql.json +70 -0
- package/demo/app/user/plugin/main/api_user_client/data_count/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_client/data_count/index.js +61 -0
- package/demo/app/user/plugin/main/api_user_client/email_code/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_client/email_code/email_code.js +300 -0
- package/demo/app/user/plugin/main/api_user_client/email_code/index.js +18 -0
- package/demo/app/user/plugin/main/api_user_client/email_code/param.json +56 -0
- package/demo/app/user/plugin/main/api_user_client/forgot/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_client/forgot/index.js +36 -0
- package/demo/app/user/plugin/main/api_user_client/forgot/param.json +57 -0
- package/demo/app/user/plugin/main/api_user_client/ip/api.json +39 -0
- package/demo/app/user/plugin/main/api_user_client/ip/index.js +43 -0
- package/demo/app/user/plugin/main/api_user_client/ip/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_client/ip/sql.json +70 -0
- package/demo/app/user/plugin/main/api_user_client/message/api.json +29 -0
- package/demo/app/user/plugin/main/api_user_client/message/index.js +19 -0
- package/demo/app/user/plugin/main/api_user_client/message/param.json +36 -0
- package/demo/app/user/plugin/main/api_user_client/message/sql.json +21 -0
- package/demo/app/user/plugin/main/api_user_client/oauth/WXBizDataCrypt.js +33 -0
- package/demo/app/user/plugin/main/api_user_client/oauth/api.json +31 -0
- package/demo/app/user/plugin/main/api_user_client/oauth/index.js +16 -0
- package/demo/app/user/plugin/main/api_user_client/oauth/oauth.js +315 -0
- package/demo/app/user/plugin/main/api_user_client/oauth/oauth.json +88 -0
- package/demo/app/user/plugin/main/api_user_client/oauth/param.json +111 -0
- package/demo/app/user/plugin/main/api_user_client/password/api.json +21 -0
- package/demo/app/user/plugin/main/api_user_client/password/index.js +64 -0
- package/demo/app/user/plugin/main/api_user_client/password/param.json +45 -0
- package/demo/app/user/plugin/main/api_user_client/phone_code/aliyun.js +230 -0
- package/demo/app/user/plugin/main/api_user_client/phone_code/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_client/phone_code/index.js +18 -0
- package/demo/app/user/plugin/main/api_user_client/phone_code/param.json +58 -0
- package/demo/app/user/plugin/main/api_user_client/phone_code/phone_code.js +297 -0
- package/demo/app/user/plugin/main/api_user_client/realname/api.json +21 -0
- package/demo/app/user/plugin/main/api_user_client/realname/index.js +45 -0
- package/demo/app/user/plugin/main/api_user_client/realname/param.json +74 -0
- package/demo/app/user/plugin/main/api_user_client/servicer/api.json +29 -0
- package/demo/app/user/plugin/main/api_user_client/servicer/index.js +19 -0
- package/demo/app/user/plugin/main/api_user_client/servicer/param.json +41 -0
- package/demo/app/user/plugin/main/api_user_client/servicer/sql.json +113 -0
- package/demo/app/user/plugin/main/api_user_client/set_address/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_client/set_address/index.js +98 -0
- package/demo/app/user/plugin/main/api_user_client/set_address/param.json +165 -0
- package/demo/app/user/plugin/main/api_user_client/set_avatar/api.json +35 -0
- package/demo/app/user/plugin/main/api_user_client/set_avatar/index.js +77 -0
- package/demo/app/user/plugin/main/api_user_client/set_info/api.json +35 -0
- package/demo/app/user/plugin/main/api_user_client/set_info/index.js +44 -0
- package/demo/app/user/plugin/main/api_user_client/set_nickname/api.json +35 -0
- package/demo/app/user/plugin/main/api_user_client/set_nickname/index.js +46 -0
- package/demo/app/user/plugin/main/api_user_client/set_pay_password/api.json +21 -0
- package/demo/app/user/plugin/main/api_user_client/set_pay_password/index.js +64 -0
- package/demo/app/user/plugin/main/api_user_client/sign_address/api.json +39 -0
- package/demo/app/user/plugin/main/api_user_client/sign_address/index.js +114 -0
- package/demo/app/user/plugin/main/api_user_client/sign_address/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_client/sign_address/sql.json +70 -0
- package/demo/app/user/plugin/main/api_user_client/sign_auto/api.json +29 -0
- package/demo/app/user/plugin/main/api_user_client/sign_auto/index.js +141 -0
- package/demo/app/user/plugin/main/api_user_client/sign_auto/param.json +42 -0
- package/demo/app/user/plugin/main/api_user_client/sign_in/api.json +11 -0
- package/demo/app/user/plugin/main/api_user_client/sign_in/index.js +274 -0
- package/demo/app/user/plugin/main/api_user_client/sign_in/param.json +125 -0
- package/demo/app/user/plugin/main/api_user_client/sign_in/state.js +37 -0
- package/demo/app/user/plugin/main/api_user_client/sign_out/api.json +9 -0
- package/demo/app/user/plugin/main/api_user_client/sign_out/index.js +28 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up/api.json +12 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up/index.js +189 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up/param.json +83 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up_in/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up_in/index.js +137 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up_in/param.json +33 -0
- package/demo/app/user/plugin/main/api_user_client/state/api.json +9 -0
- package/demo/app/user/plugin/main/api_user_client/state/index.js +19 -0
- package/demo/app/user/plugin/main/api_user_client/token/api.json +25 -0
- package/demo/app/user/plugin/main/api_user_client/token/index.js +20 -0
- package/demo/app/user/plugin/main/api_user_client/token/param.json +16 -0
- package/demo/app/user/plugin/main/api_user_client/unsubscribe/api.json +29 -0
- package/demo/app/user/plugin/main/api_user_client/unsubscribe/index.js +91 -0
- package/demo/app/user/plugin/main/api_user_client/unsubscribe/param.json +71 -0
- package/demo/app/user/plugin/main/api_user_client/yun_avatar/api.json +31 -0
- package/demo/app/user/plugin/main/api_user_client/yun_avatar/index.js +56 -0
- package/demo/app/user/plugin/main/api_user_client/yun_avatar/param.json +50 -0
- package/demo/app/user/plugin/main/api_user_web/avatar/api.json +28 -0
- package/demo/app/user/plugin/main/api_user_web/avatar/index.js +51 -0
- package/demo/app/user/plugin/main/api_user_web/login/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_web/login/index.js +12 -0
- package/demo/app/user/plugin/main/api_user_web/root/api.json +38 -0
- package/demo/app/user/plugin/main/api_user_web/root/index.js +67 -0
- package/demo/app/user/plugin/main/index.js +144 -0
- package/demo/app/user/plugin/main/plugin.json +20 -0
- package/demo/app/user/plugin/server/api_user_client/address/api.json +16 -0
- package/demo/app/user/plugin/server/api_user_client/address/index.js +79 -0
- package/demo/app/user/plugin/server/api_user_client/address/param.json +288 -0
- package/demo/app/user/plugin/server/api_user_client/address/sql.json +56 -0
- package/demo/app/user/plugin/server/api_user_client/count/api.json +12 -0
- package/demo/app/user/plugin/server/api_user_client/count/param.json +646 -0
- package/demo/app/user/plugin/server/api_user_client/count/sql.json +82 -0
- package/demo/app/user/plugin/server/api_user_client/info/api.json +16 -0
- package/demo/app/user/plugin/server/api_user_client/info/index.js +42 -0
- package/demo/app/user/plugin/server/api_user_client/info/param.json +531 -0
- package/demo/app/user/plugin/server/api_user_client/info/sql.json +84 -0
- package/demo/app/user/plugin/server/api_user_client/message/api.json +12 -0
- package/demo/app/user/plugin/server/api_user_client/message/param.json +366 -0
- package/demo/app/user/plugin/server/api_user_client/message/sql.json +88 -0
- package/demo/app/user/plugin/server/api_user_client/nation/api.json +12 -0
- package/demo/app/user/plugin/server/api_user_client/nation/param.json +74 -0
- package/demo/app/user/plugin/server/api_user_client/nation/sql.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/account/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/account/param.json +620 -0
- package/demo/app/user/plugin/server/api_user_manage/account/sql.json +105 -0
- package/demo/app/user/plugin/server/api_user_manage/address/api.json +19 -0
- package/demo/app/user/plugin/server/api_user_manage/address/index.js +57 -0
- package/demo/app/user/plugin/server/api_user_manage/address/param.json +288 -0
- package/demo/app/user/plugin/server/api_user_manage/address/sql.json +44 -0
- package/demo/app/user/plugin/server/api_user_manage/admin/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/admin/param.json +147 -0
- package/demo/app/user/plugin/server/api_user_manage/admin/sql.json +24 -0
- package/demo/app/user/plugin/server/api_user_manage/admin_log/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/admin_log/param.json +226 -0
- package/demo/app/user/plugin/server/api_user_manage/admin_log/sql.json +32 -0
- package/demo/app/user/plugin/server/api_user_manage/count/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/count/param.json +646 -0
- package/demo/app/user/plugin/server/api_user_manage/count/sql.json +72 -0
- package/demo/app/user/plugin/server/api_user_manage/group/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/group/param.json +187 -0
- package/demo/app/user/plugin/server/api_user_manage/group/sql.json +39 -0
- package/demo/app/user/plugin/server/api_user_manage/group_log/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/group_log/param.json +235 -0
- package/demo/app/user/plugin/server/api_user_manage/group_log/sql.json +32 -0
- package/demo/app/user/plugin/server/api_user_manage/info/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/info/param.json +531 -0
- package/demo/app/user/plugin/server/api_user_manage/info/sql.json +71 -0
- package/demo/app/user/plugin/server/api_user_manage/message/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/message/param.json +366 -0
- package/demo/app/user/plugin/server/api_user_manage/message/sql.json +75 -0
- package/demo/app/user/plugin/server/api_user_manage/nation/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/nation/param.json +74 -0
- package/demo/app/user/plugin/server/api_user_manage/nation/sql.json +16 -0
- package/demo/app/user/plugin/server/api_user_manage/state/api.json +18 -0
- package/demo/app/user/plugin/server/api_user_manage/state/param.json +98 -0
- package/demo/app/user/plugin/server/api_user_manage/state/sql.json +29 -0
- package/demo/app/user/plugin/server/db/account.db.json +460 -0
- package/demo/app/user/plugin/server/db/address.db.json +262 -0
- package/demo/app/user/plugin/server/db/admin.db.json +117 -0
- package/demo/app/user/plugin/server/db/admin_log.db.json +189 -0
- package/demo/app/user/plugin/server/db/count.db.json +298 -0
- package/demo/app/user/plugin/server/db/group.db.json +117 -0
- package/demo/app/user/plugin/server/db/group_log.db.json +190 -0
- package/demo/app/user/plugin/server/db/info.db.json +496 -0
- package/demo/app/user/plugin/server/db/message.db.json +262 -0
- package/demo/app/user/plugin/server/db/nation.db.json +46 -0
- package/demo/app/user/plugin/server/db/state.db.json +64 -0
- package/demo/config/development.json +109 -0
- package/demo/config/local.json +111 -0
- package/demo/config/lock.cache +5 -0
- package/demo/config/test.json +109 -0
- package/demo/config/tpl.json +107 -0
- package/demo/index.js +5 -3
- package/demo/static/file/image/1.png +0 -0
- package/index.js +7 -6
- package/middleware/cors/index.js +1 -1
- package/middleware/cors/middleware.json +3 -1
- package/middleware/log/index.js +1 -1
- package/middleware/log/middleware.json +1 -1
- package/middleware/mqtt_base/index.js +1 -1
- package/middleware/mqtt_base/middleware.json +3 -1
- package/middleware/waf/index.js +1 -1
- package/middleware/waf/middleware.json +1 -1
- package/middleware/waf_ip/index.js +1 -1
- package/middleware/waf_ip/middleware.json +1 -1
- package/middleware/web_after/index.js +20 -0
- package/middleware/web_after/middleware.json +9 -0
- package/middleware/web_base/index.js +1 -1
- package/middleware/web_base/middleware.json +1 -1
- package/middleware/web_before/index.js +27 -0
- package/middleware/web_before/middleware.json +9 -0
- package/middleware/web_check/index.js +22 -0
- package/middleware/web_check/middleware.json +9 -0
- package/middleware/web_main/index.js +22 -0
- package/middleware/web_main/middleware.json +9 -0
- package/middleware/web_proxy/index.js +1 -1
- package/middleware/web_proxy/middleware.json +1 -1
- package/middleware/web_render/index.js +81 -0
- package/middleware/web_render/middleware.json +9 -0
- package/middleware/web_socket/index.js +1 -1
- package/middleware/web_socket/middleware.json +1 -1
- package/middleware/web_static/index.js +1 -1
- package/middleware/web_static/middleware.json +1 -1
- package/package.json +2 -2
- package/middleware/web_event/index.js +0 -413
- package/middleware/web_event/middleware.json +0 -10
- package/middleware/web_router/index.js +0 -33
- package/middleware/web_router/middleware.json +0 -10
|
@@ -0,0 +1,315 @@
|
|
|
1
|
+
const WXBizDataCrypt = require('./WXBizDataCrypt');
|
|
2
|
+
const cg = require('./oauth.json');
|
|
3
|
+
|
|
4
|
+
/**
|
|
5
|
+
* Oauth授权类
|
|
6
|
+
*/
|
|
7
|
+
class Oauth {
|
|
8
|
+
/**
|
|
9
|
+
* 配置参数
|
|
10
|
+
* @param {Object} config
|
|
11
|
+
*/
|
|
12
|
+
constructor(config) {
|
|
13
|
+
this.config = Object.assign({}, cg, config);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* 构建配置模型
|
|
19
|
+
* @param {Object} config
|
|
20
|
+
* @return {Object} 返回配置
|
|
21
|
+
*/
|
|
22
|
+
Oauth.prototype.model = function(config) {
|
|
23
|
+
config.dict = Object.assign({
|
|
24
|
+
"code": "code",
|
|
25
|
+
"scope": "scope",
|
|
26
|
+
"client_id": "client_id",
|
|
27
|
+
"client_secret": "client_secret",
|
|
28
|
+
"openid": "openid",
|
|
29
|
+
"access_token": "access_token",
|
|
30
|
+
"refresh_token": "refresh_token",
|
|
31
|
+
"redirect_uri": "redirect_uri",
|
|
32
|
+
"state": "state"
|
|
33
|
+
}, config.dict);
|
|
34
|
+
|
|
35
|
+
return config;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* 授权链接
|
|
40
|
+
*/
|
|
41
|
+
Oauth.prototype.connect = async function(db, ctx, config) {
|
|
42
|
+
console.log('connect');
|
|
43
|
+
return $.ret.body = {
|
|
44
|
+
url: config.url_code
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* 回调链接
|
|
50
|
+
*/
|
|
51
|
+
Oauth.prototype.callback = async function(db, ctx, config) {
|
|
52
|
+
console.log(req);
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* 绑定链接
|
|
57
|
+
*/
|
|
58
|
+
Oauth.prototype.bind = async function(db, ctx, config) {
|
|
59
|
+
var req = ctx.request;
|
|
60
|
+
var body = req.body;
|
|
61
|
+
var {
|
|
62
|
+
openid,
|
|
63
|
+
encryptedData,
|
|
64
|
+
iv,
|
|
65
|
+
appid,
|
|
66
|
+
session_key,
|
|
67
|
+
nickName,
|
|
68
|
+
city,
|
|
69
|
+
province,
|
|
70
|
+
country,
|
|
71
|
+
avatarUrl
|
|
72
|
+
} = body;
|
|
73
|
+
|
|
74
|
+
var pc = new WXBizDataCrypt(appid, session_key);
|
|
75
|
+
var data = pc.decryptData(encryptedData, iv);
|
|
76
|
+
if (!data) {
|
|
77
|
+
return $.ret.error(10000, "授权验证失败!");
|
|
78
|
+
}
|
|
79
|
+
var phone = data.phoneNumber;
|
|
80
|
+
if (!phone) {
|
|
81
|
+
return $.ret.error(70001, "未授权登录!");
|
|
82
|
+
}
|
|
83
|
+
var db1 = db.new("user_account", "user_id");
|
|
84
|
+
var user = await db1.getObj({
|
|
85
|
+
phone
|
|
86
|
+
});
|
|
87
|
+
if (!user) {
|
|
88
|
+
var len = phone.length;
|
|
89
|
+
var p = phone.substring(len - 6, len).md5();
|
|
90
|
+
var salt = p.substring(0, 6);
|
|
91
|
+
var password = (p + salt).md5();
|
|
92
|
+
var username = phone;
|
|
93
|
+
var invite_code = (username + password).md5().substring(0, 6);
|
|
94
|
+
|
|
95
|
+
await db1.add({
|
|
96
|
+
username,
|
|
97
|
+
salt,
|
|
98
|
+
password,
|
|
99
|
+
phone,
|
|
100
|
+
invite_code,
|
|
101
|
+
wallet_address: phone
|
|
102
|
+
});
|
|
103
|
+
// console.log("注册账户", db1.error);
|
|
104
|
+
user = await db1.getObj({
|
|
105
|
+
phone
|
|
106
|
+
});
|
|
107
|
+
if (!user) {
|
|
108
|
+
return $.ret.error(10000, "创建用户失败!");
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
|
|
112
|
+
user.nickname = nickName;
|
|
113
|
+
user.avatar = avatarUrl;
|
|
114
|
+
|
|
115
|
+
var db2 = db.new("user_info", "user_id");
|
|
116
|
+
|
|
117
|
+
var user_id = user.user_id;
|
|
118
|
+
var info = await db2.getObj({
|
|
119
|
+
user_id
|
|
120
|
+
});
|
|
121
|
+
if (!info) {
|
|
122
|
+
await db2.add({
|
|
123
|
+
user_id,
|
|
124
|
+
city,
|
|
125
|
+
country,
|
|
126
|
+
province
|
|
127
|
+
});
|
|
128
|
+
info = await db2.getObj({
|
|
129
|
+
user_id
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
var u = Object.assign({}, user);
|
|
134
|
+
delete u.password;
|
|
135
|
+
delete u.salt;
|
|
136
|
+
delete u.time_create;
|
|
137
|
+
ctx.session.user = user;
|
|
138
|
+
var ip = ctx.ip.replace('::ffff:', '');
|
|
139
|
+
// var user = Object.assign({}, u);
|
|
140
|
+
// 自动生成的uuid是通过IP和浏览器信息加密而成,如果需要解密确认其身份,可再加上user_id加密,自行生成uuid
|
|
141
|
+
var ret = $.ret.body({
|
|
142
|
+
token: ctx.session.uuid,
|
|
143
|
+
user,
|
|
144
|
+
ip
|
|
145
|
+
});
|
|
146
|
+
var userInfo = {
|
|
147
|
+
nickName,
|
|
148
|
+
city,
|
|
149
|
+
province,
|
|
150
|
+
country,
|
|
151
|
+
avatarUrl
|
|
152
|
+
};
|
|
153
|
+
var params = {
|
|
154
|
+
openid: openid,
|
|
155
|
+
info: JSON.stringify(userInfo)
|
|
156
|
+
};
|
|
157
|
+
await $.bind_account(db, params, user);
|
|
158
|
+
// $.log.debug('入场', body);
|
|
159
|
+
return ret
|
|
160
|
+
};
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* 解绑链接
|
|
164
|
+
*/
|
|
165
|
+
Oauth.prototype.unbind = async function(db, ctx, config) {
|
|
166
|
+
|
|
167
|
+
};
|
|
168
|
+
|
|
169
|
+
/**
|
|
170
|
+
* 1.通过code换取token
|
|
171
|
+
* @param {Object} req 查询参数
|
|
172
|
+
* @param {Object} db
|
|
173
|
+
* @param {Object} config
|
|
174
|
+
*/
|
|
175
|
+
Oauth.prototype.code_to_token = async function(db, ctx, config) {
|
|
176
|
+
var ret;
|
|
177
|
+
var req = ctx.request;
|
|
178
|
+
// req里面需传code和appid两个参数
|
|
179
|
+
var d = config.dict;
|
|
180
|
+
var query = req.query;
|
|
181
|
+
var code = query[d.code];
|
|
182
|
+
var appid = query[d.client_id];
|
|
183
|
+
db.table = config.name.replace("_mini", "") + "_app";
|
|
184
|
+
var qy = {};
|
|
185
|
+
qy[d.client_id] = appid;
|
|
186
|
+
|
|
187
|
+
var obj = await db.getObj(qy);
|
|
188
|
+
if (!obj) {
|
|
189
|
+
var conf = await $.config.conf();
|
|
190
|
+
if (conf.wechat_mini_appid === appid) {
|
|
191
|
+
obj = {
|
|
192
|
+
encrypt: conf.wechat_mini_encrypt,
|
|
193
|
+
appid: conf.wechat_mini_appid,
|
|
194
|
+
token: conf.wechat_mini_token,
|
|
195
|
+
encoding_aes_key: conf.wechat_mini_encoding_aes_key,
|
|
196
|
+
appsecret: conf.wechat_mini_appsecret,
|
|
197
|
+
type: "小程序"
|
|
198
|
+
};
|
|
199
|
+
} else {
|
|
200
|
+
return $.ret.error(60000, d.client_id + ":" + appid + "不存在!");
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
var url = config.url_token.replace("{client_id}", appid).replace("{code}", code).replace("{client_secret}",
|
|
204
|
+
obj[d.client_secret]);
|
|
205
|
+
var http = new $.Http();
|
|
206
|
+
var html = await http.get(url);
|
|
207
|
+
if (html.body) {
|
|
208
|
+
var json = html.body.toJson();
|
|
209
|
+
if (json.errcode && json.errmsg) {
|
|
210
|
+
return $.ret.error(30000, json.errmsg)
|
|
211
|
+
}
|
|
212
|
+
var openid = json[d.openid];
|
|
213
|
+
if (openid) {
|
|
214
|
+
if (obj.type == "小程序") {
|
|
215
|
+
db.table = "wechat_info";
|
|
216
|
+
var user_info = await db.getObj({
|
|
217
|
+
openid
|
|
218
|
+
});
|
|
219
|
+
if (user_info) {
|
|
220
|
+
var user_id = user_info.user_id;
|
|
221
|
+
db.table = "user_account";
|
|
222
|
+
var user = await db.getObj({
|
|
223
|
+
user_id
|
|
224
|
+
});
|
|
225
|
+
if (!user) {
|
|
226
|
+
return $.ret.body(json);
|
|
227
|
+
}
|
|
228
|
+
user.openid = openid;
|
|
229
|
+
var token = ctx.session.uuid;
|
|
230
|
+
user.token = token;
|
|
231
|
+
ctx.session.user = user;
|
|
232
|
+
|
|
233
|
+
db.table = "user_state";
|
|
234
|
+
var state = await db.getObj({
|
|
235
|
+
user_id
|
|
236
|
+
});
|
|
237
|
+
|
|
238
|
+
if (state) {
|
|
239
|
+
await db.set({
|
|
240
|
+
user_id
|
|
241
|
+
}, {
|
|
242
|
+
token,
|
|
243
|
+
times: state.times + 1
|
|
244
|
+
});
|
|
245
|
+
} else {
|
|
246
|
+
await db.add({
|
|
247
|
+
user_id,
|
|
248
|
+
token,
|
|
249
|
+
times: 1
|
|
250
|
+
});
|
|
251
|
+
}
|
|
252
|
+
return $.ret.body(user);
|
|
253
|
+
} else {
|
|
254
|
+
var bl = await db.add({
|
|
255
|
+
openid,
|
|
256
|
+
user_id: 0
|
|
257
|
+
});
|
|
258
|
+
return $.ret.body(json);
|
|
259
|
+
}
|
|
260
|
+
} else {
|
|
261
|
+
url = config.url_user_info.replace("{access_token}", json[d.access_token]).replace("{openid}",
|
|
262
|
+
openid);
|
|
263
|
+
html = await http.get(url);
|
|
264
|
+
if (html.body) {
|
|
265
|
+
var users = html.body.toJson();
|
|
266
|
+
db.table = "wechat_info";
|
|
267
|
+
db.key = "info_id";
|
|
268
|
+
qy = {};
|
|
269
|
+
qy["openid"] = openid;
|
|
270
|
+
user = await db.getObj(qy);
|
|
271
|
+
if (!user) {
|
|
272
|
+
var body = {};
|
|
273
|
+
body["openid"] = openid;
|
|
274
|
+
await db.add(body);
|
|
275
|
+
user = await db.getObj(qy);
|
|
276
|
+
}
|
|
277
|
+
if (user) {
|
|
278
|
+
user[d.access_token] = json[d.access_token];
|
|
279
|
+
user[d.refresh_token] = json[d.refresh_token];
|
|
280
|
+
user.info = JSON.stringify(users);
|
|
281
|
+
body = Object.assign({}, user, json, users);
|
|
282
|
+
delete body.info;
|
|
283
|
+
ret = $.ret.body(body);
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
}
|
|
289
|
+
return ret;
|
|
290
|
+
};
|
|
291
|
+
|
|
292
|
+
/**
|
|
293
|
+
* 运行
|
|
294
|
+
*/
|
|
295
|
+
Oauth.prototype.run = async function(db, ctx) {
|
|
296
|
+
var req = ctx.request;
|
|
297
|
+
var path = req.path;
|
|
298
|
+
var dict = this.config;
|
|
299
|
+
var ret = {};
|
|
300
|
+
for (var k in dict) {
|
|
301
|
+
var p = "/api/user/oauth/" + k + "/";
|
|
302
|
+
if (path.indexOf(p) === 0) {
|
|
303
|
+
var fun_name = path.replace(p, '');
|
|
304
|
+
if (this[fun_name]) {
|
|
305
|
+
// console.log("有此路径", fun_name);
|
|
306
|
+
dict[k].name = k;
|
|
307
|
+
ret = await this[fun_name](db, ctx, this.model(dict[k]));
|
|
308
|
+
break;
|
|
309
|
+
}
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
return ret;
|
|
313
|
+
};
|
|
314
|
+
|
|
315
|
+
module.exports = Oauth;
|
|
@@ -0,0 +1,88 @@
|
|
|
1
|
+
{
|
|
2
|
+
"wechat": {
|
|
3
|
+
"client_id": "",
|
|
4
|
+
"client_secret": "",
|
|
5
|
+
"token": "",
|
|
6
|
+
"scope": "snsapi_userinfo",
|
|
7
|
+
"url_code": "https://open.weixin.qq.com/connect/oauth2/authorize?appid={client_id}&redirect_uri={redirect_uri}&response_type=code&scope={scope}&state={state}#wechat_redirect",
|
|
8
|
+
"url_token": "https://api.weixin.qq.com/sns/oauth2/access_token?appid={client_id}&secret={client_secret}&code={code}&grant_type=authorization_code",
|
|
9
|
+
"url_user_info": "https://api.weixin.qq.com/sns/userinfo?access_token={access_token}&openid={openid}&lang=zh_CN",
|
|
10
|
+
"url_check_token": "https://api.weixin.qq.com/sns/auth?access_token={access_token}&openid={openid}",
|
|
11
|
+
"url_refresh_token": "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid={client_id}&grant_type=refresh_token&refresh_token={refresh_token}",
|
|
12
|
+
"dict": {
|
|
13
|
+
"client_id": "appid",
|
|
14
|
+
"client_secret": "secret",
|
|
15
|
+
"openid": "openid"
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
"wechat_mini": {
|
|
19
|
+
"client_id": "wx9af97e2bea3bc126",
|
|
20
|
+
"client_secret": "",
|
|
21
|
+
"token": "",
|
|
22
|
+
"scope": "snsapi_userinfo",
|
|
23
|
+
"url_code": "https://open.weixin.qq.com/connect/oauth2/authorize?appid={client_id}&redirect_uri={redirect_uri}&response_type=code&scope={scope}&state={state}#wechat_redirect",
|
|
24
|
+
"url_token": "https://api.weixin.qq.com/sns/jscode2session?appid={client_id}&secret={client_secret}&js_code={code}&grant_type=authorization_code",
|
|
25
|
+
"url_user_info": "https://api.weixin.qq.com/sns/userinfo?access_token={access_token}&openid={openid}&lang=zh_CN",
|
|
26
|
+
"url_check_token": "https://api.weixin.qq.com/sns/auth?access_token={access_token}&openid={openid}",
|
|
27
|
+
"url_refresh_token": "https://api.weixin.qq.com/sns/oauth2/refresh_token?appid={client_id}&grant_type=refresh_token&refresh_token={refresh_token}",
|
|
28
|
+
"dict": {
|
|
29
|
+
"client_id": "appid",
|
|
30
|
+
"client_secret": "appsecret",
|
|
31
|
+
"openid": "openid"
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
"qq": {
|
|
35
|
+
"client_id": "",
|
|
36
|
+
"client_secret": "",
|
|
37
|
+
"scope": "get_user_info",
|
|
38
|
+
"url_code": "https://graph.qq.com/oauth2.0/authorize?grant_type=code&client_id={client_id}&redirect_uri={redirect_uri}&state={state}&scope={scope}&display=mobile",
|
|
39
|
+
"url_token": "https://graph.qq.com/oauth2.0/token?grant_type=authorization_code&client_id={client_id}&client_secret={client_secret}",
|
|
40
|
+
"url_user_info": "https://graph.qq.com/user/get_user_info?access_token={access_token}&oauth_consumer_key={client_id}&openid={openid}",
|
|
41
|
+
"url_check_token": "https://graph.qq.com/user/get_user_info?access_token{access_token}&oauth_consumer_key={client_id}&openid={openid}&format=json",
|
|
42
|
+
"url_refresh_token": "https://graph.qq.com/oauth2.0/token?grant_type=refresh_token&client_id={client_id}&client_secret={client_secret}&refresh_token={refresh_token}",
|
|
43
|
+
"dict": {
|
|
44
|
+
"openid": "openid",
|
|
45
|
+
"access_token": "client_secret"
|
|
46
|
+
}
|
|
47
|
+
},
|
|
48
|
+
"taobao": {
|
|
49
|
+
"client_id": "",
|
|
50
|
+
"client_secret": "",
|
|
51
|
+
"url_code": "https://oauth.taobao.com/authorize?response_type=code&client_id={client_id}&redirect_uri={redirect_uri}&state={state}&view=web",
|
|
52
|
+
"url_token": "https://oauth.taobao.com/token?grant_type=authorization_code&client_id={client_id}&client_secret={client_secret}&client_secret={client_secret}&code={code}&redirect_uri={redirect_uri}",
|
|
53
|
+
"url_user_info": "",
|
|
54
|
+
"url_check_token": "",
|
|
55
|
+
"url_refresh_token": "",
|
|
56
|
+
"dict": {
|
|
57
|
+
"expires_in": "expires_in",
|
|
58
|
+
"openid": "taobao_user_id"
|
|
59
|
+
}
|
|
60
|
+
},
|
|
61
|
+
"sina": {
|
|
62
|
+
"client_id": "",
|
|
63
|
+
"client_secret": "",
|
|
64
|
+
"url_code": "",
|
|
65
|
+
"url_token": "",
|
|
66
|
+
"url_user_info": "",
|
|
67
|
+
"url_check_token": "",
|
|
68
|
+
"url_refresh_token": ""
|
|
69
|
+
},
|
|
70
|
+
"github": {
|
|
71
|
+
"client_id": "",
|
|
72
|
+
"client_secret": "",
|
|
73
|
+
"url_code": "",
|
|
74
|
+
"url_token": "",
|
|
75
|
+
"url_user_info": "",
|
|
76
|
+
"url_check_token": "",
|
|
77
|
+
"url_refresh_token": ""
|
|
78
|
+
},
|
|
79
|
+
"gitee": {
|
|
80
|
+
"client_id": "",
|
|
81
|
+
"client_secret": "",
|
|
82
|
+
"url_code": "",
|
|
83
|
+
"url_token": "",
|
|
84
|
+
"url_user_info": "",
|
|
85
|
+
"url_check_token": "",
|
|
86
|
+
"url_refresh_token": ""
|
|
87
|
+
}
|
|
88
|
+
}
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
{
|
|
2
|
+
// 是否启用过滤, 启用过滤后, 不符合的参数会被过滤掉
|
|
3
|
+
"filter": true,
|
|
4
|
+
// 校验脚本文件, 可以使用脚本的方式加一步进行校验, 让传参更加安全
|
|
5
|
+
"func_file": "",
|
|
6
|
+
// get请求
|
|
7
|
+
"get": {
|
|
8
|
+
// 查询参数校验项
|
|
9
|
+
"query": ["client_id", "client_secret", "redirect_uri", "scope", "state", "code", "access_token",
|
|
10
|
+
"refresh_token", "openid"
|
|
11
|
+
],
|
|
12
|
+
// 查询必填参数
|
|
13
|
+
"query_required": []
|
|
14
|
+
},
|
|
15
|
+
// post请求
|
|
16
|
+
"post": {
|
|
17
|
+
// 查询参数校验项
|
|
18
|
+
"query": [],
|
|
19
|
+
// 查询必填参数
|
|
20
|
+
"query_required": [],
|
|
21
|
+
// 正文参数校验项
|
|
22
|
+
"body": ["client_id", "client_secret", "redirect_uri", "scope", "state", "code", "access_token",
|
|
23
|
+
"refresh_token", "openid"
|
|
24
|
+
],
|
|
25
|
+
// 正文必填参数
|
|
26
|
+
"body_required": []
|
|
27
|
+
},
|
|
28
|
+
// 校验列表
|
|
29
|
+
"list": [{
|
|
30
|
+
// 参数key名
|
|
31
|
+
"name": "client_id",
|
|
32
|
+
// 参数中文名
|
|
33
|
+
"title": "应用ID",
|
|
34
|
+
// 描述
|
|
35
|
+
"desction": "填写第三方的AppID",
|
|
36
|
+
// 数据类型
|
|
37
|
+
"type": "string"
|
|
38
|
+
}, {
|
|
39
|
+
// 参数key名
|
|
40
|
+
"name": "redirect_uri",
|
|
41
|
+
// 参数中文名
|
|
42
|
+
"title": "回调URL",
|
|
43
|
+
// 描述
|
|
44
|
+
"desction": "用于校验、登录成功后的回调跳转地址",
|
|
45
|
+
// 数据类型
|
|
46
|
+
"type": "string"
|
|
47
|
+
}, {
|
|
48
|
+
// 参数key名
|
|
49
|
+
"name": "scope",
|
|
50
|
+
// 参数中文名
|
|
51
|
+
"title": "授权域",
|
|
52
|
+
// 描述
|
|
53
|
+
"desction": "从第三方申请的,用户允许的授权功能范围",
|
|
54
|
+
// 数据类型
|
|
55
|
+
"type": "string"
|
|
56
|
+
}, {
|
|
57
|
+
// 参数key名
|
|
58
|
+
"name": "state",
|
|
59
|
+
// 参数中文名
|
|
60
|
+
"title": "回调状态",
|
|
61
|
+
// 描述
|
|
62
|
+
"desction": "用来校验识别是否非法操作",
|
|
63
|
+
// 数据类型
|
|
64
|
+
"type": "string"
|
|
65
|
+
}, {
|
|
66
|
+
// 参数key名
|
|
67
|
+
"name": "client_secret",
|
|
68
|
+
// 参数中文名
|
|
69
|
+
"title": "应用secret",
|
|
70
|
+
// 描述
|
|
71
|
+
"desction": "应用密钥,用来获取临时访问牌token",
|
|
72
|
+
// 数据类型
|
|
73
|
+
"type": "string"
|
|
74
|
+
}, {
|
|
75
|
+
// 参数key名
|
|
76
|
+
"name": "code",
|
|
77
|
+
// 参数中文名
|
|
78
|
+
"title": "授权访问码",
|
|
79
|
+
// 描述
|
|
80
|
+
"desction": "临时授权,用来换取临时访问牌token",
|
|
81
|
+
// 数据类型
|
|
82
|
+
"type": "string"
|
|
83
|
+
}, {
|
|
84
|
+
// 参数key名
|
|
85
|
+
"name": "access_token",
|
|
86
|
+
// 参数中文名
|
|
87
|
+
"title": "访问牌token",
|
|
88
|
+
// 描述
|
|
89
|
+
"desction": "临时访问牌,用来获取用户信息等",
|
|
90
|
+
// 数据类型
|
|
91
|
+
"type": "string"
|
|
92
|
+
}, {
|
|
93
|
+
// 参数key名
|
|
94
|
+
"name": "refresh_token",
|
|
95
|
+
// 参数中文名
|
|
96
|
+
"title": "刷新访问牌token",
|
|
97
|
+
// 描述
|
|
98
|
+
"desction": "用来刷新临时访问牌,重新获取token",
|
|
99
|
+
// 数据类型
|
|
100
|
+
"type": "string"
|
|
101
|
+
}, {
|
|
102
|
+
// 参数key名
|
|
103
|
+
"name": "openid",
|
|
104
|
+
// 参数中文名
|
|
105
|
+
"title": "用户开放ID",
|
|
106
|
+
// 描述
|
|
107
|
+
"desction": "用来识别获取用户信息",
|
|
108
|
+
// 数据类型
|
|
109
|
+
"type": "string"
|
|
110
|
+
}]
|
|
111
|
+
}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
{
|
|
2
|
+
// 路由路径
|
|
3
|
+
"path": "/api/user/password",
|
|
4
|
+
// 名称, 用于动态增删改API配置
|
|
5
|
+
"name": "user_password",
|
|
6
|
+
// 标题, 用于开发文档显示
|
|
7
|
+
"title": "修改密码",
|
|
8
|
+
// 描述, 用于介绍该路由的作用
|
|
9
|
+
"description": "描述接口使用方法",
|
|
10
|
+
// 函数文件, 用于驱动脚本, 实现业务
|
|
11
|
+
"func_file": "./index.js",
|
|
12
|
+
// 请求方法, 选填 GET, POST, ALL。 ALL指同时支持GET/POST
|
|
13
|
+
"method": "POST",
|
|
14
|
+
// 开放域, 如果域未开放, 则只有特定的协议头才能访问该API, 同时API文档不接见
|
|
15
|
+
"scope": true,
|
|
16
|
+
/* 授权协议 */
|
|
17
|
+
"oauth": {
|
|
18
|
+
// 是否需要登录, true表示需要登录才能访问该接口
|
|
19
|
+
"signIn": true
|
|
20
|
+
}
|
|
21
|
+
}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* @description 接口主函数
|
|
3
|
+
* @param {Object} ctx HTTP上下文
|
|
4
|
+
* @param {Object} db 数据管理器,如: { next: async function{}, ret: {} }
|
|
5
|
+
* @return {Object} 执行结果
|
|
6
|
+
*/
|
|
7
|
+
async function main(ctx, db) {
|
|
8
|
+
// 获取请求参数
|
|
9
|
+
var req = ctx.request;
|
|
10
|
+
var {
|
|
11
|
+
query,
|
|
12
|
+
body
|
|
13
|
+
} = req;
|
|
14
|
+
var user = ctx.session.user;
|
|
15
|
+
if (!user) {
|
|
16
|
+
var token = ctx.headers[$.dict.token];
|
|
17
|
+
if (token) {
|
|
18
|
+
user = await $.cache.get($.dict.session_id + '_' + token);
|
|
19
|
+
}
|
|
20
|
+
if (!user) {
|
|
21
|
+
return $.ret.error(10001, '账户未登录!');
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
var {
|
|
25
|
+
password_old,
|
|
26
|
+
password,
|
|
27
|
+
confirm_password,
|
|
28
|
+
ticket
|
|
29
|
+
} = body;
|
|
30
|
+
|
|
31
|
+
var db1 = db.new("user_account", "user_id");
|
|
32
|
+
var obj = await db1.getObj({
|
|
33
|
+
username: user.username
|
|
34
|
+
});
|
|
35
|
+
if (!obj) {
|
|
36
|
+
return $.ret.error(10001, '账户不存在!');
|
|
37
|
+
}
|
|
38
|
+
if (ticket) {
|
|
39
|
+
if (ticket !== user.token.md5()) {
|
|
40
|
+
return $.ret.error(10002, '身份验证失败,无法修改密码!');
|
|
41
|
+
}
|
|
42
|
+
} else {
|
|
43
|
+
var pass = (password_old + user.salt).md5();
|
|
44
|
+
if (pass !== obj.password) {
|
|
45
|
+
return $.ret.error(10002, '原密码输入错误!');
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
var password = (password + user.salt).md5();
|
|
49
|
+
var user_id = user.user_id;
|
|
50
|
+
var bl = await db1.set({
|
|
51
|
+
user_id
|
|
52
|
+
}, {
|
|
53
|
+
password
|
|
54
|
+
});
|
|
55
|
+
|
|
56
|
+
if (bl > 0) {
|
|
57
|
+
user.password = password;
|
|
58
|
+
ctx.session.user = user;
|
|
59
|
+
return $.ret.bl(true, "密码修改成功!");
|
|
60
|
+
}
|
|
61
|
+
return $.ret.bl(false, "密码修改失败!");
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
exports.main = main;
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
{
|
|
2
|
+
// 是否启用过滤, 启用过滤后, 不符合的参数会被过滤掉
|
|
3
|
+
"filter": true,
|
|
4
|
+
// get请求
|
|
5
|
+
"get": {
|
|
6
|
+
// 正文必填参数
|
|
7
|
+
"query_required": ["password_old", "password", "confirm_password"]
|
|
8
|
+
},
|
|
9
|
+
// post请求
|
|
10
|
+
"post": {
|
|
11
|
+
// 正文必填参数
|
|
12
|
+
"body_required": ["password_old", "password", "confirm_password"]
|
|
13
|
+
},
|
|
14
|
+
// 校验列表
|
|
15
|
+
"list": [
|
|
16
|
+
{
|
|
17
|
+
"name": "password",
|
|
18
|
+
"title": "密码",
|
|
19
|
+
"type": "string",
|
|
20
|
+
"string": {
|
|
21
|
+
"format": "password",
|
|
22
|
+
"different": "username",
|
|
23
|
+
"min": 6
|
|
24
|
+
}
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
"name": "confirm_password",
|
|
28
|
+
"title": "确认密码",
|
|
29
|
+
"type": "string",
|
|
30
|
+
"string": {
|
|
31
|
+
"format": "password",
|
|
32
|
+
"identical": "password"
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
{
|
|
36
|
+
"name": "password_old",
|
|
37
|
+
"title": "旧密码",
|
|
38
|
+
"type": "string",
|
|
39
|
+
"string": {
|
|
40
|
+
"format": "password",
|
|
41
|
+
"different": "password"
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
]
|
|
45
|
+
}
|