├── .prettierignore ├── src ├── redux │ ├── middleware │ │ ├── index.js │ │ └── logger.js │ ├── reducers │ │ ├── user │ │ │ ├── index.js │ │ │ └── userList.js │ │ ├── home │ │ │ ├── index.js │ │ │ ├── login.js │ │ │ └── register.js │ │ └── index.js │ ├── store │ │ └── configureStore.js │ └── actions │ │ ├── User.js │ │ └── Home.js ├── index.css ├── components │ ├── Login │ │ ├── cool-background.png │ │ ├── form.module.css │ │ ├── Login.js │ │ └── Register.js │ └── UserList.js ├── App.module.css ├── index.js ├── App.test.js ├── constants │ ├── ConstTypes.js │ └── ActionTypes.js ├── containers │ ├── User │ │ └── UserList.js │ └── Home │ │ ├── Login.js │ │ └── Register.js ├── App.js ├── common │ └── NotFound │ │ ├── NotFound.js │ │ └── NotFound.css ├── routes │ └── index.js ├── api │ └── http.js └── registerServiceWorker.js ├── public ├── favicon.ico ├── manifest.json └── index.html ├── .prettierrc ├── server ├── db │ ├── config │ │ ├── config.js │ │ └── mongoose.js │ ├── models │ │ └── UserModel.js │ ├── README.md │ └── schemas │ │ └── UserSchema.js ├── constant │ └── constant.js ├── routes │ ├── jwt.js │ ├── index.js │ └── user.js ├── package.json ├── server.js └── yarn.lock ├── .eslintrc ├── .gitignore ├── config-overrides.js ├── LICENSE ├── README.md └── package.json /.prettierignore: -------------------------------------------------------------------------------- 1 | node_modules/ 2 | build/ 3 | public/ -------------------------------------------------------------------------------- /src/redux/middleware/index.js: -------------------------------------------------------------------------------- 1 | import logger from './logger'; 2 | 3 | export { logger }; 4 | -------------------------------------------------------------------------------- /src/index.css: -------------------------------------------------------------------------------- 1 | body { 2 | margin: 0; 3 | padding: 0; 4 | font-family: sans-serif; 5 | } 6 | -------------------------------------------------------------------------------- /public/favicon.ico: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/luffyZh/express-react-scaffold/HEAD/public/favicon.ico -------------------------------------------------------------------------------- /src/redux/middleware/logger.js: -------------------------------------------------------------------------------- 1 | import logger from 'redux-logger'; 2 | 3 | export default logger; 4 | -------------------------------------------------------------------------------- /.prettierrc: -------------------------------------------------------------------------------- 1 | { 2 | "semi": true, 3 | "singleQuote": true, 4 | "tabWidth": 2, 5 | "trailingComma": "none", 6 | "printWidth": 80 7 | } 8 | -------------------------------------------------------------------------------- /src/components/Login/cool-background.png: -------------------------------------------------------------------------------- https://raw.githubusercontent.com/luffyZh/express-react-scaffold/HEAD/src/components/Login/cool-background.png -------------------------------------------------------------------------------- /server/db/config/config.js: -------------------------------------------------------------------------------- 1 | // 数据库地址: 'mongodb://用户名:密码@ip地址:端口号/数据库'; 2 | // 一般如果没设置用户名和密码直接写IP地址就可以,数据库你可以新建一个 3 | module.exports = { 4 | mongodb: 'mongodb://127.0.0.1:27017/luffy_blog' 5 | }; 6 | -------------------------------------------------------------------------------- /src/redux/reducers/user/index.js: -------------------------------------------------------------------------------- 1 | import { combineReducers } from 'redux'; 2 | import userList from './userList'; 3 | 4 | const user = combineReducers({ 5 | userList 6 | }); 7 | 8 | export default user; 9 | -------------------------------------------------------------------------------- /src/App.module.css: -------------------------------------------------------------------------------- 1 | .App { 2 | text-align: center; 3 | } 4 | 5 | .AppHeader { 6 | background-color: #00BFFF; 7 | height: 150px; 8 | padding: 20px; 9 | color: white; 10 | } 11 | 12 | .AppTitle { 13 | font-size: 1.5em; 14 | } -------------------------------------------------------------------------------- /server/db/models/UserModel.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const UserSchema = require('../schemas/UserSchema'); 3 | //创建model,这个地方的user对应mongodb数据库中users的conllection。 4 | const User = mongoose.model('user', UserSchema); 5 | module.exports = User; 6 | -------------------------------------------------------------------------------- /server/db/README.md: -------------------------------------------------------------------------------- 1 | ### config文件夹 2 | #### 用于配置mongodb的文件夹 3 | #### config.js用于配置本机的MongoDB链接地址 4 | #### mongoose.js用于连接MongoDB数据库并且建立Schema和Model 5 | 6 | ### schemas文件夹 7 | #### schema.js用于定义各种Schema 8 | 9 | ### model文件夹 10 | #### model.js用于定义各种Model 11 | -------------------------------------------------------------------------------- /src/redux/reducers/home/index.js: -------------------------------------------------------------------------------- 1 | import { combineReducers } from 'redux'; 2 | import login from './login'; 3 | import register from './register'; 4 | 5 | const home = combineReducers({ 6 | login, 7 | register 8 | }); 9 | 10 | export default home; 11 | -------------------------------------------------------------------------------- /src/redux/reducers/index.js: -------------------------------------------------------------------------------- 1 | import { combineReducers } from 'redux'; 2 | import user from './user/index'; 3 | import home from './home/index'; 4 | 5 | const rootReducer = combineReducers({ 6 | home, 7 | user 8 | }); 9 | 10 | export default rootReducer; 11 | -------------------------------------------------------------------------------- /src/index.js: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactDOM from 'react-dom'; 3 | import RootRouter from './routes/index'; 4 | import registerServiceWorker from './registerServiceWorker'; 5 | 6 | ReactDOM.render(, document.getElementById('root')); 7 | registerServiceWorker(); 8 | -------------------------------------------------------------------------------- /server/db/schemas/UserSchema.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose'); 2 | const Schema = mongoose.Schema; 3 | //创建Schema 4 | const UserSchema = new Schema({ 5 | username: String, 6 | password: String, 7 | email: String, 8 | role: Number 9 | }); 10 | module.exports = UserSchema; 11 | -------------------------------------------------------------------------------- /src/App.test.js: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import ReactDOM from 'react-dom'; 3 | import App from './App'; 4 | 5 | it('renders without crashing', () => { 6 | const div = document.createElement('div'); 7 | ReactDOM.render(, div); 8 | ReactDOM.unmountComponentAtNode(div); 9 | }); 10 | -------------------------------------------------------------------------------- /src/constants/ConstTypes.js: -------------------------------------------------------------------------------- 1 | // 所有操作的状态值 2 | export const OperationStatus = { 3 | initial: 'initial', 4 | loading: 'loading', 5 | load_success: 'load_success', 6 | load_fail: 'load_fail', 7 | editing: 'editing', 8 | saving: 'saving', 9 | save_success: 'save_success', 10 | save_fail: 'save_fail' 11 | }; 12 | -------------------------------------------------------------------------------- /server/constant/constant.js: -------------------------------------------------------------------------------- 1 | const crypto = require('crypto'); 2 | 3 | module.exports = { 4 | MD5_SUFFIX: 'luffyZhouNodeCrawler我是一个固定长度的盐值', 5 | md5: pwd => { 6 | let md5 = crypto.createHash('md5'); 7 | return md5.update(pwd).digest('hex'); 8 | }, 9 | secretKey: 'luffy_youdao_1993711_26_jwttoken' 10 | }; 11 | -------------------------------------------------------------------------------- /server/routes/jwt.js: -------------------------------------------------------------------------------- 1 | const expressJwt = require('express-jwt'); 2 | const { secretKey } = require('../constant/constant'); 3 | 4 | const jwtAuth = expressJwt({ 5 | secret: secretKey, 6 | credentialsRequired: true // 设置为false就不进行校验了,游客也可以访问 7 | }).unless({ 8 | path: ['/api/user/login', '/api/user/register'] 9 | }); 10 | 11 | module.exports = jwtAuth; 12 | -------------------------------------------------------------------------------- /public/manifest.json: -------------------------------------------------------------------------------- 1 | { 2 | "short_name": "React App", 3 | "name": "Create React App Sample", 4 | "icons": [ 5 | { 6 | "src": "favicon.ico", 7 | "sizes": "64x64 32x32 24x24 16x16", 8 | "type": "image/x-icon" 9 | } 10 | ], 11 | "start_url": "./index.html", 12 | "display": "standalone", 13 | "theme_color": "#000000", 14 | "background_color": "#ffffff" 15 | } 16 | -------------------------------------------------------------------------------- /.eslintrc: -------------------------------------------------------------------------------- 1 | { 2 | "parser": "babel-eslint", 3 | "parserOptions": { 4 | "ecmaVersion": 6, 5 | "sourceType": "module", 6 | "ecmaFeatures": { 7 | "jsx": true 8 | } 9 | }, 10 | "env": { 11 | "browser": true, 12 | "node": true 13 | }, 14 | "rules": { 15 | "semi": 2, 16 | "no-unused-vars": "off" 17 | } 18 | } -------------------------------------------------------------------------------- /.gitignore: -------------------------------------------------------------------------------- 1 | # See https://help.github.com/ignore-files/ for more about ignoring files. 2 | 3 | # dependencies 4 | /node_modules 5 | /server/node_modules 6 | 7 | # testing 8 | /coverage 9 | 10 | # production 11 | /build 12 | 13 | # misc 14 | .DS_Store 15 | .env.local 16 | .env.development.local 17 | .env.test.local 18 | .env.production.local 19 | 20 | npm-debug.log* 21 | yarn-debug.log* 22 | yarn-error.log* 23 | 24 | .idea 25 | -------------------------------------------------------------------------------- /server/db/config/mongoose.js: -------------------------------------------------------------------------------- 1 | // 用于连接数据库并且定义Schema和Model 2 | const mongoose = require('mongoose'); 3 | const config = require('./config'); 4 | module.exports = () => { 5 | mongoose.connect(config.mongodb); //连接mongodb数据库 6 | // 实例化连接对象 7 | var db = mongoose.connection; 8 | db.on('error', console.error.bind(console, '连接错误:')); 9 | db.once('open', callback => { 10 | console.log('MongoDB连接成功!!'); 11 | }); 12 | return db; 13 | }; 14 | -------------------------------------------------------------------------------- /src/containers/User/UserList.js: -------------------------------------------------------------------------------- 1 | import { connect } from 'react-redux'; 2 | import UserList from '../../components/UserList'; 3 | import { fetchAllUserList } from '../../redux/actions/User'; 4 | 5 | const mapStateToProps = state => ({ 6 | list: state.user.userList.list 7 | }); 8 | 9 | const mapDispatchToProps = dispatch => ({ 10 | fetchAllUserList() { 11 | dispatch(fetchAllUserList()); 12 | } 13 | }); 14 | 15 | export default connect( 16 | mapStateToProps, 17 | mapDispatchToProps 18 | )(UserList); 19 | -------------------------------------------------------------------------------- /src/containers/Home/Login.js: -------------------------------------------------------------------------------- 1 | import { connect } from 'react-redux'; 2 | import Login from '../../components/Login/Login'; 3 | import { postUserLogin, resetLoginStatus } from '../../redux/actions/Home'; 4 | 5 | const mapStateToProps = state => ({ 6 | loginMsg: state.home.login.loginMsg, 7 | status: state.home.login.status 8 | }); 9 | 10 | const mapDispatchToProps = dispatch => ({ 11 | postUserLogin(postData) { 12 | dispatch(postUserLogin(postData)); 13 | }, 14 | resetLoginStatus() { 15 | dispatch(resetLoginStatus()); 16 | } 17 | }); 18 | 19 | export default connect( 20 | mapStateToProps, 21 | mapDispatchToProps 22 | )(Login); 23 | -------------------------------------------------------------------------------- /server/package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "description": "server config", 5 | "main": "server.js", 6 | "author": "luffy", 7 | "license": "MIT", 8 | "dependencies": { 9 | "babel-cli": "^6.26.0", 10 | "babel-preset-es2015": "^6.24.1", 11 | "body-parser": "^1.18.2", 12 | "crypto": "^1.0.1", 13 | "express": "^4.16.3", 14 | "express-jwt": "^5.3.1", 15 | "jsonwebtoken": "^8.2.1", 16 | "mongoose": "^5.0.16", 17 | "morgan": "^1.9.0" 18 | }, 19 | "scripts": { 20 | "start": "nodemon ./server.js", 21 | "build": "babel ./server.js --out-file server-compiled.js", 22 | "serve": "node server-compiled.js" 23 | } 24 | } 25 | -------------------------------------------------------------------------------- /config-overrides.js: -------------------------------------------------------------------------------- 1 | /* config-overrides.js */ 2 | const { injectBabelPlugin } = require('react-app-rewired'); 3 | const rewireLess = require('react-app-rewire-less'); 4 | const rewireCssModules = require('react-app-rewire-css-modules'); 5 | 6 | module.exports = function override(config, env) { 7 | config = injectBabelPlugin( 8 | ['import', { libraryName: 'antd', style: true }], 9 | config 10 | ); 11 | config = rewireCssModules(config, env); 12 | config = rewireLess.withLoaderOptions({ 13 | modifyVars: { 14 | '@primary-color': '#00BFFF', 15 | '@input-height-base': '40px', 16 | '@btn-height-base': '40px' 17 | } 18 | })(config, env); 19 | return config; 20 | }; 21 | -------------------------------------------------------------------------------- /src/containers/Home/Register.js: -------------------------------------------------------------------------------- 1 | import { connect } from 'react-redux'; 2 | import Register from '../../components/Login/Register'; 3 | import { 4 | postUserRegister, 5 | resetRegisterStatus 6 | } from '../../redux/actions/Home'; 7 | 8 | const mapStateToProps = state => ({ 9 | registerMsg: state.home.register.registerMsg, 10 | registerResult: state.home.register.registerResult 11 | }); 12 | 13 | const mapDispatchToProps = dispatch => ({ 14 | postUserRegister(postData) { 15 | dispatch(postUserRegister(postData)); 16 | }, 17 | resetRegisterStatus() { 18 | dispatch(resetRegisterStatus()); 19 | } 20 | }); 21 | 22 | export default connect( 23 | mapStateToProps, 24 | mapDispatchToProps 25 | )(Register); 26 | -------------------------------------------------------------------------------- /src/App.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | import { Link } from 'react-router-dom'; 3 | import { Button } from 'antd'; 4 | /* 此处注意,如果使用CSS Module,则必须命名css文件为*.module.css的形式 */ 5 | /* More detail can see from https://github.com/codebandits/react-app-rewire-css-modules */ 6 | import styles from './App.module.css'; 7 | 8 | class App extends Component { 9 | render() { 10 | return ( 11 |
12 |
13 |

Express-JWT-Auth

14 | 15 | 16 | 17 |
18 | ); 19 | } 20 | } 21 | 22 | export default App; 23 | -------------------------------------------------------------------------------- /src/constants/ActionTypes.js: -------------------------------------------------------------------------------- 1 | // 获取所有用户信息 2 | export const FETCH_ALL_USER_LIST = 'FETCH_ALL_USER_LIST'; 3 | export const FETCH_ALL_USER_LIST_SUCCESS = 'FETCH_ALL_USER_LIST_SUCCESS'; 4 | export const FETCH_ALL_USER_LIST_FAIL = 'FETCH_ALL_USER_LIST_FAIL'; 5 | 6 | // 用户注册 7 | export const USER_REGISTER = 'USER_REGISTER'; 8 | export const USER_REGISTER_SUCCESS = 'USER_REGISTER_SUCCESS'; 9 | export const USER_REGISTER_FAIL = 'USER_REGISTER_FAIL'; 10 | export const RESET_REGISTER_STATUS = 'RESET_REGISTER_STATUS'; 11 | 12 | // 用户登录 13 | export const USER_LOGIN = 'USER_LOGIN'; 14 | export const USER_LOGIN_SUCCESS = 'USER_LOGIN_SUCCESS'; 15 | export const USER_LOGIN_FAIL = 'USER_LOGIN_FAIL'; 16 | export const RESET_LOGIN_STATUS = 'RESET_LOGIN_STATUS'; 17 | -------------------------------------------------------------------------------- /src/redux/store/configureStore.js: -------------------------------------------------------------------------------- 1 | import { createStore, applyMiddleware } from 'redux'; 2 | import thunkMiddleware from 'redux-thunk'; 3 | import { logger } from '../middleware'; 4 | import rootReducer from '../reducers'; 5 | 6 | const nextReducer = require('../reducers'); 7 | 8 | function configure(initialState) { 9 | const create = window.devToolsExtension 10 | ? window.devToolsExtension()(createStore) 11 | : createStore; 12 | 13 | const createStoreWithMiddleware = applyMiddleware(thunkMiddleware, logger)( 14 | create 15 | ); 16 | 17 | const store = createStoreWithMiddleware(rootReducer, initialState); 18 | 19 | if (module.hot) { 20 | module.hot.accept('../reducers', () => { 21 | store.replaceReducer(nextReducer); 22 | }); 23 | } 24 | return store; 25 | } 26 | export default configure; 27 | -------------------------------------------------------------------------------- /src/components/Login/form.module.css: -------------------------------------------------------------------------------- 1 | .formContainer { 2 | position: absolute; 3 | width: 100%; 4 | height: 100%; 5 | background: url('./cool-background.png'); 6 | background-size: cover; 7 | } 8 | .cardStyle { 9 | width: 40%; 10 | top: 50%; 11 | left: 50%; 12 | transform: translate(-50%, -50%); 13 | } 14 | .formTitle { 15 | text-align: center; 16 | font-weight: 600; 17 | font-size: 26px; 18 | } 19 | .formButton { 20 | width:100%; 21 | } 22 | .otherInfo { 23 | text-align: center; 24 | color: #00bfff; 25 | } 26 | .otherInfo > span { 27 | font-size: 16px; 28 | cursor: pointer; 29 | margin: 0 4px; 30 | } 31 | .spinContainer { 32 | position: absolute; 33 | width: 100%; 34 | height: 100%; 35 | display: flex; 36 | justify-content: center; 37 | align-items: center; 38 | z-index: 9; 39 | background-color: rgba(0, 0, 0, 0.26); 40 | } -------------------------------------------------------------------------------- /server/server.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const path = require('path'); 3 | const logger = require('morgan'); 4 | const bodyParser = require('body-parser'); 5 | const mongoose = require('./db/config/mongoose'); // 连接mongodb数据库 6 | const router = require('./routes/index.js'); 7 | 8 | const app = express(); 9 | const db = mongoose(); 10 | // 加载日志的中间件 11 | // 每一次服务请求都会将信息打印在控制台中 12 | app.use(logger('dev')); 13 | // 给app配置bodyParser中间件 14 | // 通过如下配置再路由种处理request时,可以直接获得post请求的body部分 15 | app.use(bodyParser.urlencoded({ extended: true })); 16 | app.use(bodyParser.json()); 17 | 18 | //app.use('/',express.static(path.join(__dirname,"..",'build'))); 19 | // app.use('/',express.static(path.join(__dirname,"..",'static'))); 20 | 21 | // 所有的路由会加上“/api”前缀 22 | app.use('/api', router); //添加router中间件 23 | 24 | // express 自动帮我们创建一个server,封装的node底层http 25 | app.listen(3003, () => { 26 | console.log('node server is listening 3003'); 27 | }); 28 | -------------------------------------------------------------------------------- /src/redux/reducers/user/userList.js: -------------------------------------------------------------------------------- 1 | import { 2 | FETCH_ALL_USER_LIST, 3 | FETCH_ALL_USER_LIST_SUCCESS, 4 | FETCH_ALL_USER_LIST_FAIL 5 | } from '../../../constants/ActionTypes'; 6 | import { OperationStatus } from '../../../constants/ConstTypes'; 7 | 8 | const initialState = { 9 | list: [] 10 | }; 11 | 12 | const userList = (state = initialState, { type, payload }) => { 13 | switch (type) { 14 | case FETCH_ALL_USER_LIST: 15 | return { 16 | ...state, 17 | status: OperationStatus.initial 18 | }; 19 | case FETCH_ALL_USER_LIST_SUCCESS: 20 | return { 21 | ...state, 22 | list: payload, 23 | status: OperationStatus.load_success 24 | }; 25 | case FETCH_ALL_USER_LIST_FAIL: 26 | return { 27 | ...state, 28 | status: OperationStatus.load_fail 29 | }; 30 | default: 31 | return state; 32 | } 33 | }; 34 | 35 | export default userList; 36 | -------------------------------------------------------------------------------- /src/redux/actions/User.js: -------------------------------------------------------------------------------- 1 | import { 2 | FETCH_ALL_USER_LIST, 3 | FETCH_ALL_USER_LIST_SUCCESS, 4 | FETCH_ALL_USER_LIST_FAIL 5 | } from '../../constants/ActionTypes'; 6 | // import axios from 'axios'; 7 | import http from '../../api/http'; 8 | 9 | // 获取用户列表 10 | const getAllUserList = () => ({ 11 | type: FETCH_ALL_USER_LIST 12 | }); 13 | const getAllUserListSuccess = payload => ({ 14 | type: FETCH_ALL_USER_LIST_SUCCESS, 15 | payload 16 | }); 17 | const getAllUserListFail = () => ({ 18 | type: FETCH_ALL_USER_LIST_FAIL 19 | }); 20 | export const fetchAllUserList = () => dispatch => { 21 | dispatch(getAllUserList()); 22 | // 获取用户列表 23 | // 因为设置了proxy的缘故,所以不需要写http://localhost:3003 24 | // 会自动定向到后端服务器 25 | return http 26 | .get('/user/list') 27 | .then(res => { 28 | return dispatch(getAllUserListSuccess(res.data)); 29 | }) 30 | .catch(error => { 31 | console.log(error); 32 | dispatch(getAllUserListFail()); 33 | }); 34 | }; 35 | -------------------------------------------------------------------------------- /server/routes/index.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const user = require('./user'); 3 | const jwtAuth = require('./jwt'); 4 | // 注册路由 5 | const router = express.Router(); 6 | // 所有请求过来都会进行身份验证 7 | router.use(jwtAuth); 8 | // 路由中间件 9 | router.use((req, res, next) => { 10 | // 任何路由信息都会执行这里面的语句 11 | console.log('this is a api request!'); 12 | // 把它交给下一个中间件,注意中间件的注册顺序是按序执行 13 | next(); 14 | }); 15 | 16 | router.use('/user', user); 17 | // 处理 404 18 | router.use((req, res, next) => { 19 | var err = new Error('Not Found'); 20 | err.status = 404; 21 | next(err); 22 | }); 23 | // 处理5错误 24 | router.use((err, req, res, next) => { 25 | if (err.name === 'UnauthorizedError') { 26 | res.status(401).json({ 27 | code: 401, 28 | message: 'invalid token', 29 | data: err 30 | }); 31 | } else { 32 | res.status(err.status || 500).json({ 33 | code: err.status || 500, 34 | message: err.message, 35 | data: err 36 | }); 37 | } 38 | }); 39 | 40 | module.exports = router; 41 | -------------------------------------------------------------------------------- /src/redux/reducers/home/login.js: -------------------------------------------------------------------------------- 1 | import { 2 | USER_LOGIN, 3 | USER_LOGIN_SUCCESS, 4 | USER_LOGIN_FAIL, 5 | RESET_LOGIN_STATUS 6 | } from '../../../constants/ActionTypes'; 7 | import { OperationStatus } from '../../../constants/ConstTypes'; 8 | 9 | const initialState = { 10 | loginMsg: '', 11 | status: OperationStatus.initial 12 | }; 13 | 14 | const login = (state = initialState, { type, payload }) => { 15 | switch (type) { 16 | case USER_LOGIN: 17 | return { 18 | ...state, 19 | status: OperationStatus.initial 20 | }; 21 | case USER_LOGIN_SUCCESS: 22 | return { 23 | ...state, 24 | loginMsg: payload.message, 25 | status: OperationStatus.load_success 26 | }; 27 | case USER_LOGIN_FAIL: 28 | return { 29 | ...state, 30 | loginMsg: payload.message, 31 | status: OperationStatus.load_fail 32 | }; 33 | case RESET_LOGIN_STATUS: 34 | return initialState; 35 | default: 36 | return state; 37 | } 38 | }; 39 | 40 | export default login; 41 | -------------------------------------------------------------------------------- /LICENSE: -------------------------------------------------------------------------------- 1 | MIT License 2 | 3 | Copyright (c) 2019 luffyZhou 4 | 5 | Permission is hereby granted, free of charge, to any person obtaining a copy 6 | of this software and associated documentation files (the "Software"), to deal 7 | in the Software without restriction, including without limitation the rights 8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 9 | copies of the Software, and to permit persons to whom the Software is 10 | furnished to do so, subject to the following conditions: 11 | 12 | The above copyright notice and this permission notice shall be included in all 13 | copies or substantial portions of the Software. 14 | 15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE 21 | SOFTWARE. 22 | -------------------------------------------------------------------------------- /src/common/NotFound/NotFound.js: -------------------------------------------------------------------------------- 1 | import React from 'react'; 2 | import { Button } from 'antd'; 3 | import EmptyData from 'uxcore-empty-data'; 4 | import './NotFound.css'; 5 | 6 | class NotFound extends React.Component { 7 | constructor(props) { 8 | super(props); 9 | this.onMainClick = this.onMainClick.bind(this); 10 | } 11 | onMainClick(e) { 12 | this.props.history.push('/'); 13 | } 14 | render() { 15 | return ( 16 |
17 |
18 | 19 |
20 |
21 |
22 |

页面出错了

23 |

24 | 您访问的页面不存在,请确认链接无误后再试。 25 |

26 |
27 | 30 |
31 |
32 |
33 |
34 | ); 35 | } 36 | } 37 | export default NotFound; 38 | -------------------------------------------------------------------------------- /src/redux/reducers/home/register.js: -------------------------------------------------------------------------------- 1 | import { 2 | USER_REGISTER, 3 | USER_REGISTER_SUCCESS, 4 | USER_REGISTER_FAIL, 5 | RESET_REGISTER_STATUS 6 | } from '../../../constants/ActionTypes'; 7 | import { OperationStatus } from '../../../constants/ConstTypes'; 8 | 9 | const initialState = { 10 | registerMsg: '' 11 | }; 12 | 13 | const register = (state = initialState, { type, payload }) => { 14 | switch (type) { 15 | case USER_REGISTER: 16 | return { 17 | ...state, 18 | status: OperationStatus.initial 19 | }; 20 | case USER_REGISTER_SUCCESS: 21 | return { 22 | ...state, 23 | registerMsg: payload.message, 24 | registerResult: payload.success, 25 | status: OperationStatus.load_success 26 | }; 27 | case USER_REGISTER_FAIL: 28 | return { 29 | ...state, 30 | registerMsg: payload.message, 31 | registerResult: payload.success, 32 | status: OperationStatus.load_fail 33 | }; 34 | case RESET_REGISTER_STATUS: 35 | return initialState; 36 | default: 37 | return state; 38 | } 39 | }; 40 | 41 | export default register; 42 | -------------------------------------------------------------------------------- /src/components/UserList.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | import { Table } from 'antd'; 3 | 4 | class UserList extends Component { 5 | constructor(props) { 6 | super(props); 7 | this.state = { userList: this.props.list }; 8 | } 9 | 10 | componentDidMount() { 11 | this.props.fetchAllUserList(); 12 | } 13 | 14 | componentWillReceiveProps(nextProps) { 15 | this.setState({ userList: nextProps.list }); 16 | } 17 | 18 | shouldComponentUpdate(nextProps, nextState) { 19 | return this.state.userList !== nextState.userList; 20 | } 21 | 22 | render() { 23 | const columns = [ 24 | { 25 | title: '姓名', 26 | dataIndex: 'username', 27 | key: 'username' 28 | }, 29 | { 30 | title: '邮箱', 31 | dataIndex: 'email', 32 | key: 'email' 33 | } 34 | ]; 35 | return ( 36 |
37 |

用户列表页

38 |
39 | record._id} 43 | /> 44 | 45 | 46 | ); 47 | } 48 | } 49 | export default UserList; 50 | -------------------------------------------------------------------------------- /src/routes/index.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | import { Router, Route, Switch, Redirect } from 'react-router-dom'; 3 | import { Provider } from 'react-redux'; 4 | import { createBrowserHistory } from 'history'; 5 | import configure from '../redux/store/configureStore'; 6 | import App from '../App'; 7 | import UserList from '../containers/User/UserList'; 8 | import LoginForm from '../containers/Home/Login'; 9 | import RegisterForm from '../containers/Home/Register'; 10 | import NotFound from '../common/NotFound/NotFound'; 11 | 12 | const history = createBrowserHistory(); 13 | const store = configure(); 14 | 15 | class RootRouter extends Component { 16 | render() { 17 | return ( 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | ); 31 | } 32 | } 33 | 34 | export default RootRouter; 35 | -------------------------------------------------------------------------------- /src/common/NotFound/NotFound.css: -------------------------------------------------------------------------------- 1 | #scene-defaultpage-demo-basic { 2 | position:relative; 3 | height:500px; 4 | } 5 | .fillErrorDemo { 6 | position:absolute; 7 | left:50%; 8 | top:50%; 9 | transform:translate(-50%,-50%); 10 | width:684px; 11 | height:220px; 12 | } 13 | .fillErrorDemo .errorLeft { 14 | float:left; 15 | width:220px; 16 | height:220px; 17 | } 18 | .fillErrorDemo .errorLeft .kuma-empty-data-icon{ 19 | height:220px; 20 | width:220px; 21 | } 22 | .fillErrorDemo .errorLeft .kuma-empty-data-content{ 23 | display:none; 24 | } 25 | .fillErrorDemo .errorRight { 26 | float:right; 27 | display:table; 28 | width:400px; 29 | height:100%; 30 | 31 | } 32 | .fillErrorDemo .errorRight .tips{ 33 | display:table-cell; 34 | vertical-align:middle; 35 | margin-right:64px; 36 | width:400px; 37 | } 38 | .fillErrorDemo .errorRight .tipsTitle { 39 | margin-bottom:28px; 40 | line-height:32px; 41 | font-size:32px; 42 | color:rgba(31,56,88,1); 43 | letter-spacing:0; 44 | } 45 | .fillErrorDemo .errorRight .errorRips{ 46 | line-height:22px; 47 | font-size:14px; 48 | letter-spacing:0; 49 | color: rgba(-2147483648,26,-2147483648,0.60); 50 | } 51 | .fillErrorDemo .errorRight .errorButtons{ 52 | margin-top:28px; 53 | } 54 | .fillErrorDemo .errorButtons button{ 55 | margin-right:12px; 56 | } 57 | .kuma-button span { 58 | display:inline-block; 59 | line-height:12px; 60 | } 61 | .kuma-empty-data-icon { 62 | background-size: cover; 63 | } -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # express-react-scaffold 2 | 后端使用express,前端使用react的精简全家桶脚手架。 3 | ### 目录 4 | ``` 5 | express-react-scaffold 6 | - public 7 | - server //后端 8 | - db //数据库目录 9 | - routes //后端路由 10 | - public 11 | - server.js // 后端入口文件 12 | - src //前端 13 | - common // 公共组件 14 | - components // 展示组件 15 | - constants // 系统常量 16 | - containers // 状态组件 17 | - redux // redux相关 18 | - actions 19 | - reducers 20 | - store 21 | - middleware 22 | - App.js 23 | - index.js // 前端入口文件 24 | - .eslintrc //eslint配置文件 25 | - .gitignore 26 | - config-overrides.js 27 | - package.json 28 | - README.md 29 | - yarn.lock 30 | ``` 31 | ### 后端 32 | 只提供API接口服务,采用express+MongoDB 33 | ### 前端 34 | 使用react全家桶,react+react-router+react-redux 35 | 36 | ### Version 37 | - 新增CSS Module,依赖的是[react-app-rewire-css-modules](https://github.com/codebandits/react-app-rewire-css-modules) 38 | > 使用CSS Module需要注意,.css文件的命名规则需要是*.module.css,这样才会被解析成css module,否则只会当成普通的css文件。详情见上方链接 39 | 40 | ### 使用 41 | ``` 42 | 1. git clone https://github.com/luffyZh/express-react-scaffold.git 43 | 2. cd express-react-scaffold 44 | 3. yarn install // 安装前端依赖 45 | 4. cd server && yarn install // 安装后端依赖 46 | 5. yarn start // 在express-react-scaffold目录下 47 | ``` 48 | > 使用之前请安装MongoDB并且在/server/config里面配置好你的数据库连接 49 | 50 | **更多细节,请访问如下链接查看:https://juejin.im/post/5ae3317e6fb9a07ac021fba4** 51 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "express-react-cli", 3 | "version": "0.1.0", 4 | "private": true, 5 | "dependencies": { 6 | "antd": "^3.4.4", 7 | "axios": "^0.18.0", 8 | "babel-plugin-import": "^1.7.0", 9 | "express-validator": "^5.3.1", 10 | "history": "^4.7.2", 11 | "react": "^16.3.2", 12 | "react-app-rewire-less": "^2.1.1", 13 | "react-app-rewired": "^1.5.2", 14 | "react-dom": "^16.3.2", 15 | "react-redux": "^5.0.7", 16 | "react-router-dom": "^4.2.2", 17 | "react-scripts": "1.1.4", 18 | "redux": "^4.0.0", 19 | "redux-logger": "^3.0.6", 20 | "redux-thunk": "^2.2.0", 21 | "sweetalert": "^2.1.0", 22 | "uxcore-empty-data": "^0.1.5" 23 | }, 24 | "scripts": { 25 | "react-start": "react-app-rewired start", 26 | "react-build": "react-app-rewired build", 27 | "start": "concurrently \"react-app-rewired start\" \"cd server && yarn start\"", 28 | "build": "concurrently \"react-app-rewired build\" \"cd server && yarn build\"", 29 | "test": "react-scripts test --env=jsdom", 30 | "eject": "react-scripts eject", 31 | "format": "prettier --write \"**/*.js\"" 32 | }, 33 | "proxy": "http://127.0.0.1:3003", 34 | "devDependencies": { 35 | "concurrently": "^3.5.1", 36 | "husky": "^1.3.1", 37 | "lint-staged": "^8.1.0", 38 | "node-sass": "^4.9.0", 39 | "nodemon": "^1.18.9", 40 | "prettier": "1.15.3", 41 | "react-app-rewire-css-modules": "codebandits/react-app-rewire-css-modules", 42 | "sass-loader": "^7.0.1" 43 | }, 44 | "husky": { 45 | "hooks": { 46 | "pre-commit": "lint-staged" 47 | } 48 | }, 49 | "lint-staged": { 50 | "*.{js,json,css,md}": [ 51 | "prettier --write", 52 | "git add" 53 | ] 54 | } 55 | } 56 | -------------------------------------------------------------------------------- /public/index.html: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 | 11 | 12 | 13 | 22 | Express-React-Scaffold-JWT 23 | 24 | 25 | 28 |
29 | 39 | 40 | 41 | -------------------------------------------------------------------------------- /src/redux/actions/Home.js: -------------------------------------------------------------------------------- 1 | import { 2 | USER_REGISTER, 3 | USER_REGISTER_SUCCESS, 4 | USER_REGISTER_FAIL, 5 | USER_LOGIN, 6 | USER_LOGIN_SUCCESS, 7 | USER_LOGIN_FAIL, 8 | RESET_REGISTER_STATUS, 9 | RESET_LOGIN_STATUS 10 | } from '../../constants/ActionTypes'; 11 | // import axios from 'axios'; 12 | import http from '../../api/http'; 13 | 14 | // 用户注册 15 | const userRegister = () => ({ 16 | type: USER_REGISTER 17 | }); 18 | const userRegisterSuccess = payload => ({ 19 | type: USER_REGISTER_SUCCESS, 20 | payload 21 | }); 22 | const userRegisterFail = payload => ({ 23 | type: USER_REGISTER_FAIL, 24 | payload 25 | }); 26 | export const resetRegisterStatus = () => ({ 27 | type: RESET_REGISTER_STATUS 28 | }); 29 | export const postUserRegister = postData => (dispatch, getState) => { 30 | dispatch(userRegister()); 31 | return http 32 | .post('/user/register', postData) 33 | .then(res => { 34 | return dispatch(userRegisterSuccess(res.data)); 35 | }) 36 | .catch(error => { 37 | dispatch(userRegisterFail(error)); 38 | }); 39 | }; 40 | // 用户登陆 41 | const userLogin = () => ({ 42 | type: USER_LOGIN 43 | }); 44 | const userLoginSuccess = payload => ({ 45 | type: USER_LOGIN_SUCCESS, 46 | payload 47 | }); 48 | const userLoginFail = payload => ({ 49 | type: USER_LOGIN_FAIL, 50 | payload 51 | }); 52 | export const resetLoginStatus = () => ({ 53 | type: RESET_LOGIN_STATUS 54 | }); 55 | export const postUserLogin = postData => (dispatch, getState) => { 56 | dispatch(userLogin()); 57 | return http 58 | .post('/user/login', postData) 59 | .then(res => { 60 | if (res.code !== 0) { 61 | return dispatch(userLoginFail(res)); 62 | } 63 | return dispatch(userLoginSuccess(res.data)); 64 | }) 65 | .catch(error => { 66 | console.log(error); 67 | dispatch(userLoginFail(error)); 68 | }); 69 | }; 70 | -------------------------------------------------------------------------------- /src/api/http.js: -------------------------------------------------------------------------------- 1 | import { createBrowserHistory } from 'history'; 2 | import axios from 'axios'; 3 | import swal from 'sweetalert'; 4 | 5 | axios.defaults.baseURL = '/api'; 6 | 7 | const history = createBrowserHistory(); 8 | 9 | // 拦截请求,给所有的请求都带上token 10 | axios.interceptors.request.use(request => { 11 | const luffy_jwt_token = window.localStorage.getItem('luffy_jwt_token'); 12 | if (luffy_jwt_token) { 13 | /* 14 | 此处有坑,在此记录 15 | request.headers['Authorization'] 16 | 必须通过此种形式设置Authorization,否则后端即使收到字段也会出现问题,返回401 17 | - request.headers.Authorization或request.headers.authorization可以设置成功, 18 | 浏览器查看也没有任何问题,但是在后端会报401并且后端一律只能拿到小写的, 19 | 也就是res.headers.authorization,后端用大写获取会报undefined 20 | */ 21 | request.headers['Authorization'] = `Bearer ${luffy_jwt_token}`; 22 | } 23 | return request; 24 | }); 25 | 26 | // 拦截响应,遇到token不合法则报错 27 | axios.interceptors.response.use( 28 | response => { 29 | const res = response.data; 30 | if (res.data.token) { 31 | console.log('token:', res.data.token); 32 | window.localStorage.setItem('luffy_jwt_token', res.data.token); 33 | } 34 | return res; 35 | }, 36 | error => { 37 | const errRes = error.response.data; 38 | if (error.response.status === 401) { 39 | window.localStorage.removeItem('luffy_jwt_token'); 40 | swal('Auth Error!', `${errRes.message}, please login!`, 'error').then( 41 | () => { 42 | history.push('/login'); 43 | setTimeout(() => { 44 | window.location.reload(); 45 | }, 0); 46 | } 47 | ); 48 | } 49 | return Promise.reject(errRes); // 返回接口返回的错误信息 50 | } 51 | ); 52 | 53 | export default class http { 54 | static get(url, params) { 55 | return new Promise((resolve, reject) => { 56 | axios 57 | .get(url, { 58 | params: params 59 | }) 60 | .then(res => { 61 | resolve(res); 62 | }) 63 | .catch(err => { 64 | reject(err); 65 | }); 66 | }); 67 | } 68 | 69 | static post(url, body) { 70 | return new Promise((resolve, reject) => { 71 | axios 72 | .post(url, body) 73 | .then(res => { 74 | resolve(res); 75 | }) 76 | .catch(err => { 77 | reject(err); 78 | }); 79 | }); 80 | } 81 | } 82 | -------------------------------------------------------------------------------- /src/components/Login/Login.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | import { Form, Icon, Input, Button, Checkbox, Card, Spin } from 'antd'; 3 | import { Link } from 'react-router-dom'; 4 | import swal from 'sweetalert'; 5 | import { OperationStatus } from '../../constants/ConstTypes'; 6 | import styles from './form.module.css'; 7 | 8 | const FormItem = Form.Item; 9 | 10 | class NormalLoginForm extends Component { 11 | constructor(props) { 12 | super(props); 13 | this.state = { spinShow: 'none', buttonDisbled: false }; 14 | } 15 | handleSubmit = e => { 16 | e.preventDefault(); 17 | this.props.form.validateFields((err, values) => { 18 | if (!err) { 19 | this.props.postUserLogin(values); 20 | this.setState({ spinShow: 'flex', buttonDisbled: true }); 21 | } 22 | }); 23 | }; 24 | 25 | componentWillReceiveProps(nextProps) { 26 | if (nextProps.status === OperationStatus.load_fail) { 27 | swal('用户名或密码错误', '', 'error').then(() => { 28 | this.props.resetLoginStatus(); 29 | this.setState({ spinShow: 'none', buttonDisbled: false }); 30 | }); 31 | } 32 | if (nextProps.status === OperationStatus.load_success) { 33 | setTimeout(() => { 34 | this.props.history.push('/'); 35 | }, 1000); 36 | } 37 | } 38 | 39 | forgetPassword = () => { 40 | swal('忘记密码?', '忘了就忘了吧,暂时我也没办法帮你找回来!', 'info'); 41 | }; 42 | 43 | render() { 44 | const { getFieldDecorator } = this.props.form; 45 | return ( 46 |
47 |
51 | 52 |
53 | 54 |

JWT登录

55 |
56 | 57 | {getFieldDecorator('username', { 58 | rules: [{ required: true, message: '请输入用户名!' }] 59 | })( 60 | 63 | } 64 | placeholder="用户名" 65 | /> 66 | )} 67 | 68 | 69 | {getFieldDecorator('password', { 70 | rules: [{ required: true, message: '请输入密码!' }] 71 | })( 72 | 75 | } 76 | type="password" 77 | placeholder="密码" 78 | /> 79 | )} 80 | 81 | 82 | {getFieldDecorator('remember', { 83 | valuePropName: 'checked', 84 | initialValue: true 85 | })(记住我)} 86 | 87 | 88 | 95 |
96 | 97 | 注册账号 98 | 99 | |忘记密码 100 |
101 |
102 | 103 |
104 |
105 | ); 106 | } 107 | } 108 | 109 | const LoginForm = Form.create()(NormalLoginForm); 110 | export default LoginForm; 111 | -------------------------------------------------------------------------------- /src/components/Login/Register.js: -------------------------------------------------------------------------------- 1 | import React, { Component } from 'react'; 2 | import { Form, Icon, Input, Button, Card } from 'antd'; 3 | import { Link } from 'react-router-dom'; 4 | import swal from 'sweetalert'; 5 | import styles from './form.module.css'; 6 | 7 | const FormItem = Form.Item; 8 | 9 | class NormalRegisterForm extends Component { 10 | handleSubmit = e => { 11 | e.preventDefault(); 12 | this.props.form.validateFields((err, values) => { 13 | if (!err) { 14 | console.log('Received values of form: ', values); 15 | this.props.postUserRegister(values); 16 | } else { 17 | if (err.username) { 18 | swal(`${err.username.errors[0].message}`, '', 'error'); 19 | } else if (err.email) { 20 | swal(`${err.email.errors[0].message}`, '', 'error'); 21 | } else if (err.password) { 22 | swal(`${err.password.errors[0].message}`, '', 'error'); 23 | } 24 | } 25 | }); 26 | }; 27 | 28 | componentWillReceiveProps(nextProps) { 29 | if (nextProps.registerResult) { 30 | swal('注册成功', '', 'success').then(() => { 31 | setTimeout(() => { 32 | this.props.history.push('/login'); 33 | }, 600); 34 | }); 35 | } else { 36 | if (nextProps.registerMsg !== '') { 37 | this.props.resetRegisterStatus(); 38 | swal(`${nextProps.registerMsg}`, '', 'error'); 39 | } 40 | } 41 | } 42 | 43 | changePasswordType = e => { 44 | const formObj = this.props.form.getFieldsValue(); 45 | if (formObj.username === '' || formObj.email === '') { 46 | e.target.type = 'text'; 47 | } else { 48 | e.target.type = 'password'; 49 | } 50 | }; 51 | 52 | render() { 53 | const { getFieldDecorator } = this.props.form; 54 | return ( 55 |
56 | 57 |

JWT注册

58 |
59 | 60 | {getFieldDecorator('username', { 61 | rules: [{ required: true, message: '请输入用户名!' }] 62 | })( 63 | 66 | } 67 | placeholder="用户名" 68 | /> 69 | )} 70 | 71 | 72 | {getFieldDecorator('email', { 73 | rules: [ 74 | { 75 | type: 'email', 76 | message: '输入的邮箱信息不合法!' 77 | }, 78 | { 79 | required: true, 80 | message: '请输入你的邮箱!' 81 | } 82 | ] 83 | })( 84 | 87 | } 88 | type="text" 89 | placeholder="邮箱" 90 | /> 91 | )} 92 | 93 | 94 | {getFieldDecorator('password', { 95 | rules: [{ required: true, message: '请输入密码!' }] 96 | })( 97 | 100 | } 101 | type="password" 102 | placeholder="密码" 103 | onFocus={this.changePasswordType} 104 | /> 105 | )} 106 | 107 | 108 | 115 |
116 | 117 | 已有账号,返回登录 118 | 119 |
120 |
121 | 122 |
123 |
124 | ); 125 | } 126 | } 127 | 128 | const RegisterForm = Form.create()(NormalRegisterForm); 129 | export default RegisterForm; 130 | -------------------------------------------------------------------------------- /server/routes/user.js: -------------------------------------------------------------------------------- 1 | const express = require('express'); 2 | const jwt = require('jsonwebtoken'); 3 | const { body, oneOf, validationResult } = require('express-validator/check'); 4 | const User = require('../db/models/UserModel'); // 引入模型 5 | const { MD5_SUFFIX, md5, secretKey } = require('../constant/constant'); 6 | 7 | const router = express.Router(); 8 | 9 | // 获取用户列表 10 | router.get('/list', (req, res) => { 11 | User.find({}, (err, data) => { 12 | if (err) next(err); 13 | res.json({ 14 | code: 0, 15 | message: '', 16 | data 17 | }); 18 | }); 19 | }); 20 | 21 | // 用户登录接口 22 | router.post( 23 | '/login', 24 | [ 25 | [ 26 | body('username') 27 | .isString() 28 | .withMessage('username类型不正确'), 29 | body('password') 30 | .isString() 31 | .withMessage('password类型不正确') 32 | ] 33 | ], 34 | (req, res) => { 35 | const errors = validationResult(req); 36 | if (!errors.isEmpty()) { 37 | return res.status(422).json({ 38 | code: 422, 39 | message: '字段名称不合法', 40 | data: { 41 | success: false, 42 | error: errors.array() 43 | } 44 | }); 45 | } 46 | const tokenObj = { 47 | username: req.body.username 48 | }; 49 | User.findOne( 50 | { 51 | username: req.body.username 52 | }, 53 | (err, user) => { 54 | if (err) { 55 | res.send('server or db error'); 56 | } else { 57 | User.findOne( 58 | { 59 | //判断密码是否正确 60 | username: req.body.username, 61 | password: md5(req.body.password + MD5_SUFFIX) 62 | }, 63 | (err, user) => { 64 | if (user !== null) { 65 | // 用户登录成功过后生成token返给前端 66 | let token = jwt.sign(tokenObj, secretKey, { 67 | expiresIn: 60 // 授权时效24小时 68 | }); 69 | res.json({ 70 | code: 0, 71 | message: 'success', 72 | data: { 73 | success: true, 74 | token: token 75 | } 76 | }); 77 | } else { 78 | res.json({ 79 | code: 404, 80 | message: 'User not found', 81 | data: { 82 | success: false 83 | } 84 | }); 85 | } 86 | } 87 | ); 88 | } 89 | } 90 | ); 91 | } 92 | ); 93 | 94 | // 用户注册接口 95 | router.post( 96 | '/register', 97 | [ 98 | body('username').isLength({ min: 6 }), 99 | body('email').isEmail(), 100 | body('password').isLength({ min: 6 }) 101 | ], 102 | (req, res) => { 103 | // Finds the validation errors in this request and wraps them in an object with handy functions 104 | const errors = validationResult(req); 105 | console.log(errors, errors.isEmpty(), errors.array()); 106 | if (!errors.isEmpty()) { 107 | return res.status(422).json({ 108 | code: 422, 109 | message: '字段名称不合法', 110 | data: { 111 | success: false, 112 | error: errors.array() 113 | } 114 | }); 115 | } 116 | User.findOne( 117 | { 118 | //查找是否存在 119 | username: req.body.username 120 | }, 121 | (err, user) => { 122 | if (err) { 123 | res.send('server or db error'); 124 | } else { 125 | if (user === null) { 126 | const insertObj = { 127 | username: req.body.username, 128 | password: md5(req.body.password + MD5_SUFFIX), 129 | email: req.body.email, 130 | role: 10.0 131 | }; 132 | const newUser = new User(insertObj); 133 | newUser.save(insertObj, (err, doc) => { 134 | if (err) { 135 | res.json({ 136 | code: 500, 137 | messsge: '用户注册失败', 138 | data: { 139 | success: false 140 | } 141 | }); 142 | } else { 143 | console.log(doc); 144 | res.json({ 145 | code: 0, 146 | message: '用户注册成功', 147 | data: { success: true } 148 | }); 149 | } 150 | }); 151 | } else { 152 | res.json({ 153 | code: 423, 154 | messsge: '用户名已存在', 155 | data: { 156 | success: false 157 | } 158 | }); 159 | } 160 | } 161 | } 162 | ); 163 | } 164 | ); 165 | 166 | module.exports = router; 167 | -------------------------------------------------------------------------------- /src/registerServiceWorker.js: -------------------------------------------------------------------------------- 1 | // In production, we register a service worker to serve assets from local cache. 2 | 3 | // This lets the app load faster on subsequent visits in production, and gives 4 | // it offline capabilities. However, it also means that developers (and users) 5 | // will only see deployed updates on the "N+1" visit to a page, since previously 6 | // cached resources are updated in the background. 7 | 8 | // To learn more about the benefits of this model, read https://goo.gl/KwvDNy. 9 | // This link also includes instructions on opting out of this behavior. 10 | 11 | const isLocalhost = Boolean( 12 | window.location.hostname === 'localhost' || 13 | // [::1] is the IPv6 localhost address. 14 | window.location.hostname === '[::1]' || 15 | // 127.0.0.1/8 is considered localhost for IPv4. 16 | window.location.hostname.match( 17 | /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/ 18 | ) 19 | ); 20 | 21 | export default function register() { 22 | if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) { 23 | // The URL constructor is available in all browsers that support SW. 24 | const publicUrl = new URL(process.env.PUBLIC_URL, window.location); 25 | if (publicUrl.origin !== window.location.origin) { 26 | // Our service worker won't work if PUBLIC_URL is on a different origin 27 | // from what our page is served on. This might happen if a CDN is used to 28 | // serve assets; see https://github.com/facebookincubator/create-react-app/issues/2374 29 | return; 30 | } 31 | 32 | window.addEventListener('load', () => { 33 | const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`; 34 | 35 | if (isLocalhost) { 36 | // This is running on localhost. Lets check if a service worker still exists or not. 37 | checkValidServiceWorker(swUrl); 38 | 39 | // Add some additional logging to localhost, pointing developers to the 40 | // service worker/PWA documentation. 41 | navigator.serviceWorker.ready.then(() => { 42 | console.log( 43 | 'This web app is being served cache-first by a service ' + 44 | 'worker. To learn more, visit https://goo.gl/SC7cgQ' 45 | ); 46 | }); 47 | } else { 48 | // Is not local host. Just register service worker 49 | registerValidSW(swUrl); 50 | } 51 | }); 52 | } 53 | } 54 | 55 | function registerValidSW(swUrl) { 56 | navigator.serviceWorker 57 | .register(swUrl) 58 | .then(registration => { 59 | registration.onupdatefound = () => { 60 | const installingWorker = registration.installing; 61 | installingWorker.onstatechange = () => { 62 | if (installingWorker.state === 'installed') { 63 | if (navigator.serviceWorker.controller) { 64 | // At this point, the old content will have been purged and 65 | // the fresh content will have been added to the cache. 66 | // It's the perfect time to display a "New content is 67 | // available; please refresh." message in your web app. 68 | console.log('New content is available; please refresh.'); 69 | } else { 70 | // At this point, everything has been precached. 71 | // It's the perfect time to display a 72 | // "Content is cached for offline use." message. 73 | console.log('Content is cached for offline use.'); 74 | } 75 | } 76 | }; 77 | }; 78 | }) 79 | .catch(error => { 80 | console.error('Error during service worker registration:', error); 81 | }); 82 | } 83 | 84 | function checkValidServiceWorker(swUrl) { 85 | // Check if the service worker can be found. If it can't reload the page. 86 | fetch(swUrl) 87 | .then(response => { 88 | // Ensure service worker exists, and that we really are getting a JS file. 89 | if ( 90 | response.status === 404 || 91 | response.headers.get('content-type').indexOf('javascript') === -1 92 | ) { 93 | // No service worker found. Probably a different app. Reload the page. 94 | navigator.serviceWorker.ready.then(registration => { 95 | registration.unregister().then(() => { 96 | window.location.reload(); 97 | }); 98 | }); 99 | } else { 100 | // Service worker found. Proceed as normal. 101 | registerValidSW(swUrl); 102 | } 103 | }) 104 | .catch(() => { 105 | console.log( 106 | 'No internet connection found. App is running in offline mode.' 107 | ); 108 | }); 109 | } 110 | 111 | export function unregister() { 112 | if ('serviceWorker' in navigator) { 113 | navigator.serviceWorker.ready.then(registration => { 114 | registration.unregister(); 115 | }); 116 | } 117 | } 118 | -------------------------------------------------------------------------------- /server/yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | abbrev@1: 6 | version "1.1.1" 7 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" 8 | 9 | accepts@~1.3.5: 10 | version "1.3.5" 11 | resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.5.tgz#eb777df6011723a3b14e8a72c0805c8e86746bd2" 12 | dependencies: 13 | mime-types "~2.1.18" 14 | negotiator "0.6.1" 15 | 16 | ansi-regex@^2.0.0: 17 | version "2.1.1" 18 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" 19 | 20 | ansi-styles@^2.2.1: 21 | version "2.2.1" 22 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe" 23 | 24 | anymatch@^1.3.0: 25 | version "1.3.2" 26 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-1.3.2.tgz#553dcb8f91e3c889845dfdba34c77721b90b9d7a" 27 | dependencies: 28 | micromatch "^2.1.5" 29 | normalize-path "^2.0.0" 30 | 31 | aproba@^1.0.3: 32 | version "1.2.0" 33 | resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a" 34 | 35 | are-we-there-yet@~1.1.2: 36 | version "1.1.4" 37 | resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz#bb5dca382bb94f05e15194373d16fd3ba1ca110d" 38 | dependencies: 39 | delegates "^1.0.0" 40 | readable-stream "^2.0.6" 41 | 42 | arr-diff@^2.0.0: 43 | version "2.0.0" 44 | resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-2.0.0.tgz#8f3b827f955a8bd669697e4a4256ac3ceae356cf" 45 | dependencies: 46 | arr-flatten "^1.0.1" 47 | 48 | arr-flatten@^1.0.1: 49 | version "1.1.0" 50 | resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1" 51 | 52 | array-flatten@1.1.1: 53 | version "1.1.1" 54 | resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" 55 | 56 | array-unique@^0.2.1: 57 | version "0.2.1" 58 | resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.2.1.tgz#a1d97ccafcbc2625cc70fadceb36a50c58b01a53" 59 | 60 | async-each@^1.0.0: 61 | version "1.0.1" 62 | resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.1.tgz#19d386a1d9edc6e7c1c85d388aedbcc56d33602d" 63 | 64 | async@2.1.4: 65 | version "2.1.4" 66 | resolved "https://registry.yarnpkg.com/async/-/async-2.1.4.tgz#2d2160c7788032e4dd6cbe2502f1f9a2c8f6cde4" 67 | dependencies: 68 | lodash "^4.14.0" 69 | 70 | async@^1.5.0: 71 | version "1.5.2" 72 | resolved "https://registry.yarnpkg.com/async/-/async-1.5.2.tgz#ec6a61ae56480c0c3cb241c95618e20892f9672a" 73 | 74 | babel-cli@^6.26.0: 75 | version "6.26.0" 76 | resolved "https://registry.yarnpkg.com/babel-cli/-/babel-cli-6.26.0.tgz#502ab54874d7db88ad00b887a06383ce03d002f1" 77 | dependencies: 78 | babel-core "^6.26.0" 79 | babel-polyfill "^6.26.0" 80 | babel-register "^6.26.0" 81 | babel-runtime "^6.26.0" 82 | commander "^2.11.0" 83 | convert-source-map "^1.5.0" 84 | fs-readdir-recursive "^1.0.0" 85 | glob "^7.1.2" 86 | lodash "^4.17.4" 87 | output-file-sync "^1.1.2" 88 | path-is-absolute "^1.0.1" 89 | slash "^1.0.0" 90 | source-map "^0.5.6" 91 | v8flags "^2.1.1" 92 | optionalDependencies: 93 | chokidar "^1.6.1" 94 | 95 | babel-code-frame@^6.26.0: 96 | version "6.26.0" 97 | resolved "https://registry.yarnpkg.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz#63fd43f7dc1e3bb7ce35947db8fe369a3f58c74b" 98 | dependencies: 99 | chalk "^1.1.3" 100 | esutils "^2.0.2" 101 | js-tokens "^3.0.2" 102 | 103 | babel-core@^6.26.0: 104 | version "6.26.3" 105 | resolved "https://registry.yarnpkg.com/babel-core/-/babel-core-6.26.3.tgz#b2e2f09e342d0f0c88e2f02e067794125e75c207" 106 | dependencies: 107 | babel-code-frame "^6.26.0" 108 | babel-generator "^6.26.0" 109 | babel-helpers "^6.24.1" 110 | babel-messages "^6.23.0" 111 | babel-register "^6.26.0" 112 | babel-runtime "^6.26.0" 113 | babel-template "^6.26.0" 114 | babel-traverse "^6.26.0" 115 | babel-types "^6.26.0" 116 | babylon "^6.18.0" 117 | convert-source-map "^1.5.1" 118 | debug "^2.6.9" 119 | json5 "^0.5.1" 120 | lodash "^4.17.4" 121 | minimatch "^3.0.4" 122 | path-is-absolute "^1.0.1" 123 | private "^0.1.8" 124 | slash "^1.0.0" 125 | source-map "^0.5.7" 126 | 127 | babel-generator@^6.26.0: 128 | version "6.26.1" 129 | resolved "https://registry.yarnpkg.com/babel-generator/-/babel-generator-6.26.1.tgz#1844408d3b8f0d35a404ea7ac180f087a601bd90" 130 | dependencies: 131 | babel-messages "^6.23.0" 132 | babel-runtime "^6.26.0" 133 | babel-types "^6.26.0" 134 | detect-indent "^4.0.0" 135 | jsesc "^1.3.0" 136 | lodash "^4.17.4" 137 | source-map "^0.5.7" 138 | trim-right "^1.0.1" 139 | 140 | babel-helper-call-delegate@^6.24.1: 141 | version "6.24.1" 142 | resolved "https://registry.yarnpkg.com/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz#ece6aacddc76e41c3461f88bfc575bd0daa2df8d" 143 | dependencies: 144 | babel-helper-hoist-variables "^6.24.1" 145 | babel-runtime "^6.22.0" 146 | babel-traverse "^6.24.1" 147 | babel-types "^6.24.1" 148 | 149 | babel-helper-define-map@^6.24.1: 150 | version "6.26.0" 151 | resolved "https://registry.yarnpkg.com/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz#a5f56dab41a25f97ecb498c7ebaca9819f95be5f" 152 | dependencies: 153 | babel-helper-function-name "^6.24.1" 154 | babel-runtime "^6.26.0" 155 | babel-types "^6.26.0" 156 | lodash "^4.17.4" 157 | 158 | babel-helper-function-name@^6.24.1: 159 | version "6.24.1" 160 | resolved "https://registry.yarnpkg.com/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz#d3475b8c03ed98242a25b48351ab18399d3580a9" 161 | dependencies: 162 | babel-helper-get-function-arity "^6.24.1" 163 | babel-runtime "^6.22.0" 164 | babel-template "^6.24.1" 165 | babel-traverse "^6.24.1" 166 | babel-types "^6.24.1" 167 | 168 | babel-helper-get-function-arity@^6.24.1: 169 | version "6.24.1" 170 | resolved "https://registry.yarnpkg.com/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz#8f7782aa93407c41d3aa50908f89b031b1b6853d" 171 | dependencies: 172 | babel-runtime "^6.22.0" 173 | babel-types "^6.24.1" 174 | 175 | babel-helper-hoist-variables@^6.24.1: 176 | version "6.24.1" 177 | resolved "https://registry.yarnpkg.com/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz#1ecb27689c9d25513eadbc9914a73f5408be7a76" 178 | dependencies: 179 | babel-runtime "^6.22.0" 180 | babel-types "^6.24.1" 181 | 182 | babel-helper-optimise-call-expression@^6.24.1: 183 | version "6.24.1" 184 | resolved "https://registry.yarnpkg.com/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz#f7a13427ba9f73f8f4fa993c54a97882d1244257" 185 | dependencies: 186 | babel-runtime "^6.22.0" 187 | babel-types "^6.24.1" 188 | 189 | babel-helper-regex@^6.24.1: 190 | version "6.26.0" 191 | resolved "https://registry.yarnpkg.com/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz#325c59f902f82f24b74faceed0363954f6495e72" 192 | dependencies: 193 | babel-runtime "^6.26.0" 194 | babel-types "^6.26.0" 195 | lodash "^4.17.4" 196 | 197 | babel-helper-replace-supers@^6.24.1: 198 | version "6.24.1" 199 | resolved "https://registry.yarnpkg.com/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz#bf6dbfe43938d17369a213ca8a8bf74b6a90ab1a" 200 | dependencies: 201 | babel-helper-optimise-call-expression "^6.24.1" 202 | babel-messages "^6.23.0" 203 | babel-runtime "^6.22.0" 204 | babel-template "^6.24.1" 205 | babel-traverse "^6.24.1" 206 | babel-types "^6.24.1" 207 | 208 | babel-helpers@^6.24.1: 209 | version "6.24.1" 210 | resolved "https://registry.yarnpkg.com/babel-helpers/-/babel-helpers-6.24.1.tgz#3471de9caec388e5c850e597e58a26ddf37602b2" 211 | dependencies: 212 | babel-runtime "^6.22.0" 213 | babel-template "^6.24.1" 214 | 215 | babel-messages@^6.23.0: 216 | version "6.23.0" 217 | resolved "https://registry.yarnpkg.com/babel-messages/-/babel-messages-6.23.0.tgz#f3cdf4703858035b2a2951c6ec5edf6c62f2630e" 218 | dependencies: 219 | babel-runtime "^6.22.0" 220 | 221 | babel-plugin-check-es2015-constants@^6.22.0: 222 | version "6.22.0" 223 | resolved "https://registry.yarnpkg.com/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz#35157b101426fd2ffd3da3f75c7d1e91835bbf8a" 224 | dependencies: 225 | babel-runtime "^6.22.0" 226 | 227 | babel-plugin-transform-es2015-arrow-functions@^6.22.0: 228 | version "6.22.0" 229 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz#452692cb711d5f79dc7f85e440ce41b9f244d221" 230 | dependencies: 231 | babel-runtime "^6.22.0" 232 | 233 | babel-plugin-transform-es2015-block-scoped-functions@^6.22.0: 234 | version "6.22.0" 235 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz#bbc51b49f964d70cb8d8e0b94e820246ce3a6141" 236 | dependencies: 237 | babel-runtime "^6.22.0" 238 | 239 | babel-plugin-transform-es2015-block-scoping@^6.24.1: 240 | version "6.26.0" 241 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz#d70f5299c1308d05c12f463813b0a09e73b1895f" 242 | dependencies: 243 | babel-runtime "^6.26.0" 244 | babel-template "^6.26.0" 245 | babel-traverse "^6.26.0" 246 | babel-types "^6.26.0" 247 | lodash "^4.17.4" 248 | 249 | babel-plugin-transform-es2015-classes@^6.24.1: 250 | version "6.24.1" 251 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz#5a4c58a50c9c9461e564b4b2a3bfabc97a2584db" 252 | dependencies: 253 | babel-helper-define-map "^6.24.1" 254 | babel-helper-function-name "^6.24.1" 255 | babel-helper-optimise-call-expression "^6.24.1" 256 | babel-helper-replace-supers "^6.24.1" 257 | babel-messages "^6.23.0" 258 | babel-runtime "^6.22.0" 259 | babel-template "^6.24.1" 260 | babel-traverse "^6.24.1" 261 | babel-types "^6.24.1" 262 | 263 | babel-plugin-transform-es2015-computed-properties@^6.24.1: 264 | version "6.24.1" 265 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz#6fe2a8d16895d5634f4cd999b6d3480a308159b3" 266 | dependencies: 267 | babel-runtime "^6.22.0" 268 | babel-template "^6.24.1" 269 | 270 | babel-plugin-transform-es2015-destructuring@^6.22.0: 271 | version "6.23.0" 272 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz#997bb1f1ab967f682d2b0876fe358d60e765c56d" 273 | dependencies: 274 | babel-runtime "^6.22.0" 275 | 276 | babel-plugin-transform-es2015-duplicate-keys@^6.24.1: 277 | version "6.24.1" 278 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz#73eb3d310ca969e3ef9ec91c53741a6f1576423e" 279 | dependencies: 280 | babel-runtime "^6.22.0" 281 | babel-types "^6.24.1" 282 | 283 | babel-plugin-transform-es2015-for-of@^6.22.0: 284 | version "6.23.0" 285 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz#f47c95b2b613df1d3ecc2fdb7573623c75248691" 286 | dependencies: 287 | babel-runtime "^6.22.0" 288 | 289 | babel-plugin-transform-es2015-function-name@^6.24.1: 290 | version "6.24.1" 291 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz#834c89853bc36b1af0f3a4c5dbaa94fd8eacaa8b" 292 | dependencies: 293 | babel-helper-function-name "^6.24.1" 294 | babel-runtime "^6.22.0" 295 | babel-types "^6.24.1" 296 | 297 | babel-plugin-transform-es2015-literals@^6.22.0: 298 | version "6.22.0" 299 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz#4f54a02d6cd66cf915280019a31d31925377ca2e" 300 | dependencies: 301 | babel-runtime "^6.22.0" 302 | 303 | babel-plugin-transform-es2015-modules-amd@^6.24.1: 304 | version "6.24.1" 305 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz#3b3e54017239842d6d19c3011c4bd2f00a00d154" 306 | dependencies: 307 | babel-plugin-transform-es2015-modules-commonjs "^6.24.1" 308 | babel-runtime "^6.22.0" 309 | babel-template "^6.24.1" 310 | 311 | babel-plugin-transform-es2015-modules-commonjs@^6.24.1: 312 | version "6.26.2" 313 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.2.tgz#58a793863a9e7ca870bdc5a881117ffac27db6f3" 314 | dependencies: 315 | babel-plugin-transform-strict-mode "^6.24.1" 316 | babel-runtime "^6.26.0" 317 | babel-template "^6.26.0" 318 | babel-types "^6.26.0" 319 | 320 | babel-plugin-transform-es2015-modules-systemjs@^6.24.1: 321 | version "6.24.1" 322 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz#ff89a142b9119a906195f5f106ecf305d9407d23" 323 | dependencies: 324 | babel-helper-hoist-variables "^6.24.1" 325 | babel-runtime "^6.22.0" 326 | babel-template "^6.24.1" 327 | 328 | babel-plugin-transform-es2015-modules-umd@^6.24.1: 329 | version "6.24.1" 330 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz#ac997e6285cd18ed6176adb607d602344ad38468" 331 | dependencies: 332 | babel-plugin-transform-es2015-modules-amd "^6.24.1" 333 | babel-runtime "^6.22.0" 334 | babel-template "^6.24.1" 335 | 336 | babel-plugin-transform-es2015-object-super@^6.24.1: 337 | version "6.24.1" 338 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz#24cef69ae21cb83a7f8603dad021f572eb278f8d" 339 | dependencies: 340 | babel-helper-replace-supers "^6.24.1" 341 | babel-runtime "^6.22.0" 342 | 343 | babel-plugin-transform-es2015-parameters@^6.24.1: 344 | version "6.24.1" 345 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz#57ac351ab49caf14a97cd13b09f66fdf0a625f2b" 346 | dependencies: 347 | babel-helper-call-delegate "^6.24.1" 348 | babel-helper-get-function-arity "^6.24.1" 349 | babel-runtime "^6.22.0" 350 | babel-template "^6.24.1" 351 | babel-traverse "^6.24.1" 352 | babel-types "^6.24.1" 353 | 354 | babel-plugin-transform-es2015-shorthand-properties@^6.24.1: 355 | version "6.24.1" 356 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz#24f875d6721c87661bbd99a4622e51f14de38aa0" 357 | dependencies: 358 | babel-runtime "^6.22.0" 359 | babel-types "^6.24.1" 360 | 361 | babel-plugin-transform-es2015-spread@^6.22.0: 362 | version "6.22.0" 363 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz#d6d68a99f89aedc4536c81a542e8dd9f1746f8d1" 364 | dependencies: 365 | babel-runtime "^6.22.0" 366 | 367 | babel-plugin-transform-es2015-sticky-regex@^6.24.1: 368 | version "6.24.1" 369 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz#00c1cdb1aca71112cdf0cf6126c2ed6b457ccdbc" 370 | dependencies: 371 | babel-helper-regex "^6.24.1" 372 | babel-runtime "^6.22.0" 373 | babel-types "^6.24.1" 374 | 375 | babel-plugin-transform-es2015-template-literals@^6.22.0: 376 | version "6.22.0" 377 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz#a84b3450f7e9f8f1f6839d6d687da84bb1236d8d" 378 | dependencies: 379 | babel-runtime "^6.22.0" 380 | 381 | babel-plugin-transform-es2015-typeof-symbol@^6.22.0: 382 | version "6.23.0" 383 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz#dec09f1cddff94b52ac73d505c84df59dcceb372" 384 | dependencies: 385 | babel-runtime "^6.22.0" 386 | 387 | babel-plugin-transform-es2015-unicode-regex@^6.24.1: 388 | version "6.24.1" 389 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz#d38b12f42ea7323f729387f18a7c5ae1faeb35e9" 390 | dependencies: 391 | babel-helper-regex "^6.24.1" 392 | babel-runtime "^6.22.0" 393 | regexpu-core "^2.0.0" 394 | 395 | babel-plugin-transform-regenerator@^6.24.1: 396 | version "6.26.0" 397 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz#e0703696fbde27f0a3efcacf8b4dca2f7b3a8f2f" 398 | dependencies: 399 | regenerator-transform "^0.10.0" 400 | 401 | babel-plugin-transform-strict-mode@^6.24.1: 402 | version "6.24.1" 403 | resolved "https://registry.yarnpkg.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz#d5faf7aa578a65bbe591cf5edae04a0c67020758" 404 | dependencies: 405 | babel-runtime "^6.22.0" 406 | babel-types "^6.24.1" 407 | 408 | babel-polyfill@^6.26.0: 409 | version "6.26.0" 410 | resolved "https://registry.yarnpkg.com/babel-polyfill/-/babel-polyfill-6.26.0.tgz#379937abc67d7895970adc621f284cd966cf2153" 411 | dependencies: 412 | babel-runtime "^6.26.0" 413 | core-js "^2.5.0" 414 | regenerator-runtime "^0.10.5" 415 | 416 | babel-preset-es2015@^6.24.1: 417 | version "6.24.1" 418 | resolved "https://registry.yarnpkg.com/babel-preset-es2015/-/babel-preset-es2015-6.24.1.tgz#d44050d6bc2c9feea702aaf38d727a0210538939" 419 | dependencies: 420 | babel-plugin-check-es2015-constants "^6.22.0" 421 | babel-plugin-transform-es2015-arrow-functions "^6.22.0" 422 | babel-plugin-transform-es2015-block-scoped-functions "^6.22.0" 423 | babel-plugin-transform-es2015-block-scoping "^6.24.1" 424 | babel-plugin-transform-es2015-classes "^6.24.1" 425 | babel-plugin-transform-es2015-computed-properties "^6.24.1" 426 | babel-plugin-transform-es2015-destructuring "^6.22.0" 427 | babel-plugin-transform-es2015-duplicate-keys "^6.24.1" 428 | babel-plugin-transform-es2015-for-of "^6.22.0" 429 | babel-plugin-transform-es2015-function-name "^6.24.1" 430 | babel-plugin-transform-es2015-literals "^6.22.0" 431 | babel-plugin-transform-es2015-modules-amd "^6.24.1" 432 | babel-plugin-transform-es2015-modules-commonjs "^6.24.1" 433 | babel-plugin-transform-es2015-modules-systemjs "^6.24.1" 434 | babel-plugin-transform-es2015-modules-umd "^6.24.1" 435 | babel-plugin-transform-es2015-object-super "^6.24.1" 436 | babel-plugin-transform-es2015-parameters "^6.24.1" 437 | babel-plugin-transform-es2015-shorthand-properties "^6.24.1" 438 | babel-plugin-transform-es2015-spread "^6.22.0" 439 | babel-plugin-transform-es2015-sticky-regex "^6.24.1" 440 | babel-plugin-transform-es2015-template-literals "^6.22.0" 441 | babel-plugin-transform-es2015-typeof-symbol "^6.22.0" 442 | babel-plugin-transform-es2015-unicode-regex "^6.24.1" 443 | babel-plugin-transform-regenerator "^6.24.1" 444 | 445 | babel-register@^6.26.0: 446 | version "6.26.0" 447 | resolved "https://registry.yarnpkg.com/babel-register/-/babel-register-6.26.0.tgz#6ed021173e2fcb486d7acb45c6009a856f647071" 448 | dependencies: 449 | babel-core "^6.26.0" 450 | babel-runtime "^6.26.0" 451 | core-js "^2.5.0" 452 | home-or-tmp "^2.0.0" 453 | lodash "^4.17.4" 454 | mkdirp "^0.5.1" 455 | source-map-support "^0.4.15" 456 | 457 | babel-runtime@^6.18.0, babel-runtime@^6.22.0, babel-runtime@^6.26.0: 458 | version "6.26.0" 459 | resolved "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz#965c7058668e82b55d7bfe04ff2337bc8b5647fe" 460 | dependencies: 461 | core-js "^2.4.0" 462 | regenerator-runtime "^0.11.0" 463 | 464 | babel-template@^6.24.1, babel-template@^6.26.0: 465 | version "6.26.0" 466 | resolved "https://registry.yarnpkg.com/babel-template/-/babel-template-6.26.0.tgz#de03e2d16396b069f46dd9fff8521fb1a0e35e02" 467 | dependencies: 468 | babel-runtime "^6.26.0" 469 | babel-traverse "^6.26.0" 470 | babel-types "^6.26.0" 471 | babylon "^6.18.0" 472 | lodash "^4.17.4" 473 | 474 | babel-traverse@^6.24.1, babel-traverse@^6.26.0: 475 | version "6.26.0" 476 | resolved "https://registry.yarnpkg.com/babel-traverse/-/babel-traverse-6.26.0.tgz#46a9cbd7edcc62c8e5c064e2d2d8d0f4035766ee" 477 | dependencies: 478 | babel-code-frame "^6.26.0" 479 | babel-messages "^6.23.0" 480 | babel-runtime "^6.26.0" 481 | babel-types "^6.26.0" 482 | babylon "^6.18.0" 483 | debug "^2.6.8" 484 | globals "^9.18.0" 485 | invariant "^2.2.2" 486 | lodash "^4.17.4" 487 | 488 | babel-types@^6.19.0, babel-types@^6.24.1, babel-types@^6.26.0: 489 | version "6.26.0" 490 | resolved "https://registry.yarnpkg.com/babel-types/-/babel-types-6.26.0.tgz#a3b073f94ab49eb6fa55cd65227a334380632497" 491 | dependencies: 492 | babel-runtime "^6.26.0" 493 | esutils "^2.0.2" 494 | lodash "^4.17.4" 495 | to-fast-properties "^1.0.3" 496 | 497 | babylon@^6.18.0: 498 | version "6.18.0" 499 | resolved "https://registry.yarnpkg.com/babylon/-/babylon-6.18.0.tgz#af2f3b88fa6f5c1e4c634d1a0f8eac4f55b395e3" 500 | 501 | balanced-match@^1.0.0: 502 | version "1.0.0" 503 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" 504 | 505 | basic-auth@~2.0.0: 506 | version "2.0.0" 507 | resolved "https://registry.yarnpkg.com/basic-auth/-/basic-auth-2.0.0.tgz#015db3f353e02e56377755f962742e8981e7bbba" 508 | dependencies: 509 | safe-buffer "5.1.1" 510 | 511 | binary-extensions@^1.0.0: 512 | version "1.11.0" 513 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-1.11.0.tgz#46aa1751fb6a2f93ee5e689bb1087d4b14c6c205" 514 | 515 | bluebird@3.5.0: 516 | version "3.5.0" 517 | resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.5.0.tgz#791420d7f551eea2897453a8a77653f96606d67c" 518 | 519 | body-parser@1.18.2, body-parser@^1.18.2: 520 | version "1.18.2" 521 | resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.18.2.tgz#87678a19d84b47d859b83199bd59bce222b10454" 522 | dependencies: 523 | bytes "3.0.0" 524 | content-type "~1.0.4" 525 | debug "2.6.9" 526 | depd "~1.1.1" 527 | http-errors "~1.6.2" 528 | iconv-lite "0.4.19" 529 | on-finished "~2.3.0" 530 | qs "6.5.1" 531 | raw-body "2.3.2" 532 | type-is "~1.6.15" 533 | 534 | brace-expansion@^1.1.7: 535 | version "1.1.11" 536 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" 537 | dependencies: 538 | balanced-match "^1.0.0" 539 | concat-map "0.0.1" 540 | 541 | braces@^1.8.2: 542 | version "1.8.5" 543 | resolved "https://registry.yarnpkg.com/braces/-/braces-1.8.5.tgz#ba77962e12dff969d6b76711e914b737857bf6a7" 544 | dependencies: 545 | expand-range "^1.8.1" 546 | preserve "^0.2.0" 547 | repeat-element "^1.1.2" 548 | 549 | bson@~1.0.4: 550 | version "1.0.6" 551 | resolved "https://registry.yarnpkg.com/bson/-/bson-1.0.6.tgz#444db59ddd4c24f0cb063aabdc5c8c7b0ceca912" 552 | 553 | buffer-equal-constant-time@1.0.1: 554 | version "1.0.1" 555 | resolved "https://registry.yarnpkg.com/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz#f8e71132f7ffe6e01a5c9697a4c6f3e48d5cc819" 556 | 557 | bytes@3.0.0: 558 | version "3.0.0" 559 | resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048" 560 | 561 | chalk@^1.1.3: 562 | version "1.1.3" 563 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz#a8115c55e4a702fe4d150abd3872822a7e09fc98" 564 | dependencies: 565 | ansi-styles "^2.2.1" 566 | escape-string-regexp "^1.0.2" 567 | has-ansi "^2.0.0" 568 | strip-ansi "^3.0.0" 569 | supports-color "^2.0.0" 570 | 571 | chokidar@^1.6.1: 572 | version "1.7.0" 573 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-1.7.0.tgz#798e689778151c8076b4b360e5edd28cda2bb468" 574 | dependencies: 575 | anymatch "^1.3.0" 576 | async-each "^1.0.0" 577 | glob-parent "^2.0.0" 578 | inherits "^2.0.1" 579 | is-binary-path "^1.0.0" 580 | is-glob "^2.0.0" 581 | path-is-absolute "^1.0.0" 582 | readdirp "^2.0.0" 583 | optionalDependencies: 584 | fsevents "^1.0.0" 585 | 586 | chownr@^1.0.1: 587 | version "1.0.1" 588 | resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.0.1.tgz#e2a75042a9551908bebd25b8523d5f9769d79181" 589 | 590 | code-point-at@^1.0.0: 591 | version "1.1.0" 592 | resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" 593 | 594 | commander@^2.11.0: 595 | version "2.15.1" 596 | resolved "https://registry.yarnpkg.com/commander/-/commander-2.15.1.tgz#df46e867d0fc2aec66a34662b406a9ccafff5b0f" 597 | 598 | concat-map@0.0.1: 599 | version "0.0.1" 600 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 601 | 602 | console-control-strings@^1.0.0, console-control-strings@~1.1.0: 603 | version "1.1.0" 604 | resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" 605 | 606 | content-disposition@0.5.2: 607 | version "0.5.2" 608 | resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.2.tgz#0cf68bb9ddf5f2be7961c3a85178cb85dba78cb4" 609 | 610 | content-type@~1.0.4: 611 | version "1.0.4" 612 | resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" 613 | 614 | convert-source-map@^1.5.0, convert-source-map@^1.5.1: 615 | version "1.5.1" 616 | resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.5.1.tgz#b8278097b9bc229365de5c62cf5fcaed8b5599e5" 617 | 618 | cookie-signature@1.0.6: 619 | version "1.0.6" 620 | resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" 621 | 622 | cookie@0.3.1: 623 | version "0.3.1" 624 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.3.1.tgz#e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb" 625 | 626 | core-js@^2.4.0, core-js@^2.5.0: 627 | version "2.5.5" 628 | resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.5.5.tgz#b14dde936c640c0579a6b50cabcc132dd6127e3b" 629 | 630 | core-util-is@~1.0.0: 631 | version "1.0.2" 632 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" 633 | 634 | crypto@^1.0.1: 635 | version "1.0.1" 636 | resolved "https://registry.yarnpkg.com/crypto/-/crypto-1.0.1.tgz#2af1b7cad8175d24c8a1b0778255794a21803037" 637 | 638 | debug@2.6.9, debug@^2.1.2, debug@^2.6.8, debug@^2.6.9: 639 | version "2.6.9" 640 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" 641 | dependencies: 642 | ms "2.0.0" 643 | 644 | deep-extend@~0.4.0: 645 | version "0.4.2" 646 | resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.4.2.tgz#48b699c27e334bf89f10892be432f6e4c7d34a7f" 647 | 648 | delegates@^1.0.0: 649 | version "1.0.0" 650 | resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" 651 | 652 | depd@1.1.1: 653 | version "1.1.1" 654 | resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.1.tgz#5783b4e1c459f06fa5ca27f991f3d06e7a310359" 655 | 656 | depd@~1.1.1, depd@~1.1.2: 657 | version "1.1.2" 658 | resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" 659 | 660 | destroy@~1.0.4: 661 | version "1.0.4" 662 | resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" 663 | 664 | detect-indent@^4.0.0: 665 | version "4.0.0" 666 | resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-4.0.0.tgz#f76d064352cdf43a1cb6ce619c4ee3a9475de208" 667 | dependencies: 668 | repeating "^2.0.0" 669 | 670 | detect-libc@^1.0.2: 671 | version "1.0.3" 672 | resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" 673 | 674 | ecdsa-sig-formatter@1.0.10: 675 | version "1.0.10" 676 | resolved "https://registry.yarnpkg.com/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.10.tgz#1c595000f04a8897dfb85000892a0f4c33af86c3" 677 | dependencies: 678 | safe-buffer "^5.0.1" 679 | 680 | ee-first@1.1.1: 681 | version "1.1.1" 682 | resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" 683 | 684 | encodeurl@~1.0.2: 685 | version "1.0.2" 686 | resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" 687 | 688 | escape-html@~1.0.3: 689 | version "1.0.3" 690 | resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" 691 | 692 | escape-string-regexp@^1.0.2: 693 | version "1.0.5" 694 | resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4" 695 | 696 | esutils@^2.0.2: 697 | version "2.0.2" 698 | resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.2.tgz#0abf4f1caa5bcb1f7a9d8acc6dea4faaa04bac9b" 699 | 700 | etag@~1.8.1: 701 | version "1.8.1" 702 | resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" 703 | 704 | expand-brackets@^0.1.4: 705 | version "0.1.5" 706 | resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-0.1.5.tgz#df07284e342a807cd733ac5af72411e581d1177b" 707 | dependencies: 708 | is-posix-bracket "^0.1.0" 709 | 710 | expand-range@^1.8.1: 711 | version "1.8.2" 712 | resolved "https://registry.yarnpkg.com/expand-range/-/expand-range-1.8.2.tgz#a299effd335fe2721ebae8e257ec79644fc85337" 713 | dependencies: 714 | fill-range "^2.1.0" 715 | 716 | express-jwt@^5.3.1: 717 | version "5.3.1" 718 | resolved "https://registry.yarnpkg.com/express-jwt/-/express-jwt-5.3.1.tgz#66f05c7dddb5409c037346a98b88965bb10ea4ae" 719 | dependencies: 720 | async "^1.5.0" 721 | express-unless "^0.3.0" 722 | jsonwebtoken "^8.1.0" 723 | lodash.set "^4.0.0" 724 | 725 | express-unless@^0.3.0: 726 | version "0.3.1" 727 | resolved "https://registry.yarnpkg.com/express-unless/-/express-unless-0.3.1.tgz#2557c146e75beb903e2d247f9b5ba01452696e20" 728 | 729 | express@^4.16.3: 730 | version "4.16.3" 731 | resolved "https://registry.yarnpkg.com/express/-/express-4.16.3.tgz#6af8a502350db3246ecc4becf6b5a34d22f7ed53" 732 | dependencies: 733 | accepts "~1.3.5" 734 | array-flatten "1.1.1" 735 | body-parser "1.18.2" 736 | content-disposition "0.5.2" 737 | content-type "~1.0.4" 738 | cookie "0.3.1" 739 | cookie-signature "1.0.6" 740 | debug "2.6.9" 741 | depd "~1.1.2" 742 | encodeurl "~1.0.2" 743 | escape-html "~1.0.3" 744 | etag "~1.8.1" 745 | finalhandler "1.1.1" 746 | fresh "0.5.2" 747 | merge-descriptors "1.0.1" 748 | methods "~1.1.2" 749 | on-finished "~2.3.0" 750 | parseurl "~1.3.2" 751 | path-to-regexp "0.1.7" 752 | proxy-addr "~2.0.3" 753 | qs "6.5.1" 754 | range-parser "~1.2.0" 755 | safe-buffer "5.1.1" 756 | send "0.16.2" 757 | serve-static "1.13.2" 758 | setprototypeof "1.1.0" 759 | statuses "~1.4.0" 760 | type-is "~1.6.16" 761 | utils-merge "1.0.1" 762 | vary "~1.1.2" 763 | 764 | extglob@^0.3.1: 765 | version "0.3.2" 766 | resolved "https://registry.yarnpkg.com/extglob/-/extglob-0.3.2.tgz#2e18ff3d2f49ab2765cec9023f011daa8d8349a1" 767 | dependencies: 768 | is-extglob "^1.0.0" 769 | 770 | filename-regex@^2.0.0: 771 | version "2.0.1" 772 | resolved "https://registry.yarnpkg.com/filename-regex/-/filename-regex-2.0.1.tgz#c1c4b9bee3e09725ddb106b75c1e301fe2f18b26" 773 | 774 | fill-range@^2.1.0: 775 | version "2.2.3" 776 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-2.2.3.tgz#50b77dfd7e469bc7492470963699fe7a8485a723" 777 | dependencies: 778 | is-number "^2.1.0" 779 | isobject "^2.0.0" 780 | randomatic "^1.1.3" 781 | repeat-element "^1.1.2" 782 | repeat-string "^1.5.2" 783 | 784 | finalhandler@1.1.1: 785 | version "1.1.1" 786 | resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.1.tgz#eebf4ed840079c83f4249038c9d703008301b105" 787 | dependencies: 788 | debug "2.6.9" 789 | encodeurl "~1.0.2" 790 | escape-html "~1.0.3" 791 | on-finished "~2.3.0" 792 | parseurl "~1.3.2" 793 | statuses "~1.4.0" 794 | unpipe "~1.0.0" 795 | 796 | for-in@^1.0.1: 797 | version "1.0.2" 798 | resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80" 799 | 800 | for-own@^0.1.4: 801 | version "0.1.5" 802 | resolved "https://registry.yarnpkg.com/for-own/-/for-own-0.1.5.tgz#5265c681a4f294dabbf17c9509b6763aa84510ce" 803 | dependencies: 804 | for-in "^1.0.1" 805 | 806 | forwarded@~0.1.2: 807 | version "0.1.2" 808 | resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84" 809 | 810 | fresh@0.5.2: 811 | version "0.5.2" 812 | resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" 813 | 814 | fs-minipass@^1.2.5: 815 | version "1.2.5" 816 | resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-1.2.5.tgz#06c277218454ec288df77ada54a03b8702aacb9d" 817 | dependencies: 818 | minipass "^2.2.1" 819 | 820 | fs-readdir-recursive@^1.0.0: 821 | version "1.1.0" 822 | resolved "https://registry.yarnpkg.com/fs-readdir-recursive/-/fs-readdir-recursive-1.1.0.tgz#e32fc030a2ccee44a6b5371308da54be0b397d27" 823 | 824 | fs.realpath@^1.0.0: 825 | version "1.0.0" 826 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 827 | 828 | fsevents@^1.0.0: 829 | version "1.2.3" 830 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.2.3.tgz#08292982e7059f6674c93d8b829c1e8604979ac0" 831 | dependencies: 832 | nan "^2.9.2" 833 | node-pre-gyp "^0.9.0" 834 | 835 | gauge@~2.7.3: 836 | version "2.7.4" 837 | resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7" 838 | dependencies: 839 | aproba "^1.0.3" 840 | console-control-strings "^1.0.0" 841 | has-unicode "^2.0.0" 842 | object-assign "^4.1.0" 843 | signal-exit "^3.0.0" 844 | string-width "^1.0.1" 845 | strip-ansi "^3.0.1" 846 | wide-align "^1.1.0" 847 | 848 | glob-base@^0.3.0: 849 | version "0.3.0" 850 | resolved "https://registry.yarnpkg.com/glob-base/-/glob-base-0.3.0.tgz#dbb164f6221b1c0b1ccf82aea328b497df0ea3c4" 851 | dependencies: 852 | glob-parent "^2.0.0" 853 | is-glob "^2.0.0" 854 | 855 | glob-parent@^2.0.0: 856 | version "2.0.0" 857 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-2.0.0.tgz#81383d72db054fcccf5336daa902f182f6edbb28" 858 | dependencies: 859 | is-glob "^2.0.0" 860 | 861 | glob@^7.0.5, glob@^7.1.2: 862 | version "7.1.2" 863 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.2.tgz#c19c9df9a028702d678612384a6552404c636d15" 864 | dependencies: 865 | fs.realpath "^1.0.0" 866 | inflight "^1.0.4" 867 | inherits "2" 868 | minimatch "^3.0.4" 869 | once "^1.3.0" 870 | path-is-absolute "^1.0.0" 871 | 872 | globals@^9.18.0: 873 | version "9.18.0" 874 | resolved "https://registry.yarnpkg.com/globals/-/globals-9.18.0.tgz#aa3896b3e69b487f17e31ed2143d69a8e30c2d8a" 875 | 876 | graceful-fs@^4.1.2, graceful-fs@^4.1.4: 877 | version "4.1.11" 878 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.1.11.tgz#0e8bdfe4d1ddb8854d64e04ea7c00e2a026e5658" 879 | 880 | has-ansi@^2.0.0: 881 | version "2.0.0" 882 | resolved "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz#34f5049ce1ecdf2b0649af3ef24e45ed35416d91" 883 | dependencies: 884 | ansi-regex "^2.0.0" 885 | 886 | has-unicode@^2.0.0: 887 | version "2.0.1" 888 | resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" 889 | 890 | home-or-tmp@^2.0.0: 891 | version "2.0.0" 892 | resolved "https://registry.yarnpkg.com/home-or-tmp/-/home-or-tmp-2.0.0.tgz#e36c3f2d2cae7d746a857e38d18d5f32a7882db8" 893 | dependencies: 894 | os-homedir "^1.0.0" 895 | os-tmpdir "^1.0.1" 896 | 897 | http-errors@1.6.2: 898 | version "1.6.2" 899 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.2.tgz#0a002cc85707192a7e7946ceedc11155f60ec736" 900 | dependencies: 901 | depd "1.1.1" 902 | inherits "2.0.3" 903 | setprototypeof "1.0.3" 904 | statuses ">= 1.3.1 < 2" 905 | 906 | http-errors@~1.6.2: 907 | version "1.6.3" 908 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.6.3.tgz#8b55680bb4be283a0b5bf4ea2e38580be1d9320d" 909 | dependencies: 910 | depd "~1.1.2" 911 | inherits "2.0.3" 912 | setprototypeof "1.1.0" 913 | statuses ">= 1.4.0 < 2" 914 | 915 | iconv-lite@0.4.19: 916 | version "0.4.19" 917 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.19.tgz#f7468f60135f5e5dad3399c0a81be9a1603a082b" 918 | 919 | iconv-lite@^0.4.4: 920 | version "0.4.21" 921 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.21.tgz#c47f8733d02171189ebc4a400f3218d348094798" 922 | dependencies: 923 | safer-buffer "^2.1.0" 924 | 925 | ignore-walk@^3.0.1: 926 | version "3.0.1" 927 | resolved "https://registry.yarnpkg.com/ignore-walk/-/ignore-walk-3.0.1.tgz#a83e62e7d272ac0e3b551aaa82831a19b69f82f8" 928 | dependencies: 929 | minimatch "^3.0.4" 930 | 931 | inflight@^1.0.4: 932 | version "1.0.6" 933 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 934 | dependencies: 935 | once "^1.3.0" 936 | wrappy "1" 937 | 938 | inherits@2, inherits@2.0.3, inherits@^2.0.1, inherits@~2.0.3: 939 | version "2.0.3" 940 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" 941 | 942 | ini@~1.3.0: 943 | version "1.3.5" 944 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.5.tgz#eee25f56db1c9ec6085e0c22778083f596abf927" 945 | 946 | invariant@^2.2.2: 947 | version "2.2.4" 948 | resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6" 949 | dependencies: 950 | loose-envify "^1.0.0" 951 | 952 | ipaddr.js@1.6.0: 953 | version "1.6.0" 954 | resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.6.0.tgz#e3fa357b773da619f26e95f049d055c72796f86b" 955 | 956 | is-binary-path@^1.0.0: 957 | version "1.0.1" 958 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898" 959 | dependencies: 960 | binary-extensions "^1.0.0" 961 | 962 | is-buffer@^1.1.5: 963 | version "1.1.6" 964 | resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be" 965 | 966 | is-dotfile@^1.0.0: 967 | version "1.0.3" 968 | resolved "https://registry.yarnpkg.com/is-dotfile/-/is-dotfile-1.0.3.tgz#a6a2f32ffd2dfb04f5ca25ecd0f6b83cf798a1e1" 969 | 970 | is-equal-shallow@^0.1.3: 971 | version "0.1.3" 972 | resolved "https://registry.yarnpkg.com/is-equal-shallow/-/is-equal-shallow-0.1.3.tgz#2238098fc221de0bcfa5d9eac4c45d638aa1c534" 973 | dependencies: 974 | is-primitive "^2.0.0" 975 | 976 | is-extendable@^0.1.1: 977 | version "0.1.1" 978 | resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89" 979 | 980 | is-extglob@^1.0.0: 981 | version "1.0.0" 982 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-1.0.0.tgz#ac468177c4943405a092fc8f29760c6ffc6206c0" 983 | 984 | is-finite@^1.0.0: 985 | version "1.0.2" 986 | resolved "https://registry.yarnpkg.com/is-finite/-/is-finite-1.0.2.tgz#cc6677695602be550ef11e8b4aa6305342b6d0aa" 987 | dependencies: 988 | number-is-nan "^1.0.0" 989 | 990 | is-fullwidth-code-point@^1.0.0: 991 | version "1.0.0" 992 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" 993 | dependencies: 994 | number-is-nan "^1.0.0" 995 | 996 | is-glob@^2.0.0, is-glob@^2.0.1: 997 | version "2.0.1" 998 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-2.0.1.tgz#d096f926a3ded5600f3fdfd91198cb0888c2d863" 999 | dependencies: 1000 | is-extglob "^1.0.0" 1001 | 1002 | is-number@^2.1.0: 1003 | version "2.1.0" 1004 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-2.1.0.tgz#01fcbbb393463a548f2f466cce16dece49db908f" 1005 | dependencies: 1006 | kind-of "^3.0.2" 1007 | 1008 | is-number@^3.0.0: 1009 | version "3.0.0" 1010 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195" 1011 | dependencies: 1012 | kind-of "^3.0.2" 1013 | 1014 | is-posix-bracket@^0.1.0: 1015 | version "0.1.1" 1016 | resolved "https://registry.yarnpkg.com/is-posix-bracket/-/is-posix-bracket-0.1.1.tgz#3334dc79774368e92f016e6fbc0a88f5cd6e6bc4" 1017 | 1018 | is-primitive@^2.0.0: 1019 | version "2.0.0" 1020 | resolved "https://registry.yarnpkg.com/is-primitive/-/is-primitive-2.0.0.tgz#207bab91638499c07b2adf240a41a87210034575" 1021 | 1022 | isarray@1.0.0, isarray@~1.0.0: 1023 | version "1.0.0" 1024 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" 1025 | 1026 | isobject@^2.0.0: 1027 | version "2.1.0" 1028 | resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89" 1029 | dependencies: 1030 | isarray "1.0.0" 1031 | 1032 | js-tokens@^3.0.0, js-tokens@^3.0.2: 1033 | version "3.0.2" 1034 | resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz#9866df395102130e38f7f996bceb65443209c25b" 1035 | 1036 | jsesc@^1.3.0: 1037 | version "1.3.0" 1038 | resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-1.3.0.tgz#46c3fec8c1892b12b0833db9bc7622176dbab34b" 1039 | 1040 | jsesc@~0.5.0: 1041 | version "0.5.0" 1042 | resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d" 1043 | 1044 | json5@^0.5.1: 1045 | version "0.5.1" 1046 | resolved "https://registry.yarnpkg.com/json5/-/json5-0.5.1.tgz#1eade7acc012034ad84e2396767ead9fa5495821" 1047 | 1048 | jsonwebtoken@^8.1.0, jsonwebtoken@^8.2.1: 1049 | version "8.2.1" 1050 | resolved "https://registry.yarnpkg.com/jsonwebtoken/-/jsonwebtoken-8.2.1.tgz#333ee39aa8f238f32fa41693e7a2fb7e42f82b31" 1051 | dependencies: 1052 | jws "^3.1.4" 1053 | lodash.includes "^4.3.0" 1054 | lodash.isboolean "^3.0.3" 1055 | lodash.isinteger "^4.0.4" 1056 | lodash.isnumber "^3.0.3" 1057 | lodash.isplainobject "^4.0.6" 1058 | lodash.isstring "^4.0.1" 1059 | lodash.once "^4.0.0" 1060 | ms "^2.1.1" 1061 | xtend "^4.0.1" 1062 | 1063 | jwa@^1.1.5: 1064 | version "1.1.6" 1065 | resolved "https://registry.yarnpkg.com/jwa/-/jwa-1.1.6.tgz#87240e76c9808dbde18783cf2264ef4929ee50e6" 1066 | dependencies: 1067 | buffer-equal-constant-time "1.0.1" 1068 | ecdsa-sig-formatter "1.0.10" 1069 | safe-buffer "^5.0.1" 1070 | 1071 | jws@^3.1.4: 1072 | version "3.1.5" 1073 | resolved "https://registry.yarnpkg.com/jws/-/jws-3.1.5.tgz#80d12d05b293d1e841e7cb8b4e69e561adcf834f" 1074 | dependencies: 1075 | jwa "^1.1.5" 1076 | safe-buffer "^5.0.1" 1077 | 1078 | kareem@2.0.6: 1079 | version "2.0.6" 1080 | resolved "https://registry.yarnpkg.com/kareem/-/kareem-2.0.6.tgz#011ed59fd718bb147c63141a799fc888cd5a211b" 1081 | 1082 | kind-of@^3.0.2: 1083 | version "3.2.2" 1084 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64" 1085 | dependencies: 1086 | is-buffer "^1.1.5" 1087 | 1088 | kind-of@^4.0.0: 1089 | version "4.0.0" 1090 | resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57" 1091 | dependencies: 1092 | is-buffer "^1.1.5" 1093 | 1094 | lodash.get@4.4.2: 1095 | version "4.4.2" 1096 | resolved "https://registry.yarnpkg.com/lodash.get/-/lodash.get-4.4.2.tgz#2d177f652fa31e939b4438d5341499dfa3825e99" 1097 | 1098 | lodash.includes@^4.3.0: 1099 | version "4.3.0" 1100 | resolved "https://registry.yarnpkg.com/lodash.includes/-/lodash.includes-4.3.0.tgz#60bb98a87cb923c68ca1e51325483314849f553f" 1101 | 1102 | lodash.isboolean@^3.0.3: 1103 | version "3.0.3" 1104 | resolved "https://registry.yarnpkg.com/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz#6c2e171db2a257cd96802fd43b01b20d5f5870f6" 1105 | 1106 | lodash.isinteger@^4.0.4: 1107 | version "4.0.4" 1108 | resolved "https://registry.yarnpkg.com/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz#619c0af3d03f8b04c31f5882840b77b11cd68343" 1109 | 1110 | lodash.isnumber@^3.0.3: 1111 | version "3.0.3" 1112 | resolved "https://registry.yarnpkg.com/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz#3ce76810c5928d03352301ac287317f11c0b1ffc" 1113 | 1114 | lodash.isplainobject@^4.0.6: 1115 | version "4.0.6" 1116 | resolved "https://registry.yarnpkg.com/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz#7c526a52d89b45c45cc690b88163be0497f550cb" 1117 | 1118 | lodash.isstring@^4.0.1: 1119 | version "4.0.1" 1120 | resolved "https://registry.yarnpkg.com/lodash.isstring/-/lodash.isstring-4.0.1.tgz#d527dfb5456eca7cc9bb95d5daeaf88ba54a5451" 1121 | 1122 | lodash.once@^4.0.0: 1123 | version "4.1.1" 1124 | resolved "https://registry.yarnpkg.com/lodash.once/-/lodash.once-4.1.1.tgz#0dd3971213c7c56df880977d504c88fb471a97ac" 1125 | 1126 | lodash.set@^4.0.0: 1127 | version "4.3.2" 1128 | resolved "https://registry.yarnpkg.com/lodash.set/-/lodash.set-4.3.2.tgz#d8757b1da807dde24816b0d6a84bea1a76230b23" 1129 | 1130 | lodash@^4.14.0, lodash@^4.17.4: 1131 | version "4.17.10" 1132 | resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.10.tgz#1b7793cf7259ea38fb3661d4d38b3260af8ae4e7" 1133 | 1134 | loose-envify@^1.0.0: 1135 | version "1.3.1" 1136 | resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.3.1.tgz#d1a8ad33fa9ce0e713d65fdd0ac8b748d478c848" 1137 | dependencies: 1138 | js-tokens "^3.0.0" 1139 | 1140 | media-typer@0.3.0: 1141 | version "0.3.0" 1142 | resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" 1143 | 1144 | merge-descriptors@1.0.1: 1145 | version "1.0.1" 1146 | resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" 1147 | 1148 | methods@~1.1.2: 1149 | version "1.1.2" 1150 | resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" 1151 | 1152 | micromatch@^2.1.5: 1153 | version "2.3.11" 1154 | resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-2.3.11.tgz#86677c97d1720b363431d04d0d15293bd38c1565" 1155 | dependencies: 1156 | arr-diff "^2.0.0" 1157 | array-unique "^0.2.1" 1158 | braces "^1.8.2" 1159 | expand-brackets "^0.1.4" 1160 | extglob "^0.3.1" 1161 | filename-regex "^2.0.0" 1162 | is-extglob "^1.0.0" 1163 | is-glob "^2.0.1" 1164 | kind-of "^3.0.2" 1165 | normalize-path "^2.0.1" 1166 | object.omit "^2.0.0" 1167 | parse-glob "^3.0.4" 1168 | regex-cache "^0.4.2" 1169 | 1170 | mime-db@~1.33.0: 1171 | version "1.33.0" 1172 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.33.0.tgz#a3492050a5cb9b63450541e39d9788d2272783db" 1173 | 1174 | mime-types@~2.1.18: 1175 | version "2.1.18" 1176 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.18.tgz#6f323f60a83d11146f831ff11fd66e2fe5503bb8" 1177 | dependencies: 1178 | mime-db "~1.33.0" 1179 | 1180 | mime@1.4.1: 1181 | version "1.4.1" 1182 | resolved "https://registry.yarnpkg.com/mime/-/mime-1.4.1.tgz#121f9ebc49e3766f311a76e1fa1c8003c4b03aa6" 1183 | 1184 | minimatch@^3.0.2, minimatch@^3.0.4: 1185 | version "3.0.4" 1186 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" 1187 | dependencies: 1188 | brace-expansion "^1.1.7" 1189 | 1190 | minimist@0.0.8: 1191 | version "0.0.8" 1192 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d" 1193 | 1194 | minimist@^1.2.0: 1195 | version "1.2.0" 1196 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284" 1197 | 1198 | minipass@^2.2.1, minipass@^2.2.4: 1199 | version "2.2.4" 1200 | resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.2.4.tgz#03c824d84551ec38a8d1bb5bc350a5a30a354a40" 1201 | dependencies: 1202 | safe-buffer "^5.1.1" 1203 | yallist "^3.0.0" 1204 | 1205 | minizlib@^1.1.0: 1206 | version "1.1.0" 1207 | resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-1.1.0.tgz#11e13658ce46bc3a70a267aac58359d1e0c29ceb" 1208 | dependencies: 1209 | minipass "^2.2.1" 1210 | 1211 | mkdirp@^0.5.0, mkdirp@^0.5.1: 1212 | version "0.5.1" 1213 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903" 1214 | dependencies: 1215 | minimist "0.0.8" 1216 | 1217 | mongodb-core@3.0.7: 1218 | version "3.0.7" 1219 | resolved "https://registry.yarnpkg.com/mongodb-core/-/mongodb-core-3.0.7.tgz#a9941f14883a75768d554cef5fd67756a9cc0f25" 1220 | dependencies: 1221 | bson "~1.0.4" 1222 | require_optional "^1.0.1" 1223 | 1224 | mongodb@3.0.7: 1225 | version "3.0.7" 1226 | resolved "https://registry.yarnpkg.com/mongodb/-/mongodb-3.0.7.tgz#cfcbaee992d78dabca67177f8f9db9cf13ac3a44" 1227 | dependencies: 1228 | mongodb-core "3.0.7" 1229 | 1230 | mongoose-legacy-pluralize@1.0.2: 1231 | version "1.0.2" 1232 | resolved "https://registry.yarnpkg.com/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz#3ba9f91fa507b5186d399fb40854bff18fb563e4" 1233 | 1234 | mongoose@^5.0.16: 1235 | version "5.0.16" 1236 | resolved "https://registry.yarnpkg.com/mongoose/-/mongoose-5.0.16.tgz#a405ff0a6583442d9c55fead8ea4fdbdc0b4f5ba" 1237 | dependencies: 1238 | async "2.1.4" 1239 | bson "~1.0.4" 1240 | kareem "2.0.6" 1241 | lodash.get "4.4.2" 1242 | mongodb "3.0.7" 1243 | mongoose-legacy-pluralize "1.0.2" 1244 | mpath "0.4.1" 1245 | mquery "3.0.0" 1246 | ms "2.0.0" 1247 | regexp-clone "0.0.1" 1248 | sliced "1.0.1" 1249 | 1250 | morgan@^1.9.0: 1251 | version "1.9.0" 1252 | resolved "https://registry.yarnpkg.com/morgan/-/morgan-1.9.0.tgz#d01fa6c65859b76fcf31b3cb53a3821a311d8051" 1253 | dependencies: 1254 | basic-auth "~2.0.0" 1255 | debug "2.6.9" 1256 | depd "~1.1.1" 1257 | on-finished "~2.3.0" 1258 | on-headers "~1.0.1" 1259 | 1260 | mpath@0.4.1: 1261 | version "0.4.1" 1262 | resolved "https://registry.yarnpkg.com/mpath/-/mpath-0.4.1.tgz#ed10388430380bf7bbb5be1391e5d6969cb08e89" 1263 | 1264 | mquery@3.0.0: 1265 | version "3.0.0" 1266 | resolved "https://registry.yarnpkg.com/mquery/-/mquery-3.0.0.tgz#e5f387dbabc0b9b69859e550e810faabe0ceabb0" 1267 | dependencies: 1268 | bluebird "3.5.0" 1269 | debug "2.6.9" 1270 | regexp-clone "0.0.1" 1271 | sliced "0.0.5" 1272 | 1273 | ms@2.0.0: 1274 | version "2.0.0" 1275 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 1276 | 1277 | ms@^2.1.1: 1278 | version "2.1.1" 1279 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.1.tgz#30a5864eb3ebb0a66f2ebe6d727af06a09d86e0a" 1280 | 1281 | nan@^2.9.2: 1282 | version "2.10.0" 1283 | resolved "https://registry.yarnpkg.com/nan/-/nan-2.10.0.tgz#96d0cd610ebd58d4b4de9cc0c6828cda99c7548f" 1284 | 1285 | needle@^2.2.0: 1286 | version "2.2.1" 1287 | resolved "https://registry.yarnpkg.com/needle/-/needle-2.2.1.tgz#b5e325bd3aae8c2678902fa296f729455d1d3a7d" 1288 | dependencies: 1289 | debug "^2.1.2" 1290 | iconv-lite "^0.4.4" 1291 | sax "^1.2.4" 1292 | 1293 | negotiator@0.6.1: 1294 | version "0.6.1" 1295 | resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.1.tgz#2b327184e8992101177b28563fb5e7102acd0ca9" 1296 | 1297 | node-pre-gyp@^0.9.0: 1298 | version "0.9.1" 1299 | resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.9.1.tgz#f11c07516dd92f87199dbc7e1838eab7cd56c9e0" 1300 | dependencies: 1301 | detect-libc "^1.0.2" 1302 | mkdirp "^0.5.1" 1303 | needle "^2.2.0" 1304 | nopt "^4.0.1" 1305 | npm-packlist "^1.1.6" 1306 | npmlog "^4.0.2" 1307 | rc "^1.1.7" 1308 | rimraf "^2.6.1" 1309 | semver "^5.3.0" 1310 | tar "^4" 1311 | 1312 | nopt@^4.0.1: 1313 | version "4.0.1" 1314 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-4.0.1.tgz#d0d4685afd5415193c8c7505602d0d17cd64474d" 1315 | dependencies: 1316 | abbrev "1" 1317 | osenv "^0.1.4" 1318 | 1319 | normalize-path@^2.0.0, normalize-path@^2.0.1: 1320 | version "2.1.1" 1321 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.1.1.tgz#1ab28b556e198363a8c1a6f7e6fa20137fe6aed9" 1322 | dependencies: 1323 | remove-trailing-separator "^1.0.1" 1324 | 1325 | npm-bundled@^1.0.1: 1326 | version "1.0.3" 1327 | resolved "https://registry.yarnpkg.com/npm-bundled/-/npm-bundled-1.0.3.tgz#7e71703d973af3370a9591bafe3a63aca0be2308" 1328 | 1329 | npm-packlist@^1.1.6: 1330 | version "1.1.10" 1331 | resolved "https://registry.yarnpkg.com/npm-packlist/-/npm-packlist-1.1.10.tgz#1039db9e985727e464df066f4cf0ab6ef85c398a" 1332 | dependencies: 1333 | ignore-walk "^3.0.1" 1334 | npm-bundled "^1.0.1" 1335 | 1336 | npmlog@^4.0.2: 1337 | version "4.1.2" 1338 | resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-4.1.2.tgz#08a7f2a8bf734604779a9efa4ad5cc717abb954b" 1339 | dependencies: 1340 | are-we-there-yet "~1.1.2" 1341 | console-control-strings "~1.1.0" 1342 | gauge "~2.7.3" 1343 | set-blocking "~2.0.0" 1344 | 1345 | number-is-nan@^1.0.0: 1346 | version "1.0.1" 1347 | resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" 1348 | 1349 | object-assign@^4.1.0: 1350 | version "4.1.1" 1351 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 1352 | 1353 | object.omit@^2.0.0: 1354 | version "2.0.1" 1355 | resolved "https://registry.yarnpkg.com/object.omit/-/object.omit-2.0.1.tgz#1a9c744829f39dbb858c76ca3579ae2a54ebd1fa" 1356 | dependencies: 1357 | for-own "^0.1.4" 1358 | is-extendable "^0.1.1" 1359 | 1360 | on-finished@~2.3.0: 1361 | version "2.3.0" 1362 | resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" 1363 | dependencies: 1364 | ee-first "1.1.1" 1365 | 1366 | on-headers@~1.0.1: 1367 | version "1.0.1" 1368 | resolved "https://registry.yarnpkg.com/on-headers/-/on-headers-1.0.1.tgz#928f5d0f470d49342651ea6794b0857c100693f7" 1369 | 1370 | once@^1.3.0: 1371 | version "1.4.0" 1372 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 1373 | dependencies: 1374 | wrappy "1" 1375 | 1376 | os-homedir@^1.0.0: 1377 | version "1.0.2" 1378 | resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3" 1379 | 1380 | os-tmpdir@^1.0.0, os-tmpdir@^1.0.1: 1381 | version "1.0.2" 1382 | resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" 1383 | 1384 | osenv@^0.1.4: 1385 | version "0.1.5" 1386 | resolved "https://registry.yarnpkg.com/osenv/-/osenv-0.1.5.tgz#85cdfafaeb28e8677f416e287592b5f3f49ea410" 1387 | dependencies: 1388 | os-homedir "^1.0.0" 1389 | os-tmpdir "^1.0.0" 1390 | 1391 | output-file-sync@^1.1.2: 1392 | version "1.1.2" 1393 | resolved "https://registry.yarnpkg.com/output-file-sync/-/output-file-sync-1.1.2.tgz#d0a33eefe61a205facb90092e826598d5245ce76" 1394 | dependencies: 1395 | graceful-fs "^4.1.4" 1396 | mkdirp "^0.5.1" 1397 | object-assign "^4.1.0" 1398 | 1399 | parse-glob@^3.0.4: 1400 | version "3.0.4" 1401 | resolved "https://registry.yarnpkg.com/parse-glob/-/parse-glob-3.0.4.tgz#b2c376cfb11f35513badd173ef0bb6e3a388391c" 1402 | dependencies: 1403 | glob-base "^0.3.0" 1404 | is-dotfile "^1.0.0" 1405 | is-extglob "^1.0.0" 1406 | is-glob "^2.0.0" 1407 | 1408 | parseurl@~1.3.2: 1409 | version "1.3.2" 1410 | resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.2.tgz#fc289d4ed8993119460c156253262cdc8de65bf3" 1411 | 1412 | path-is-absolute@^1.0.0, path-is-absolute@^1.0.1: 1413 | version "1.0.1" 1414 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 1415 | 1416 | path-to-regexp@0.1.7: 1417 | version "0.1.7" 1418 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" 1419 | 1420 | preserve@^0.2.0: 1421 | version "0.2.0" 1422 | resolved "https://registry.yarnpkg.com/preserve/-/preserve-0.2.0.tgz#815ed1f6ebc65926f865b310c0713bcb3315ce4b" 1423 | 1424 | private@^0.1.6, private@^0.1.8: 1425 | version "0.1.8" 1426 | resolved "https://registry.yarnpkg.com/private/-/private-0.1.8.tgz#2381edb3689f7a53d653190060fcf822d2f368ff" 1427 | 1428 | process-nextick-args@~2.0.0: 1429 | version "2.0.0" 1430 | resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.0.tgz#a37d732f4271b4ab1ad070d35508e8290788ffaa" 1431 | 1432 | proxy-addr@~2.0.3: 1433 | version "2.0.3" 1434 | resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.3.tgz#355f262505a621646b3130a728eb647e22055341" 1435 | dependencies: 1436 | forwarded "~0.1.2" 1437 | ipaddr.js "1.6.0" 1438 | 1439 | qs@6.5.1: 1440 | version "6.5.1" 1441 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.5.1.tgz#349cdf6eef89ec45c12d7d5eb3fc0c870343a6d8" 1442 | 1443 | randomatic@^1.1.3: 1444 | version "1.1.7" 1445 | resolved "https://registry.yarnpkg.com/randomatic/-/randomatic-1.1.7.tgz#c7abe9cc8b87c0baa876b19fde83fd464797e38c" 1446 | dependencies: 1447 | is-number "^3.0.0" 1448 | kind-of "^4.0.0" 1449 | 1450 | range-parser@~1.2.0: 1451 | version "1.2.0" 1452 | resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.0.tgz#f49be6b487894ddc40dcc94a322f611092e00d5e" 1453 | 1454 | raw-body@2.3.2: 1455 | version "2.3.2" 1456 | resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.3.2.tgz#bcd60c77d3eb93cde0050295c3f379389bc88f89" 1457 | dependencies: 1458 | bytes "3.0.0" 1459 | http-errors "1.6.2" 1460 | iconv-lite "0.4.19" 1461 | unpipe "1.0.0" 1462 | 1463 | rc@^1.1.7: 1464 | version "1.2.6" 1465 | resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.6.tgz#eb18989c6d4f4f162c399f79ddd29f3835568092" 1466 | dependencies: 1467 | deep-extend "~0.4.0" 1468 | ini "~1.3.0" 1469 | minimist "^1.2.0" 1470 | strip-json-comments "~2.0.1" 1471 | 1472 | readable-stream@^2.0.2, readable-stream@^2.0.6: 1473 | version "2.3.6" 1474 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.6.tgz#b11c27d88b8ff1fbe070643cf94b0c79ae1b0aaf" 1475 | dependencies: 1476 | core-util-is "~1.0.0" 1477 | inherits "~2.0.3" 1478 | isarray "~1.0.0" 1479 | process-nextick-args "~2.0.0" 1480 | safe-buffer "~5.1.1" 1481 | string_decoder "~1.1.1" 1482 | util-deprecate "~1.0.1" 1483 | 1484 | readdirp@^2.0.0: 1485 | version "2.1.0" 1486 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-2.1.0.tgz#4ed0ad060df3073300c48440373f72d1cc642d78" 1487 | dependencies: 1488 | graceful-fs "^4.1.2" 1489 | minimatch "^3.0.2" 1490 | readable-stream "^2.0.2" 1491 | set-immediate-shim "^1.0.1" 1492 | 1493 | regenerate@^1.2.1: 1494 | version "1.3.3" 1495 | resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.3.3.tgz#0c336d3980553d755c39b586ae3b20aa49c82b7f" 1496 | 1497 | regenerator-runtime@^0.10.5: 1498 | version "0.10.5" 1499 | resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.10.5.tgz#336c3efc1220adcedda2c9fab67b5a7955a33658" 1500 | 1501 | regenerator-runtime@^0.11.0: 1502 | version "0.11.1" 1503 | resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz#be05ad7f9bf7d22e056f9726cee5017fbf19e2e9" 1504 | 1505 | regenerator-transform@^0.10.0: 1506 | version "0.10.1" 1507 | resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.10.1.tgz#1e4996837231da8b7f3cf4114d71b5691a0680dd" 1508 | dependencies: 1509 | babel-runtime "^6.18.0" 1510 | babel-types "^6.19.0" 1511 | private "^0.1.6" 1512 | 1513 | regex-cache@^0.4.2: 1514 | version "0.4.4" 1515 | resolved "https://registry.yarnpkg.com/regex-cache/-/regex-cache-0.4.4.tgz#75bdc58a2a1496cec48a12835bc54c8d562336dd" 1516 | dependencies: 1517 | is-equal-shallow "^0.1.3" 1518 | 1519 | regexp-clone@0.0.1: 1520 | version "0.0.1" 1521 | resolved "https://registry.yarnpkg.com/regexp-clone/-/regexp-clone-0.0.1.tgz#a7c2e09891fdbf38fbb10d376fb73003e68ac589" 1522 | 1523 | regexpu-core@^2.0.0: 1524 | version "2.0.0" 1525 | resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-2.0.0.tgz#49d038837b8dcf8bfa5b9a42139938e6ea2ae240" 1526 | dependencies: 1527 | regenerate "^1.2.1" 1528 | regjsgen "^0.2.0" 1529 | regjsparser "^0.1.4" 1530 | 1531 | regjsgen@^0.2.0: 1532 | version "0.2.0" 1533 | resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.2.0.tgz#6c016adeac554f75823fe37ac05b92d5a4edb1f7" 1534 | 1535 | regjsparser@^0.1.4: 1536 | version "0.1.5" 1537 | resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.1.5.tgz#7ee8f84dc6fa792d3fd0ae228d24bd949ead205c" 1538 | dependencies: 1539 | jsesc "~0.5.0" 1540 | 1541 | remove-trailing-separator@^1.0.1: 1542 | version "1.1.0" 1543 | resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef" 1544 | 1545 | repeat-element@^1.1.2: 1546 | version "1.1.2" 1547 | resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.2.tgz#ef089a178d1483baae4d93eb98b4f9e4e11d990a" 1548 | 1549 | repeat-string@^1.5.2: 1550 | version "1.6.1" 1551 | resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637" 1552 | 1553 | repeating@^2.0.0: 1554 | version "2.0.1" 1555 | resolved "https://registry.yarnpkg.com/repeating/-/repeating-2.0.1.tgz#5214c53a926d3552707527fbab415dbc08d06dda" 1556 | dependencies: 1557 | is-finite "^1.0.0" 1558 | 1559 | require_optional@^1.0.1: 1560 | version "1.0.1" 1561 | resolved "https://registry.yarnpkg.com/require_optional/-/require_optional-1.0.1.tgz#4cf35a4247f64ca3df8c2ef208cc494b1ca8fc2e" 1562 | dependencies: 1563 | resolve-from "^2.0.0" 1564 | semver "^5.1.0" 1565 | 1566 | resolve-from@^2.0.0: 1567 | version "2.0.0" 1568 | resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-2.0.0.tgz#9480ab20e94ffa1d9e80a804c7ea147611966b57" 1569 | 1570 | rimraf@^2.6.1: 1571 | version "2.6.2" 1572 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.2.tgz#2ed8150d24a16ea8651e6d6ef0f47c4158ce7a36" 1573 | dependencies: 1574 | glob "^7.0.5" 1575 | 1576 | safe-buffer@5.1.1: 1577 | version "5.1.1" 1578 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.1.tgz#893312af69b2123def71f57889001671eeb2c853" 1579 | 1580 | safe-buffer@^5.0.1, safe-buffer@^5.1.1, safe-buffer@~5.1.0, safe-buffer@~5.1.1: 1581 | version "5.1.2" 1582 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" 1583 | 1584 | safer-buffer@^2.1.0: 1585 | version "2.1.2" 1586 | resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" 1587 | 1588 | sax@^1.2.4: 1589 | version "1.2.4" 1590 | resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" 1591 | 1592 | semver@^5.1.0, semver@^5.3.0: 1593 | version "5.5.0" 1594 | resolved "https://registry.yarnpkg.com/semver/-/semver-5.5.0.tgz#dc4bbc7a6ca9d916dee5d43516f0092b58f7b8ab" 1595 | 1596 | send@0.16.2: 1597 | version "0.16.2" 1598 | resolved "https://registry.yarnpkg.com/send/-/send-0.16.2.tgz#6ecca1e0f8c156d141597559848df64730a6bbc1" 1599 | dependencies: 1600 | debug "2.6.9" 1601 | depd "~1.1.2" 1602 | destroy "~1.0.4" 1603 | encodeurl "~1.0.2" 1604 | escape-html "~1.0.3" 1605 | etag "~1.8.1" 1606 | fresh "0.5.2" 1607 | http-errors "~1.6.2" 1608 | mime "1.4.1" 1609 | ms "2.0.0" 1610 | on-finished "~2.3.0" 1611 | range-parser "~1.2.0" 1612 | statuses "~1.4.0" 1613 | 1614 | serve-static@1.13.2: 1615 | version "1.13.2" 1616 | resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.13.2.tgz#095e8472fd5b46237db50ce486a43f4b86c6cec1" 1617 | dependencies: 1618 | encodeurl "~1.0.2" 1619 | escape-html "~1.0.3" 1620 | parseurl "~1.3.2" 1621 | send "0.16.2" 1622 | 1623 | set-blocking@~2.0.0: 1624 | version "2.0.0" 1625 | resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" 1626 | 1627 | set-immediate-shim@^1.0.1: 1628 | version "1.0.1" 1629 | resolved "https://registry.yarnpkg.com/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz#4b2b1b27eb808a9f8dcc481a58e5e56f599f3f61" 1630 | 1631 | setprototypeof@1.0.3: 1632 | version "1.0.3" 1633 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.0.3.tgz#66567e37043eeb4f04d91bd658c0cbefb55b8e04" 1634 | 1635 | setprototypeof@1.1.0: 1636 | version "1.1.0" 1637 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656" 1638 | 1639 | signal-exit@^3.0.0: 1640 | version "3.0.2" 1641 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.2.tgz#b5fdc08f1287ea1178628e415e25132b73646c6d" 1642 | 1643 | slash@^1.0.0: 1644 | version "1.0.0" 1645 | resolved "https://registry.yarnpkg.com/slash/-/slash-1.0.0.tgz#c41f2f6c39fc16d1cd17ad4b5d896114ae470d55" 1646 | 1647 | sliced@0.0.5: 1648 | version "0.0.5" 1649 | resolved "https://registry.yarnpkg.com/sliced/-/sliced-0.0.5.tgz#5edc044ca4eb6f7816d50ba2fc63e25d8fe4707f" 1650 | 1651 | sliced@1.0.1: 1652 | version "1.0.1" 1653 | resolved "https://registry.yarnpkg.com/sliced/-/sliced-1.0.1.tgz#0b3a662b5d04c3177b1926bea82b03f837a2ef41" 1654 | 1655 | source-map-support@^0.4.15: 1656 | version "0.4.18" 1657 | resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.4.18.tgz#0286a6de8be42641338594e97ccea75f0a2c585f" 1658 | dependencies: 1659 | source-map "^0.5.6" 1660 | 1661 | source-map@^0.5.6, source-map@^0.5.7: 1662 | version "0.5.7" 1663 | resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc" 1664 | 1665 | "statuses@>= 1.3.1 < 2", "statuses@>= 1.4.0 < 2": 1666 | version "1.5.0" 1667 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" 1668 | 1669 | statuses@~1.4.0: 1670 | version "1.4.0" 1671 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.4.0.tgz#bb73d446da2796106efcc1b601a253d6c46bd087" 1672 | 1673 | string-width@^1.0.1, string-width@^1.0.2: 1674 | version "1.0.2" 1675 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" 1676 | dependencies: 1677 | code-point-at "^1.0.0" 1678 | is-fullwidth-code-point "^1.0.0" 1679 | strip-ansi "^3.0.0" 1680 | 1681 | string_decoder@~1.1.1: 1682 | version "1.1.1" 1683 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" 1684 | dependencies: 1685 | safe-buffer "~5.1.0" 1686 | 1687 | strip-ansi@^3.0.0, strip-ansi@^3.0.1: 1688 | version "3.0.1" 1689 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" 1690 | dependencies: 1691 | ansi-regex "^2.0.0" 1692 | 1693 | strip-json-comments@~2.0.1: 1694 | version "2.0.1" 1695 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" 1696 | 1697 | supports-color@^2.0.0: 1698 | version "2.0.0" 1699 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7" 1700 | 1701 | tar@^4: 1702 | version "4.4.1" 1703 | resolved "https://registry.yarnpkg.com/tar/-/tar-4.4.1.tgz#b25d5a8470c976fd7a9a8a350f42c59e9fa81749" 1704 | dependencies: 1705 | chownr "^1.0.1" 1706 | fs-minipass "^1.2.5" 1707 | minipass "^2.2.4" 1708 | minizlib "^1.1.0" 1709 | mkdirp "^0.5.0" 1710 | safe-buffer "^5.1.1" 1711 | yallist "^3.0.2" 1712 | 1713 | to-fast-properties@^1.0.3: 1714 | version "1.0.3" 1715 | resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-1.0.3.tgz#b83571fa4d8c25b82e231b06e3a3055de4ca1a47" 1716 | 1717 | trim-right@^1.0.1: 1718 | version "1.0.1" 1719 | resolved "https://registry.yarnpkg.com/trim-right/-/trim-right-1.0.1.tgz#cb2e1203067e0c8de1f614094b9fe45704ea6003" 1720 | 1721 | type-is@~1.6.15, type-is@~1.6.16: 1722 | version "1.6.16" 1723 | resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.16.tgz#f89ce341541c672b25ee7ae3c73dee3b2be50194" 1724 | dependencies: 1725 | media-typer "0.3.0" 1726 | mime-types "~2.1.18" 1727 | 1728 | unpipe@1.0.0, unpipe@~1.0.0: 1729 | version "1.0.0" 1730 | resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" 1731 | 1732 | user-home@^1.1.1: 1733 | version "1.1.1" 1734 | resolved "https://registry.yarnpkg.com/user-home/-/user-home-1.1.1.tgz#2b5be23a32b63a7c9deb8d0f28d485724a3df190" 1735 | 1736 | util-deprecate@~1.0.1: 1737 | version "1.0.2" 1738 | resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" 1739 | 1740 | utils-merge@1.0.1: 1741 | version "1.0.1" 1742 | resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" 1743 | 1744 | v8flags@^2.1.1: 1745 | version "2.1.1" 1746 | resolved "https://registry.yarnpkg.com/v8flags/-/v8flags-2.1.1.tgz#aab1a1fa30d45f88dd321148875ac02c0b55e5b4" 1747 | dependencies: 1748 | user-home "^1.1.1" 1749 | 1750 | vary@~1.1.2: 1751 | version "1.1.2" 1752 | resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" 1753 | 1754 | wide-align@^1.1.0: 1755 | version "1.1.2" 1756 | resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.2.tgz#571e0f1b0604636ebc0dfc21b0339bbe31341710" 1757 | dependencies: 1758 | string-width "^1.0.2" 1759 | 1760 | wrappy@1: 1761 | version "1.0.2" 1762 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 1763 | 1764 | xtend@^4.0.1: 1765 | version "4.0.1" 1766 | resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af" 1767 | 1768 | yallist@^3.0.0, yallist@^3.0.2: 1769 | version "3.0.2" 1770 | resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.0.2.tgz#8452b4bb7e83c7c188d8041c1a837c773d6d8bb9" 1771 | --------------------------------------------------------------------------------