mm_os 2.8.0 → 2.8.2
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/core/com/param/drive.js +5 -4
- package/demo/app/dev/README.md +1 -0
- package/demo/app/dev/app.js +149 -0
- package/demo/app/dev/app.json +12 -0
- package/demo/app/dev/event_api/client/event.json +11 -0
- package/demo/app/dev/event_api/client/main.js +19 -0
- package/demo/app/dev/event_api/manage/event.json +19 -0
- package/demo/app/dev/event_api/manage/main.js +26 -0
- package/demo/app/dev/plugin/doc/static/api_list.html +144 -0
- package/demo/app/dev/plugin/doc/static/api_view.html +692 -0
- package/demo/app/dev/plugin/doc/static/index.html +138 -0
- package/demo/app/dev/plugin/doc/static/request_test.html +311 -0
- package/demo/app/dev/plugin/main/api_dev_client/api/api.json +11 -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/app/api.json +13 -0
- package/demo/app/dev/plugin/main/api_dev_client/app/index.js +13 -0
- package/demo/app/dev/plugin/main/api_dev_client/app/param.json +147 -0
- package/demo/app/dev/plugin/main/api_dev_client/app/sql.json +28 -0
- package/demo/app/dev/plugin/main/api_dev_client/auto/api.json +37 -0
- package/demo/app/dev/plugin/main/api_dev_client/auto/auto_db.js +70 -0
- package/demo/app/dev/plugin/main/api_dev_client/auto/auto_file.js +32 -0
- package/demo/app/dev/plugin/main/api_dev_client/auto/index.js +51 -0
- package/demo/app/dev/plugin/main/api_dev_client/auto/param.json +51 -0
- package/demo/app/dev/plugin/main/api_dev_client/com.js +349 -0
- package/demo/app/dev/plugin/main/api_dev_client/db/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/db/index.js +71 -0
- package/demo/app/dev/plugin/main/api_dev_client/db/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/dict/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/dict/index.js +49 -0
- package/demo/app/dev/plugin/main/api_dev_client/dict/param.json +29 -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/dev/plugin/main/api_dev_client/help/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/help/index.js +14 -0
- package/demo/app/dev/plugin/main/api_dev_client/help/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/nav/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/nav/index.js +36 -0
- package/demo/app/dev/plugin/main/api_dev_client/nav/param.json +36 -0
- package/demo/app/dev/plugin/main/api_dev_client/plugin/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/plugin/index.js +13 -0
- package/demo/app/dev/plugin/main/api_dev_client/plugin/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/source/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/source/index.js +14 -0
- package/demo/app/dev/plugin/main/api_dev_client/source/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/sql/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/sql/index.js +13 -0
- package/demo/app/dev/plugin/main/api_dev_client/sql/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/task/api.json +16 -0
- package/demo/app/dev/plugin/main/api_dev_client/task/index.js +13 -0
- package/demo/app/dev/plugin/main/api_dev_client/task/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/translate/api.json +39 -0
- package/demo/app/dev/plugin/main/api_dev_client/translate/index.js +43 -0
- package/demo/app/dev/plugin/main/api_dev_client/translate/param.json +130 -0
- package/demo/app/dev/plugin/main/api_dev_client/translate/sql.json +62 -0
- package/demo/app/dev/plugin/main/api_dev_client/ui/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/ui/index.js +146 -0
- package/demo/app/dev/plugin/main/api_dev_client/ui/param.json +31 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/api.json +10 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/index.js +100 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/param.json +29 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/block/nav.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/block/obj.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/block/post.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/block/query.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/page/edit.vue +39 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/page/list.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/page/search.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/page/table.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/page/type.vue +12 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/page/view.vue +56 -0
- package/demo/app/dev/plugin/main/api_dev_client/view/tpl/view.json +48 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/api.json +37 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/auto_db.js +120 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/copy/copy.js +101 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/copy/copy_framework.js +118 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/copy/copy_template.js +78 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/copy_file.js +97 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/common.js +198 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/django_server.js +104 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/helper.js +161 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/koa_art_server.js +102 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/mini_app_home.js +415 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/razor.js +0 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/springboot.js +0 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/thinkphp.js +0 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/uni_app_home.js +418 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/vue_cli_admin.js +78 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create/vue_cli_home.js +112 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/create_file.js +97 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/db/add_data.js +221 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/db/create_table.js +162 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/db/set_auth_table.js +86 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/index.js +524 -0
- package/demo/app/dev/plugin/main/api_dev_manage/auto_subject/param.json +37 -0
- package/demo/app/route/app.js +131 -0
- package/demo/app/route/app.json +11 -0
- package/demo/app/route/event_api/client/event.json +10 -0
- package/demo/app/route/event_api/client/main.js +19 -0
- package/demo/app/route/event_api/manage/event.json +18 -0
- package/demo/app/route/event_api/manage/main.js +70 -0
- package/demo/app/route/plugin/main/api_route_client/pass/api.json +37 -0
- package/demo/app/route/plugin/main/api_route_client/pass/index.js +33 -0
- package/demo/app/route/plugin/main/api_route_client/pass/param.json +50 -0
- package/demo/app/route/plugin/main/index.js +144 -0
- package/demo/app/route/plugin/main/plugin.json +20 -0
- package/demo/app/sys/app.js +169 -0
- package/demo/app/sys/app.json +11 -0
- package/demo/app/sys/event_api/api/before.js +80 -0
- package/demo/app/sys/event_api/api/check.js +103 -0
- package/demo/app/sys/event_api/api/event.json +31 -0
- package/demo/app/sys/event_api/api/main.js +19 -0
- package/demo/app/sys/event_api/apis/before.js +80 -0
- package/demo/app/sys/event_api/apis/event.json +21 -0
- package/demo/app/sys/event_api/apis/main.js +19 -0
- package/demo/app/sys/event_api/client/event.json +10 -0
- package/demo/app/sys/event_api/client/main.js +17 -0
- package/demo/app/sys/event_api/doc/event.json +18 -0
- package/demo/app/sys/event_api/doc/main.js +67 -0
- package/demo/app/sys/event_api/img/event.json +11 -0
- package/demo/app/sys/event_api/img/main.js +90 -0
- package/demo/app/sys/event_api/manage/event.json +10 -0
- package/demo/app/sys/event_api/manage/main.js +19 -0
- package/demo/app/sys/event_api/upload/event.json +10 -0
- package/demo/app/sys/event_api/upload/main.js +17 -0
- package/demo/app/sys/plugin/app_admin/index.js +127 -0
- package/demo/app/sys/plugin/app_admin/plugin.json +20 -0
- package/demo/app/sys/plugin/main/api_client/config/api.json +39 -0
- package/demo/app/sys/plugin/main/api_client/config/index.js +37 -0
- package/demo/app/sys/plugin/main/api_client/config/param.json +27 -0
- package/demo/app/sys/plugin/main/api_client/config/sql.json +70 -0
- package/demo/app/sys/plugin/main/api_client/lang/api.json +37 -0
- package/demo/app/sys/plugin/main/api_client/lang/index.js +27 -0
- package/demo/app/sys/plugin/main/api_client/lang/param.json +22 -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 +39 -0
- package/demo/app/sys/plugin/main/api_client/nav/param.json +87 -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/translate/api.json +39 -0
- package/demo/app/sys/plugin/main/api_client/translate/index.js +21 -0
- package/demo/app/sys/plugin/main/api_client/translate/param.json +130 -0
- package/demo/app/sys/plugin/main/api_client/translate/sql.json +62 -0
- package/demo/app/sys/plugin/main/api_upload/image/api.json +15 -0
- package/demo/app/sys/plugin/main/api_upload/image/index.js +62 -0
- package/demo/app/sys/plugin/main/api_upload/image/param.json +9 -0
- package/demo/app/sys/plugin/main/task/task_demo/index.js +37 -0
- package/demo/app/sys/plugin/main/task/task_demo/task.json +24 -0
- package/demo/app/sys/plugin/user/index.js +127 -0
- package/demo/app/sys/plugin/user/plugin.json +20 -0
- package/demo/app/sys/plugin/user/static/img/logo.png +0 -0
- package/demo/app/sys/static/img/avatar_1674484608066.png +0 -0
- package/demo/app/sys/static/img/avatar_1674633778171.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1674962702334.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1675075431736.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1675497065533.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685352550990.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685353685992.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685353956587.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685353971148.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685353983723.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685354014745.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685354122355.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685357983520.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685358453383.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685416570438.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685512675830.png +0 -0
- package/demo/app/sys/static/img/avatar_1685939425608.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1685939886560.jpeg +0 -0
- package/demo/app/sys/static/img/avatar_1686106313194.png +0 -0
- package/demo/app/sys/static/img/avatar_1686371876175.png +0 -0
- package/demo/app/sys/static/img/avatar_1686372033596.png +0 -0
- package/demo/app/sys/static/img/avatar_1688215220669.png +0 -0
- package/demo/app/sys/static/img/avatar_1688531184690.png +0 -0
- package/demo/app/sys/static/img/avatar_1688531233080.png +0 -0
- package/demo/app/sys/static/img/avatar_1688548526909.png +0 -0
- package/demo/app/sys/static/img/avatar_1688549213411.png +0 -0
- package/demo/app/sys/static/img/avatar_1688549511977.png +0 -0
- package/demo/app/sys/static/img/avatar_1688549685464.png +0 -0
- package/demo/app/sys/static/img/avatar_1688608623049.png +0 -0
- package/demo/app/sys/static/img/avatar_1688638500476.png +0 -0
- package/demo/app/sys/static/img/avatar_1688638515195.png +0 -0
- package/demo/app/sys/static/img/avatar_1688638539928.png +0 -0
- package/demo/app/sys/static/img/avatar_1688638557960.png +0 -0
- package/demo/app/sys/static/img/avatar_1688638761798.png +0 -0
- package/demo/app/sys/static/img/avatar_1688638943140.png +0 -0
- package/demo/app/sys/static/img/avatar_1688639068330.png +0 -0
- package/demo/app/sys/static/img/image_1685357101273.jpeg +0 -0
- package/demo/app/sys/static/img/logo.png +0 -0
- package/demo/app/user/app.js +148 -0
- package/demo/app/user/app.json +11 -0
- package/demo/app/user/event_api/client/event.json +10 -0
- package/demo/app/user/event_api/client/main.js +18 -0
- package/demo/app/user/event_api/manage/event.json +10 -0
- package/demo/app/user/event_api/manage/main.js +19 -0
- package/demo/app/user/plugin/main/api_user_client/account/api.json +39 -0
- package/demo/app/user/plugin/main/api_user_client/account/index.js +53 -0
- package/demo/app/user/plugin/main/api_user_client/account/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 +84 -0
- package/demo/app/user/plugin/main/api_user_client/base/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_client/core/api.json +20 -0
- package/demo/app/user/plugin/main/api_user_client/core/forgot.js +14 -0
- package/demo/app/user/plugin/main/api_user_client/core/password.js +14 -0
- package/demo/app/user/plugin/main/api_user_client/core/sign_out.js +26 -0
- package/demo/app/user/plugin/main/api_user_client/core/state.js +21 -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 +40 -0
- package/demo/app/user/plugin/main/api_user_client/count/param.json +40 -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 - /345/211/257/346/234/254.jsbat" +41 -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 +56 -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 +270 -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 +56 -0
- package/demo/app/user/plugin/main/api_user_client/password/param.json +44 -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/index.js_ +230 -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 +278 -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 +48 -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 +101 -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 +47 -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 +49 -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 +67 -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 +275 -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_up/api.json +12 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up/index.js +110 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up/param.json +65 -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 +110 -0
- package/demo/app/user/plugin/main/api_user_client/sign_up_in/param.json +34 -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_manage/account_base/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_manage/account_base/index.js +40 -0
- package/demo/app/user/plugin/main/api_user_manage/account_base/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_manage/invitation_code/api.json +37 -0
- package/demo/app/user/plugin/main/api_user_manage/invitation_code/index.js +106 -0
- package/demo/app/user/plugin/main/api_user_manage/invitation_code/param.json +130 -0
- package/demo/app/user/plugin/main/api_user_manage/update_team/api.json +35 -0
- package/demo/app/user/plugin/main/api_user_manage/update_team/index.js +218 -0
- package/demo/app/user/plugin/main/api_user_manage/update_team/param.json +130 -0
- package/demo/app/user/static/img/logo.png +0 -0
- package/demo/app/ws/app.js +122 -0
- package/demo/app/ws/app.json +11 -0
- package/demo/app/ws/event_api/client/event.json +10 -0
- package/demo/app/ws/event_api/client/main.js +17 -0
- package/demo/app/ws/socket/ws/index.js +43 -0
- package/demo/app/ws/socket/ws/socket.json +14 -0
- package/demo/config/development.json +95 -0
- package/demo/config/face.sql +3824 -0
- package/demo/config/local.json +80 -0
- package/demo/index.js +19 -0
- package/package.json +59 -58
- package/cache/test/main/config.json +0 -7
|
@@ -0,0 +1,270 @@
|
|
|
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
|
+
"open_id": "open_id",
|
|
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
|
+
var db1 = db.new("user_account", "user_id");
|
|
81
|
+
var user = await db1.getObj({
|
|
82
|
+
phone
|
|
83
|
+
});
|
|
84
|
+
if (!user) {
|
|
85
|
+
var len = phone.length;
|
|
86
|
+
var p = phone.substring(len - 6, len).md5();
|
|
87
|
+
var salt = p.substring(0, 6);
|
|
88
|
+
var password = (p + salt).md5();
|
|
89
|
+
var username = phone;
|
|
90
|
+
var invite_code = (username + password).md5().substring(0, 6);
|
|
91
|
+
|
|
92
|
+
await db1.add({
|
|
93
|
+
username,
|
|
94
|
+
salt,
|
|
95
|
+
password,
|
|
96
|
+
phone,
|
|
97
|
+
invite_code,
|
|
98
|
+
wallet_address: phone
|
|
99
|
+
});
|
|
100
|
+
// console.log("注册账户", db1.error);
|
|
101
|
+
user = await db1.getObj({
|
|
102
|
+
phone
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
if (!user) {
|
|
106
|
+
return $.ret.error(10000, "创建用户失败!");
|
|
107
|
+
}
|
|
108
|
+
user.nickname = nickName;
|
|
109
|
+
user.avatar = avatarUrl;
|
|
110
|
+
|
|
111
|
+
var db2 = db.new("user_info", "user_id");
|
|
112
|
+
|
|
113
|
+
var user_id = user.user_id;
|
|
114
|
+
info = await db2.getObj({
|
|
115
|
+
user_id
|
|
116
|
+
});
|
|
117
|
+
if (!info) {
|
|
118
|
+
await db2.add({
|
|
119
|
+
user_id,
|
|
120
|
+
city,
|
|
121
|
+
country,
|
|
122
|
+
province
|
|
123
|
+
});
|
|
124
|
+
info = await db2.getObj({
|
|
125
|
+
user_id
|
|
126
|
+
});
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
var u = Object.assign({}, user);
|
|
130
|
+
delete u.password;
|
|
131
|
+
delete u.salt;
|
|
132
|
+
delete u.time_create;
|
|
133
|
+
ctx.session.user = user;
|
|
134
|
+
var ip = ctx.ip.replace('::ffff:', '');
|
|
135
|
+
// var user = Object.assign({}, u);
|
|
136
|
+
// 自动生成的uuid是通过IP和浏览器信息加密而成,如果需要解密确认其身份,可再加上user_id加密,自行生成uuid
|
|
137
|
+
var ret = $.ret.body({
|
|
138
|
+
token: ctx.session.uuid,
|
|
139
|
+
user,
|
|
140
|
+
ip
|
|
141
|
+
});
|
|
142
|
+
var userInfo = {
|
|
143
|
+
nickName,
|
|
144
|
+
city,
|
|
145
|
+
province,
|
|
146
|
+
country,
|
|
147
|
+
avatarUrl
|
|
148
|
+
};
|
|
149
|
+
var params = {
|
|
150
|
+
open_id: openid,
|
|
151
|
+
info: JSON.stringify(userInfo)
|
|
152
|
+
};
|
|
153
|
+
$.bind_account(db, params, user);
|
|
154
|
+
// $.log.debug('入场', body);
|
|
155
|
+
return ret
|
|
156
|
+
};
|
|
157
|
+
|
|
158
|
+
/**
|
|
159
|
+
* 解绑链接
|
|
160
|
+
*/
|
|
161
|
+
Oauth.prototype.unbind = async function(db, ctx, config) {
|
|
162
|
+
|
|
163
|
+
};
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* 1.通过code换取token
|
|
167
|
+
* @param {Object} req 查询参数
|
|
168
|
+
* @param {Object} db
|
|
169
|
+
* @param {Object} config
|
|
170
|
+
*/
|
|
171
|
+
Oauth.prototype.code_to_token = async function(db, ctx, config) {
|
|
172
|
+
var ret;
|
|
173
|
+
var req = ctx.request;
|
|
174
|
+
// req里面需传code和appid两个参数
|
|
175
|
+
var d = config.dict;
|
|
176
|
+
var query = req.query;
|
|
177
|
+
var code = query[d.code];
|
|
178
|
+
var appid = query[d.client_id];
|
|
179
|
+
db.table = config.name.replace("_mini", "") + "_app";
|
|
180
|
+
// console.log(d.code,code,d.client_id,appid);
|
|
181
|
+
var qy = {};
|
|
182
|
+
qy[d.client_id] = appid;
|
|
183
|
+
var obj = await db.getObj(qy);
|
|
184
|
+
if (!obj) {
|
|
185
|
+
return $.ret.error(60000, d.client_id + ":" + appid + "不存在!");
|
|
186
|
+
}
|
|
187
|
+
var url = config.url_token.replace("{client_id}", appid).replace("{code}", code).replace("{client_secret}",
|
|
188
|
+
obj[d.client_secret]);
|
|
189
|
+
var http = new $.Http();
|
|
190
|
+
var html = await http.get(url);
|
|
191
|
+
if (html.body) {
|
|
192
|
+
var json = html.body.toJson();
|
|
193
|
+
if (json.errcode && json.errmsg) {
|
|
194
|
+
return $.ret.error(30000, json.errmsg)
|
|
195
|
+
}
|
|
196
|
+
if (json[d.open_id]) {
|
|
197
|
+
if (obj.type == "小程序") {
|
|
198
|
+
db.table = "wechat_info";
|
|
199
|
+
var user_info = await db.getObj({
|
|
200
|
+
open_id: json[d.open_id]
|
|
201
|
+
});
|
|
202
|
+
if (user_info) {
|
|
203
|
+
var user_id = user_info.user_id;
|
|
204
|
+
db.table = "user_account";
|
|
205
|
+
var user = await db.getObj({
|
|
206
|
+
user_id
|
|
207
|
+
});
|
|
208
|
+
user.open_id = json[d.open_id];
|
|
209
|
+
user.token = ctx.session.uuid;
|
|
210
|
+
ctx.session.user = user;
|
|
211
|
+
return $.ret.body(user);
|
|
212
|
+
} else {
|
|
213
|
+
return $.ret.body(json);
|
|
214
|
+
}
|
|
215
|
+
} else {
|
|
216
|
+
url = config.url_user_info.replace("{access_token}", json[d.access_token]).replace("{open_id}",
|
|
217
|
+
json[d.open_id]);
|
|
218
|
+
html = await http.get(url);
|
|
219
|
+
if (html.body) {
|
|
220
|
+
var users = html.body.toJson();
|
|
221
|
+
db.table = "wechat_info";
|
|
222
|
+
db.key = "info_id";
|
|
223
|
+
qy = {};
|
|
224
|
+
qy["open_id"] = json[d.open_id];
|
|
225
|
+
user = await db.getObj(qy);
|
|
226
|
+
if (!user) {
|
|
227
|
+
var body = {};
|
|
228
|
+
body["open_id"] = json[d.open_id];
|
|
229
|
+
await db.add(body);
|
|
230
|
+
user = await db.getObj(qy);
|
|
231
|
+
}
|
|
232
|
+
if (user) {
|
|
233
|
+
user[d.access_token] = json[d.access_token];
|
|
234
|
+
user[d.refresh_token] = json[d.refresh_token];
|
|
235
|
+
user.info = JSON.stringify(users);
|
|
236
|
+
body = Object.assign({}, user, json, users);
|
|
237
|
+
delete body.info;
|
|
238
|
+
ret = $.ret.body(body);
|
|
239
|
+
}
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
}
|
|
244
|
+
return ret;
|
|
245
|
+
};
|
|
246
|
+
|
|
247
|
+
/**
|
|
248
|
+
* 运行
|
|
249
|
+
*/
|
|
250
|
+
Oauth.prototype.run = async function(db, ctx) {
|
|
251
|
+
var req = ctx.request;
|
|
252
|
+
var path = req.path;
|
|
253
|
+
var dict = this.config;
|
|
254
|
+
var ret = {};
|
|
255
|
+
for (var k in dict) {
|
|
256
|
+
var p = "/api/user/oauth/" + k + "/";
|
|
257
|
+
if (path.indexOf(p) === 0) {
|
|
258
|
+
var fun_name = path.replace(p, '');
|
|
259
|
+
if (this[fun_name]) {
|
|
260
|
+
// console.log("有此路径", fun_name);
|
|
261
|
+
dict[k].name = k;
|
|
262
|
+
ret = await this[fun_name](db, ctx, this.model(dict[k]));
|
|
263
|
+
break;
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
return ret;
|
|
268
|
+
};
|
|
269
|
+
|
|
270
|
+
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={open_id}&lang=zh_CN",
|
|
10
|
+
"url_check_token": "https://api.weixin.qq.com/sns/auth?access_token={access_token}&openid={open_id}",
|
|
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
|
+
"open_id": "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={open_id}&lang=zh_CN",
|
|
26
|
+
"url_check_token": "https://api.weixin.qq.com/sns/auth?access_token={access_token}&openid={open_id}",
|
|
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
|
+
"open_id": "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={open_id}",
|
|
41
|
+
"url_check_token": "https://graph.qq.com/user/get_user_info?access_token{access_token}&oauth_consumer_key={client_id}&openid={open_id}&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
|
+
"open_id": "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
|
+
"open_id": "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", "open_id"
|
|
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", "open_id"
|
|
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": "open_id",
|
|
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,56 @@
|
|
|
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
|
+
// 获取请求参数
|
|
10
|
+
var req = ctx.request;
|
|
11
|
+
var {
|
|
12
|
+
query,
|
|
13
|
+
body
|
|
14
|
+
} = req;
|
|
15
|
+
var user = ctx.session.user;
|
|
16
|
+
if(!user){
|
|
17
|
+
var token = ctx.headers[$.dict.token];
|
|
18
|
+
if (token) {
|
|
19
|
+
user = await $.cache.get($.dict.session_id + '_' + token);
|
|
20
|
+
}
|
|
21
|
+
if(!user){
|
|
22
|
+
return $.ret.error(10001, '账户未登录!');
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
var {
|
|
26
|
+
password_old,
|
|
27
|
+
password,
|
|
28
|
+
confirm_password
|
|
29
|
+
} = body;
|
|
30
|
+
|
|
31
|
+
var db1 = db.new("user_account", "user_id");
|
|
32
|
+
var obj = await db1.getObj({ username: user.username });
|
|
33
|
+
if (!obj) {
|
|
34
|
+
return $.ret.error(10001, '账户不存在!');
|
|
35
|
+
}
|
|
36
|
+
var pass = (password_old + user.salt).md5();
|
|
37
|
+
if(pass !== obj.password){
|
|
38
|
+
return $.ret.error(10002, '原密码输入错误!');
|
|
39
|
+
}
|
|
40
|
+
var password = (password + user.salt).md5();
|
|
41
|
+
var user_id = user.user_id;
|
|
42
|
+
var bl = await db1.set({
|
|
43
|
+
user_id
|
|
44
|
+
}, {
|
|
45
|
+
password
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
if (bl > 0) {
|
|
49
|
+
user.password = password;
|
|
50
|
+
ctx.session.user = user;
|
|
51
|
+
return $.ret.bl(true, "密码修改成功!");
|
|
52
|
+
}
|
|
53
|
+
return $.ret.bl(false, "密码修改失败!");
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
exports.main = main;
|
|
@@ -0,0 +1,44 @@
|
|
|
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
|
+
}
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
"name": "confirm_password",
|
|
27
|
+
"title": "确认密码",
|
|
28
|
+
"type": "string",
|
|
29
|
+
"string": {
|
|
30
|
+
"format": "password",
|
|
31
|
+
"identical": "password"
|
|
32
|
+
}
|
|
33
|
+
},
|
|
34
|
+
{
|
|
35
|
+
"name": "password_old",
|
|
36
|
+
"title": "旧密码",
|
|
37
|
+
"type": "string",
|
|
38
|
+
"string": {
|
|
39
|
+
"format": "password",
|
|
40
|
+
"different": "password"
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
]
|
|
44
|
+
}
|