├── .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 |
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 |
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 |
--------------------------------------------------------------------------------