├── .gitignore ├── Procfile ├── config.js ├── controllers ├── Auth │ ├── ChangePassword.js │ ├── Login.js │ ├── Logout.js │ └── Signup.js ├── Post │ ├── Comment.js │ ├── FetchPost.js │ └── postAction.js └── User │ ├── Chat.js │ ├── FetchUser.js │ └── UserAction.js ├── index.js ├── middleware └── AuthRequired.js ├── models ├── Chat.js ├── Comment.js ├── FriendRequest.js ├── Notification.js ├── Post.js └── User.js ├── package.json ├── routes ├── Auth.js ├── Post.js └── User.js ├── socket.js ├── utils ├── CreateNotification.js ├── FilterCommentData.js ├── FilterPostData.js ├── FilterUserData.js ├── ValidateEmail.js └── socket │ └── SendDataToFriend.js └── yarn.lock /.gitignore: -------------------------------------------------------------------------------- 1 | /node_modules 2 | /.env 3 | -------------------------------------------------------------------------------- /Procfile: -------------------------------------------------------------------------------- 1 | web:node index.js -------------------------------------------------------------------------------- /config.js: -------------------------------------------------------------------------------- 1 | module.exports = { 2 | PORT: process.env.PORT || 4000, 3 | MONGODB_URI: process.env.MONGODB_URI || "mongodb://localhost:27017/facebook_clone", 4 | JWT_SECRET: process.env.JWT_SECRET || "itssecret", 5 | JWT_EXP: process.env.JWT_EXPIRE || '10h', 6 | ADMIN_EMAIL: process.env.ADMIN_EMAIL || "admin@gmail.com", 7 | ADMIN_PASSWORD: process.env.ADMIN_PASSWORD || "admin@123", 8 | } 9 | -------------------------------------------------------------------------------- /controllers/Auth/ChangePassword.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const bcrypt = require('bcrypt') 3 | 4 | module.exports = async (req, res) => { 5 | let { currentPassword, newPassword } = req.body 6 | try { 7 | const user = await User.findById(req.userId) 8 | let matchPassword = await bcrypt.compare(currentPassword,user.password) 9 | if(!matchPassword){ 10 | return res.status(400).json({error:"Current Password is Incorrect Please Try Again"}) 11 | } 12 | 13 | if(!newPassword){ 14 | return res.status(400).json({error:"Current Password is Required"}) 15 | } 16 | 17 | let generatePasswordHash = await bcrypt.hash(newPassword,8) 18 | user.password = generatePasswordHash 19 | await user.save() 20 | res.status(200).json({message:"Password Updated Successfully"}) 21 | 22 | } catch (err) { 23 | console.log(err) 24 | return res.status(500).json({error:"Something went wrong"}) 25 | } 26 | } 27 | -------------------------------------------------------------------------------- /controllers/Auth/Login.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const jwt = require('jsonwebtoken') 3 | const bcrypt = require('bcrypt') 4 | const ValidateEmail = require('../../utils/ValidateEmail') 5 | const {JWT_SECRET,JWT_EXP} = require("../../config") 6 | 7 | module.exports = async (req, res) => { 8 | const { email, password } = req.body 9 | let error = {} 10 | 11 | if (!ValidateEmail(email)) { 12 | error.email = 'email address should be valid ' 13 | } 14 | if (!email || email.trim().length === 0) { 15 | error.email = 'email field must be required' 16 | } 17 | 18 | if (!password || password.trim().length === 0) { 19 | error.password = 'password must be required' 20 | } 21 | 22 | if (Object.keys(error).length) { 23 | return res.status(422).json({ error }) 24 | } 25 | 26 | try { 27 | const user = await User.findOne({ email }) 28 | if (!user) { 29 | return res.status(400).json({ error: 'email not found' }) 30 | } 31 | 32 | const verifyPassword = await bcrypt.compare(password, user.password) 33 | if (!verifyPassword) { 34 | return res.status(400).json({ error: 'password is incorrect' }) 35 | } 36 | 37 | const token = jwt.sign({ userId: user.id }, JWT_SECRET, { 38 | expiresIn: JWT_EXP, 39 | }) 40 | 41 | user.active = true 42 | await user.save() 43 | 44 | 45 | return res.status(201).json({ 46 | message: 'login successfully', 47 | data: { 48 | token, 49 | } 50 | }) 51 | } catch (err) { 52 | console.log(err) 53 | return res.status(500).json({error:"Something went wrong"}) 54 | } 55 | } 56 | -------------------------------------------------------------------------------- /controllers/Auth/Logout.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | 3 | module.exports = async (req, res) => { 4 | try { 5 | const user = await User.findById(req.userId) 6 | if (user) { 7 | user.active = false 8 | await user.save() 9 | 10 | const accountData = { 11 | id: user.id, 12 | name: user.name, 13 | email: user.email, 14 | profile_pic: user.profile_pic, 15 | } 16 | 17 | res 18 | .status(201) 19 | .json({ message: 'logout successfully', account: accountData }) 20 | } else { 21 | res.status(404).json({ error: 'user not found' }) 22 | } 23 | } catch (err) { 24 | console.log(err) 25 | return res.status(500).json({error:"Something went wrong"}) 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /controllers/Auth/Signup.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const jwt = require('jsonwebtoken') 3 | const bcrypt = require('bcrypt') 4 | const ValidateEmail = require('../../utils/ValidateEmail') 5 | const {JWT_SECRET,JWT_EXP} = require("../../config") 6 | 7 | module.exports = async (req, res) => { 8 | const { name, email, password } = req.body 9 | let error = {} 10 | if (!name || name.trim().length === 0) { 11 | error.name = 'name field must be required' 12 | } 13 | if (!ValidateEmail(email)) { 14 | error.email = 'email address should be valid ' 15 | } 16 | if (!email || email.trim().length === 0) { 17 | error.email = 'email field must be required' 18 | } 19 | if (!password || password.trim().length === 0) { 20 | error.password = 'password must be required' 21 | } 22 | 23 | if (Object.keys(error).length) { 24 | return res.status(422).json({ error }) 25 | } 26 | 27 | try { 28 | const user = await User.findOne({ email }) 29 | if (user) res.status(400).json({ error: 'email already exists' }) 30 | 31 | const hashPassword = await bcrypt.hash(password, 8) 32 | 33 | const registerUser = new User({ 34 | name, 35 | email, 36 | password: hashPassword, 37 | }) 38 | 39 | const saveUser = await registerUser.save() 40 | 41 | const token = jwt.sign({ userId: saveUser.id }, JWT_SECRET, { 42 | expiresIn: JWT_EXP, 43 | }) 44 | 45 | saveUser.active = true 46 | await saveUser.save() 47 | 48 | 49 | 50 | res.status(201).json({ 51 | message: `Account created for ${email}`, 52 | data: { 53 | token, 54 | 55 | }, 56 | }) 57 | } catch (err) { 58 | console.log(err) 59 | return res.status(500).json({error:"Something went wrong"}) 60 | } 61 | } 62 | -------------------------------------------------------------------------------- /controllers/Post/Comment.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const Post = require('../../models/Post') 3 | const Comment = require('../../models/Comment') 4 | const FilterCommentData = require('../../utils/FilterCommentData') 5 | const sendDataToFriends = require('../../utils/socket/SendDataToFriend') 6 | 7 | exports.createComment = async (req, res) => { 8 | const { text, image } = req.body 9 | if (!text || (text.trim().length === 0 && !image)) { 10 | return res.status(422).json({ error: 'enter something or comment image' }) 11 | } 12 | try { 13 | const post = await Post.findById(req.params.postId) 14 | if (!post) { 15 | return res.status(404).json({ error: 'post not found' }) 16 | } 17 | 18 | let body = {} 19 | if (image) { 20 | body.image = image 21 | } 22 | 23 | if (text) { 24 | body.text = text 25 | } 26 | 27 | const createComment = new Comment({ 28 | user: req.userId, 29 | post: req.params.postId, 30 | body, 31 | }) 32 | 33 | const saveComment = await createComment.save() 34 | const comment = await Comment.findById(saveComment.id).populate( 35 | 'user', 36 | '_id name profile_pic', 37 | ) 38 | 39 | const filterComment = FilterCommentData(comment) 40 | res.status(201).json({ 41 | message: 'commented on post successfully', 42 | comment: filterComment, 43 | }) 44 | await sendDataToFriends({ req, key: 'post-comment', data: filterComment }) 45 | } catch (err) { 46 | console.log(err) 47 | return res.status(500).json({error:"Something went wrong"}) 48 | } 49 | } 50 | 51 | exports.fetchComments = async (req, res) => { 52 | let page = parseInt(req.query.page || 0) 53 | let limit = 3 54 | 55 | try { 56 | const comments = await Comment.find({ post: req.params.postId }) 57 | .sort({ createdAt: -1 }) 58 | .limit(limit) 59 | .skip(page * limit) 60 | .populate('user', '_id name profile_pic') 61 | const filterComments = comments.map((comment) => FilterCommentData(comment)) 62 | const totalCount = await Comment.countDocuments({ post: req.params.postId }) 63 | 64 | const paginationData = { 65 | currentPage: page, 66 | totalPage: Math.ceil(totalCount / limit), 67 | totalComments: totalCount, 68 | } 69 | res 70 | .status(200) 71 | .json({ comments: filterComments, pagination: paginationData }) 72 | } catch (err) { 73 | console.log(err) 74 | return res.status(500).json({error:"Something went wrong"}) 75 | } 76 | } 77 | 78 | exports.likeDislikeComment = async (req, res) => { 79 | try { 80 | const comment = await Comment.findById(req.params.commentId).populate( 81 | 'user', 82 | ) 83 | 84 | if (!comment) { 85 | return res.status(404).json({ error: 'comment not found' }) 86 | } 87 | 88 | let commentData 89 | 90 | const index = comment.likes.indexOf(req.userId) 91 | if (index !== -1) { 92 | comment.likes.splice(index, 1) 93 | await comment.save() 94 | 95 | commentData = FilterCommentData(comment) 96 | 97 | res.status(200).json({ message: 'removed likes', comment: commentData }) 98 | 99 | await sendDataToFriends({ 100 | req, 101 | key: 'comment-like-change', 102 | data: commentData, 103 | }) 104 | return 105 | } 106 | 107 | comment.likes.push(req.userId) 108 | await comment.save() 109 | commentData = FilterCommentData(comment) 110 | res.status(200).json({ message: 'add like', comment: commentData }) 111 | await sendDataToFriends({ 112 | req, 113 | key: 'comment-like-change', 114 | data: commentData, 115 | }) 116 | } catch (err) { 117 | console.log(err) 118 | return res.status(500).json({error:"Something went wrong"}) 119 | } 120 | } 121 | -------------------------------------------------------------------------------- /controllers/Post/FetchPost.js: -------------------------------------------------------------------------------- 1 | const Post = require('../../models/Post') 2 | const Comment = require('../../models/Comment') 3 | const FilterPostData = require('../../utils/FilterPostData') 4 | 5 | exports.fetchPostById = async (req, res) => { 6 | try { 7 | const post = await Post.findById(req.params.postId) 8 | .populate('user') 9 | .populate({ path: 'body.with'}) 10 | 11 | let postData = FilterPostData(post) 12 | 13 | res.status(200).json({ post: postData }) 14 | } catch (err) { 15 | console.log(err) 16 | return res.status(500).json({error:"Something went wrong"}) 17 | } 18 | } 19 | 20 | exports.fetchAllPosts = async (req, res) => { 21 | let page = parseInt(req.query.page || 0) 22 | let limit = 3 23 | 24 | try { 25 | const posts = await Post.find() 26 | .sort({ createdAt: -1 }) 27 | .limit(limit) 28 | .skip(page * limit) 29 | .populate('user') 30 | .populate({ path: 'body.with' }) 31 | 32 | let postsData = posts.map((post) => FilterPostData(post)) 33 | 34 | const totalCount = await Post.estimatedDocumentCount().exec() 35 | const paginationData = { 36 | currentPage:page, 37 | totalPage:Math.ceil(totalCount/limit), 38 | totalPost:totalCount 39 | } 40 | res.status(200).json({ posts: postsData,pagination:paginationData }) 41 | } catch (err) { 42 | console.log(err) 43 | return res.status(500).json({error:"Something went wrong"}) 44 | } 45 | } 46 | -------------------------------------------------------------------------------- /controllers/Post/postAction.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const Post = require('../../models/Post') 3 | const FilterPostData = require('../../utils/FilterPostData') 4 | const sendDataToFriends = require("../../utils/socket/SendDataToFriend") 5 | exports.createPost = async (req, res) => { 6 | let { content, privacy, image, body } = req.body 7 | 8 | if (!content && content.trim().length === 0 && !image) { 9 | return res.status(422).json({ 10 | error: 11 | 'Post Image or Write Some Content to Post. Can`t upload empty post', 12 | }) 13 | } 14 | try { 15 | const createPost = new Post({ 16 | image, 17 | privacy, 18 | content, 19 | user: req.userId, 20 | isProfilePost: false, 21 | }) 22 | 23 | const savePost = await createPost.save() 24 | 25 | if (Object.keys(body).length) { 26 | savePost.body = { 27 | feelings: body.feelings, 28 | at: body.at, 29 | date: body.date, 30 | with: body.with.map((user) => user), 31 | } 32 | 33 | await savePost.save() 34 | } 35 | const post = await Post.findById(savePost.id) 36 | .populate('user') 37 | .populate({ path: 'body.with', select: '_id name' }) 38 | const postData = FilterPostData(post) 39 | 40 | res 41 | .status(201) 42 | .json({ message: 'post created successfully', post: postData }) 43 | 44 | let dataToSend = { 45 | req, key: "new-post", data: postData, 46 | notif_body:`${post.user.name} has created new post` 47 | } 48 | await sendDataToFriends(dataToSend) 49 | 50 | } catch (err) { 51 | console.log(err) 52 | return res.status(500).json({error:"Something went wrong"}) 53 | } 54 | } 55 | 56 | exports.likeDislikePost = async (req, res) => { 57 | try { 58 | const post = await Post.findById(req.params.postId) 59 | .populate('user') 60 | .populate({ path: 'body.with', select: '_id name' }) 61 | if (!post) { 62 | 63 | return res.status(404).json({ error: 'post not found' }) 64 | } 65 | 66 | let postData 67 | 68 | const index = post.likes.indexOf(req.userId) 69 | if (index !== -1) { 70 | post.likes.splice(index, 1) 71 | await post.save() 72 | postData = FilterPostData(post) 73 | res.status(200).json({ message: 'removed likes', post: postData }) 74 | await sendDataToFriends({ req, key: "post-like-change", data: postData }) 75 | return; 76 | 77 | } 78 | 79 | post.likes.push(req.userId) 80 | await post.save() 81 | postData = FilterPostData(post) 82 | res.status(200).json({ message: 'add like', post: postData }) 83 | await sendDataToFriends({ req, key: "post-like-change", data: postData }) 84 | } catch (err) { 85 | console.log(err) 86 | return res.status(500).json({error:"Something went wrong"}) 87 | } 88 | } 89 | 90 | 91 | -------------------------------------------------------------------------------- /controllers/User/Chat.js: -------------------------------------------------------------------------------- 1 | const Chat = require('../../models/Chat') 2 | const User = require('../../models/User') 3 | const FilterUserData = require('../../utils/FilterUserData') 4 | 5 | exports.sendMessageToFriend = async (req, res) => { 6 | const { text, image } = req.body 7 | 8 | if (!text && !image) { 9 | return res 10 | .status(422) 11 | .json({ error: 'Don`t send empty message type something' }) 12 | } 13 | try { 14 | const friend = await User.findById(req.params.friendId) 15 | if (!friend) { 16 | return res.status(404).json({ error: 'Friend Not Found' }) 17 | } 18 | 19 | const chat = new Chat({ 20 | sender: req.userId, 21 | receiver: req.params.friendId, 22 | body: { 23 | text: text || '', 24 | image: image || '', 25 | }, 26 | }) 27 | 28 | const saveChat = await chat.save() 29 | 30 | const getChat = await Chat.findById(saveChat.id) 31 | .populate('sender') 32 | .populate('receiver') 33 | const chatdata = { 34 | id: saveChat.id, 35 | sender: FilterUserData(getChat.sender), 36 | receiver: FilterUserData(getChat.receiver), 37 | body: getChat.body, 38 | createdAt: getChat.createdAt, 39 | } 40 | res.status(201).json({ data: chatdata }) 41 | if (getChat.receiver.socketId) { 42 | req.io 43 | .to(getChat.receiver.socketId) 44 | .emit('new-message', { data: chatdata }) 45 | } 46 | } catch (err) { 47 | console.log(err) 48 | return res.status(500).json({error:"Something went wrong"}) 49 | } 50 | } 51 | 52 | exports.getFriendMessages = async (req, res) => { 53 | try { 54 | const messages = await Chat.find({ 55 | $or: [ 56 | { sender: req.userId, receiver: req.params.friendId }, 57 | { receiver: req.userId, sender: req.params.friendId }, 58 | ], 59 | }) 60 | .populate('sender') 61 | .populate('receiver') 62 | 63 | const messagesData = messages.map((message) => { 64 | return { 65 | id: message.id, 66 | sender: FilterUserData(message.sender), 67 | receiver: FilterUserData(message.receiver), 68 | body:message.body, 69 | createdAt: message.createdAt, 70 | 71 | } 72 | }) 73 | 74 | res.status(200).json({ data: messagesData }) 75 | } catch (err) { 76 | console.log(err) 77 | return res.status(500).json({error:"Something went wrong"}) 78 | } 79 | } 80 | -------------------------------------------------------------------------------- /controllers/User/FetchUser.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const Notification = require('../../models/Notification') 3 | const FriendRequest = require('../../models/FriendRequest') 4 | const FilterUserData = require('../../utils/FilterUserData') 5 | 6 | exports.fetchUserById = async (req, res) => { 7 | try { 8 | const user = await User.findById(req.params.user_id).populate('friends') 9 | const userData = FilterUserData(user) 10 | 11 | res.status(200).json({ user: userData }) 12 | } catch (err) { 13 | console.log(err) 14 | return res.status(500).json({error:"Something went wrong"}) 15 | } 16 | } 17 | 18 | exports.fetchRecommandedUsers = async (req, res) => { 19 | try { 20 | const users = await User.find() 21 | .where('_id') 22 | .ne(req.userId) 23 | .populate('friends') 24 | 25 | const usersData = users.map((user) => { 26 | return FilterUserData(user) 27 | }) 28 | res.status(200).json({ users: usersData }) 29 | } catch (err) { 30 | console.log(err) 31 | return res.status(500).json({error:"Something went wrong"}) 32 | } 33 | } 34 | exports.me = async (req, res) => { 35 | try { 36 | const user = await User.findById(req.userId).populate('friends') 37 | if (!user) { 38 | return res.status(404).json({ error: 'user not found' }) 39 | } 40 | 41 | const userData = FilterUserData(user) 42 | 43 | const friends = user.friends.map((friend) => { 44 | return { 45 | ...FilterUserData(friend), 46 | } 47 | }) 48 | 49 | userData.friends = friends 50 | const notifications = await Notification.find({ user: req.userId }).sort({ 51 | createdAt: -1, 52 | }) 53 | let notifData = notifications.map((notif) => { 54 | return { 55 | id: notif.id, 56 | body: notif.body, 57 | createdAt: notif.createdAt, 58 | } 59 | }) 60 | 61 | res.status(200).json({ user: userData, notifications: notifData }) 62 | } catch (err) { 63 | console.log(err) 64 | return res.status(500).json({error:"Something went wrong"}) 65 | } 66 | } 67 | 68 | exports.fetchIncommingFriendRequest = async (req, res) => { 69 | try { 70 | const friends = await FriendRequest.find({ 71 | $and: [{ isAccepted: false }, { receiver: req.userId }], 72 | }).populate('sender', '_id name profile_pic active') 73 | 74 | const friendsData = friends.map((friend) => { 75 | return { 76 | id: friend.id, 77 | user: FilterUserData(friend.sender), 78 | } 79 | }) 80 | 81 | res.status(200).json({ friends: friendsData }) 82 | } catch (err) { 83 | console.log(err) 84 | return res.status(500).json({error:"Something went wrong"}) 85 | } 86 | } 87 | 88 | exports.fetchSendedFriendRequest = async (req, res) => { 89 | try { 90 | const friends = await FriendRequest.find({ 91 | $and: [{ isAccepted: false }, { sender: req.userId }], 92 | }).populate('receiver') 93 | const friendsData = friends.map((friend) => { 94 | return { 95 | id: friend.id, 96 | user: FilterUserData(friend.receiver), 97 | } 98 | }) 99 | 100 | res.status(200).json({ friends: friendsData }) 101 | } catch (err) { 102 | console.log(err) 103 | return res.status(500).json({error:"Something went wrong"}) 104 | } 105 | } 106 | 107 | exports.searchUsers = async (req, res) => { 108 | try { 109 | const users = await User.find({ 110 | name: { $regex: req.query.name, $options: 'i' }, 111 | }).populate("friends") 112 | 113 | const usersData = users.map((user) => FilterUserData(user)) 114 | 115 | res.status(200).json({ users: usersData }) 116 | } catch (err) { 117 | console.log(err) 118 | return res.status(500).json({error:"Something went wrong"}) 119 | } 120 | } 121 | -------------------------------------------------------------------------------- /controllers/User/UserAction.js: -------------------------------------------------------------------------------- 1 | const User = require('../../models/User') 2 | const FriendRequest = require('../../models/FriendRequest') 3 | const FilterUserData = require('../../utils/FilterUserData') 4 | const Notification = require('../../models/Notification') 5 | const CreateNotification = require('../../utils/CreateNotification') 6 | 7 | exports.sendFriendRequest = async (req, res) => { 8 | try { 9 | const user = await User.findById(req.params.userId) 10 | if (!user) { 11 | return res.status(404).json({ error: 'User not found' }) 12 | } 13 | 14 | if (req.userId == req.params.userId) { 15 | return res 16 | .status(400) 17 | .json({ error: 'You cannot send friend request to yourself' }) 18 | } 19 | 20 | if (user.friends.includes(req.userId)) { 21 | return res.status(400).json({ error: 'Already Friends' }) 22 | } 23 | 24 | const friendRequest = await FriendRequest.findOne({ 25 | sender: req.userId, 26 | receiver: req.params.userId, 27 | }) 28 | 29 | if (friendRequest) { 30 | return res.status(400).json({ error: 'Friend Request already send' }) 31 | } 32 | 33 | const newFriendRequest = new FriendRequest({ 34 | sender: req.userId, 35 | receiver: req.params.userId, 36 | }) 37 | 38 | const save = await newFriendRequest.save() 39 | 40 | const friend = await FriendRequest.findById(save.id).populate('receiver') 41 | 42 | const chunkData = { 43 | id: friend.id, 44 | user: FilterUserData(friend.receiver), 45 | } 46 | 47 | res 48 | .status(200) 49 | .json({ message: 'Friend Request Sended', friend: chunkData }) 50 | 51 | const sender = await FriendRequest.findById(save.id).populate('sender') 52 | let notification = await CreateNotification({ 53 | user: req.params.userId, 54 | body: `${sender.sender.name} has send you friend request`, 55 | }) 56 | const senderData = { 57 | id: sender.id, 58 | user: FilterUserData(sender.sender), 59 | } 60 | 61 | if (user.socketId) { 62 | req.io 63 | .to(user.socketId) 64 | .emit('friend-request-status', { sender: senderData }) 65 | req.io.to(user.socketId).emit('Notification', { data: notification }) 66 | } 67 | } catch (err) { 68 | console.log(err) 69 | return res.status(500).json({error:"Something went wrong"}) 70 | } 71 | } 72 | 73 | exports.acceptFriendRequest = async (req, res) => { 74 | try { 75 | const friendsRequest = await FriendRequest.findById(req.params.requestId) 76 | if (!friendsRequest) { 77 | return res 78 | .status(404) 79 | .json({ error: 'Request already accepted or not sended yet' }) 80 | } 81 | 82 | const sender = await User.findById(friendsRequest.sender) 83 | if (sender.friends.includes(friendsRequest.receiver)) { 84 | return res.status(400).json({ error: 'already in your friend lists' }) 85 | } 86 | sender.friends.push(req.userId) 87 | await sender.save() 88 | 89 | const currentUser = await User.findById(req.userId) 90 | if (currentUser.friends.includes(friendsRequest.sender)) { 91 | return res.status(400).json({ error: 'already friend ' }) 92 | } 93 | currentUser.friends.push(friendsRequest.sender) 94 | await currentUser.save() 95 | 96 | const chunkData = FilterUserData(sender) 97 | 98 | await FriendRequest.deleteOne({ _id: req.params.requestId }) 99 | res 100 | .status(200) 101 | .json({ message: 'Friend Request Accepted', user: chunkData }) 102 | 103 | let notification = await CreateNotification({ 104 | user: sender.id, 105 | body: `${currentUser.name} has accepted your friend request`, 106 | }) 107 | if (sender.socketId) { 108 | let currentUserData = FilterUserData(currentUser) 109 | req.io.to(sender.socketId).emit('friend-request-accept-status', { 110 | user: currentUserData, 111 | request_id: req.params.requestId, 112 | }) 113 | req.io.to(sender.socketId).emit('Notification', { data: notification }) 114 | } 115 | } catch (err) { 116 | console.log(err) 117 | return res.status(500).json({error:"Something went wrong"}) 118 | } 119 | } 120 | 121 | exports.cancelSendedFriendRequest = async (req, res) => { 122 | try { 123 | const friendsRequest = await FriendRequest.findById( 124 | req.params.requestId, 125 | ).populate('receiver') 126 | if (!friendsRequest) { 127 | return res 128 | .status(404) 129 | .json({ error: 'Request already cenceled or not sended yet' }) 130 | } 131 | await FriendRequest.deleteOne({ _id: req.params.requestId }) 132 | 133 | res.status(200).json({ message: 'Friend Request Canceled' }) 134 | if (friendsRequest.receiver.socketId) { 135 | req.io 136 | .to(friendsRequest.receiver.socketId) 137 | .emit('sended-friend-request-cancel', { 138 | requestId: req.params.requestId, 139 | }) 140 | } 141 | } catch (err) { 142 | console.log(err) 143 | return res.status(500).json({error:"Something went wrong"}) 144 | } 145 | } 146 | 147 | exports.declineFriendRequest = async (req, res) => { 148 | try { 149 | const friendsRequest = await FriendRequest.findById( 150 | req.params.requestId, 151 | ).populate('sender') 152 | if (!friendsRequest) { 153 | return res 154 | .status(404) 155 | .json({ error: 'Request already declined or not sended yet' }) 156 | } 157 | await FriendRequest.deleteOne({ _id: req.params.requestId }) 158 | 159 | res.status(200).json({ message: 'Friend Request Declined' }) 160 | if (friendsRequest.sender.socketId) { 161 | req.io 162 | .to(friendsRequest.sender.socketId) 163 | .emit('received-friend-request-decline', { 164 | requestId: req.params.requestId, 165 | }) 166 | } 167 | } catch (err) { 168 | console.log(err) 169 | return res.status(500).json({error:"Something went wrong"}) 170 | } 171 | } 172 | 173 | exports.updateProfilePic = async (req, res) => { 174 | const { profile_url } = req.body 175 | try { 176 | const user = await User.findById(req.userId) 177 | user.profile_pic = profile_url 178 | await user.save() 179 | 180 | const getUser = await User.findById(req.userId).populate('friends') 181 | const userData = FilterUserData(getUser) 182 | 183 | const friends = getUser.friends.map((friend) => { 184 | return { 185 | ...FilterUserData(friend), 186 | } 187 | }) 188 | 189 | userData.friends = friends 190 | res.status(200).json({ message: 'profile image updated', user: userData }) 191 | } catch (err) { 192 | console.log(err) 193 | return res.status(500).json({error:"Something went wrong"}) 194 | } 195 | } 196 | 197 | exports.updateCoverPic = async (req, res) => { 198 | const { cover_url } = req.body 199 | try { 200 | const user = await User.findById(req.userId) 201 | user.cover_image = cover_url 202 | await user.save() 203 | 204 | const getUser = await User.findById(req.userId).populate('friends') 205 | const userData = FilterUserData(getUser) 206 | 207 | const friends = getUser.friends.map((friend) => { 208 | return { 209 | ...FilterUserData(friend), 210 | } 211 | }) 212 | 213 | userData.friends = friends 214 | res.status(200).json({ message: 'profile image updated', user: userData }) 215 | } catch (err) { 216 | console.log(err) 217 | return res.status(500).json({error:"Something went wrong"}) 218 | } 219 | } 220 | 221 | exports.updateProfile = async (req, res) => { 222 | try { 223 | const user = await User.findById(req.userId) 224 | 225 | if (req.params.input === 'name') { 226 | user.name = req.body.name 227 | } 228 | if (req.params.input === 'email') { 229 | user.email = req.body.email 230 | } 231 | 232 | if (req.params.input === 'bio') { 233 | user.bio = req.body.bio 234 | } 235 | if (req.params.input === 'location') { 236 | user.location = req.body.location 237 | } 238 | if (req.params.input === 'education') { 239 | user.education = req.body.education 240 | } 241 | 242 | await user.save() 243 | res.status(200).json({ message: 'Updated Successfully' }) 244 | } catch (err) { 245 | console.log(err) 246 | return res.status(500).json({error:"Something went wrong"}) 247 | } 248 | } 249 | 250 | exports.clearNotification = async (req, res) => { 251 | try { 252 | await Notification.deleteMany({ user: req.userId }) 253 | res.status(200).json({ message: 'Notification Cleared Successfully' }) 254 | } catch (err) { 255 | console.log(err) 256 | return res.status(500).json({error:"Something went wrong"}) 257 | } 258 | } 259 | -------------------------------------------------------------------------------- /index.js: -------------------------------------------------------------------------------- 1 | const express = require('express') 2 | const cors = require('cors') 3 | const mongoose = require('mongoose') 4 | require("dotenv").config() 5 | const app = express() 6 | const http = require('http') 7 | const server = http.createServer(app) 8 | const io = require('socket.io')(server) 9 | 10 | const UserRoutes = require('./routes/User') 11 | const AuthRoutes = require('./routes/Auth') 12 | const PostRoutes = require('./routes/Post') 13 | 14 | const PORT = process.env.PORT || 5000 15 | const {MONGODB_URI} = require("./config") 16 | 17 | app.use(cors()) 18 | app.use(express.json()) 19 | 20 | app.use((req, res, next) => { 21 | io.req = req 22 | req.io = io 23 | next() 24 | }) 25 | 26 | app.use('/api/auth', AuthRoutes) 27 | app.use('/api/user', UserRoutes) 28 | app.use('/api/post', PostRoutes) 29 | 30 | require('./socket')(io) 31 | 32 | mongoose 33 | .connect(MONGODB_URI, { 34 | useNewUrlParser: true, 35 | useUnifiedTopology: true, 36 | useCreateIndex: true, 37 | }) 38 | .then(() => { 39 | console.log('database connected') 40 | server.listen(PORT, () => console.log(`server started on port ${PORT}`)) 41 | }) 42 | .catch((err) => console.log(err)) 43 | -------------------------------------------------------------------------------- /middleware/AuthRequired.js: -------------------------------------------------------------------------------- 1 | const jwt = require('jsonwebtoken') 2 | 3 | module.exports = (req, res, next) => { 4 | const authHeader = req.get('authorization') 5 | 6 | if (authHeader) { 7 | const token = authHeader.split('Bearer ')[1] 8 | if (token) { 9 | let userId 10 | try { 11 | let decodedToken = jwt.decode(token) 12 | userId = decodedToken.userId 13 | } catch (err) { 14 | return res.status(400).json({ error: 'token are expired or incorrect' }) 15 | } 16 | 17 | if (userId) { 18 | req.userId = userId 19 | next() 20 | } else { 21 | return res.status(400).json({ error: 'Not Loggedin' }) 22 | } 23 | } else { 24 | return res.status(400).json({ error: 'Not Loggedin' }) 25 | } 26 | } else { 27 | return res.status(400).json({ error: 'Not Loggedin' }) 28 | } 29 | } 30 | -------------------------------------------------------------------------------- /models/Chat.js: -------------------------------------------------------------------------------- 1 | const { Schema, model } = require('mongoose') 2 | 3 | const chatSchema = new Schema( 4 | { 5 | sender: { 6 | type: Schema.Types.ObjectId, 7 | ref: 'User', 8 | }, 9 | receiver: { 10 | type: Schema.Types.ObjectId, 11 | ref: 'User', 12 | }, 13 | body: { 14 | type: Object, 15 | required: true, 16 | }, 17 | }, 18 | { timestamps: true }, 19 | ) 20 | 21 | module.exports = model('Chat', chatSchema) 22 | -------------------------------------------------------------------------------- /models/Comment.js: -------------------------------------------------------------------------------- 1 | const { Schema, model } = require('mongoose') 2 | 3 | const commentSchema = new Schema({ 4 | post: { 5 | type: Schema.Types.ObjectId, 6 | ref: 'Post', 7 | }, 8 | 9 | user: { 10 | type: Schema.Types.ObjectId, 11 | ref: 'User', 12 | }, 13 | body: { 14 | image: String, 15 | text: { 16 | type: String, 17 | trim: true, 18 | }, 19 | }, 20 | 21 | likes: [{ type: Schema.Types.ObjectId, ref: 'User' }], 22 | }) 23 | 24 | module.exports = model('Comment', commentSchema) 25 | -------------------------------------------------------------------------------- /models/FriendRequest.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose') 2 | 3 | const Schema = mongoose.Schema 4 | 5 | const FriendRequestSchema = new Schema( 6 | { 7 | sender: { 8 | type: Schema.Types.ObjectId, 9 | ref: 'User', 10 | }, 11 | receiver: { 12 | type: Schema.Types.ObjectId, 13 | ref: 'User', 14 | }, 15 | isAccepted: { 16 | type: Boolean, 17 | default: false, 18 | }, 19 | }, 20 | { timestamps: true }, 21 | ) 22 | 23 | module.exports = mongoose.model('FriendRequest', FriendRequestSchema) 24 | -------------------------------------------------------------------------------- /models/Notification.js: -------------------------------------------------------------------------------- 1 | const { Schema, model } = require("mongoose") 2 | 3 | 4 | const notificationSchema = new Schema({ 5 | body: { 6 | type: String, 7 | required: true 8 | }, 9 | 10 | user: { 11 | type: Schema.Types.ObjectId, 12 | ref: "User" 13 | } 14 | 15 | }, { timestamps: true }) 16 | 17 | 18 | module.exports = model("Notification",notificationSchema) -------------------------------------------------------------------------------- /models/Post.js: -------------------------------------------------------------------------------- 1 | const { Schema, model } = require('mongoose') 2 | 3 | const postSchema = new Schema( 4 | { 5 | user: { 6 | type: Schema.Types.ObjectId, 7 | ref: 'User', 8 | }, 9 | content: { 10 | type: String, 11 | trim: true, 12 | }, 13 | body: { 14 | feelings: { 15 | type: String, 16 | trim: true, 17 | }, 18 | with: [ 19 | { 20 | type: Schema.Types.ObjectId, 21 | ref: 'User', 22 | }, 23 | ], 24 | at: { 25 | type: String, 26 | trim: true, 27 | }, 28 | date: String, 29 | }, 30 | image: String, 31 | isProfilePost: { 32 | type: Boolean, 33 | default: false, 34 | }, 35 | 36 | profilePostData: { 37 | coverImage: String, 38 | profileImage: String, 39 | }, 40 | 41 | privacy: { 42 | type: String, 43 | enum: ['Only me', 'Public'], 44 | default: 'Public', 45 | }, 46 | 47 | likes: [ 48 | { 49 | type: Schema.Types.ObjectId, 50 | ref: 'User', 51 | }, 52 | ], 53 | 54 | hearts: [ 55 | { 56 | type: Schema.Types.ObjectId, 57 | ref: 'User', 58 | }, 59 | ], 60 | }, 61 | { timestamps: true }, 62 | ) 63 | 64 | module.exports = model('Post', postSchema) 65 | -------------------------------------------------------------------------------- /models/User.js: -------------------------------------------------------------------------------- 1 | const mongoose = require('mongoose') 2 | 3 | const Schema = mongoose.Schema 4 | 5 | const UserSchema = new Schema( 6 | { 7 | name: { 8 | type: String, 9 | trim: true, 10 | required: true, 11 | }, 12 | email: { 13 | type: String, 14 | trim: true, 15 | unique: true, 16 | required: true, 17 | }, 18 | password: { 19 | type: String, 20 | required: true, 21 | }, 22 | 23 | profile_pic: { 24 | type: String, 25 | default: '', 26 | }, 27 | 28 | cover_image: { 29 | type: String, 30 | default: '', 31 | }, 32 | 33 | bio: { 34 | type: String, 35 | default: '', 36 | trim: true, 37 | }, 38 | active: { 39 | type: Boolean, 40 | default: false, 41 | }, 42 | socketId: { 43 | type: String, 44 | default: '', 45 | }, 46 | jwtToken: [String], 47 | 48 | location: { 49 | type: Object, 50 | }, 51 | education: { 52 | type: String, 53 | trim: true, 54 | }, 55 | 56 | friends: [{ type: Schema.Types.ObjectId, ref: 'User' }], 57 | }, 58 | 59 | { timestamps: true }, 60 | ) 61 | 62 | UserSchema.index({ name: 'text', email: 'text'}) 63 | module.exports = mongoose.model('User', UserSchema) 64 | -------------------------------------------------------------------------------- /package.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "server", 3 | "version": "1.0.0", 4 | "main": "index.js", 5 | "license": "MIT", 6 | "scripts": { 7 | "dev": "nodemon index.js", 8 | "start": "node index.js" 9 | }, 10 | "dependencies": { 11 | "bcrypt": "^5.0.0", 12 | "cors": "^2.8.5", 13 | "express": "^4.17.1", 14 | "jsonwebtoken": "^8.5.1", 15 | "mongoose": "^5.10.7", 16 | "multer": "^1.4.2", 17 | "socket.io": "^2.3.0", 18 | "dotenv": "^8.2.0" 19 | }, 20 | "devDependencies": { 21 | "nodemon": "^2.0.4" 22 | } 23 | } -------------------------------------------------------------------------------- /routes/Auth.js: -------------------------------------------------------------------------------- 1 | const router = require('express').Router() 2 | const SignupUser = require('../controllers/Auth/Signup') 3 | const LoginUser = require('../controllers/Auth/Login') 4 | const Logout = require('../controllers/Auth/Logout') 5 | const ChangePassword = require("../controllers/Auth/ChangePassword") 6 | 7 | const authRequired = require("../middleware/AuthRequired") 8 | 9 | router.post('/signup', SignupUser) 10 | router.post('/login', LoginUser) 11 | router.get("/logout",authRequired,Logout) 12 | 13 | router.put("/update_password",authRequired,ChangePassword) 14 | module.exports = router 15 | -------------------------------------------------------------------------------- /routes/Post.js: -------------------------------------------------------------------------------- 1 | const router = require('express').Router() 2 | const { 3 | createComment, 4 | fetchComments, 5 | likeDislikeComment, 6 | createReply 7 | } = require('../controllers/Post/Comment') 8 | const { 9 | fetchAllPosts, 10 | fetchPostById, 11 | } = require('../controllers/Post/FetchPost') 12 | const { 13 | createPost, 14 | likeDislikePost, 15 | } = require('../controllers/Post/postAction') 16 | const authRequired = require('../middleware/AuthRequired') 17 | 18 | router.post('/', authRequired, createPost) 19 | router.get('/', authRequired, fetchAllPosts) 20 | router.get('/:postId', authRequired, fetchPostById) 21 | 22 | router.get('/comment/:commentId/like_dislike', authRequired, likeDislikeComment) 23 | 24 | router.get('/:postId/like_dislike', authRequired, likeDislikePost) 25 | router.get('/:postId/comment', authRequired, fetchComments) 26 | router.post('/:postId/comment', authRequired, createComment) 27 | 28 | module.exports = router 29 | -------------------------------------------------------------------------------- /routes/User.js: -------------------------------------------------------------------------------- 1 | const router = require('express').Router() 2 | const { 3 | me, 4 | fetchUserById, 5 | fetchRecommandedUsers, 6 | fetchSendedFriendRequest, 7 | fetchIncommingFriendRequest, 8 | searchUsers 9 | } = require('../controllers/User/FetchUser') 10 | 11 | const { 12 | sendMessageToFriend, 13 | getFriendMessages, 14 | } = require('../controllers/User/Chat') 15 | const { 16 | sendFriendRequest, 17 | acceptFriendRequest, 18 | declineFriendRequest, 19 | cancelSendedFriendRequest, 20 | updateProfilePic, 21 | updateCoverPic, 22 | updateProfile, 23 | clearNotification, 24 | } = require('../controllers/User/UserAction') 25 | const authRequired = require('../middleware/AuthRequired') 26 | 27 | router.get('/me', authRequired, me) 28 | router.get('/recommanded_users', authRequired, fetchRecommandedUsers) 29 | router.get('/friend_request/sended', authRequired, fetchSendedFriendRequest) 30 | router.get( 31 | '/friend_request/received', 32 | authRequired, 33 | fetchIncommingFriendRequest, 34 | ) 35 | 36 | router.get('/search', searchUsers) 37 | router.get('/friend_request/:userId/send', authRequired, sendFriendRequest) 38 | router.get( 39 | '/friend_request/:requestId/accept', 40 | authRequired, 41 | acceptFriendRequest, 42 | ) 43 | router.get( 44 | '/friend_request/:requestId/decline', 45 | authRequired, 46 | declineFriendRequest, 47 | ) 48 | router.get( 49 | '/friend_request/:requestId/cancel', 50 | authRequired, 51 | cancelSendedFriendRequest, 52 | ) 53 | router.get('/:user_id', authRequired, fetchUserById) 54 | 55 | router.post('/chat/:friendId/send', authRequired, sendMessageToFriend) 56 | router.get('/chat/:friendId/get_messages', authRequired, getFriendMessages) 57 | 58 | router.put('/profile_pic/update', authRequired, updateProfilePic) 59 | router.put('/cover_pic/update', authRequired, updateCoverPic) 60 | router.put('/update_profile/:input', authRequired, updateProfile) 61 | router.delete('/notifications/clear', authRequired, clearNotification) 62 | 63 | module.exports = router 64 | -------------------------------------------------------------------------------- /socket.js: -------------------------------------------------------------------------------- 1 | const User = require('./models/User') 2 | const jwt = require('jsonwebtoken') 3 | 4 | module.exports = (io) => { 5 | io.on('connection', (socket) => { 6 | if (io.req) { 7 | socket.broadcast.emit('friend-login-status', { user_id: io.req.userId }) 8 | addSocketIdInDB(socket.id, io.req.userId) 9 | 10 | socket.on('disconnect', () => { 11 | socket.broadcast.emit('friend-logout-status', { 12 | user_id: io.req.userId, 13 | }) 14 | io.req.userId = null 15 | }) 16 | } 17 | }) 18 | } 19 | 20 | async function addSocketIdInDB(socket_id, user_id) { 21 | const user = await User.findById(user_id) 22 | if (socket_id) { 23 | user.socketId = socket_id 24 | } 25 | await user.save() 26 | } 27 | -------------------------------------------------------------------------------- /utils/CreateNotification.js: -------------------------------------------------------------------------------- 1 | const Notification = require("../models/Notification") 2 | 3 | module.exports = async ({ user, body }) => { 4 | const notification = new Notification({ user, body }) 5 | const saveNotification = await notification.save() 6 | return { 7 | id: saveNotification.id, 8 | body, 9 | createdAt:notification.createdAt 10 | } 11 | 12 | } -------------------------------------------------------------------------------- /utils/FilterCommentData.js: -------------------------------------------------------------------------------- 1 | const { post } = require('../routes/Post') 2 | 3 | module.exports = (comment) => { 4 | return { 5 | id: comment.id, 6 | post: comment.post, 7 | user: { 8 | id: comment.user._id, 9 | name: comment.user.name, 10 | email: comment.user.email, 11 | profile_pic: comment.user.profile_pic, 12 | }, 13 | body: comment.body, 14 | likes: comment.likes, 15 | } 16 | } 17 | -------------------------------------------------------------------------------- /utils/FilterPostData.js: -------------------------------------------------------------------------------- 1 | module.exports = (post) => { 2 | return { 3 | id: post.id, 4 | content: post.content, 5 | body: { 6 | feelings: post.body.feelings, 7 | with: post.body.with.map((user) => ({ 8 | id: user._id, 9 | name: user.name, 10 | })), 11 | at: post.body.at, 12 | date: post.body.date, 13 | }, 14 | image: post.image, 15 | isProfilePost: post.isProfilePost, 16 | profilePostData: post.profilePostData, 17 | privacy: post.privacy, 18 | createdAt: post.createdAt, 19 | likes: post.likes, 20 | user: { 21 | id: post.user._id, 22 | name: post.user.name, 23 | active: post.user.active, 24 | profile_pic: post.user.profile_pic, 25 | }, 26 | } 27 | } 28 | -------------------------------------------------------------------------------- /utils/FilterUserData.js: -------------------------------------------------------------------------------- 1 | module.exports = (user) => { 2 | return { 3 | id: user.id, 4 | name: user.name, 5 | email: user.email, 6 | profile_pic: user.profile_pic, 7 | cover_image: user.cover_image, 8 | bio: user.bio, 9 | location: user.location, 10 | education: user.education, 11 | active: user.active, 12 | createdAt: user.createdAt, 13 | friends: user.friends.map((friend) => ({ 14 | id: friend._id, 15 | name:friend.name 16 | })), 17 | } 18 | } 19 | -------------------------------------------------------------------------------- /utils/ValidateEmail.js: -------------------------------------------------------------------------------- 1 | module.exports = (email) => { 2 | const re = /^(([^<>()\[\]\\.,;:\s@"]+(\.[^<>()\[\]\\.,;:\s@"]+)*)|(".+"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/ 3 | return re.test(String(email).toLowerCase()) 4 | } 5 | -------------------------------------------------------------------------------- /utils/socket/SendDataToFriend.js: -------------------------------------------------------------------------------- 1 | const User = require("../../models/User") 2 | const CreateNotification = require("../CreateNotification") 3 | 4 | module.exports = async ({ req, key, data, notif_body }) => { 5 | const friend = await User.findById(req.userId).populate("friends") 6 | 7 | 8 | friend.friends.forEach(async user => { 9 | if (user.socketId) { 10 | req.io.to(user.socketId).emit(key, { data }) 11 | if (notif_body) { 12 | let notification = await CreateNotification({ user: user._id, body: notif_body }) 13 | req.io.to(user.socketId).emit("Notification", { data: notification }) 14 | } 15 | } 16 | }) 17 | } -------------------------------------------------------------------------------- /yarn.lock: -------------------------------------------------------------------------------- 1 | # THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. 2 | # yarn lockfile v1 3 | 4 | 5 | "@sindresorhus/is@^0.14.0": 6 | version "0.14.0" 7 | resolved "https://registry.yarnpkg.com/@sindresorhus/is/-/is-0.14.0.tgz#9fb3a3cf3132328151f353de4632e01e52102bea" 8 | integrity sha512-9NET910DNaIPngYnLLPeg+Ogzqsi9uM4mSboU5y6p8S5DzMTVEsJZrawi+BoDNUVBa2DhJqQYUFvMDfgU062LQ== 9 | 10 | "@szmarczak/http-timer@^1.1.2": 11 | version "1.1.2" 12 | resolved "https://registry.yarnpkg.com/@szmarczak/http-timer/-/http-timer-1.1.2.tgz#b1665e2c461a2cd92f4c1bbf50d5454de0d4b421" 13 | integrity sha512-XIB2XbzHTN6ieIjfIMV9hlVcfPU26s2vafYWQcZHWXHOxiaRZYEDKEwdl129Zyg50+foYV2jCgtrqSA6qNuNSA== 14 | dependencies: 15 | defer-to-connect "^1.0.1" 16 | 17 | "@types/color-name@^1.1.1": 18 | version "1.1.1" 19 | resolved "https://registry.yarnpkg.com/@types/color-name/-/color-name-1.1.1.tgz#1c1261bbeaa10a8055bbc5d8ab84b7b2afc846a0" 20 | integrity sha512-rr+OQyAjxze7GgWrSaJwydHStIhHq2lvY3BOC2Mj7KnzI7XK0Uw1TOOdI9lDoajEbSWLiYgoo4f1R51erQfhPQ== 21 | 22 | abbrev@1: 23 | version "1.1.1" 24 | resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8" 25 | integrity sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q== 26 | 27 | accepts@~1.3.4, accepts@~1.3.7: 28 | version "1.3.7" 29 | resolved "https://registry.yarnpkg.com/accepts/-/accepts-1.3.7.tgz#531bc726517a3b2b41f850021c6cc15eaab507cd" 30 | integrity sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA== 31 | dependencies: 32 | mime-types "~2.1.24" 33 | negotiator "0.6.2" 34 | 35 | after@0.8.2: 36 | version "0.8.2" 37 | resolved "https://registry.yarnpkg.com/after/-/after-0.8.2.tgz#fedb394f9f0e02aa9768e702bda23b505fae7e1f" 38 | integrity sha1-/ts5T58OAqqXaOcCvaI7UF+ufh8= 39 | 40 | ansi-align@^3.0.0: 41 | version "3.0.0" 42 | resolved "https://registry.yarnpkg.com/ansi-align/-/ansi-align-3.0.0.tgz#b536b371cf687caaef236c18d3e21fe3797467cb" 43 | integrity sha512-ZpClVKqXN3RGBmKibdfWzqCY4lnjEuoNzU5T0oEFpfd/z5qJHVarukridD4juLO2FXMiwUQxr9WqQtaYa8XRYw== 44 | dependencies: 45 | string-width "^3.0.0" 46 | 47 | ansi-regex@^2.0.0: 48 | version "2.1.1" 49 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df" 50 | integrity sha1-w7M6te42DYbg5ijwRorn7yfWVN8= 51 | 52 | ansi-regex@^3.0.0: 53 | version "3.0.0" 54 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998" 55 | integrity sha1-7QMXwyIGT3lGbAKWa922Bas32Zg= 56 | 57 | ansi-regex@^4.1.0: 58 | version "4.1.0" 59 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-4.1.0.tgz#8b9f8f08cf1acb843756a839ca8c7e3168c51997" 60 | integrity sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg== 61 | 62 | ansi-regex@^5.0.0: 63 | version "5.0.0" 64 | resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-5.0.0.tgz#388539f55179bf39339c81af30a654d69f87cb75" 65 | integrity sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg== 66 | 67 | ansi-styles@^4.1.0: 68 | version "4.2.1" 69 | resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-4.2.1.tgz#90ae75c424d008d2624c5bf29ead3177ebfcf359" 70 | integrity sha512-9VGjrMsG1vePxcSweQsN20KY/c4zN0h9fLjqAbwbPfahM3t+NL+M9HC8xeXG2I8pX5NoamTGNuomEUFI7fcUjA== 71 | dependencies: 72 | "@types/color-name" "^1.1.1" 73 | color-convert "^2.0.1" 74 | 75 | anymatch@~3.1.1: 76 | version "3.1.1" 77 | resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-3.1.1.tgz#c55ecf02185e2469259399310c173ce31233b142" 78 | integrity sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg== 79 | dependencies: 80 | normalize-path "^3.0.0" 81 | picomatch "^2.0.4" 82 | 83 | append-field@^1.0.0: 84 | version "1.0.0" 85 | resolved "https://registry.yarnpkg.com/append-field/-/append-field-1.0.0.tgz#1e3440e915f0b1203d23748e78edd7b9b5b43e56" 86 | integrity sha1-HjRA6RXwsSA9I3SOeO3XubW0PlY= 87 | 88 | aproba@^1.0.3: 89 | version "1.2.0" 90 | resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a" 91 | integrity sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw== 92 | 93 | are-we-there-yet@~1.1.2: 94 | version "1.1.5" 95 | resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz#4b35c2944f062a8bfcda66410760350fe9ddfc21" 96 | integrity sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w== 97 | dependencies: 98 | delegates "^1.0.0" 99 | readable-stream "^2.0.6" 100 | 101 | array-flatten@1.1.1: 102 | version "1.1.1" 103 | resolved "https://registry.yarnpkg.com/array-flatten/-/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2" 104 | integrity sha1-ml9pkFGx5wczKPKgCJaLZOopVdI= 105 | 106 | arraybuffer.slice@~0.0.7: 107 | version "0.0.7" 108 | resolved "https://registry.yarnpkg.com/arraybuffer.slice/-/arraybuffer.slice-0.0.7.tgz#3bbc4275dd584cc1b10809b89d4e8b63a69e7675" 109 | integrity sha512-wGUIVQXuehL5TCqQun8OW81jGzAWycqzFF8lFp+GOM5BXLYj3bKNsYC4daB7n6XjCqxQA/qgTJ+8ANR3acjrog== 110 | 111 | async-limiter@~1.0.0: 112 | version "1.0.1" 113 | resolved "https://registry.yarnpkg.com/async-limiter/-/async-limiter-1.0.1.tgz#dd379e94f0db8310b08291f9d64c3209766617fd" 114 | integrity sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ== 115 | 116 | backo2@1.0.2: 117 | version "1.0.2" 118 | resolved "https://registry.yarnpkg.com/backo2/-/backo2-1.0.2.tgz#31ab1ac8b129363463e35b3ebb69f4dfcfba7947" 119 | integrity sha1-MasayLEpNjRj41s+u2n038+6eUc= 120 | 121 | balanced-match@^1.0.0: 122 | version "1.0.0" 123 | resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767" 124 | integrity sha1-ibTRmasr7kneFk6gK4nORi1xt2c= 125 | 126 | base64-arraybuffer@0.1.5: 127 | version "0.1.5" 128 | resolved "https://registry.yarnpkg.com/base64-arraybuffer/-/base64-arraybuffer-0.1.5.tgz#73926771923b5a19747ad666aa5cd4bf9c6e9ce8" 129 | integrity sha1-c5JncZI7Whl0etZmqlzUv5xunOg= 130 | 131 | base64id@2.0.0: 132 | version "2.0.0" 133 | resolved "https://registry.yarnpkg.com/base64id/-/base64id-2.0.0.tgz#2770ac6bc47d312af97a8bf9a634342e0cd25cb6" 134 | integrity sha512-lGe34o6EHj9y3Kts9R4ZYs/Gr+6N7MCaMlIFA3F1R2O5/m7K06AxfSeO5530PEERE6/WyEg3lsuyw4GHlPZHog== 135 | 136 | bcrypt@^5.0.0: 137 | version "5.0.0" 138 | resolved "https://registry.yarnpkg.com/bcrypt/-/bcrypt-5.0.0.tgz#051407c7cd5ffbfb773d541ca3760ea0754e37e2" 139 | integrity sha512-jB0yCBl4W/kVHM2whjfyqnxTmOHkCX4kHEa5nYKSoGeYe8YrjTYTc87/6bwt1g8cmV0QrbhKriETg9jWtcREhg== 140 | dependencies: 141 | node-addon-api "^3.0.0" 142 | node-pre-gyp "0.15.0" 143 | 144 | better-assert@~1.0.0: 145 | version "1.0.2" 146 | resolved "https://registry.yarnpkg.com/better-assert/-/better-assert-1.0.2.tgz#40866b9e1b9e0b55b481894311e68faffaebc522" 147 | integrity sha1-QIZrnhueC1W0gYlDEeaPr/rrxSI= 148 | dependencies: 149 | callsite "1.0.0" 150 | 151 | binary-extensions@^2.0.0: 152 | version "2.1.0" 153 | resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-2.1.0.tgz#30fa40c9e7fe07dbc895678cd287024dea241dd9" 154 | integrity sha512-1Yj8h9Q+QDF5FzhMs/c9+6UntbD5MkRfRwac8DoEm9ZfUBZ7tZ55YcGVAzEe4bXsdQHEk+s9S5wsOKVdZrw0tQ== 155 | 156 | bl@^2.2.1: 157 | version "2.2.1" 158 | resolved "https://registry.yarnpkg.com/bl/-/bl-2.2.1.tgz#8c11a7b730655c5d56898cdc871224f40fd901d5" 159 | integrity sha512-6Pesp1w0DEX1N550i/uGV/TqucVL4AM/pgThFSN/Qq9si1/DF9aIHs1BxD8V/QU0HoeHO6cQRTAuYnLPKq1e4g== 160 | dependencies: 161 | readable-stream "^2.3.5" 162 | safe-buffer "^5.1.1" 163 | 164 | blob@0.0.5: 165 | version "0.0.5" 166 | resolved "https://registry.yarnpkg.com/blob/-/blob-0.0.5.tgz#d680eeef25f8cd91ad533f5b01eed48e64caf683" 167 | integrity sha512-gaqbzQPqOoamawKg0LGVd7SzLgXS+JH61oWprSLH+P+abTczqJbhTR8CmJ2u9/bUYNmHTGJx/UEmn6doAvvuig== 168 | 169 | bluebird@3.5.1: 170 | version "3.5.1" 171 | resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.5.1.tgz#d9551f9de98f1fcda1e683d17ee91a0602ee2eb9" 172 | integrity sha512-MKiLiV+I1AA596t9w1sQJ8jkiSr5+ZKi0WKrYGUn6d1Fx+Ij4tIj+m2WMQSGczs5jZVxV339chE8iwk6F64wjA== 173 | 174 | body-parser@1.19.0: 175 | version "1.19.0" 176 | resolved "https://registry.yarnpkg.com/body-parser/-/body-parser-1.19.0.tgz#96b2709e57c9c4e09a6fd66a8fd979844f69f08a" 177 | integrity sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw== 178 | dependencies: 179 | bytes "3.1.0" 180 | content-type "~1.0.4" 181 | debug "2.6.9" 182 | depd "~1.1.2" 183 | http-errors "1.7.2" 184 | iconv-lite "0.4.24" 185 | on-finished "~2.3.0" 186 | qs "6.7.0" 187 | raw-body "2.4.0" 188 | type-is "~1.6.17" 189 | 190 | boxen@^4.2.0: 191 | version "4.2.0" 192 | resolved "https://registry.yarnpkg.com/boxen/-/boxen-4.2.0.tgz#e411b62357d6d6d36587c8ac3d5d974daa070e64" 193 | integrity sha512-eB4uT9RGzg2odpER62bBwSLvUeGC+WbRjjyyFhGsKnc8wp/m0+hQsMUvUe3H2V0D5vw0nBdO1hCJoZo5mKeuIQ== 194 | dependencies: 195 | ansi-align "^3.0.0" 196 | camelcase "^5.3.1" 197 | chalk "^3.0.0" 198 | cli-boxes "^2.2.0" 199 | string-width "^4.1.0" 200 | term-size "^2.1.0" 201 | type-fest "^0.8.1" 202 | widest-line "^3.1.0" 203 | 204 | brace-expansion@^1.1.7: 205 | version "1.1.11" 206 | resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd" 207 | integrity sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA== 208 | dependencies: 209 | balanced-match "^1.0.0" 210 | concat-map "0.0.1" 211 | 212 | braces@~3.0.2: 213 | version "3.0.2" 214 | resolved "https://registry.yarnpkg.com/braces/-/braces-3.0.2.tgz#3454e1a462ee8d599e236df336cd9ea4f8afe107" 215 | integrity sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A== 216 | dependencies: 217 | fill-range "^7.0.1" 218 | 219 | bson@^1.1.4: 220 | version "1.1.5" 221 | resolved "https://registry.yarnpkg.com/bson/-/bson-1.1.5.tgz#2aaae98fcdf6750c0848b0cba1ddec3c73060a34" 222 | integrity sha512-kDuEzldR21lHciPQAIulLs1LZlCXdLziXI6Mb/TDkwXhb//UORJNPXgcRs2CuO4H0DcMkpfT3/ySsP3unoZjBg== 223 | 224 | buffer-equal-constant-time@1.0.1: 225 | version "1.0.1" 226 | resolved "https://registry.yarnpkg.com/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz#f8e71132f7ffe6e01a5c9697a4c6f3e48d5cc819" 227 | integrity sha1-+OcRMvf/5uAaXJaXpMbz5I1cyBk= 228 | 229 | buffer-from@^1.0.0: 230 | version "1.1.1" 231 | resolved "https://registry.yarnpkg.com/buffer-from/-/buffer-from-1.1.1.tgz#32713bc028f75c02fdb710d7c7bcec1f2c6070ef" 232 | integrity sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A== 233 | 234 | busboy@^0.2.11: 235 | version "0.2.14" 236 | resolved "https://registry.yarnpkg.com/busboy/-/busboy-0.2.14.tgz#6c2a622efcf47c57bbbe1e2a9c37ad36c7925453" 237 | integrity sha1-bCpiLvz0fFe7vh4qnDetNseSVFM= 238 | dependencies: 239 | dicer "0.2.5" 240 | readable-stream "1.1.x" 241 | 242 | bytes@3.1.0: 243 | version "3.1.0" 244 | resolved "https://registry.yarnpkg.com/bytes/-/bytes-3.1.0.tgz#f6cf7933a360e0588fa9fde85651cdc7f805d1f6" 245 | integrity sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg== 246 | 247 | cacheable-request@^6.0.0: 248 | version "6.1.0" 249 | resolved "https://registry.yarnpkg.com/cacheable-request/-/cacheable-request-6.1.0.tgz#20ffb8bd162ba4be11e9567d823db651052ca912" 250 | integrity sha512-Oj3cAGPCqOZX7Rz64Uny2GYAZNliQSqfbePrgAQ1wKAihYmCUnraBtJtKcGR4xz7wF+LoJC+ssFZvv5BgF9Igg== 251 | dependencies: 252 | clone-response "^1.0.2" 253 | get-stream "^5.1.0" 254 | http-cache-semantics "^4.0.0" 255 | keyv "^3.0.0" 256 | lowercase-keys "^2.0.0" 257 | normalize-url "^4.1.0" 258 | responselike "^1.0.2" 259 | 260 | callsite@1.0.0: 261 | version "1.0.0" 262 | resolved "https://registry.yarnpkg.com/callsite/-/callsite-1.0.0.tgz#280398e5d664bd74038b6f0905153e6e8af1bc20" 263 | integrity sha1-KAOY5dZkvXQDi28JBRU+borxvCA= 264 | 265 | camelcase@^5.3.1: 266 | version "5.3.1" 267 | resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-5.3.1.tgz#e3c9b31569e106811df242f715725a1f4c494320" 268 | integrity sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg== 269 | 270 | chalk@^3.0.0: 271 | version "3.0.0" 272 | resolved "https://registry.yarnpkg.com/chalk/-/chalk-3.0.0.tgz#3f73c2bf526591f574cc492c51e2456349f844e4" 273 | integrity sha512-4D3B6Wf41KOYRFdszmDqMCGq5VV/uMAB273JILmO+3jAlh8X4qDtdtgCR3fxtbLEMzSx22QdhnDcJvu2u1fVwg== 274 | dependencies: 275 | ansi-styles "^4.1.0" 276 | supports-color "^7.1.0" 277 | 278 | chokidar@^3.2.2: 279 | version "3.4.2" 280 | resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-3.4.2.tgz#38dc8e658dec3809741eb3ef7bb0a47fe424232d" 281 | integrity sha512-IZHaDeBeI+sZJRX7lGcXsdzgvZqKv6sECqsbErJA4mHWfpRrD8B97kSFN4cQz6nGBGiuFia1MKR4d6c1o8Cv7A== 282 | dependencies: 283 | anymatch "~3.1.1" 284 | braces "~3.0.2" 285 | glob-parent "~5.1.0" 286 | is-binary-path "~2.1.0" 287 | is-glob "~4.0.1" 288 | normalize-path "~3.0.0" 289 | readdirp "~3.4.0" 290 | optionalDependencies: 291 | fsevents "~2.1.2" 292 | 293 | chownr@^1.1.1: 294 | version "1.1.4" 295 | resolved "https://registry.yarnpkg.com/chownr/-/chownr-1.1.4.tgz#6fc9d7b42d32a583596337666e7d08084da2cc6b" 296 | integrity sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg== 297 | 298 | ci-info@^2.0.0: 299 | version "2.0.0" 300 | resolved "https://registry.yarnpkg.com/ci-info/-/ci-info-2.0.0.tgz#67a9e964be31a51e15e5010d58e6f12834002f46" 301 | integrity sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ== 302 | 303 | cli-boxes@^2.2.0: 304 | version "2.2.1" 305 | resolved "https://registry.yarnpkg.com/cli-boxes/-/cli-boxes-2.2.1.tgz#ddd5035d25094fce220e9cab40a45840a440318f" 306 | integrity sha512-y4coMcylgSCdVinjiDBuR8PCC2bLjyGTwEmPb9NHR/QaNU6EUOXcTY/s6VjGMD6ENSEaeQYHCY0GNGS5jfMwPw== 307 | 308 | clone-response@^1.0.2: 309 | version "1.0.2" 310 | resolved "https://registry.yarnpkg.com/clone-response/-/clone-response-1.0.2.tgz#d1dc973920314df67fbeb94223b4ee350239e96b" 311 | integrity sha1-0dyXOSAxTfZ/vrlCI7TuNQI56Ws= 312 | dependencies: 313 | mimic-response "^1.0.0" 314 | 315 | code-point-at@^1.0.0: 316 | version "1.1.0" 317 | resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77" 318 | integrity sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c= 319 | 320 | color-convert@^2.0.1: 321 | version "2.0.1" 322 | resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-2.0.1.tgz#72d3a68d598c9bdb3af2ad1e84f21d896abd4de3" 323 | integrity sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ== 324 | dependencies: 325 | color-name "~1.1.4" 326 | 327 | color-name@~1.1.4: 328 | version "1.1.4" 329 | resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.4.tgz#c2a09a87acbde69543de6f63fa3995c826c536a2" 330 | integrity sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA== 331 | 332 | component-bind@1.0.0: 333 | version "1.0.0" 334 | resolved "https://registry.yarnpkg.com/component-bind/-/component-bind-1.0.0.tgz#00c608ab7dcd93897c0009651b1d3a8e1e73bbd1" 335 | integrity sha1-AMYIq33Nk4l8AAllGx06jh5zu9E= 336 | 337 | component-emitter@1.2.1: 338 | version "1.2.1" 339 | resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.2.1.tgz#137918d6d78283f7df7a6b7c5a63e140e69425e6" 340 | integrity sha1-E3kY1teCg/ffemt8WmPhQOaUJeY= 341 | 342 | component-emitter@~1.3.0: 343 | version "1.3.0" 344 | resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.3.0.tgz#16e4070fba8ae29b679f2215853ee181ab2eabc0" 345 | integrity sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg== 346 | 347 | component-inherit@0.0.3: 348 | version "0.0.3" 349 | resolved "https://registry.yarnpkg.com/component-inherit/-/component-inherit-0.0.3.tgz#645fc4adf58b72b649d5cae65135619db26ff143" 350 | integrity sha1-ZF/ErfWLcrZJ1crmUTVhnbJv8UM= 351 | 352 | concat-map@0.0.1: 353 | version "0.0.1" 354 | resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b" 355 | integrity sha1-2Klr13/Wjfd5OnMDajug1UBdR3s= 356 | 357 | concat-stream@^1.5.2: 358 | version "1.6.2" 359 | resolved "https://registry.yarnpkg.com/concat-stream/-/concat-stream-1.6.2.tgz#904bdf194cd3122fc675c77fc4ac3d4ff0fd1a34" 360 | integrity sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw== 361 | dependencies: 362 | buffer-from "^1.0.0" 363 | inherits "^2.0.3" 364 | readable-stream "^2.2.2" 365 | typedarray "^0.0.6" 366 | 367 | configstore@^5.0.1: 368 | version "5.0.1" 369 | resolved "https://registry.yarnpkg.com/configstore/-/configstore-5.0.1.tgz#d365021b5df4b98cdd187d6a3b0e3f6a7cc5ed96" 370 | integrity sha512-aMKprgk5YhBNyH25hj8wGt2+D52Sw1DRRIzqBwLp2Ya9mFmY8KPvvtvmna8SxVR9JMZ4kzMD68N22vlaRpkeFA== 371 | dependencies: 372 | dot-prop "^5.2.0" 373 | graceful-fs "^4.1.2" 374 | make-dir "^3.0.0" 375 | unique-string "^2.0.0" 376 | write-file-atomic "^3.0.0" 377 | xdg-basedir "^4.0.0" 378 | 379 | console-control-strings@^1.0.0, console-control-strings@~1.1.0: 380 | version "1.1.0" 381 | resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e" 382 | integrity sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4= 383 | 384 | content-disposition@0.5.3: 385 | version "0.5.3" 386 | resolved "https://registry.yarnpkg.com/content-disposition/-/content-disposition-0.5.3.tgz#e130caf7e7279087c5616c2007d0485698984fbd" 387 | integrity sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g== 388 | dependencies: 389 | safe-buffer "5.1.2" 390 | 391 | content-type@~1.0.4: 392 | version "1.0.4" 393 | resolved "https://registry.yarnpkg.com/content-type/-/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b" 394 | integrity sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA== 395 | 396 | cookie-signature@1.0.6: 397 | version "1.0.6" 398 | resolved "https://registry.yarnpkg.com/cookie-signature/-/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c" 399 | integrity sha1-4wOogrNCzD7oylE6eZmXNNqzriw= 400 | 401 | cookie@0.3.1: 402 | version "0.3.1" 403 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.3.1.tgz#e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb" 404 | integrity sha1-5+Ch+e9DtMi6klxcWpboBtFoc7s= 405 | 406 | cookie@0.4.0: 407 | version "0.4.0" 408 | resolved "https://registry.yarnpkg.com/cookie/-/cookie-0.4.0.tgz#beb437e7022b3b6d49019d088665303ebe9c14ba" 409 | integrity sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg== 410 | 411 | core-util-is@~1.0.0: 412 | version "1.0.2" 413 | resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7" 414 | integrity sha1-tf1UIgqivFq1eqtxQMlAdUUDwac= 415 | 416 | cors@^2.8.5: 417 | version "2.8.5" 418 | resolved "https://registry.yarnpkg.com/cors/-/cors-2.8.5.tgz#eac11da51592dd86b9f06f6e7ac293b3df875d29" 419 | integrity sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g== 420 | dependencies: 421 | object-assign "^4" 422 | vary "^1" 423 | 424 | crypto-random-string@^2.0.0: 425 | version "2.0.0" 426 | resolved "https://registry.yarnpkg.com/crypto-random-string/-/crypto-random-string-2.0.0.tgz#ef2a7a966ec11083388369baa02ebead229b30d5" 427 | integrity sha512-v1plID3y9r/lPhviJ1wrXpLeyUIGAZ2SHNYTEapm7/8A9nLPoyvVp3RK/EPFqn5kEznyWgYZNsRtYYIWbuG8KA== 428 | 429 | debug@2.6.9, debug@^2.2.0: 430 | version "2.6.9" 431 | resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f" 432 | integrity sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA== 433 | dependencies: 434 | ms "2.0.0" 435 | 436 | debug@3.1.0, debug@~3.1.0: 437 | version "3.1.0" 438 | resolved "https://registry.yarnpkg.com/debug/-/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261" 439 | integrity sha512-OX8XqP7/1a9cqkxYw2yXss15f26NKWBpDXQd0/uK/KPqdQhxbPa994hnzjcE2VqQpDslf55723cKPUOGSmMY3g== 440 | dependencies: 441 | ms "2.0.0" 442 | 443 | debug@^3.2.6: 444 | version "3.2.6" 445 | resolved "https://registry.yarnpkg.com/debug/-/debug-3.2.6.tgz#e83d17de16d8a7efb7717edbe5fb10135eee629b" 446 | integrity sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ== 447 | dependencies: 448 | ms "^2.1.1" 449 | 450 | debug@~4.1.0: 451 | version "4.1.1" 452 | resolved "https://registry.yarnpkg.com/debug/-/debug-4.1.1.tgz#3b72260255109c6b589cee050f1d516139664791" 453 | integrity sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw== 454 | dependencies: 455 | ms "^2.1.1" 456 | 457 | decompress-response@^3.3.0: 458 | version "3.3.0" 459 | resolved "https://registry.yarnpkg.com/decompress-response/-/decompress-response-3.3.0.tgz#80a4dd323748384bfa248083622aedec982adff3" 460 | integrity sha1-gKTdMjdIOEv6JICDYirt7Jgq3/M= 461 | dependencies: 462 | mimic-response "^1.0.0" 463 | 464 | deep-extend@^0.6.0: 465 | version "0.6.0" 466 | resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.6.0.tgz#c4fa7c95404a17a9c3e8ca7e1537312b736330ac" 467 | integrity sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA== 468 | 469 | defer-to-connect@^1.0.1: 470 | version "1.1.3" 471 | resolved "https://registry.yarnpkg.com/defer-to-connect/-/defer-to-connect-1.1.3.tgz#331ae050c08dcf789f8c83a7b81f0ed94f4ac591" 472 | integrity sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ== 473 | 474 | delegates@^1.0.0: 475 | version "1.0.0" 476 | resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a" 477 | integrity sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o= 478 | 479 | denque@^1.4.1: 480 | version "1.4.1" 481 | resolved "https://registry.yarnpkg.com/denque/-/denque-1.4.1.tgz#6744ff7641c148c3f8a69c307e51235c1f4a37cf" 482 | integrity sha512-OfzPuSZKGcgr96rf1oODnfjqBFmr1DVoc/TrItj3Ohe0Ah1C5WX5Baquw/9U9KovnQ88EqmJbD66rKYUQYN1tQ== 483 | 484 | depd@~1.1.2: 485 | version "1.1.2" 486 | resolved "https://registry.yarnpkg.com/depd/-/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9" 487 | integrity sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak= 488 | 489 | destroy@~1.0.4: 490 | version "1.0.4" 491 | resolved "https://registry.yarnpkg.com/destroy/-/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80" 492 | integrity sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA= 493 | 494 | detect-libc@^1.0.2: 495 | version "1.0.3" 496 | resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b" 497 | integrity sha1-+hN8S9aY7fVc1c0CrFWfkaTEups= 498 | 499 | dicer@0.2.5: 500 | version "0.2.5" 501 | resolved "https://registry.yarnpkg.com/dicer/-/dicer-0.2.5.tgz#5996c086bb33218c812c090bddc09cd12facb70f" 502 | integrity sha1-WZbAhrszIYyBLAkL3cCc0S+stw8= 503 | dependencies: 504 | readable-stream "1.1.x" 505 | streamsearch "0.1.2" 506 | 507 | dot-prop@^5.2.0: 508 | version "5.3.0" 509 | resolved "https://registry.yarnpkg.com/dot-prop/-/dot-prop-5.3.0.tgz#90ccce708cd9cd82cc4dc8c3ddd9abdd55b20e88" 510 | integrity sha512-QM8q3zDe58hqUqjraQOmzZ1LIH9SWQJTlEKCH4kJ2oQvLZk7RbQXvtDM2XEq3fwkV9CCvvH4LA0AV+ogFsBM2Q== 511 | dependencies: 512 | is-obj "^2.0.0" 513 | 514 | dotenv@^8.2.0: 515 | version "8.2.0" 516 | resolved "https://registry.yarnpkg.com/dotenv/-/dotenv-8.2.0.tgz#97e619259ada750eea3e4ea3e26bceea5424b16a" 517 | integrity sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw== 518 | 519 | duplexer3@^0.1.4: 520 | version "0.1.4" 521 | resolved "https://registry.yarnpkg.com/duplexer3/-/duplexer3-0.1.4.tgz#ee01dd1cac0ed3cbc7fdbea37dc0a8f1ce002ce2" 522 | integrity sha1-7gHdHKwO08vH/b6jfcCo8c4ALOI= 523 | 524 | ecdsa-sig-formatter@1.0.11: 525 | version "1.0.11" 526 | resolved "https://registry.yarnpkg.com/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz#ae0f0fa2d85045ef14a817daa3ce9acd0489e5bf" 527 | integrity sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ== 528 | dependencies: 529 | safe-buffer "^5.0.1" 530 | 531 | ee-first@1.1.1: 532 | version "1.1.1" 533 | resolved "https://registry.yarnpkg.com/ee-first/-/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d" 534 | integrity sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0= 535 | 536 | emoji-regex@^7.0.1: 537 | version "7.0.3" 538 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-7.0.3.tgz#933a04052860c85e83c122479c4748a8e4c72156" 539 | integrity sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA== 540 | 541 | emoji-regex@^8.0.0: 542 | version "8.0.0" 543 | resolved "https://registry.yarnpkg.com/emoji-regex/-/emoji-regex-8.0.0.tgz#e818fd69ce5ccfcb404594f842963bf53164cc37" 544 | integrity sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A== 545 | 546 | encodeurl@~1.0.2: 547 | version "1.0.2" 548 | resolved "https://registry.yarnpkg.com/encodeurl/-/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59" 549 | integrity sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k= 550 | 551 | end-of-stream@^1.1.0: 552 | version "1.4.4" 553 | resolved "https://registry.yarnpkg.com/end-of-stream/-/end-of-stream-1.4.4.tgz#5ae64a5f45057baf3626ec14da0ca5e4b2431eb0" 554 | integrity sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q== 555 | dependencies: 556 | once "^1.4.0" 557 | 558 | engine.io-client@~3.4.0: 559 | version "3.4.3" 560 | resolved "https://registry.yarnpkg.com/engine.io-client/-/engine.io-client-3.4.3.tgz#192d09865403e3097e3575ebfeb3861c4d01a66c" 561 | integrity sha512-0NGY+9hioejTEJCaSJZfWZLk4FPI9dN+1H1C4+wj2iuFba47UgZbJzfWs4aNFajnX/qAaYKbe2lLTfEEWzCmcw== 562 | dependencies: 563 | component-emitter "~1.3.0" 564 | component-inherit "0.0.3" 565 | debug "~4.1.0" 566 | engine.io-parser "~2.2.0" 567 | has-cors "1.1.0" 568 | indexof "0.0.1" 569 | parseqs "0.0.5" 570 | parseuri "0.0.5" 571 | ws "~6.1.0" 572 | xmlhttprequest-ssl "~1.5.4" 573 | yeast "0.1.2" 574 | 575 | engine.io-parser@~2.2.0: 576 | version "2.2.0" 577 | resolved "https://registry.yarnpkg.com/engine.io-parser/-/engine.io-parser-2.2.0.tgz#312c4894f57d52a02b420868da7b5c1c84af80ed" 578 | integrity sha512-6I3qD9iUxotsC5HEMuuGsKA0cXerGz+4uGcXQEkfBidgKf0amsjrrtwcbwK/nzpZBxclXlV7gGl9dgWvu4LF6w== 579 | dependencies: 580 | after "0.8.2" 581 | arraybuffer.slice "~0.0.7" 582 | base64-arraybuffer "0.1.5" 583 | blob "0.0.5" 584 | has-binary2 "~1.0.2" 585 | 586 | engine.io@~3.4.0: 587 | version "3.4.2" 588 | resolved "https://registry.yarnpkg.com/engine.io/-/engine.io-3.4.2.tgz#8fc84ee00388e3e228645e0a7d3dfaeed5bd122c" 589 | integrity sha512-b4Q85dFkGw+TqgytGPrGgACRUhsdKc9S9ErRAXpPGy/CXKs4tYoHDkvIRdsseAF7NjfVwjRFIn6KTnbw7LwJZg== 590 | dependencies: 591 | accepts "~1.3.4" 592 | base64id "2.0.0" 593 | cookie "0.3.1" 594 | debug "~4.1.0" 595 | engine.io-parser "~2.2.0" 596 | ws "^7.1.2" 597 | 598 | escape-goat@^2.0.0: 599 | version "2.1.1" 600 | resolved "https://registry.yarnpkg.com/escape-goat/-/escape-goat-2.1.1.tgz#1b2dc77003676c457ec760b2dc68edb648188675" 601 | integrity sha512-8/uIhbG12Csjy2JEW7D9pHbreaVaS/OpN3ycnyvElTdwM5n6GY6W6e2IPemfvGZeUMqZ9A/3GqIZMgKnBhAw/Q== 602 | 603 | escape-html@~1.0.3: 604 | version "1.0.3" 605 | resolved "https://registry.yarnpkg.com/escape-html/-/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988" 606 | integrity sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg= 607 | 608 | etag@~1.8.1: 609 | version "1.8.1" 610 | resolved "https://registry.yarnpkg.com/etag/-/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887" 611 | integrity sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc= 612 | 613 | express@^4.17.1: 614 | version "4.17.1" 615 | resolved "https://registry.yarnpkg.com/express/-/express-4.17.1.tgz#4491fc38605cf51f8629d39c2b5d026f98a4c134" 616 | integrity sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g== 617 | dependencies: 618 | accepts "~1.3.7" 619 | array-flatten "1.1.1" 620 | body-parser "1.19.0" 621 | content-disposition "0.5.3" 622 | content-type "~1.0.4" 623 | cookie "0.4.0" 624 | cookie-signature "1.0.6" 625 | debug "2.6.9" 626 | depd "~1.1.2" 627 | encodeurl "~1.0.2" 628 | escape-html "~1.0.3" 629 | etag "~1.8.1" 630 | finalhandler "~1.1.2" 631 | fresh "0.5.2" 632 | merge-descriptors "1.0.1" 633 | methods "~1.1.2" 634 | on-finished "~2.3.0" 635 | parseurl "~1.3.3" 636 | path-to-regexp "0.1.7" 637 | proxy-addr "~2.0.5" 638 | qs "6.7.0" 639 | range-parser "~1.2.1" 640 | safe-buffer "5.1.2" 641 | send "0.17.1" 642 | serve-static "1.14.1" 643 | setprototypeof "1.1.1" 644 | statuses "~1.5.0" 645 | type-is "~1.6.18" 646 | utils-merge "1.0.1" 647 | vary "~1.1.2" 648 | 649 | fill-range@^7.0.1: 650 | version "7.0.1" 651 | resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-7.0.1.tgz#1919a6a7c75fe38b2c7c77e5198535da9acdda40" 652 | integrity sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ== 653 | dependencies: 654 | to-regex-range "^5.0.1" 655 | 656 | finalhandler@~1.1.2: 657 | version "1.1.2" 658 | resolved "https://registry.yarnpkg.com/finalhandler/-/finalhandler-1.1.2.tgz#b7e7d000ffd11938d0fdb053506f6ebabe9f587d" 659 | integrity sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA== 660 | dependencies: 661 | debug "2.6.9" 662 | encodeurl "~1.0.2" 663 | escape-html "~1.0.3" 664 | on-finished "~2.3.0" 665 | parseurl "~1.3.3" 666 | statuses "~1.5.0" 667 | unpipe "~1.0.0" 668 | 669 | forwarded@~0.1.2: 670 | version "0.1.2" 671 | resolved "https://registry.yarnpkg.com/forwarded/-/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84" 672 | integrity sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ= 673 | 674 | fresh@0.5.2: 675 | version "0.5.2" 676 | resolved "https://registry.yarnpkg.com/fresh/-/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7" 677 | integrity sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac= 678 | 679 | fs-minipass@^1.2.5: 680 | version "1.2.7" 681 | resolved "https://registry.yarnpkg.com/fs-minipass/-/fs-minipass-1.2.7.tgz#ccff8570841e7fe4265693da88936c55aed7f7c7" 682 | integrity sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA== 683 | dependencies: 684 | minipass "^2.6.0" 685 | 686 | fs.realpath@^1.0.0: 687 | version "1.0.0" 688 | resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f" 689 | integrity sha1-FQStJSMVjKpA20onh8sBQRmU6k8= 690 | 691 | fsevents@~2.1.2: 692 | version "2.1.3" 693 | resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-2.1.3.tgz#fb738703ae8d2f9fe900c33836ddebee8b97f23e" 694 | integrity sha512-Auw9a4AxqWpa9GUfj370BMPzzyncfBABW8Mab7BGWBYDj4Isgq+cDKtx0i6u9jcX9pQDnswsaaOTgTmA5pEjuQ== 695 | 696 | gauge@~2.7.3: 697 | version "2.7.4" 698 | resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7" 699 | integrity sha1-LANAXHU4w51+s3sxcCLjJfsBi/c= 700 | dependencies: 701 | aproba "^1.0.3" 702 | console-control-strings "^1.0.0" 703 | has-unicode "^2.0.0" 704 | object-assign "^4.1.0" 705 | signal-exit "^3.0.0" 706 | string-width "^1.0.1" 707 | strip-ansi "^3.0.1" 708 | wide-align "^1.1.0" 709 | 710 | get-stream@^4.1.0: 711 | version "4.1.0" 712 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-4.1.0.tgz#c1b255575f3dc21d59bfc79cd3d2b46b1c3a54b5" 713 | integrity sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w== 714 | dependencies: 715 | pump "^3.0.0" 716 | 717 | get-stream@^5.1.0: 718 | version "5.2.0" 719 | resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-5.2.0.tgz#4966a1795ee5ace65e706c4b7beb71257d6e22d3" 720 | integrity sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA== 721 | dependencies: 722 | pump "^3.0.0" 723 | 724 | glob-parent@~5.1.0: 725 | version "5.1.1" 726 | resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-5.1.1.tgz#b6c1ef417c4e5663ea498f1c45afac6916bbc229" 727 | integrity sha512-FnI+VGOpnlGHWZxthPGR+QhR78fuiK0sNLkHQv+bL9fQi57lNNdquIbna/WrfROrolq8GK5Ek6BiMwqL/voRYQ== 728 | dependencies: 729 | is-glob "^4.0.1" 730 | 731 | glob@^7.1.3: 732 | version "7.1.6" 733 | resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.6.tgz#141f33b81a7c2492e125594307480c46679278a6" 734 | integrity sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA== 735 | dependencies: 736 | fs.realpath "^1.0.0" 737 | inflight "^1.0.4" 738 | inherits "2" 739 | minimatch "^3.0.4" 740 | once "^1.3.0" 741 | path-is-absolute "^1.0.0" 742 | 743 | global-dirs@^2.0.1: 744 | version "2.0.1" 745 | resolved "https://registry.yarnpkg.com/global-dirs/-/global-dirs-2.0.1.tgz#acdf3bb6685bcd55cb35e8a052266569e9469201" 746 | integrity sha512-5HqUqdhkEovj2Of/ms3IeS/EekcO54ytHRLV4PEY2rhRwrHXLQjeVEES0Lhka0xwNDtGYn58wyC4s5+MHsOO6A== 747 | dependencies: 748 | ini "^1.3.5" 749 | 750 | got@^9.6.0: 751 | version "9.6.0" 752 | resolved "https://registry.yarnpkg.com/got/-/got-9.6.0.tgz#edf45e7d67f99545705de1f7bbeeeb121765ed85" 753 | integrity sha512-R7eWptXuGYxwijs0eV+v3o6+XH1IqVK8dJOEecQfTmkncw9AV4dcw/Dhxi8MdlqPthxxpZyizMzyg8RTmEsG+Q== 754 | dependencies: 755 | "@sindresorhus/is" "^0.14.0" 756 | "@szmarczak/http-timer" "^1.1.2" 757 | cacheable-request "^6.0.0" 758 | decompress-response "^3.3.0" 759 | duplexer3 "^0.1.4" 760 | get-stream "^4.1.0" 761 | lowercase-keys "^1.0.1" 762 | mimic-response "^1.0.1" 763 | p-cancelable "^1.0.0" 764 | to-readable-stream "^1.0.0" 765 | url-parse-lax "^3.0.0" 766 | 767 | graceful-fs@^4.1.2: 768 | version "4.2.4" 769 | resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.2.4.tgz#2256bde14d3632958c465ebc96dc467ca07a29fb" 770 | integrity sha512-WjKPNJF79dtJAVniUlGGWHYGz2jWxT6VhN/4m1NdkbZ2nOsEF+cI1Edgql5zCRhs/VsQYRvrXctxktVXZUkixw== 771 | 772 | has-binary2@~1.0.2: 773 | version "1.0.3" 774 | resolved "https://registry.yarnpkg.com/has-binary2/-/has-binary2-1.0.3.tgz#7776ac627f3ea77250cfc332dab7ddf5e4f5d11d" 775 | integrity sha512-G1LWKhDSvhGeAQ8mPVQlqNcOB2sJdwATtZKl2pDKKHfpf/rYj24lkinxf69blJbnsvtqqNU+L3SL50vzZhXOnw== 776 | dependencies: 777 | isarray "2.0.1" 778 | 779 | has-cors@1.1.0: 780 | version "1.1.0" 781 | resolved "https://registry.yarnpkg.com/has-cors/-/has-cors-1.1.0.tgz#5e474793f7ea9843d1bb99c23eef49ff126fff39" 782 | integrity sha1-XkdHk/fqmEPRu5nCPu9J/xJv/zk= 783 | 784 | has-flag@^3.0.0: 785 | version "3.0.0" 786 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd" 787 | integrity sha1-tdRU3CGZriJWmfNGfloH87lVuv0= 788 | 789 | has-flag@^4.0.0: 790 | version "4.0.0" 791 | resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-4.0.0.tgz#944771fd9c81c81265c4d6941860da06bb59479b" 792 | integrity sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ== 793 | 794 | has-unicode@^2.0.0: 795 | version "2.0.1" 796 | resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9" 797 | integrity sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk= 798 | 799 | has-yarn@^2.1.0: 800 | version "2.1.0" 801 | resolved "https://registry.yarnpkg.com/has-yarn/-/has-yarn-2.1.0.tgz#137e11354a7b5bf11aa5cb649cf0c6f3ff2b2e77" 802 | integrity sha512-UqBRqi4ju7T+TqGNdqAO0PaSVGsDGJUBQvk9eUWNGRY1CFGDzYhLWoM7JQEemnlvVcv/YEmc2wNW8BC24EnUsw== 803 | 804 | http-cache-semantics@^4.0.0: 805 | version "4.1.0" 806 | resolved "https://registry.yarnpkg.com/http-cache-semantics/-/http-cache-semantics-4.1.0.tgz#49e91c5cbf36c9b94bcfcd71c23d5249ec74e390" 807 | integrity sha512-carPklcUh7ROWRK7Cv27RPtdhYhUsela/ue5/jKzjegVvXDqM2ILE9Q2BGn9JZJh1g87cp56su/FgQSzcWS8cQ== 808 | 809 | http-errors@1.7.2: 810 | version "1.7.2" 811 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.2.tgz#4f5029cf13239f31036e5b2e55292bcfbcc85c8f" 812 | integrity sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg== 813 | dependencies: 814 | depd "~1.1.2" 815 | inherits "2.0.3" 816 | setprototypeof "1.1.1" 817 | statuses ">= 1.5.0 < 2" 818 | toidentifier "1.0.0" 819 | 820 | http-errors@~1.7.2: 821 | version "1.7.3" 822 | resolved "https://registry.yarnpkg.com/http-errors/-/http-errors-1.7.3.tgz#6c619e4f9c60308c38519498c14fbb10aacebb06" 823 | integrity sha512-ZTTX0MWrsQ2ZAhA1cejAwDLycFsd7I7nVtnkT3Ol0aqodaKW+0CTZDQ1uBv5whptCnc8e8HeRRJxRs0kmm/Qfw== 824 | dependencies: 825 | depd "~1.1.2" 826 | inherits "2.0.4" 827 | setprototypeof "1.1.1" 828 | statuses ">= 1.5.0 < 2" 829 | toidentifier "1.0.0" 830 | 831 | iconv-lite@0.4.24, iconv-lite@^0.4.4: 832 | version "0.4.24" 833 | resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.24.tgz#2022b4b25fbddc21d2f524974a474aafe733908b" 834 | integrity sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA== 835 | dependencies: 836 | safer-buffer ">= 2.1.2 < 3" 837 | 838 | ignore-by-default@^1.0.1: 839 | version "1.0.1" 840 | resolved "https://registry.yarnpkg.com/ignore-by-default/-/ignore-by-default-1.0.1.tgz#48ca6d72f6c6a3af00a9ad4ae6876be3889e2b09" 841 | integrity sha1-SMptcvbGo68Aqa1K5odr44ieKwk= 842 | 843 | ignore-walk@^3.0.1: 844 | version "3.0.3" 845 | resolved "https://registry.yarnpkg.com/ignore-walk/-/ignore-walk-3.0.3.tgz#017e2447184bfeade7c238e4aefdd1e8f95b1e37" 846 | integrity sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw== 847 | dependencies: 848 | minimatch "^3.0.4" 849 | 850 | import-lazy@^2.1.0: 851 | version "2.1.0" 852 | resolved "https://registry.yarnpkg.com/import-lazy/-/import-lazy-2.1.0.tgz#05698e3d45c88e8d7e9d92cb0584e77f096f3e43" 853 | integrity sha1-BWmOPUXIjo1+nZLLBYTnfwlvPkM= 854 | 855 | imurmurhash@^0.1.4: 856 | version "0.1.4" 857 | resolved "https://registry.yarnpkg.com/imurmurhash/-/imurmurhash-0.1.4.tgz#9218b9b2b928a238b13dc4fb6b6d576f231453ea" 858 | integrity sha1-khi5srkoojixPcT7a21XbyMUU+o= 859 | 860 | indexof@0.0.1: 861 | version "0.0.1" 862 | resolved "https://registry.yarnpkg.com/indexof/-/indexof-0.0.1.tgz#82dc336d232b9062179d05ab3293a66059fd435d" 863 | integrity sha1-gtwzbSMrkGIXnQWrMpOmYFn9Q10= 864 | 865 | inflight@^1.0.4: 866 | version "1.0.6" 867 | resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9" 868 | integrity sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk= 869 | dependencies: 870 | once "^1.3.0" 871 | wrappy "1" 872 | 873 | inherits@2, inherits@2.0.4, inherits@^2.0.3, inherits@~2.0.1, inherits@~2.0.3: 874 | version "2.0.4" 875 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.4.tgz#0fa2c64f932917c3433a0ded55363aae37416b7c" 876 | integrity sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ== 877 | 878 | inherits@2.0.3: 879 | version "2.0.3" 880 | resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de" 881 | integrity sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4= 882 | 883 | ini@^1.3.5, ini@~1.3.0: 884 | version "1.3.5" 885 | resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.5.tgz#eee25f56db1c9ec6085e0c22778083f596abf927" 886 | integrity sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw== 887 | 888 | ipaddr.js@1.9.1: 889 | version "1.9.1" 890 | resolved "https://registry.yarnpkg.com/ipaddr.js/-/ipaddr.js-1.9.1.tgz#bff38543eeb8984825079ff3a2a8e6cbd46781b3" 891 | integrity sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g== 892 | 893 | is-binary-path@~2.1.0: 894 | version "2.1.0" 895 | resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-2.1.0.tgz#ea1f7f3b80f064236e83470f86c09c254fb45b09" 896 | integrity sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw== 897 | dependencies: 898 | binary-extensions "^2.0.0" 899 | 900 | is-ci@^2.0.0: 901 | version "2.0.0" 902 | resolved "https://registry.yarnpkg.com/is-ci/-/is-ci-2.0.0.tgz#6bc6334181810e04b5c22b3d589fdca55026404c" 903 | integrity sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w== 904 | dependencies: 905 | ci-info "^2.0.0" 906 | 907 | is-extglob@^2.1.1: 908 | version "2.1.1" 909 | resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2" 910 | integrity sha1-qIwCU1eR8C7TfHahueqXc8gz+MI= 911 | 912 | is-fullwidth-code-point@^1.0.0: 913 | version "1.0.0" 914 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb" 915 | integrity sha1-754xOG8DGn8NZDr4L95QxFfvAMs= 916 | dependencies: 917 | number-is-nan "^1.0.0" 918 | 919 | is-fullwidth-code-point@^2.0.0: 920 | version "2.0.0" 921 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f" 922 | integrity sha1-o7MKXE8ZkYMWeqq5O+764937ZU8= 923 | 924 | is-fullwidth-code-point@^3.0.0: 925 | version "3.0.0" 926 | resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz#f116f8064fe90b3f7844a38997c0b75051269f1d" 927 | integrity sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg== 928 | 929 | is-glob@^4.0.1, is-glob@~4.0.1: 930 | version "4.0.1" 931 | resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.1.tgz#7567dbe9f2f5e2467bc77ab83c4a29482407a5dc" 932 | integrity sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg== 933 | dependencies: 934 | is-extglob "^2.1.1" 935 | 936 | is-installed-globally@^0.3.1: 937 | version "0.3.2" 938 | resolved "https://registry.yarnpkg.com/is-installed-globally/-/is-installed-globally-0.3.2.tgz#fd3efa79ee670d1187233182d5b0a1dd00313141" 939 | integrity sha512-wZ8x1js7Ia0kecP/CHM/3ABkAmujX7WPvQk6uu3Fly/Mk44pySulQpnHG46OMjHGXApINnV4QhY3SWnECO2z5g== 940 | dependencies: 941 | global-dirs "^2.0.1" 942 | is-path-inside "^3.0.1" 943 | 944 | is-npm@^4.0.0: 945 | version "4.0.0" 946 | resolved "https://registry.yarnpkg.com/is-npm/-/is-npm-4.0.0.tgz#c90dd8380696df87a7a6d823c20d0b12bbe3c84d" 947 | integrity sha512-96ECIfh9xtDDlPylNPXhzjsykHsMJZ18ASpaWzQyBr4YRTcVjUvzaHayDAES2oU/3KpljhHUjtSRNiDwi0F0ig== 948 | 949 | is-number@^7.0.0: 950 | version "7.0.0" 951 | resolved "https://registry.yarnpkg.com/is-number/-/is-number-7.0.0.tgz#7535345b896734d5f80c4d06c50955527a14f12b" 952 | integrity sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng== 953 | 954 | is-obj@^2.0.0: 955 | version "2.0.0" 956 | resolved "https://registry.yarnpkg.com/is-obj/-/is-obj-2.0.0.tgz#473fb05d973705e3fd9620545018ca8e22ef4982" 957 | integrity sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w== 958 | 959 | is-path-inside@^3.0.1: 960 | version "3.0.2" 961 | resolved "https://registry.yarnpkg.com/is-path-inside/-/is-path-inside-3.0.2.tgz#f5220fc82a3e233757291dddc9c5877f2a1f3017" 962 | integrity sha512-/2UGPSgmtqwo1ktx8NDHjuPwZWmHhO+gj0f93EkhLB5RgW9RZevWYYlIkS6zePc6U2WpOdQYIwHe9YC4DWEBVg== 963 | 964 | is-typedarray@^1.0.0: 965 | version "1.0.0" 966 | resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a" 967 | integrity sha1-5HnICFjfDBsR3dppQPlgEfzaSpo= 968 | 969 | is-yarn-global@^0.3.0: 970 | version "0.3.0" 971 | resolved "https://registry.yarnpkg.com/is-yarn-global/-/is-yarn-global-0.3.0.tgz#d502d3382590ea3004893746754c89139973e232" 972 | integrity sha512-VjSeb/lHmkoyd8ryPVIKvOCn4D1koMqY+vqyjjUfc3xyKtP4dYOxM44sZrnqQSzSds3xyOrUTLTC9LVCVgLngw== 973 | 974 | isarray@0.0.1: 975 | version "0.0.1" 976 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf" 977 | integrity sha1-ihis/Kmo9Bd+Cav8YDiTmwXR7t8= 978 | 979 | isarray@2.0.1: 980 | version "2.0.1" 981 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-2.0.1.tgz#a37d94ed9cda2d59865c9f76fe596ee1f338741e" 982 | integrity sha1-o32U7ZzaLVmGXJ92/llu4fM4dB4= 983 | 984 | isarray@~1.0.0: 985 | version "1.0.0" 986 | resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11" 987 | integrity sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE= 988 | 989 | json-buffer@3.0.0: 990 | version "3.0.0" 991 | resolved "https://registry.yarnpkg.com/json-buffer/-/json-buffer-3.0.0.tgz#5b1f397afc75d677bde8bcfc0e47e1f9a3d9a898" 992 | integrity sha1-Wx85evx11ne96Lz8Dkfh+aPZqJg= 993 | 994 | jsonwebtoken@^8.5.1: 995 | version "8.5.1" 996 | resolved "https://registry.yarnpkg.com/jsonwebtoken/-/jsonwebtoken-8.5.1.tgz#00e71e0b8df54c2121a1f26137df2280673bcc0d" 997 | integrity sha512-XjwVfRS6jTMsqYs0EsuJ4LGxXV14zQybNd4L2r0UvbVnSF9Af8x7p5MzbJ90Ioz/9TI41/hTCvznF/loiSzn8w== 998 | dependencies: 999 | jws "^3.2.2" 1000 | lodash.includes "^4.3.0" 1001 | lodash.isboolean "^3.0.3" 1002 | lodash.isinteger "^4.0.4" 1003 | lodash.isnumber "^3.0.3" 1004 | lodash.isplainobject "^4.0.6" 1005 | lodash.isstring "^4.0.1" 1006 | lodash.once "^4.0.0" 1007 | ms "^2.1.1" 1008 | semver "^5.6.0" 1009 | 1010 | jwa@^1.4.1: 1011 | version "1.4.1" 1012 | resolved "https://registry.yarnpkg.com/jwa/-/jwa-1.4.1.tgz#743c32985cb9e98655530d53641b66c8645b039a" 1013 | integrity sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA== 1014 | dependencies: 1015 | buffer-equal-constant-time "1.0.1" 1016 | ecdsa-sig-formatter "1.0.11" 1017 | safe-buffer "^5.0.1" 1018 | 1019 | jws@^3.2.2: 1020 | version "3.2.2" 1021 | resolved "https://registry.yarnpkg.com/jws/-/jws-3.2.2.tgz#001099f3639468c9414000e99995fa52fb478304" 1022 | integrity sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA== 1023 | dependencies: 1024 | jwa "^1.4.1" 1025 | safe-buffer "^5.0.1" 1026 | 1027 | kareem@2.3.1: 1028 | version "2.3.1" 1029 | resolved "https://registry.yarnpkg.com/kareem/-/kareem-2.3.1.tgz#def12d9c941017fabfb00f873af95e9c99e1be87" 1030 | integrity sha512-l3hLhffs9zqoDe8zjmb/mAN4B8VT3L56EUvKNqLFVs9YlFA+zx7ke1DO8STAdDyYNkeSo1nKmjuvQeI12So8Xw== 1031 | 1032 | keyv@^3.0.0: 1033 | version "3.1.0" 1034 | resolved "https://registry.yarnpkg.com/keyv/-/keyv-3.1.0.tgz#ecc228486f69991e49e9476485a5be1e8fc5c4d9" 1035 | integrity sha512-9ykJ/46SN/9KPM/sichzQ7OvXyGDYKGTaDlKMGCAlg2UK8KRy4jb0d8sFc+0Tt0YYnThq8X2RZgCg74RPxgcVA== 1036 | dependencies: 1037 | json-buffer "3.0.0" 1038 | 1039 | latest-version@^5.0.0: 1040 | version "5.1.0" 1041 | resolved "https://registry.yarnpkg.com/latest-version/-/latest-version-5.1.0.tgz#119dfe908fe38d15dfa43ecd13fa12ec8832face" 1042 | integrity sha512-weT+r0kTkRQdCdYCNtkMwWXQTMEswKrFBkm4ckQOMVhhqhIMI1UT2hMj+1iigIhgSZm5gTmrRXBNoGUgaTY1xA== 1043 | dependencies: 1044 | package-json "^6.3.0" 1045 | 1046 | lodash.includes@^4.3.0: 1047 | version "4.3.0" 1048 | resolved "https://registry.yarnpkg.com/lodash.includes/-/lodash.includes-4.3.0.tgz#60bb98a87cb923c68ca1e51325483314849f553f" 1049 | integrity sha1-YLuYqHy5I8aMoeUTJUgzFISfVT8= 1050 | 1051 | lodash.isboolean@^3.0.3: 1052 | version "3.0.3" 1053 | resolved "https://registry.yarnpkg.com/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz#6c2e171db2a257cd96802fd43b01b20d5f5870f6" 1054 | integrity sha1-bC4XHbKiV82WgC/UOwGyDV9YcPY= 1055 | 1056 | lodash.isinteger@^4.0.4: 1057 | version "4.0.4" 1058 | resolved "https://registry.yarnpkg.com/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz#619c0af3d03f8b04c31f5882840b77b11cd68343" 1059 | integrity sha1-YZwK89A/iwTDH1iChAt3sRzWg0M= 1060 | 1061 | lodash.isnumber@^3.0.3: 1062 | version "3.0.3" 1063 | resolved "https://registry.yarnpkg.com/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz#3ce76810c5928d03352301ac287317f11c0b1ffc" 1064 | integrity sha1-POdoEMWSjQM1IwGsKHMX8RwLH/w= 1065 | 1066 | lodash.isplainobject@^4.0.6: 1067 | version "4.0.6" 1068 | resolved "https://registry.yarnpkg.com/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz#7c526a52d89b45c45cc690b88163be0497f550cb" 1069 | integrity sha1-fFJqUtibRcRcxpC4gWO+BJf1UMs= 1070 | 1071 | lodash.isstring@^4.0.1: 1072 | version "4.0.1" 1073 | resolved "https://registry.yarnpkg.com/lodash.isstring/-/lodash.isstring-4.0.1.tgz#d527dfb5456eca7cc9bb95d5daeaf88ba54a5451" 1074 | integrity sha1-1SfftUVuynzJu5XV2ur4i6VKVFE= 1075 | 1076 | lodash.once@^4.0.0: 1077 | version "4.1.1" 1078 | resolved "https://registry.yarnpkg.com/lodash.once/-/lodash.once-4.1.1.tgz#0dd3971213c7c56df880977d504c88fb471a97ac" 1079 | integrity sha1-DdOXEhPHxW34gJd9UEyI+0cal6w= 1080 | 1081 | lowercase-keys@^1.0.0, lowercase-keys@^1.0.1: 1082 | version "1.0.1" 1083 | resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-1.0.1.tgz#6f9e30b47084d971a7c820ff15a6c5167b74c26f" 1084 | integrity sha512-G2Lj61tXDnVFFOi8VZds+SoQjtQC3dgokKdDG2mTm1tx4m50NUHBOZSBwQQHyy0V12A0JTG4icfZQH+xPyh8VA== 1085 | 1086 | lowercase-keys@^2.0.0: 1087 | version "2.0.0" 1088 | resolved "https://registry.yarnpkg.com/lowercase-keys/-/lowercase-keys-2.0.0.tgz#2603e78b7b4b0006cbca2fbcc8a3202558ac9479" 1089 | integrity sha512-tqNXrS78oMOE73NMxK4EMLQsQowWf8jKooH9g7xPavRT706R6bkQJ6DY2Te7QukaZsulxa30wQ7bk0pm4XiHmA== 1090 | 1091 | make-dir@^3.0.0: 1092 | version "3.1.0" 1093 | resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-3.1.0.tgz#415e967046b3a7f1d185277d84aa58203726a13f" 1094 | integrity sha512-g3FeP20LNwhALb/6Cz6Dd4F2ngze0jz7tbzrD2wAV+o9FeNHe4rL+yK2md0J/fiSf1sa1ADhXqi5+oVwOM/eGw== 1095 | dependencies: 1096 | semver "^6.0.0" 1097 | 1098 | media-typer@0.3.0: 1099 | version "0.3.0" 1100 | resolved "https://registry.yarnpkg.com/media-typer/-/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748" 1101 | integrity sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g= 1102 | 1103 | memory-pager@^1.0.2: 1104 | version "1.5.0" 1105 | resolved "https://registry.yarnpkg.com/memory-pager/-/memory-pager-1.5.0.tgz#d8751655d22d384682741c972f2c3d6dfa3e66b5" 1106 | integrity sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg== 1107 | 1108 | merge-descriptors@1.0.1: 1109 | version "1.0.1" 1110 | resolved "https://registry.yarnpkg.com/merge-descriptors/-/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61" 1111 | integrity sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E= 1112 | 1113 | methods@~1.1.2: 1114 | version "1.1.2" 1115 | resolved "https://registry.yarnpkg.com/methods/-/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee" 1116 | integrity sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4= 1117 | 1118 | mime-db@1.44.0: 1119 | version "1.44.0" 1120 | resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.44.0.tgz#fa11c5eb0aca1334b4233cb4d52f10c5a6272f92" 1121 | integrity sha512-/NOTfLrsPBVeH7YtFPgsVWveuL+4SjjYxaQ1xtM1KMFj7HdxlBlxeyNLzhyJVx7r4rZGJAZ/6lkKCitSc/Nmpg== 1122 | 1123 | mime-types@~2.1.24: 1124 | version "2.1.27" 1125 | resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.27.tgz#47949f98e279ea53119f5722e0f34e529bec009f" 1126 | integrity sha512-JIhqnCasI9yD+SsmkquHBxTSEuZdQX5BuQnS2Vc7puQQQ+8yiP5AY5uWhpdv4YL4VM5c6iliiYWPgJ/nJQLp7w== 1127 | dependencies: 1128 | mime-db "1.44.0" 1129 | 1130 | mime@1.6.0: 1131 | version "1.6.0" 1132 | resolved "https://registry.yarnpkg.com/mime/-/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1" 1133 | integrity sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg== 1134 | 1135 | mimic-response@^1.0.0, mimic-response@^1.0.1: 1136 | version "1.0.1" 1137 | resolved "https://registry.yarnpkg.com/mimic-response/-/mimic-response-1.0.1.tgz#4923538878eef42063cb8a3e3b0798781487ab1b" 1138 | integrity sha512-j5EctnkH7amfV/q5Hgmoal1g2QHFJRraOtmx0JpIqkxhBhI/lJSl1nMpQ45hVarwNETOoWEimndZ4QK0RHxuxQ== 1139 | 1140 | minimatch@^3.0.4: 1141 | version "3.0.4" 1142 | resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083" 1143 | integrity sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA== 1144 | dependencies: 1145 | brace-expansion "^1.1.7" 1146 | 1147 | minimist@^1.2.0, minimist@^1.2.5: 1148 | version "1.2.5" 1149 | resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.5.tgz#67d66014b66a6a8aaa0c083c5fd58df4e4e97602" 1150 | integrity sha512-FM9nNUYrRBAELZQT3xeZQ7fmMOBg6nWNmJKTcgsJeaLstP/UODVpGsr5OhXhhXg6f+qtJ8uiZ+PUxkDWcgIXLw== 1151 | 1152 | minipass@^2.6.0, minipass@^2.8.6, minipass@^2.9.0: 1153 | version "2.9.0" 1154 | resolved "https://registry.yarnpkg.com/minipass/-/minipass-2.9.0.tgz#e713762e7d3e32fed803115cf93e04bca9fcc9a6" 1155 | integrity sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg== 1156 | dependencies: 1157 | safe-buffer "^5.1.2" 1158 | yallist "^3.0.0" 1159 | 1160 | minizlib@^1.2.1: 1161 | version "1.3.3" 1162 | resolved "https://registry.yarnpkg.com/minizlib/-/minizlib-1.3.3.tgz#2290de96818a34c29551c8a8d301216bd65a861d" 1163 | integrity sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q== 1164 | dependencies: 1165 | minipass "^2.9.0" 1166 | 1167 | mkdirp@^0.5.0, mkdirp@^0.5.1, mkdirp@^0.5.3: 1168 | version "0.5.5" 1169 | resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.5.tgz#d91cefd62d1436ca0f41620e251288d420099def" 1170 | integrity sha512-NKmAlESf6jMGym1++R0Ra7wvhV+wFW63FaSOFPwRahvea0gMUcGUhVeAg/0BC0wiv9ih5NYPB1Wn1UEI1/L+xQ== 1171 | dependencies: 1172 | minimist "^1.2.5" 1173 | 1174 | mongodb@3.6.2: 1175 | version "3.6.2" 1176 | resolved "https://registry.yarnpkg.com/mongodb/-/mongodb-3.6.2.tgz#1154a4ac107bf1375112d83a29c5cf97704e96b6" 1177 | integrity sha512-sSZOb04w3HcnrrXC82NEh/YGCmBuRgR+C1hZgmmv4L6dBz4BkRse6Y8/q/neXer9i95fKUBbFi4KgeceXmbsOA== 1178 | dependencies: 1179 | bl "^2.2.1" 1180 | bson "^1.1.4" 1181 | denque "^1.4.1" 1182 | require_optional "^1.0.1" 1183 | safe-buffer "^5.1.2" 1184 | optionalDependencies: 1185 | saslprep "^1.0.0" 1186 | 1187 | mongoose-legacy-pluralize@1.0.2: 1188 | version "1.0.2" 1189 | resolved "https://registry.yarnpkg.com/mongoose-legacy-pluralize/-/mongoose-legacy-pluralize-1.0.2.tgz#3ba9f91fa507b5186d399fb40854bff18fb563e4" 1190 | integrity sha512-Yo/7qQU4/EyIS8YDFSeenIvXxZN+ld7YdV9LqFVQJzTLye8unujAWPZ4NWKfFA+RNjh+wvTWKY9Z3E5XM6ZZiQ== 1191 | 1192 | mongoose@^5.10.7: 1193 | version "5.10.7" 1194 | resolved "https://registry.yarnpkg.com/mongoose/-/mongoose-5.10.7.tgz#5590037f4d9078f4d4edac5c77f27b53829b1c94" 1195 | integrity sha512-oiofFrD4I5p3PhJXn49QyrU1nX5CY01qhPkfMMrXYPhkfGLEJVwFVO+0PsCxD91A2kQP+d/iFyk5U8e86KI8eQ== 1196 | dependencies: 1197 | bson "^1.1.4" 1198 | kareem "2.3.1" 1199 | mongodb "3.6.2" 1200 | mongoose-legacy-pluralize "1.0.2" 1201 | mpath "0.7.0" 1202 | mquery "3.2.2" 1203 | ms "2.1.2" 1204 | regexp-clone "1.0.0" 1205 | safe-buffer "5.2.1" 1206 | sift "7.0.1" 1207 | sliced "1.0.1" 1208 | 1209 | mpath@0.7.0: 1210 | version "0.7.0" 1211 | resolved "https://registry.yarnpkg.com/mpath/-/mpath-0.7.0.tgz#20e8102e276b71709d6e07e9f8d4d0f641afbfb8" 1212 | integrity sha512-Aiq04hILxhz1L+f7sjGyn7IxYzWm1zLNNXcfhDtx04kZ2Gk7uvFdgZ8ts1cWa/6d0TQmag2yR8zSGZUmp0tFNg== 1213 | 1214 | mquery@3.2.2: 1215 | version "3.2.2" 1216 | resolved "https://registry.yarnpkg.com/mquery/-/mquery-3.2.2.tgz#e1383a3951852ce23e37f619a9b350f1fb3664e7" 1217 | integrity sha512-XB52992COp0KP230I3qloVUbkLUxJIu328HBP2t2EsxSFtf4W1HPSOBWOXf1bqxK4Xbb66lfMJ+Bpfd9/yZE1Q== 1218 | dependencies: 1219 | bluebird "3.5.1" 1220 | debug "3.1.0" 1221 | regexp-clone "^1.0.0" 1222 | safe-buffer "5.1.2" 1223 | sliced "1.0.1" 1224 | 1225 | ms@2.0.0: 1226 | version "2.0.0" 1227 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8" 1228 | integrity sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g= 1229 | 1230 | ms@2.1.1: 1231 | version "2.1.1" 1232 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.1.tgz#30a5864eb3ebb0a66f2ebe6d727af06a09d86e0a" 1233 | integrity sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg== 1234 | 1235 | ms@2.1.2, ms@^2.1.1: 1236 | version "2.1.2" 1237 | resolved "https://registry.yarnpkg.com/ms/-/ms-2.1.2.tgz#d09d1f357b443f493382a8eb3ccd183872ae6009" 1238 | integrity sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w== 1239 | 1240 | multer@^1.4.2: 1241 | version "1.4.2" 1242 | resolved "https://registry.yarnpkg.com/multer/-/multer-1.4.2.tgz#2f1f4d12dbaeeba74cb37e623f234bf4d3d2057a" 1243 | integrity sha512-xY8pX7V+ybyUpbYMxtjM9KAiD9ixtg5/JkeKUTD6xilfDv0vzzOFcCp4Ljb1UU3tSOM3VTZtKo63OmzOrGi3Cg== 1244 | dependencies: 1245 | append-field "^1.0.0" 1246 | busboy "^0.2.11" 1247 | concat-stream "^1.5.2" 1248 | mkdirp "^0.5.1" 1249 | object-assign "^4.1.1" 1250 | on-finished "^2.3.0" 1251 | type-is "^1.6.4" 1252 | xtend "^4.0.0" 1253 | 1254 | needle@^2.5.0: 1255 | version "2.5.2" 1256 | resolved "https://registry.yarnpkg.com/needle/-/needle-2.5.2.tgz#cf1a8fce382b5a280108bba90a14993c00e4010a" 1257 | integrity sha512-LbRIwS9BfkPvNwNHlsA41Q29kL2L/6VaOJ0qisM5lLWsTV3nP15abO5ITL6L81zqFhzjRKDAYjpcBcwM0AVvLQ== 1258 | dependencies: 1259 | debug "^3.2.6" 1260 | iconv-lite "^0.4.4" 1261 | sax "^1.2.4" 1262 | 1263 | negotiator@0.6.2: 1264 | version "0.6.2" 1265 | resolved "https://registry.yarnpkg.com/negotiator/-/negotiator-0.6.2.tgz#feacf7ccf525a77ae9634436a64883ffeca346fb" 1266 | integrity sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw== 1267 | 1268 | node-addon-api@^3.0.0: 1269 | version "3.0.2" 1270 | resolved "https://registry.yarnpkg.com/node-addon-api/-/node-addon-api-3.0.2.tgz#04bc7b83fd845ba785bb6eae25bc857e1ef75681" 1271 | integrity sha512-+D4s2HCnxPd5PjjI0STKwncjXTUKKqm74MDMz9OPXavjsGmjkvwgLtA5yoxJUdmpj52+2u+RrXgPipahKczMKg== 1272 | 1273 | node-pre-gyp@0.15.0: 1274 | version "0.15.0" 1275 | resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.15.0.tgz#c2fc383276b74c7ffa842925241553e8b40f1087" 1276 | integrity sha512-7QcZa8/fpaU/BKenjcaeFF9hLz2+7S9AqyXFhlH/rilsQ/hPZKK32RtR5EQHJElgu+q5RfbJ34KriI79UWaorA== 1277 | dependencies: 1278 | detect-libc "^1.0.2" 1279 | mkdirp "^0.5.3" 1280 | needle "^2.5.0" 1281 | nopt "^4.0.1" 1282 | npm-packlist "^1.1.6" 1283 | npmlog "^4.0.2" 1284 | rc "^1.2.7" 1285 | rimraf "^2.6.1" 1286 | semver "^5.3.0" 1287 | tar "^4.4.2" 1288 | 1289 | nodemon@^2.0.4: 1290 | version "2.0.4" 1291 | resolved "https://registry.yarnpkg.com/nodemon/-/nodemon-2.0.4.tgz#55b09319eb488d6394aa9818148c0c2d1c04c416" 1292 | integrity sha512-Ltced+hIfTmaS28Zjv1BM552oQ3dbwPqI4+zI0SLgq+wpJhSyqgYude/aZa/3i31VCQWMfXJVxvu86abcam3uQ== 1293 | dependencies: 1294 | chokidar "^3.2.2" 1295 | debug "^3.2.6" 1296 | ignore-by-default "^1.0.1" 1297 | minimatch "^3.0.4" 1298 | pstree.remy "^1.1.7" 1299 | semver "^5.7.1" 1300 | supports-color "^5.5.0" 1301 | touch "^3.1.0" 1302 | undefsafe "^2.0.2" 1303 | update-notifier "^4.0.0" 1304 | 1305 | nopt@^4.0.1: 1306 | version "4.0.3" 1307 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-4.0.3.tgz#a375cad9d02fd921278d954c2254d5aa57e15e48" 1308 | integrity sha512-CvaGwVMztSMJLOeXPrez7fyfObdZqNUK1cPAEzLHrTybIua9pMdmmPR5YwtfNftIOMv3DPUhFaxsZMNTQO20Kg== 1309 | dependencies: 1310 | abbrev "1" 1311 | osenv "^0.1.4" 1312 | 1313 | nopt@~1.0.10: 1314 | version "1.0.10" 1315 | resolved "https://registry.yarnpkg.com/nopt/-/nopt-1.0.10.tgz#6ddd21bd2a31417b92727dd585f8a6f37608ebee" 1316 | integrity sha1-bd0hvSoxQXuScn3Vhfim83YI6+4= 1317 | dependencies: 1318 | abbrev "1" 1319 | 1320 | normalize-path@^3.0.0, normalize-path@~3.0.0: 1321 | version "3.0.0" 1322 | resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-3.0.0.tgz#0dcd69ff23a1c9b11fd0978316644a0388216a65" 1323 | integrity sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA== 1324 | 1325 | normalize-url@^4.1.0: 1326 | version "4.5.0" 1327 | resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-4.5.0.tgz#453354087e6ca96957bd8f5baf753f5982142129" 1328 | integrity sha512-2s47yzUxdexf1OhyRi4Em83iQk0aPvwTddtFz4hnSSw9dCEsLEGf6SwIO8ss/19S9iBb5sJaOuTvTGDeZI00BQ== 1329 | 1330 | npm-bundled@^1.0.1: 1331 | version "1.1.1" 1332 | resolved "https://registry.yarnpkg.com/npm-bundled/-/npm-bundled-1.1.1.tgz#1edd570865a94cdb1bc8220775e29466c9fb234b" 1333 | integrity sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA== 1334 | dependencies: 1335 | npm-normalize-package-bin "^1.0.1" 1336 | 1337 | npm-normalize-package-bin@^1.0.1: 1338 | version "1.0.1" 1339 | resolved "https://registry.yarnpkg.com/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz#6e79a41f23fd235c0623218228da7d9c23b8f6e2" 1340 | integrity sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA== 1341 | 1342 | npm-packlist@^1.1.6: 1343 | version "1.4.8" 1344 | resolved "https://registry.yarnpkg.com/npm-packlist/-/npm-packlist-1.4.8.tgz#56ee6cc135b9f98ad3d51c1c95da22bbb9b2ef3e" 1345 | integrity sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A== 1346 | dependencies: 1347 | ignore-walk "^3.0.1" 1348 | npm-bundled "^1.0.1" 1349 | npm-normalize-package-bin "^1.0.1" 1350 | 1351 | npmlog@^4.0.2: 1352 | version "4.1.2" 1353 | resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-4.1.2.tgz#08a7f2a8bf734604779a9efa4ad5cc717abb954b" 1354 | integrity sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg== 1355 | dependencies: 1356 | are-we-there-yet "~1.1.2" 1357 | console-control-strings "~1.1.0" 1358 | gauge "~2.7.3" 1359 | set-blocking "~2.0.0" 1360 | 1361 | number-is-nan@^1.0.0: 1362 | version "1.0.1" 1363 | resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d" 1364 | integrity sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0= 1365 | 1366 | object-assign@^4, object-assign@^4.1.0, object-assign@^4.1.1: 1367 | version "4.1.1" 1368 | resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863" 1369 | integrity sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM= 1370 | 1371 | object-component@0.0.3: 1372 | version "0.0.3" 1373 | resolved "https://registry.yarnpkg.com/object-component/-/object-component-0.0.3.tgz#f0c69aa50efc95b866c186f400a33769cb2f1291" 1374 | integrity sha1-8MaapQ78lbhmwYb0AKM3acsvEpE= 1375 | 1376 | on-finished@^2.3.0, on-finished@~2.3.0: 1377 | version "2.3.0" 1378 | resolved "https://registry.yarnpkg.com/on-finished/-/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947" 1379 | integrity sha1-IPEzZIGwg811M3mSoWlxqi2QaUc= 1380 | dependencies: 1381 | ee-first "1.1.1" 1382 | 1383 | once@^1.3.0, once@^1.3.1, once@^1.4.0: 1384 | version "1.4.0" 1385 | resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1" 1386 | integrity sha1-WDsap3WWHUsROsF9nFC6753Xa9E= 1387 | dependencies: 1388 | wrappy "1" 1389 | 1390 | os-homedir@^1.0.0: 1391 | version "1.0.2" 1392 | resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3" 1393 | integrity sha1-/7xJiDNuDoM94MFox+8VISGqf7M= 1394 | 1395 | os-tmpdir@^1.0.0: 1396 | version "1.0.2" 1397 | resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274" 1398 | integrity sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ= 1399 | 1400 | osenv@^0.1.4: 1401 | version "0.1.5" 1402 | resolved "https://registry.yarnpkg.com/osenv/-/osenv-0.1.5.tgz#85cdfafaeb28e8677f416e287592b5f3f49ea410" 1403 | integrity sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g== 1404 | dependencies: 1405 | os-homedir "^1.0.0" 1406 | os-tmpdir "^1.0.0" 1407 | 1408 | p-cancelable@^1.0.0: 1409 | version "1.1.0" 1410 | resolved "https://registry.yarnpkg.com/p-cancelable/-/p-cancelable-1.1.0.tgz#d078d15a3af409220c886f1d9a0ca2e441ab26cc" 1411 | integrity sha512-s73XxOZ4zpt1edZYZzvhqFa6uvQc1vwUa0K0BdtIZgQMAJj9IbebH+JkgKZc9h+B05PKHLOTl4ajG1BmNrVZlw== 1412 | 1413 | package-json@^6.3.0: 1414 | version "6.5.0" 1415 | resolved "https://registry.yarnpkg.com/package-json/-/package-json-6.5.0.tgz#6feedaca35e75725876d0b0e64974697fed145b0" 1416 | integrity sha512-k3bdm2n25tkyxcjSKzB5x8kfVxlMdgsbPr0GkZcwHsLpba6cBjqCt1KlcChKEvxHIcTB1FVMuwoijZ26xex5MQ== 1417 | dependencies: 1418 | got "^9.6.0" 1419 | registry-auth-token "^4.0.0" 1420 | registry-url "^5.0.0" 1421 | semver "^6.2.0" 1422 | 1423 | parseqs@0.0.5: 1424 | version "0.0.5" 1425 | resolved "https://registry.yarnpkg.com/parseqs/-/parseqs-0.0.5.tgz#d5208a3738e46766e291ba2ea173684921a8b89d" 1426 | integrity sha1-1SCKNzjkZ2bikbouoXNoSSGouJ0= 1427 | dependencies: 1428 | better-assert "~1.0.0" 1429 | 1430 | parseuri@0.0.5: 1431 | version "0.0.5" 1432 | resolved "https://registry.yarnpkg.com/parseuri/-/parseuri-0.0.5.tgz#80204a50d4dbb779bfdc6ebe2778d90e4bce320a" 1433 | integrity sha1-gCBKUNTbt3m/3G6+J3jZDkvOMgo= 1434 | dependencies: 1435 | better-assert "~1.0.0" 1436 | 1437 | parseurl@~1.3.3: 1438 | version "1.3.3" 1439 | resolved "https://registry.yarnpkg.com/parseurl/-/parseurl-1.3.3.tgz#9da19e7bee8d12dff0513ed5b76957793bc2e8d4" 1440 | integrity sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ== 1441 | 1442 | path-is-absolute@^1.0.0: 1443 | version "1.0.1" 1444 | resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f" 1445 | integrity sha1-F0uSaHNVNP+8es5r9TpanhtcX18= 1446 | 1447 | path-to-regexp@0.1.7: 1448 | version "0.1.7" 1449 | resolved "https://registry.yarnpkg.com/path-to-regexp/-/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c" 1450 | integrity sha1-32BBeABfUi8V60SQ5yR6G/qmf4w= 1451 | 1452 | picomatch@^2.0.4, picomatch@^2.2.1: 1453 | version "2.2.2" 1454 | resolved "https://registry.yarnpkg.com/picomatch/-/picomatch-2.2.2.tgz#21f333e9b6b8eaff02468f5146ea406d345f4dad" 1455 | integrity sha512-q0M/9eZHzmr0AulXyPwNfZjtwZ/RBZlbN3K3CErVrk50T2ASYI7Bye0EvekFY3IP1Nt2DHu0re+V2ZHIpMkuWg== 1456 | 1457 | prepend-http@^2.0.0: 1458 | version "2.0.0" 1459 | resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-2.0.0.tgz#e92434bfa5ea8c19f41cdfd401d741a3c819d897" 1460 | integrity sha1-6SQ0v6XqjBn0HN/UAddBo8gZ2Jc= 1461 | 1462 | process-nextick-args@~2.0.0: 1463 | version "2.0.1" 1464 | resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.1.tgz#7820d9b16120cc55ca9ae7792680ae7dba6d7fe2" 1465 | integrity sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag== 1466 | 1467 | proxy-addr@~2.0.5: 1468 | version "2.0.6" 1469 | resolved "https://registry.yarnpkg.com/proxy-addr/-/proxy-addr-2.0.6.tgz#fdc2336505447d3f2f2c638ed272caf614bbb2bf" 1470 | integrity sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw== 1471 | dependencies: 1472 | forwarded "~0.1.2" 1473 | ipaddr.js "1.9.1" 1474 | 1475 | pstree.remy@^1.1.7: 1476 | version "1.1.8" 1477 | resolved "https://registry.yarnpkg.com/pstree.remy/-/pstree.remy-1.1.8.tgz#c242224f4a67c21f686839bbdb4ac282b8373d3a" 1478 | integrity sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w== 1479 | 1480 | pump@^3.0.0: 1481 | version "3.0.0" 1482 | resolved "https://registry.yarnpkg.com/pump/-/pump-3.0.0.tgz#b4a2116815bde2f4e1ea602354e8c75565107a64" 1483 | integrity sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww== 1484 | dependencies: 1485 | end-of-stream "^1.1.0" 1486 | once "^1.3.1" 1487 | 1488 | pupa@^2.0.1: 1489 | version "2.0.1" 1490 | resolved "https://registry.yarnpkg.com/pupa/-/pupa-2.0.1.tgz#dbdc9ff48ffbea4a26a069b6f9f7abb051008726" 1491 | integrity sha512-hEJH0s8PXLY/cdXh66tNEQGndDrIKNqNC5xmrysZy3i5C3oEoLna7YAOad+7u125+zH1HNXUmGEkrhb3c2VriA== 1492 | dependencies: 1493 | escape-goat "^2.0.0" 1494 | 1495 | qs@6.7.0: 1496 | version "6.7.0" 1497 | resolved "https://registry.yarnpkg.com/qs/-/qs-6.7.0.tgz#41dc1a015e3d581f1621776be31afb2876a9b1bc" 1498 | integrity sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ== 1499 | 1500 | range-parser@~1.2.1: 1501 | version "1.2.1" 1502 | resolved "https://registry.yarnpkg.com/range-parser/-/range-parser-1.2.1.tgz#3cf37023d199e1c24d1a55b84800c2f3e6468031" 1503 | integrity sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg== 1504 | 1505 | raw-body@2.4.0: 1506 | version "2.4.0" 1507 | resolved "https://registry.yarnpkg.com/raw-body/-/raw-body-2.4.0.tgz#a1ce6fb9c9bc356ca52e89256ab59059e13d0332" 1508 | integrity sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q== 1509 | dependencies: 1510 | bytes "3.1.0" 1511 | http-errors "1.7.2" 1512 | iconv-lite "0.4.24" 1513 | unpipe "1.0.0" 1514 | 1515 | rc@^1.2.7, rc@^1.2.8: 1516 | version "1.2.8" 1517 | resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.8.tgz#cd924bf5200a075b83c188cd6b9e211b7fc0d3ed" 1518 | integrity sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw== 1519 | dependencies: 1520 | deep-extend "^0.6.0" 1521 | ini "~1.3.0" 1522 | minimist "^1.2.0" 1523 | strip-json-comments "~2.0.1" 1524 | 1525 | readable-stream@1.1.x: 1526 | version "1.1.14" 1527 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.1.14.tgz#7cf4c54ef648e3813084c636dd2079e166c081d9" 1528 | integrity sha1-fPTFTvZI44EwhMY23SB54WbAgdk= 1529 | dependencies: 1530 | core-util-is "~1.0.0" 1531 | inherits "~2.0.1" 1532 | isarray "0.0.1" 1533 | string_decoder "~0.10.x" 1534 | 1535 | readable-stream@^2.0.6, readable-stream@^2.2.2, readable-stream@^2.3.5: 1536 | version "2.3.7" 1537 | resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.7.tgz#1eca1cf711aef814c04f62252a36a62f6cb23b57" 1538 | integrity sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw== 1539 | dependencies: 1540 | core-util-is "~1.0.0" 1541 | inherits "~2.0.3" 1542 | isarray "~1.0.0" 1543 | process-nextick-args "~2.0.0" 1544 | safe-buffer "~5.1.1" 1545 | string_decoder "~1.1.1" 1546 | util-deprecate "~1.0.1" 1547 | 1548 | readdirp@~3.4.0: 1549 | version "3.4.0" 1550 | resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-3.4.0.tgz#9fdccdf9e9155805449221ac645e8303ab5b9ada" 1551 | integrity sha512-0xe001vZBnJEK+uKcj8qOhyAKPzIT+gStxWr3LCB0DwcXR5NZJ3IaC+yGnHCYzB/S7ov3m3EEbZI2zeNvX+hGQ== 1552 | dependencies: 1553 | picomatch "^2.2.1" 1554 | 1555 | regexp-clone@1.0.0, regexp-clone@^1.0.0: 1556 | version "1.0.0" 1557 | resolved "https://registry.yarnpkg.com/regexp-clone/-/regexp-clone-1.0.0.tgz#222db967623277056260b992626354a04ce9bf63" 1558 | integrity sha512-TuAasHQNamyyJ2hb97IuBEif4qBHGjPHBS64sZwytpLEqtBQ1gPJTnOaQ6qmpET16cK14kkjbazl6+p0RRv0yw== 1559 | 1560 | registry-auth-token@^4.0.0: 1561 | version "4.2.0" 1562 | resolved "https://registry.yarnpkg.com/registry-auth-token/-/registry-auth-token-4.2.0.tgz#1d37dffda72bbecd0f581e4715540213a65eb7da" 1563 | integrity sha512-P+lWzPrsgfN+UEpDS3U8AQKg/UjZX6mQSJueZj3EK+vNESoqBSpBUD3gmu4sF9lOsjXWjF11dQKUqemf3veq1w== 1564 | dependencies: 1565 | rc "^1.2.8" 1566 | 1567 | registry-url@^5.0.0: 1568 | version "5.1.0" 1569 | resolved "https://registry.yarnpkg.com/registry-url/-/registry-url-5.1.0.tgz#e98334b50d5434b81136b44ec638d9c2009c5009" 1570 | integrity sha512-8acYXXTI0AkQv6RAOjE3vOaIXZkT9wo4LOFbBKYQEEnnMNBpKqdUrI6S4NT0KPIo/WVvJ5tE/X5LF/TQUf0ekw== 1571 | dependencies: 1572 | rc "^1.2.8" 1573 | 1574 | require_optional@^1.0.1: 1575 | version "1.0.1" 1576 | resolved "https://registry.yarnpkg.com/require_optional/-/require_optional-1.0.1.tgz#4cf35a4247f64ca3df8c2ef208cc494b1ca8fc2e" 1577 | integrity sha512-qhM/y57enGWHAe3v/NcwML6a3/vfESLe/sGM2dII+gEO0BpKRUkWZow/tyloNqJyN6kXSl3RyyM8Ll5D/sJP8g== 1578 | dependencies: 1579 | resolve-from "^2.0.0" 1580 | semver "^5.1.0" 1581 | 1582 | resolve-from@^2.0.0: 1583 | version "2.0.0" 1584 | resolved "https://registry.yarnpkg.com/resolve-from/-/resolve-from-2.0.0.tgz#9480ab20e94ffa1d9e80a804c7ea147611966b57" 1585 | integrity sha1-lICrIOlP+h2egKgEx+oUdhGWa1c= 1586 | 1587 | responselike@^1.0.2: 1588 | version "1.0.2" 1589 | resolved "https://registry.yarnpkg.com/responselike/-/responselike-1.0.2.tgz#918720ef3b631c5642be068f15ade5a46f4ba1e7" 1590 | integrity sha1-kYcg7ztjHFZCvgaPFa3lpG9Loec= 1591 | dependencies: 1592 | lowercase-keys "^1.0.0" 1593 | 1594 | rimraf@^2.6.1: 1595 | version "2.7.1" 1596 | resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.7.1.tgz#35797f13a7fdadc566142c29d4f07ccad483e3ec" 1597 | integrity sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w== 1598 | dependencies: 1599 | glob "^7.1.3" 1600 | 1601 | safe-buffer@5.1.2, safe-buffer@~5.1.0, safe-buffer@~5.1.1: 1602 | version "5.1.2" 1603 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.2.tgz#991ec69d296e0313747d59bdfd2b745c35f8828d" 1604 | integrity sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g== 1605 | 1606 | safe-buffer@5.2.1, safe-buffer@^5.0.1, safe-buffer@^5.1.1, safe-buffer@^5.1.2: 1607 | version "5.2.1" 1608 | resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.2.1.tgz#1eaf9fa9bdb1fdd4ec75f58f9cdb4e6b7827eec6" 1609 | integrity sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ== 1610 | 1611 | "safer-buffer@>= 2.1.2 < 3": 1612 | version "2.1.2" 1613 | resolved "https://registry.yarnpkg.com/safer-buffer/-/safer-buffer-2.1.2.tgz#44fa161b0187b9549dd84bb91802f9bd8385cd6a" 1614 | integrity sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg== 1615 | 1616 | saslprep@^1.0.0: 1617 | version "1.0.3" 1618 | resolved "https://registry.yarnpkg.com/saslprep/-/saslprep-1.0.3.tgz#4c02f946b56cf54297e347ba1093e7acac4cf226" 1619 | integrity sha512-/MY/PEMbk2SuY5sScONwhUDsV2p77Znkb/q3nSVstq/yQzYJOH/Azh29p9oJLsl3LnQwSvZDKagDGBsBwSooag== 1620 | dependencies: 1621 | sparse-bitfield "^3.0.3" 1622 | 1623 | sax@^1.2.4: 1624 | version "1.2.4" 1625 | resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9" 1626 | integrity sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw== 1627 | 1628 | semver-diff@^3.1.1: 1629 | version "3.1.1" 1630 | resolved "https://registry.yarnpkg.com/semver-diff/-/semver-diff-3.1.1.tgz#05f77ce59f325e00e2706afd67bb506ddb1ca32b" 1631 | integrity sha512-GX0Ix/CJcHyB8c4ykpHGIAvLyOwOobtM/8d+TQkAd81/bEjgPHrfba41Vpesr7jX/t8Uh+R3EX9eAS5be+jQYg== 1632 | dependencies: 1633 | semver "^6.3.0" 1634 | 1635 | semver@^5.1.0, semver@^5.3.0, semver@^5.6.0, semver@^5.7.1: 1636 | version "5.7.1" 1637 | resolved "https://registry.yarnpkg.com/semver/-/semver-5.7.1.tgz#a954f931aeba508d307bbf069eff0c01c96116f7" 1638 | integrity sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ== 1639 | 1640 | semver@^6.0.0, semver@^6.2.0, semver@^6.3.0: 1641 | version "6.3.0" 1642 | resolved "https://registry.yarnpkg.com/semver/-/semver-6.3.0.tgz#ee0a64c8af5e8ceea67687b133761e1becbd1d3d" 1643 | integrity sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw== 1644 | 1645 | send@0.17.1: 1646 | version "0.17.1" 1647 | resolved "https://registry.yarnpkg.com/send/-/send-0.17.1.tgz#c1d8b059f7900f7466dd4938bdc44e11ddb376c8" 1648 | integrity sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg== 1649 | dependencies: 1650 | debug "2.6.9" 1651 | depd "~1.1.2" 1652 | destroy "~1.0.4" 1653 | encodeurl "~1.0.2" 1654 | escape-html "~1.0.3" 1655 | etag "~1.8.1" 1656 | fresh "0.5.2" 1657 | http-errors "~1.7.2" 1658 | mime "1.6.0" 1659 | ms "2.1.1" 1660 | on-finished "~2.3.0" 1661 | range-parser "~1.2.1" 1662 | statuses "~1.5.0" 1663 | 1664 | serve-static@1.14.1: 1665 | version "1.14.1" 1666 | resolved "https://registry.yarnpkg.com/serve-static/-/serve-static-1.14.1.tgz#666e636dc4f010f7ef29970a88a674320898b2f9" 1667 | integrity sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg== 1668 | dependencies: 1669 | encodeurl "~1.0.2" 1670 | escape-html "~1.0.3" 1671 | parseurl "~1.3.3" 1672 | send "0.17.1" 1673 | 1674 | set-blocking@~2.0.0: 1675 | version "2.0.0" 1676 | resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7" 1677 | integrity sha1-BF+XgtARrppoA93TgrJDkrPYkPc= 1678 | 1679 | setprototypeof@1.1.1: 1680 | version "1.1.1" 1681 | resolved "https://registry.yarnpkg.com/setprototypeof/-/setprototypeof-1.1.1.tgz#7e95acb24aa92f5885e0abef5ba131330d4ae683" 1682 | integrity sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw== 1683 | 1684 | sift@7.0.1: 1685 | version "7.0.1" 1686 | resolved "https://registry.yarnpkg.com/sift/-/sift-7.0.1.tgz#47d62c50b159d316f1372f8b53f9c10cd21a4b08" 1687 | integrity sha512-oqD7PMJ+uO6jV9EQCl0LrRw1OwsiPsiFQR5AR30heR+4Dl7jBBbDLnNvWiak20tzZlSE1H7RB30SX/1j/YYT7g== 1688 | 1689 | signal-exit@^3.0.0, signal-exit@^3.0.2: 1690 | version "3.0.3" 1691 | resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.3.tgz#a1410c2edd8f077b08b4e253c8eacfcaf057461c" 1692 | integrity sha512-VUJ49FC8U1OxwZLxIbTTrDvLnf/6TDgxZcK8wxR8zs13xpx7xbG60ndBlhNrFi2EMuFRoeDoJO7wthSLq42EjA== 1693 | 1694 | sliced@1.0.1: 1695 | version "1.0.1" 1696 | resolved "https://registry.yarnpkg.com/sliced/-/sliced-1.0.1.tgz#0b3a662b5d04c3177b1926bea82b03f837a2ef41" 1697 | integrity sha1-CzpmK10Ewxd7GSa+qCsD+Dei70E= 1698 | 1699 | socket.io-adapter@~1.1.0: 1700 | version "1.1.2" 1701 | resolved "https://registry.yarnpkg.com/socket.io-adapter/-/socket.io-adapter-1.1.2.tgz#ab3f0d6f66b8fc7fca3959ab5991f82221789be9" 1702 | integrity sha512-WzZRUj1kUjrTIrUKpZLEzFZ1OLj5FwLlAFQs9kuZJzJi5DKdU7FsWc36SNmA8iDOtwBQyT8FkrriRM8vXLYz8g== 1703 | 1704 | socket.io-client@2.3.0: 1705 | version "2.3.0" 1706 | resolved "https://registry.yarnpkg.com/socket.io-client/-/socket.io-client-2.3.0.tgz#14d5ba2e00b9bcd145ae443ab96b3f86cbcc1bb4" 1707 | integrity sha512-cEQQf24gET3rfhxZ2jJ5xzAOo/xhZwK+mOqtGRg5IowZsMgwvHwnf/mCRapAAkadhM26y+iydgwsXGObBB5ZdA== 1708 | dependencies: 1709 | backo2 "1.0.2" 1710 | base64-arraybuffer "0.1.5" 1711 | component-bind "1.0.0" 1712 | component-emitter "1.2.1" 1713 | debug "~4.1.0" 1714 | engine.io-client "~3.4.0" 1715 | has-binary2 "~1.0.2" 1716 | has-cors "1.1.0" 1717 | indexof "0.0.1" 1718 | object-component "0.0.3" 1719 | parseqs "0.0.5" 1720 | parseuri "0.0.5" 1721 | socket.io-parser "~3.3.0" 1722 | to-array "0.1.4" 1723 | 1724 | socket.io-parser@~3.3.0: 1725 | version "3.3.0" 1726 | resolved "https://registry.yarnpkg.com/socket.io-parser/-/socket.io-parser-3.3.0.tgz#2b52a96a509fdf31440ba40fed6094c7d4f1262f" 1727 | integrity sha512-hczmV6bDgdaEbVqhAeVMM/jfUfzuEZHsQg6eOmLgJht6G3mPKMxYm75w2+qhAQZ+4X+1+ATZ+QFKeOZD5riHng== 1728 | dependencies: 1729 | component-emitter "1.2.1" 1730 | debug "~3.1.0" 1731 | isarray "2.0.1" 1732 | 1733 | socket.io-parser@~3.4.0: 1734 | version "3.4.1" 1735 | resolved "https://registry.yarnpkg.com/socket.io-parser/-/socket.io-parser-3.4.1.tgz#b06af838302975837eab2dc980037da24054d64a" 1736 | integrity sha512-11hMgzL+WCLWf1uFtHSNvliI++tcRUWdoeYuwIl+Axvwy9z2gQM+7nJyN3STj1tLj5JyIUH8/gpDGxzAlDdi0A== 1737 | dependencies: 1738 | component-emitter "1.2.1" 1739 | debug "~4.1.0" 1740 | isarray "2.0.1" 1741 | 1742 | socket.io@^2.3.0: 1743 | version "2.3.0" 1744 | resolved "https://registry.yarnpkg.com/socket.io/-/socket.io-2.3.0.tgz#cd762ed6a4faeca59bc1f3e243c0969311eb73fb" 1745 | integrity sha512-2A892lrj0GcgR/9Qk81EaY2gYhCBxurV0PfmmESO6p27QPrUK1J3zdns+5QPqvUYK2q657nSj0guoIil9+7eFg== 1746 | dependencies: 1747 | debug "~4.1.0" 1748 | engine.io "~3.4.0" 1749 | has-binary2 "~1.0.2" 1750 | socket.io-adapter "~1.1.0" 1751 | socket.io-client "2.3.0" 1752 | socket.io-parser "~3.4.0" 1753 | 1754 | sparse-bitfield@^3.0.3: 1755 | version "3.0.3" 1756 | resolved "https://registry.yarnpkg.com/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz#ff4ae6e68656056ba4b3e792ab3334d38273ca11" 1757 | integrity sha1-/0rm5oZWBWuks+eSqzM004JzyhE= 1758 | dependencies: 1759 | memory-pager "^1.0.2" 1760 | 1761 | "statuses@>= 1.5.0 < 2", statuses@~1.5.0: 1762 | version "1.5.0" 1763 | resolved "https://registry.yarnpkg.com/statuses/-/statuses-1.5.0.tgz#161c7dac177659fd9811f43771fa99381478628c" 1764 | integrity sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow= 1765 | 1766 | streamsearch@0.1.2: 1767 | version "0.1.2" 1768 | resolved "https://registry.yarnpkg.com/streamsearch/-/streamsearch-0.1.2.tgz#808b9d0e56fc273d809ba57338e929919a1a9f1a" 1769 | integrity sha1-gIudDlb8Jz2Am6VzOOkpkZoanxo= 1770 | 1771 | string-width@^1.0.1: 1772 | version "1.0.2" 1773 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3" 1774 | integrity sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M= 1775 | dependencies: 1776 | code-point-at "^1.0.0" 1777 | is-fullwidth-code-point "^1.0.0" 1778 | strip-ansi "^3.0.0" 1779 | 1780 | "string-width@^1.0.2 || 2": 1781 | version "2.1.1" 1782 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e" 1783 | integrity sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw== 1784 | dependencies: 1785 | is-fullwidth-code-point "^2.0.0" 1786 | strip-ansi "^4.0.0" 1787 | 1788 | string-width@^3.0.0: 1789 | version "3.1.0" 1790 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-3.1.0.tgz#22767be21b62af1081574306f69ac51b62203961" 1791 | integrity sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w== 1792 | dependencies: 1793 | emoji-regex "^7.0.1" 1794 | is-fullwidth-code-point "^2.0.0" 1795 | strip-ansi "^5.1.0" 1796 | 1797 | string-width@^4.0.0, string-width@^4.1.0: 1798 | version "4.2.0" 1799 | resolved "https://registry.yarnpkg.com/string-width/-/string-width-4.2.0.tgz#952182c46cc7b2c313d1596e623992bd163b72b5" 1800 | integrity sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg== 1801 | dependencies: 1802 | emoji-regex "^8.0.0" 1803 | is-fullwidth-code-point "^3.0.0" 1804 | strip-ansi "^6.0.0" 1805 | 1806 | string_decoder@~0.10.x: 1807 | version "0.10.31" 1808 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94" 1809 | integrity sha1-YuIDvEF2bGwoyfyEMB2rHFMQ+pQ= 1810 | 1811 | string_decoder@~1.1.1: 1812 | version "1.1.1" 1813 | resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.1.tgz#9cf1611ba62685d7030ae9e4ba34149c3af03fc8" 1814 | integrity sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg== 1815 | dependencies: 1816 | safe-buffer "~5.1.0" 1817 | 1818 | strip-ansi@^3.0.0, strip-ansi@^3.0.1: 1819 | version "3.0.1" 1820 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf" 1821 | integrity sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8= 1822 | dependencies: 1823 | ansi-regex "^2.0.0" 1824 | 1825 | strip-ansi@^4.0.0: 1826 | version "4.0.0" 1827 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f" 1828 | integrity sha1-qEeQIusaw2iocTibY1JixQXuNo8= 1829 | dependencies: 1830 | ansi-regex "^3.0.0" 1831 | 1832 | strip-ansi@^5.1.0: 1833 | version "5.2.0" 1834 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-5.2.0.tgz#8c9a536feb6afc962bdfa5b104a5091c1ad9c0ae" 1835 | integrity sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA== 1836 | dependencies: 1837 | ansi-regex "^4.1.0" 1838 | 1839 | strip-ansi@^6.0.0: 1840 | version "6.0.0" 1841 | resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-6.0.0.tgz#0b1571dd7669ccd4f3e06e14ef1eed26225ae532" 1842 | integrity sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w== 1843 | dependencies: 1844 | ansi-regex "^5.0.0" 1845 | 1846 | strip-json-comments@~2.0.1: 1847 | version "2.0.1" 1848 | resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a" 1849 | integrity sha1-PFMZQukIwml8DsNEhYwobHygpgo= 1850 | 1851 | supports-color@^5.5.0: 1852 | version "5.5.0" 1853 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.5.0.tgz#e2e69a44ac8772f78a1ec0b35b689df6530efc8f" 1854 | integrity sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow== 1855 | dependencies: 1856 | has-flag "^3.0.0" 1857 | 1858 | supports-color@^7.1.0: 1859 | version "7.2.0" 1860 | resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-7.2.0.tgz#1b7dcdcb32b8138801b3e478ba6a51caa89648da" 1861 | integrity sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw== 1862 | dependencies: 1863 | has-flag "^4.0.0" 1864 | 1865 | tar@^4.4.2: 1866 | version "4.4.13" 1867 | resolved "https://registry.yarnpkg.com/tar/-/tar-4.4.13.tgz#43b364bc52888d555298637b10d60790254ab525" 1868 | integrity sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA== 1869 | dependencies: 1870 | chownr "^1.1.1" 1871 | fs-minipass "^1.2.5" 1872 | minipass "^2.8.6" 1873 | minizlib "^1.2.1" 1874 | mkdirp "^0.5.0" 1875 | safe-buffer "^5.1.2" 1876 | yallist "^3.0.3" 1877 | 1878 | term-size@^2.1.0: 1879 | version "2.2.0" 1880 | resolved "https://registry.yarnpkg.com/term-size/-/term-size-2.2.0.tgz#1f16adedfe9bdc18800e1776821734086fcc6753" 1881 | integrity sha512-a6sumDlzyHVJWb8+YofY4TW112G6p2FCPEAFk+59gIYHv3XHRhm9ltVQ9kli4hNWeQBwSpe8cRN25x0ROunMOw== 1882 | 1883 | to-array@0.1.4: 1884 | version "0.1.4" 1885 | resolved "https://registry.yarnpkg.com/to-array/-/to-array-0.1.4.tgz#17e6c11f73dd4f3d74cda7a4ff3238e9ad9bf890" 1886 | integrity sha1-F+bBH3PdTz10zaek/zI46a2b+JA= 1887 | 1888 | to-readable-stream@^1.0.0: 1889 | version "1.0.0" 1890 | resolved "https://registry.yarnpkg.com/to-readable-stream/-/to-readable-stream-1.0.0.tgz#ce0aa0c2f3df6adf852efb404a783e77c0475771" 1891 | integrity sha512-Iq25XBt6zD5npPhlLVXGFN3/gyR2/qODcKNNyTMd4vbm39HUaOiAM4PMq0eMVC/Tkxz+Zjdsc55g9yyz+Yq00Q== 1892 | 1893 | to-regex-range@^5.0.1: 1894 | version "5.0.1" 1895 | resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-5.0.1.tgz#1648c44aae7c8d988a326018ed72f5b4dd0392e4" 1896 | integrity sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ== 1897 | dependencies: 1898 | is-number "^7.0.0" 1899 | 1900 | toidentifier@1.0.0: 1901 | version "1.0.0" 1902 | resolved "https://registry.yarnpkg.com/toidentifier/-/toidentifier-1.0.0.tgz#7e1be3470f1e77948bc43d94a3c8f4d7752ba553" 1903 | integrity sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw== 1904 | 1905 | touch@^3.1.0: 1906 | version "3.1.0" 1907 | resolved "https://registry.yarnpkg.com/touch/-/touch-3.1.0.tgz#fe365f5f75ec9ed4e56825e0bb76d24ab74af83b" 1908 | integrity sha512-WBx8Uy5TLtOSRtIq+M03/sKDrXCLHxwDcquSP2c43Le03/9serjQBIztjRz6FkJez9D/hleyAXTBGLwwZUw9lA== 1909 | dependencies: 1910 | nopt "~1.0.10" 1911 | 1912 | type-fest@^0.8.1: 1913 | version "0.8.1" 1914 | resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-0.8.1.tgz#09e249ebde851d3b1e48d27c105444667f17b83d" 1915 | integrity sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA== 1916 | 1917 | type-is@^1.6.4, type-is@~1.6.17, type-is@~1.6.18: 1918 | version "1.6.18" 1919 | resolved "https://registry.yarnpkg.com/type-is/-/type-is-1.6.18.tgz#4e552cd05df09467dcbc4ef739de89f2cf37c131" 1920 | integrity sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g== 1921 | dependencies: 1922 | media-typer "0.3.0" 1923 | mime-types "~2.1.24" 1924 | 1925 | typedarray-to-buffer@^3.1.5: 1926 | version "3.1.5" 1927 | resolved "https://registry.yarnpkg.com/typedarray-to-buffer/-/typedarray-to-buffer-3.1.5.tgz#a97ee7a9ff42691b9f783ff1bc5112fe3fca9080" 1928 | integrity sha512-zdu8XMNEDepKKR+XYOXAVPtWui0ly0NtohUscw+UmaHiAWT8hrV1rr//H6V+0DvJ3OQ19S979M0laLfX8rm82Q== 1929 | dependencies: 1930 | is-typedarray "^1.0.0" 1931 | 1932 | typedarray@^0.0.6: 1933 | version "0.0.6" 1934 | resolved "https://registry.yarnpkg.com/typedarray/-/typedarray-0.0.6.tgz#867ac74e3864187b1d3d47d996a78ec5c8830777" 1935 | integrity sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c= 1936 | 1937 | undefsafe@^2.0.2: 1938 | version "2.0.3" 1939 | resolved "https://registry.yarnpkg.com/undefsafe/-/undefsafe-2.0.3.tgz#6b166e7094ad46313b2202da7ecc2cd7cc6e7aae" 1940 | integrity sha512-nrXZwwXrD/T/JXeygJqdCO6NZZ1L66HrxM/Z7mIq2oPanoN0F1nLx3lwJMu6AwJY69hdixaFQOuoYsMjE5/C2A== 1941 | dependencies: 1942 | debug "^2.2.0" 1943 | 1944 | unique-string@^2.0.0: 1945 | version "2.0.0" 1946 | resolved "https://registry.yarnpkg.com/unique-string/-/unique-string-2.0.0.tgz#39c6451f81afb2749de2b233e3f7c5e8843bd89d" 1947 | integrity sha512-uNaeirEPvpZWSgzwsPGtU2zVSTrn/8L5q/IexZmH0eH6SA73CmAA5U4GwORTxQAZs95TAXLNqeLoPPNO5gZfWg== 1948 | dependencies: 1949 | crypto-random-string "^2.0.0" 1950 | 1951 | unpipe@1.0.0, unpipe@~1.0.0: 1952 | version "1.0.0" 1953 | resolved "https://registry.yarnpkg.com/unpipe/-/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec" 1954 | integrity sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw= 1955 | 1956 | update-notifier@^4.0.0: 1957 | version "4.1.1" 1958 | resolved "https://registry.yarnpkg.com/update-notifier/-/update-notifier-4.1.1.tgz#895fc8562bbe666179500f9f2cebac4f26323746" 1959 | integrity sha512-9y+Kds0+LoLG6yN802wVXoIfxYEwh3FlZwzMwpCZp62S2i1/Jzeqb9Eeeju3NSHccGGasfGlK5/vEHbAifYRDg== 1960 | dependencies: 1961 | boxen "^4.2.0" 1962 | chalk "^3.0.0" 1963 | configstore "^5.0.1" 1964 | has-yarn "^2.1.0" 1965 | import-lazy "^2.1.0" 1966 | is-ci "^2.0.0" 1967 | is-installed-globally "^0.3.1" 1968 | is-npm "^4.0.0" 1969 | is-yarn-global "^0.3.0" 1970 | latest-version "^5.0.0" 1971 | pupa "^2.0.1" 1972 | semver-diff "^3.1.1" 1973 | xdg-basedir "^4.0.0" 1974 | 1975 | url-parse-lax@^3.0.0: 1976 | version "3.0.0" 1977 | resolved "https://registry.yarnpkg.com/url-parse-lax/-/url-parse-lax-3.0.0.tgz#16b5cafc07dbe3676c1b1999177823d6503acb0c" 1978 | integrity sha1-FrXK/Afb42dsGxmZF3gj1lA6yww= 1979 | dependencies: 1980 | prepend-http "^2.0.0" 1981 | 1982 | util-deprecate@~1.0.1: 1983 | version "1.0.2" 1984 | resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf" 1985 | integrity sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8= 1986 | 1987 | utils-merge@1.0.1: 1988 | version "1.0.1" 1989 | resolved "https://registry.yarnpkg.com/utils-merge/-/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713" 1990 | integrity sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM= 1991 | 1992 | vary@^1, vary@~1.1.2: 1993 | version "1.1.2" 1994 | resolved "https://registry.yarnpkg.com/vary/-/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc" 1995 | integrity sha1-IpnwLG3tMNSllhsLn3RSShj2NPw= 1996 | 1997 | wide-align@^1.1.0: 1998 | version "1.1.3" 1999 | resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.3.tgz#ae074e6bdc0c14a431e804e624549c633b000457" 2000 | integrity sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA== 2001 | dependencies: 2002 | string-width "^1.0.2 || 2" 2003 | 2004 | widest-line@^3.1.0: 2005 | version "3.1.0" 2006 | resolved "https://registry.yarnpkg.com/widest-line/-/widest-line-3.1.0.tgz#8292333bbf66cb45ff0de1603b136b7ae1496eca" 2007 | integrity sha512-NsmoXalsWVDMGupxZ5R08ka9flZjjiLvHVAWYOKtiKM8ujtZWr9cRffak+uSE48+Ob8ObalXpwyeUiyDD6QFgg== 2008 | dependencies: 2009 | string-width "^4.0.0" 2010 | 2011 | wrappy@1: 2012 | version "1.0.2" 2013 | resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f" 2014 | integrity sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8= 2015 | 2016 | write-file-atomic@^3.0.0: 2017 | version "3.0.3" 2018 | resolved "https://registry.yarnpkg.com/write-file-atomic/-/write-file-atomic-3.0.3.tgz#56bd5c5a5c70481cd19c571bd39ab965a5de56e8" 2019 | integrity sha512-AvHcyZ5JnSfq3ioSyjrBkH9yW4m7Ayk8/9My/DD9onKeu/94fwrMocemO2QAJFAlnnDN+ZDS+ZjAR5ua1/PV/Q== 2020 | dependencies: 2021 | imurmurhash "^0.1.4" 2022 | is-typedarray "^1.0.0" 2023 | signal-exit "^3.0.2" 2024 | typedarray-to-buffer "^3.1.5" 2025 | 2026 | ws@^7.1.2: 2027 | version "7.3.1" 2028 | resolved "https://registry.yarnpkg.com/ws/-/ws-7.3.1.tgz#d0547bf67f7ce4f12a72dfe31262c68d7dc551c8" 2029 | integrity sha512-D3RuNkynyHmEJIpD2qrgVkc9DQ23OrN/moAwZX4L8DfvszsJxpjQuUq3LMx6HoYji9fbIOBY18XWBsAux1ZZUA== 2030 | 2031 | ws@~6.1.0: 2032 | version "6.1.4" 2033 | resolved "https://registry.yarnpkg.com/ws/-/ws-6.1.4.tgz#5b5c8800afab925e94ccb29d153c8d02c1776ef9" 2034 | integrity sha512-eqZfL+NE/YQc1/ZynhojeV8q+H050oR8AZ2uIev7RU10svA9ZnJUddHcOUZTJLinZ9yEfdA2kSATS2qZK5fhJA== 2035 | dependencies: 2036 | async-limiter "~1.0.0" 2037 | 2038 | xdg-basedir@^4.0.0: 2039 | version "4.0.0" 2040 | resolved "https://registry.yarnpkg.com/xdg-basedir/-/xdg-basedir-4.0.0.tgz#4bc8d9984403696225ef83a1573cbbcb4e79db13" 2041 | integrity sha512-PSNhEJDejZYV7h50BohL09Er9VaIefr2LMAf3OEmpCkjOi34eYyQYAXUTjEQtZJTKcF0E2UKTh+osDLsgNim9Q== 2042 | 2043 | xmlhttprequest-ssl@~1.5.4: 2044 | version "1.5.5" 2045 | resolved "https://registry.yarnpkg.com/xmlhttprequest-ssl/-/xmlhttprequest-ssl-1.5.5.tgz#c2876b06168aadc40e57d97e81191ac8f4398b3e" 2046 | integrity sha1-wodrBhaKrcQOV9l+gRkayPQ5iz4= 2047 | 2048 | xtend@^4.0.0: 2049 | version "4.0.2" 2050 | resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.2.tgz#bb72779f5fa465186b1f438f674fa347fdb5db54" 2051 | integrity sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ== 2052 | 2053 | yallist@^3.0.0, yallist@^3.0.3: 2054 | version "3.1.1" 2055 | resolved "https://registry.yarnpkg.com/yallist/-/yallist-3.1.1.tgz#dbb7daf9bfd8bac9ab45ebf602b8cbad0d5d08fd" 2056 | integrity sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g== 2057 | 2058 | yeast@0.1.2: 2059 | version "0.1.2" 2060 | resolved "https://registry.yarnpkg.com/yeast/-/yeast-0.1.2.tgz#008e06d8094320c372dbc2f8ed76a0ca6c8ac419" 2061 | integrity sha1-AI4G2AlDIMNy28L47XagymyKxBk= 2062 | --------------------------------------------------------------------------------