Add Github Pages
This commit is contained in:
parent
7d2ba50952
commit
7d42d1a721
@ -11,7 +11,7 @@
|
||||
## 🏄 在线体验与文档地址
|
||||
|
||||
- 在线体验:项目已经部署到腾讯云服务器,各位小伙伴们可直接线上体验:[http://1.15.127.74/](http://1.15.127.74/)
|
||||
- 文档地址:文档通过 Vuepress + Gitee Pages 生成,在线访问地址:
|
||||
- 文档地址:文档通过 Docsify + Gitee Pages 生成,在线访问地址:
|
||||
|
||||
## 💻 核心技术栈
|
||||
|
||||
@ -27,7 +27,7 @@
|
||||
- 消息队列:Kafka 2.13-2.7.0
|
||||
- 搜索引擎:Elasticsearch 6.4.3
|
||||
- 安全:Spring Security
|
||||
- 邮件:Spring Mail
|
||||
- 邮件任务:Spring Mail
|
||||
- 分布式定时任务:Spring Quartz
|
||||
- 日志:SLF4J(日志接口) + Logback(日志实现)
|
||||
|
||||
|
@ -1,22 +0,0 @@
|
||||
module.exports = {
|
||||
title: '开源社区系统 — Echo', // 设置网站标题
|
||||
description : '一款基于 SpringBoot + MyBatis + MySQL + Redis + Kafka + Elasticsearch + ... 实现的开源社区系统,并提供详细的开发文档和配套教程',
|
||||
base : '/Echo/',
|
||||
themeConfig : {
|
||||
nav : [
|
||||
{
|
||||
text: '仓库地址',
|
||||
items: [
|
||||
{ text: 'Github', link: 'https://github.com/Veal98/Echo' },
|
||||
{ text: 'Gitee', link: 'https://gitee.com/veal98/echo' }
|
||||
]
|
||||
},
|
||||
{ text: '体验项目', link: 'http://1.15.127.74:8080/' },
|
||||
{ text: '配套教程', link: '/error' }
|
||||
],
|
||||
sidebar: 'auto', // 侧边栏配置
|
||||
sidebarDepth : 2,
|
||||
lastUpdated: 'Last Updated', // string | boolean
|
||||
|
||||
}
|
||||
}
|
20
docs/.vuepress/dist/404.html
vendored
20
docs/.vuepress/dist/404.html
vendored
@ -1,20 +0,0 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en-US">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta name="viewport" content="width=device-width,initial-scale=1">
|
||||
<title>VuePress</title>
|
||||
<meta name="generator" content="VuePress 1.8.0">
|
||||
|
||||
<meta name="description" content="">
|
||||
|
||||
<link rel="preload" href="/assets/css/0.styles.d39084ab.css" as="style"><link rel="preload" href="/assets/js/app.b571f5e2.js" as="script"><link rel="preload" href="/assets/js/6.6e8c67be.js" as="script"><link rel="prefetch" href="/assets/js/2.12ad9e69.js"><link rel="prefetch" href="/assets/js/3.9f41a7be.js"><link rel="prefetch" href="/assets/js/4.865692a8.js"><link rel="prefetch" href="/assets/js/5.81254301.js"><link rel="prefetch" href="/assets/js/7.0bbea29c.js">
|
||||
<link rel="stylesheet" href="/assets/css/0.styles.d39084ab.css">
|
||||
</head>
|
||||
<body>
|
||||
<div id="app" data-server-rendered="true"><div class="theme-container"><div class="theme-default-content"><h1>404</h1> <blockquote>How did we get here?</blockquote> <a href="/" class="router-link-active">
|
||||
Take me home.
|
||||
</a></div></div><div class="global-ui"></div></div>
|
||||
<script src="/assets/js/app.b571f5e2.js" defer></script><script src="/assets/js/6.6e8c67be.js" defer></script>
|
||||
</body>
|
||||
</html>
|
File diff suppressed because one or more lines are too long
@ -1 +0,0 @@
|
||||
<?xml version="1.0" encoding="UTF-8"?><svg xmlns="http://www.w3.org/2000/svg" width="12" height="13"><g stroke-width="2" stroke="#aaa" fill="none"><path d="M11.29 11.71l-4-4"/><circle cx="5" cy="5" r="4"/></g></svg>
|
Before Width: | Height: | Size: 216 B |
1
docs/.vuepress/dist/assets/js/2.12ad9e69.js
vendored
1
docs/.vuepress/dist/assets/js/2.12ad9e69.js
vendored
File diff suppressed because one or more lines are too long
1
docs/.vuepress/dist/assets/js/3.9f41a7be.js
vendored
1
docs/.vuepress/dist/assets/js/3.9f41a7be.js
vendored
@ -1 +0,0 @@
|
||||
(window.webpackJsonp=window.webpackJsonp||[]).push([[3],{328:function(t,e,n){},356:function(t,e,n){"use strict";n(328)},364:function(t,e,n){"use strict";n.r(e);var i={functional:!0,props:{type:{type:String,default:"tip"},text:String,vertical:{type:String,default:"top"}},render:function(t,e){var n=e.props,i=e.slots;return t("span",{class:["badge",n.type],style:{verticalAlign:n.vertical}},n.text||i().default)}},r=(n(356),n(42)),p=Object(r.a)(i,void 0,void 0,!1,null,"15b7b770",null);e.default=p.exports}}]);
|
1
docs/.vuepress/dist/assets/js/4.865692a8.js
vendored
1
docs/.vuepress/dist/assets/js/4.865692a8.js
vendored
@ -1 +0,0 @@
|
||||
(window.webpackJsonp=window.webpackJsonp||[]).push([[4],{329:function(e,t,c){},357:function(e,t,c){"use strict";c(329)},361:function(e,t,c){"use strict";c.r(t);var i={name:"CodeBlock",props:{title:{type:String,required:!0},active:{type:Boolean,default:!1}}},n=(c(357),c(42)),s=Object(n.a)(i,(function(){var e=this.$createElement;return(this._self._c||e)("div",{staticClass:"theme-code-block",class:{"theme-code-block__active":this.active}},[this._t("default")],2)}),[],!1,null,"6d04095e",null);t.default=s.exports}}]);
|
1
docs/.vuepress/dist/assets/js/5.81254301.js
vendored
1
docs/.vuepress/dist/assets/js/5.81254301.js
vendored
@ -1 +0,0 @@
|
||||
(window.webpackJsonp=window.webpackJsonp||[]).push([[5],{330:function(e,t,o){},358:function(e,t,o){"use strict";o(330)},362:function(e,t,o){"use strict";o.r(t);o(23),o(93),o(65),o(95);var a={name:"CodeGroup",data:function(){return{codeTabs:[],activeCodeTabIndex:-1}},watch:{activeCodeTabIndex:function(e){this.codeTabs.forEach((function(e){e.elm.classList.remove("theme-code-block__active")})),this.codeTabs[e].elm.classList.add("theme-code-block__active")}},mounted:function(){var e=this;this.codeTabs=(this.$slots.default||[]).filter((function(e){return Boolean(e.componentOptions)})).map((function(t,o){return""===t.componentOptions.propsData.active&&(e.activeCodeTabIndex=o),{title:t.componentOptions.propsData.title,elm:t.elm}})),-1===this.activeCodeTabIndex&&this.codeTabs.length>0&&(this.activeCodeTabIndex=0)},methods:{changeCodeTab:function(e){this.activeCodeTabIndex=e}}},c=(o(358),o(42)),n=Object(c.a)(a,(function(){var e=this,t=e.$createElement,o=e._self._c||t;return o("div",{staticClass:"theme-code-group"},[o("div",{staticClass:"theme-code-group__nav"},[o("ul",{staticClass:"theme-code-group__ul"},e._l(e.codeTabs,(function(t,a){return o("li",{key:t.title,staticClass:"theme-code-group__li"},[o("button",{staticClass:"theme-code-group__nav-tab",class:{"theme-code-group__nav-tab-active":a===e.activeCodeTabIndex},on:{click:function(t){return e.changeCodeTab(a)}}},[e._v("\n "+e._s(t.title)+"\n ")])])})),0)]),e._v(" "),e._t("default"),e._v(" "),e.codeTabs.length<1?o("pre",{staticClass:"pre-blank"},[e._v("// Make sure to add code blocks to your code group")]):e._e()],2)}),[],!1,null,"32c2d7ed",null);t.default=n.exports}}]);
|
1
docs/.vuepress/dist/assets/js/6.6e8c67be.js
vendored
1
docs/.vuepress/dist/assets/js/6.6e8c67be.js
vendored
@ -1 +0,0 @@
|
||||
(window.webpackJsonp=window.webpackJsonp||[]).push([[6],{360:function(t,e,s){"use strict";s.r(e);var n=["There's nothing here.","How did we get here?","That's a Four-Oh-Four.","Looks like we've got some broken links."],o={methods:{getMsg:function(){return n[Math.floor(Math.random()*n.length)]}}},i=s(42),h=Object(i.a)(o,(function(){var t=this.$createElement,e=this._self._c||t;return e("div",{staticClass:"theme-container"},[e("div",{staticClass:"theme-default-content"},[e("h1",[this._v("404")]),this._v(" "),e("blockquote",[this._v(this._s(this.getMsg()))]),this._v(" "),e("RouterLink",{attrs:{to:"/"}},[this._v("\n Take me home.\n ")])],1)])}),[],!1,null,null,null);e.default=h.exports}}]);
|
1
docs/.vuepress/dist/assets/js/7.0bbea29c.js
vendored
1
docs/.vuepress/dist/assets/js/7.0bbea29c.js
vendored
File diff suppressed because one or more lines are too long
13
docs/.vuepress/dist/assets/js/app.b571f5e2.js
vendored
13
docs/.vuepress/dist/assets/js/app.b571f5e2.js
vendored
File diff suppressed because one or more lines are too long
537
docs/Guide.md
537
docs/Guide.md
@ -1,537 +0,0 @@
|
||||
# Echo — 开源社区系统
|
||||
|
||||
---
|
||||
|
||||
## 📚 从本项目你能学到什么
|
||||
|
||||
- 学会主流的 Java Web 开发技术和框架(Spring、SpringBoot、Spring MVC、MyBatis、MySQL、Redis、Kafka、Elasticsearch、Spring Security 等)
|
||||
- 了解一个真实的 Web 项目从开发到部署的整个流程(本项目配套有大量图例和详细教程,以帮助小伙伴快速上手)
|
||||
- 掌握本项目中涉及的核心技术点以及常见面试题和解析
|
||||
|
||||
## 🏄 在线体验与文档地址
|
||||
|
||||
- 在线体验:项目已经部署到腾讯云服务器,各位小伙伴们可直接线上体验:[http://1.15.127.74/](http://1.15.127.74/)
|
||||
- 文档地址:文档通过 Vuepress + Gitee Pages 生成,在线访问地址:
|
||||
|
||||
## 💻 核心技术栈
|
||||
|
||||
后端:
|
||||
|
||||
- Spring
|
||||
- Spring Boot 2.1.5 RELEASE
|
||||
- Spring MVC
|
||||
- ORM:MyBatis
|
||||
- 数据库:MySQL 5.7
|
||||
- 分布式缓存:Redis
|
||||
- 本地缓存:Caffeine
|
||||
- 消息队列:Kafka 2.13-2.7.0
|
||||
- 搜索引擎:Elasticsearch 6.4.3
|
||||
- 安全:Spring Security
|
||||
- 邮件:Spring Mail
|
||||
- 分布式定时任务:Spring Quartz
|
||||
- 日志:SLF4J(日志接口) + Logback(日志实现)
|
||||
|
||||
前端:
|
||||
|
||||
- Thymeleaf
|
||||
- Bootstrap 4.x
|
||||
- Jquery
|
||||
- Ajax
|
||||
|
||||
## 🔨 开发环境
|
||||
|
||||
- 操作系统:Windows 10
|
||||
- 构建工具:Apache Maven
|
||||
- 集成开发工具:Intellij IDEA
|
||||
- 应用服务器:Apache Tomcat
|
||||
- 接口测试工具:Postman
|
||||
- 压力测试工具:Apache JMeter
|
||||
- 版本控制工具:Git
|
||||
- Java 版本:8
|
||||
|
||||
## 🎀 界面展示
|
||||
|
||||
首页:
|
||||
|
||||

|
||||
|
||||
登录页:
|
||||
|
||||

|
||||
|
||||
帖子详情页:
|
||||
|
||||

|
||||
|
||||
个人主页:
|
||||
|
||||

|
||||
|
||||
朋友私信页:
|
||||
|
||||

|
||||
|
||||
私信详情页:
|
||||
|
||||

|
||||
|
||||
系统通知页:
|
||||
|
||||

|
||||
|
||||
通知详情页:
|
||||
|
||||

|
||||
|
||||
账号设置页:
|
||||
|
||||

|
||||
|
||||
数据统计页:
|
||||
|
||||

|
||||
|
||||
搜索详情页:
|
||||
|
||||

|
||||
|
||||
## 🎨 功能列表
|
||||
|
||||

|
||||
|
||||
- [x] **注册**
|
||||
|
||||
- 用户注册成功,将用户信息存入 MySQL,但此时该用户状态为未激活
|
||||
- 向用户发送激活邮件,用户点击链接则激活账号(Spring Mail)
|
||||
|
||||
- [x] **登录 | 登出**
|
||||
|
||||
- 进入登录界面,动态生成验证码,并将验证码短暂存入 Redis(60 秒)
|
||||
|
||||
- 用户登录成功(验证用户名、密码、验证码),生成登录凭证且设置状态为有效,并将登录凭证存入 Redis
|
||||
|
||||
注意:登录凭证存在有效期,在所有的请求执行之前,都会检查凭证是否有效和是否过期,只要该用户的凭证有效并在有效期时间内,本次请求就会一直持有该用户信息(使用 ThreadLocal 持有用户信息)
|
||||
|
||||
- 勾选记住我,则延长登录凭证有效时间
|
||||
|
||||
- 用户登录成功,将用户信息短暂存入 Redis(1 小时)
|
||||
|
||||
- 用户登出,将凭证状态设为无效,并更新 Redis 中该用户的登录凭证信息
|
||||
|
||||
- [x] **账号设置**
|
||||
|
||||
- 修改头像
|
||||
- 将用户选择的头像图片文件上传至七牛云服务器
|
||||
- 修改密码
|
||||
|
||||
- [x] **帖子模块**
|
||||
|
||||
- 发布帖子(过滤敏感词),将其存入 MySQL
|
||||
- 分页显示所有的帖子
|
||||
- 支持按照 “发帖时间” 显示
|
||||
- 支持按照 “热度排行” 显示(Spring Quartz)
|
||||
- 查看帖子详情
|
||||
- 权限管理(Spring Security + Thymeleaf Security)
|
||||
- 未登录用户无法发帖
|
||||
- “版主” 可以看到帖子的置顶和加精按钮并执行相应操作
|
||||
- “管理员” 可以看到帖子的删除按钮并执行相应操作
|
||||
- “普通用户” 无法看到帖子的置顶、加精、删除按钮,也无法执行相应操作
|
||||
|
||||
- [x] **评论模块**
|
||||
|
||||
- 发布对帖子的评论(过滤敏感词),将其存入 MySQL
|
||||
- 分页显示评论
|
||||
- 发布对评论的回复(过滤敏感词)
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用评论功能
|
||||
|
||||
- [x] **私信模块**
|
||||
|
||||
- 发送私信(过滤敏感词)
|
||||
- 私信列表
|
||||
- 查询当前用户的会话列表
|
||||
- 每个会话只显示一条最新的私信
|
||||
- 支持分页显示
|
||||
- 私信详情
|
||||
- 查询某个会话所包含的所有私信
|
||||
- 访问私信详情时,将显示的私信设为已读状态
|
||||
- 支持分页显示
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用私信功能
|
||||
|
||||
- [x] **统一处理 404 / 500 异常**
|
||||
|
||||
- 普通请求异常
|
||||
- 异步请求异常
|
||||
|
||||
- [x] **统一记录日志**
|
||||
|
||||
- [x] **点赞模块**
|
||||
|
||||
- 支持对帖子、评论/回复点赞
|
||||
- 第 1 次点赞,第 2 次取消点赞
|
||||
- 首页统计帖子的点赞数量
|
||||
- 详情页统计帖子和评论/回复的点赞数量
|
||||
- 详情页显示当前登录用户的点赞状态(赞过了则显示已赞)
|
||||
|
||||
- 统计我的获赞数量
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用点赞相关功能
|
||||
|
||||
- [x] **关注模块**
|
||||
|
||||
- 关注功能
|
||||
- 取消关注功能
|
||||
- 统计用户的关注数和粉丝数
|
||||
- 我的关注列表(查询某个用户关注的人),支持分页
|
||||
- 我的粉丝列表(查询某个用户的粉丝),支持分页
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用关注相关功能
|
||||
|
||||
- [x] **系统通知模块**
|
||||
|
||||
- 通知列表
|
||||
- 显示评论、点赞、关注三种类型的通知
|
||||
- 通知详情
|
||||
- 分页显示某一类主题所包含的通知
|
||||
- 进入某种类型的系统通知详情,则将该页的所有未读的系统通知状态设置为已读
|
||||
- 未读数量
|
||||
- 分别显示每种类型的系统通知的未读数量
|
||||
- 显示所有系统通知的未读数量
|
||||
- 导航栏显示所有消息的未读数量(未读私信 + 未读系统通知)
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用系统通知功能
|
||||
|
||||
- [x] **搜索模块**
|
||||
|
||||
- 发布事件
|
||||
- 发布帖子时,通过消息队列将帖子异步地提交到 Elasticsearch 服务器
|
||||
- 为帖子增加评论时,通过消息队列将帖子异步地提交到 Elasticsearch 服务器
|
||||
- 搜索服务
|
||||
- 从 Elasticsearch 服务器搜索帖子
|
||||
- 从 Elasticsearch 服务器删除帖子(当帖子从数据库中被删除时)
|
||||
- 显示搜索结果
|
||||
|
||||
- [x] **网站数据统计**(管理员专属)
|
||||
|
||||
- 独立访客 UV
|
||||
- 存入 Redis 的 HyperLogLog
|
||||
- 支持单日查询和区间日期查询
|
||||
- 日活跃用户 DAU
|
||||
- 存入 Redis 的 Bitmap
|
||||
- 支持单日查询和区间日期查询
|
||||
- 权限管理(Spring Security)
|
||||
- 只有管理员可以查看网站数据统计
|
||||
|
||||
- [x] 优化网站性能
|
||||
|
||||
- 使用本地缓存 Caffeine 缓存热帖列表以及所有用户帖子的总数
|
||||
|
||||
## 🔐 待实现及优化
|
||||
|
||||
以下是我个人发现的本项目存在的问题,但是暂时没有头绪无法解决,集思广益,欢迎各位小伙伴提 PR 解决:
|
||||
|
||||
- [ ] 注册模块无法正常跳转到操作提示界面(本地运行没有问题)
|
||||
- [ ] 评论功能的前端显示部分存在 Bug
|
||||
- [ ] 查询我的评论(未完善)
|
||||
|
||||
以下是我觉得本项目还可以添加的功能,同样欢迎各位小伙伴提 issue 指出还可以增加哪些功能,或者直接提 PR 实现该功能:
|
||||
|
||||
- [ ] 忘记密码(发送邮件找回密码)
|
||||
- [ ] 查询我的点赞
|
||||
- [ ] 管理员对帖子的二次点击取消置顶功能
|
||||
- [ ] 管理员对已删除帖子的恢复功能(本项目中的删除帖子并未将其从数据库中删除,只是将其状态设置为了拉黑)
|
||||
|
||||
## 🌱 本地运行
|
||||
|
||||
各位如果需要将项目部署在本地进行测试,以下环境请提前备好:
|
||||
|
||||
- Java 8
|
||||
- MySQL 5.7
|
||||
- Redis
|
||||
- Kafka 2.13-2.7.0
|
||||
- Elasticsearch 6.4.3
|
||||
|
||||
然后**修改配置文件中的信息为你自己的本地环境,直接运行是运行不了的**,而且相关私密信息我全部用 xxxxxxx 代替了。
|
||||
|
||||
本地运行需要修改的配置文件信息如下:
|
||||
|
||||
1)`application-develop.properties`:
|
||||
|
||||
- MySQL
|
||||
- Spring Mail(邮箱需要开启 SMTP 服务)
|
||||
- Kafka:consumer.group-id(该字段见 Kafka 安装包中的 consumer.proerties,可自行修改, 修改完毕后需要重启 Kafka)
|
||||
- Elasticsearch:cluster-name(该字段见 Elasticsearch 安装包中的 elasticsearch.yml,可自行修改)
|
||||
- 七牛云(需要新建一个七牛云的对象存储空间,用来存放上传的头像图片)
|
||||
|
||||
2)`logback-spring-develop.xml`:
|
||||
|
||||
- LOG_PATH:日志存放的位置
|
||||
|
||||
每次运行需要打开:
|
||||
|
||||
- MySQL
|
||||
- Redis
|
||||
- Elasticsearch
|
||||
- Kafka
|
||||
|
||||
另外,还需要事件建好数据库表,详细见下文。
|
||||
|
||||
## 📜 数据库设计
|
||||
|
||||
用户 `user`:
|
||||
|
||||
```sql
|
||||
DROP TABLE IF EXISTS `user`;
|
||||
SET character_set_client = utf8mb4 ;
|
||||
CREATE TABLE `user` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`username` varchar(50) DEFAULT NULL,
|
||||
`password` varchar(50) DEFAULT NULL,
|
||||
`salt` varchar(50) DEFAULT NULL,
|
||||
`email` varchar(100) DEFAULT NULL,
|
||||
`type` int(11) DEFAULT NULL COMMENT '0-普通用户; 1-超级管理员; 2-版主;',
|
||||
`status` int(11) DEFAULT NULL COMMENT '0-未激活; 1-已激活;',
|
||||
`activation_code` varchar(100) DEFAULT NULL,
|
||||
`header_url` varchar(200) DEFAULT NULL,
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_username` (`username`(20)),
|
||||
KEY `index_email` (`email`(20))
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=101 DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
讨论帖 `discuss_post`:
|
||||
|
||||
```sql
|
||||
DROP TABLE IF EXISTS `discuss_post`;
|
||||
SET character_set_client = utf8mb4 ;
|
||||
CREATE TABLE `discuss_post` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`user_id` int(11) DEFAULT NULL,
|
||||
`title` varchar(100) DEFAULT NULL,
|
||||
`content` text,
|
||||
`type` int(11) DEFAULT NULL COMMENT '0-普通; 1-置顶;',
|
||||
`status` int(11) DEFAULT NULL COMMENT '0-正常; 1-精华; 2-拉黑;',
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
`comment_count` int(11) DEFAULT NULL,
|
||||
`score` double DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_user_id` (`user_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
评论(回复)`comment`:
|
||||
|
||||
```sql
|
||||
CREATE TABLE `comment` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`user_id` int(11) DEFAULT NULL,
|
||||
`entity_type` int(11) DEFAULT NULL COMMENT '评论目标的类别:1 帖子;2 评论 ',
|
||||
`entity_id` int(11) DEFAULT NULL COMMENT '评论目标的 id',
|
||||
`target_id` int(11) DEFAULT NULL COMMENT '指明对谁进行评论',
|
||||
`content` text,
|
||||
`status` int(11) DEFAULT NULL COMMENT '状态:0 正常;1 禁用',
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_user_id` (`user_id`),
|
||||
KEY `index_entity_id` (`entity_id`)
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=247 DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
私信 `message`:
|
||||
|
||||
```sql
|
||||
DROP TABLE IF EXISTS `message`;
|
||||
SET character_set_client = utf8mb4 ;
|
||||
CREATE TABLE `message` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`from_id` int(11) DEFAULT NULL,
|
||||
`to_id` int(11) DEFAULT NULL,
|
||||
`conversation_id` varchar(45) NOT NULL,
|
||||
`content` text,
|
||||
`status` int(11) DEFAULT NULL COMMENT '0-未读;1-已读;2-删除;',
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_from_id` (`from_id`),
|
||||
KEY `index_to_id` (`to_id`),
|
||||
KEY `index_conversation_id` (`conversation_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
## 🌌 理想的部署架构
|
||||
|
||||
我每个都只部署了一台,以下是理想的部署架构:
|
||||
|
||||

|
||||
|
||||
## 🎯 功能逻辑图
|
||||
|
||||
画了一些不是那么严谨的图帮助各位小伙伴理清思绪。
|
||||
|
||||
> 单向绿色箭头:
|
||||
>
|
||||
> - 前端模板 -> Controller:表示这个前端模板中有一个超链接是由这个 Controller 处理的
|
||||
> - Controller -> 前端模板:表示这个 Controller 会像该前端模板传递数据或者跳转
|
||||
>
|
||||
> 双向绿色箭头:表示 Controller 和前端模板之间进行参数的相互传递或使用
|
||||
>
|
||||
> 单向蓝色箭头: A -> B,表示 A 方法调用了 B 方法
|
||||
>
|
||||
> 单向红色箭头:数据库或缓存操作
|
||||
|
||||
### 注册
|
||||
|
||||
- 用户注册成功,将用户信息存入 MySQL,但此时该用户状态为未激活
|
||||
- 向用户发送激活邮件,用户点击链接则激活账号(Spring Mail)
|
||||
|
||||

|
||||
|
||||
### 登录 | 登出
|
||||
|
||||
- 进入登录界面,动态生成验证码,并将验证码短暂存入 Redis(60 秒)
|
||||
|
||||
- 用户登录成功(验证用户名、密码、验证码),生成登录凭证且设置状态为有效,并将登录凭证存入 Redis
|
||||
|
||||
注意:登录凭证存在有效期,在所有的请求执行之前,都会检查凭证是否有效和是否过期,只要该用户的凭证有效并在有效期时间内,本次请求就会一直持有该用户信息(使用 ThreadLocal 持有用户信息)
|
||||
|
||||
- 勾选记住我,则延长登录凭证有效时间
|
||||
|
||||
- 用户登录成功,将用户信息短暂存入 Redis(1 小时)
|
||||
|
||||
- 用户登出,将凭证状态设为无效,并更新 Redis 中该用户的登录凭证信息
|
||||
|
||||
下图是登录模块的功能逻辑图,并没有使用 Spring Security 提供的认证逻辑(我觉得这个模块是最复杂的,这张图其实很多细节还没有画全)
|
||||
|
||||

|
||||
|
||||
### 分页显示所有的帖子
|
||||
|
||||
- 支持按照 “发帖时间” 显示
|
||||
- 支持按照 “热度排行” 显示(Spring Quartz)
|
||||
- 将热帖列表和所有帖子的总数存入本地缓存 Caffeine(利用分布式定时任务 Spring Quartz 每隔一段时间就刷新计算帖子的热度/分数 — 见下文,而 Caffeine 里的数据更新不用我们操心,它天生就会自动的更新它拥有的数据,给它一个初始化方法就完事儿)
|
||||
|
||||

|
||||
|
||||
|
||||
|
||||
### 账号设置
|
||||
|
||||
- 修改头像(异步请求)
|
||||
- 将用户选择的头像图片文件上传至七牛云服务器
|
||||
- 修改密码
|
||||
|
||||
此处只画出修改头像:
|
||||
|
||||

|
||||
|
||||
### 发布帖子(异步请求)
|
||||
|
||||

|
||||
|
||||
### 显示评论及相关信息
|
||||
|
||||
> 评论部分前端的名称显示有些缺陷,有兴趣的小伙伴欢迎提 PR 解决~
|
||||
|
||||
关于评论模块需要注意的就是评论表的设计,把握其中字段的含义,才能透彻了解这个功能的逻辑。
|
||||
|
||||
评论 Comment 的目标类型(帖子,评论) entityType 和 entityId 以及对哪个用户进行评论/回复 targetId 是由前端传递给 DiscussPostController 的
|
||||
|
||||

|
||||
|
||||
一个帖子的详情页需要封装的信息大概如下:
|
||||
|
||||

|
||||
|
||||
### 添加评论(事务管理)
|
||||
|
||||

|
||||
|
||||
### 私信列表和详情页
|
||||
|
||||

|
||||
|
||||
### 发送私信(异步请求)
|
||||
|
||||

|
||||
|
||||
### 点赞(异步请求)
|
||||
|
||||
将点赞相关信息存入 Redis 的数据结构 set 中。其中,key 命名为 `like:entity:entityType:entityId`,value 即点赞用户的 id。比如 key = `like:entity:2:246` value = `11` 表示用户 11 对实体类型 2 即评论进行了点赞,该评论的 id 是 246
|
||||
|
||||
某个用户的获赞数量对应的存储在 Redis 中的 key 是 `like:user:userId`,value 就是这个用户的获赞数量
|
||||
|
||||

|
||||
|
||||
### 我的获赞数量
|
||||
|
||||

|
||||
|
||||
### 关注(异步请求)
|
||||
|
||||
- 若 A 关注了 B,则 A 是 B 的粉丝 Follower,B 是 A 的目标 Followee
|
||||
- 关注的目标可以是用户、帖子、题目等,在实现时将这些目标抽象为实体(目前只做了关注用户)
|
||||
|
||||
将某个用户关注的实体相关信息存储在 Redis 的数据结构 zset 中:key 是 `followee:userId:entityType` ,对应的 value 是 `zset(entityId, now)` ,以关注的时间进行排序。比如说 `followee:111:3` 对应的value `(20, 2020-02-03-xxxx)`,表明用户 111 关注了实体类型为 3 即人(用户),该帖子的 id 是 20,关注该帖子的时间是 2020-02-03-xxxx
|
||||
|
||||
同样的,将某个实体拥有的粉丝相关信息也存储在 Redis 的数据结构 zset 中:key 是 `follower:entityType:entityId`,对应的 value 是 `zset(userId, now)`,以关注的时间进行排序
|
||||
|
||||

|
||||
|
||||
### 关注列表
|
||||
|
||||

|
||||
|
||||
### 发送系统通知
|
||||
|
||||

|
||||
|
||||
### 显示系统通知
|
||||
|
||||

|
||||
|
||||
### 搜索
|
||||
|
||||

|
||||
|
||||
类似的,置顶、加精也会触发发帖事件,就不再图里面画出来了。
|
||||
|
||||
### 置顶加精删除(异步请求)
|
||||
|
||||

|
||||
|
||||
### 网站数据统计
|
||||
|
||||

|
||||
|
||||
### 帖子热度计算
|
||||
|
||||
每次发生点赞(给帖子点赞)、评论(给帖子评论)、加精的时候,就将这些帖子信息存入缓存 Redis 中,然后通过分布式的定时任务 Spring Quartz,每隔一段时间就从缓存中取出这些帖子进行计算分数。
|
||||
|
||||
帖子分数/热度计算公式:分数(热度) = 权重 + 发帖距离天数
|
||||
|
||||
```java
|
||||
// 计算权重
|
||||
double w = (wonderful ? 75 : 0) + commentCount * 10 + likeCount * 2;
|
||||
// 分数 = 权重 + 发帖距离天数
|
||||
double score = Math.log10(Math.max(w, 1))
|
||||
+ (post.getCreateTime().getTime() - epoch.getTime()) / (1000 * 3600 * 24);
|
||||
```
|
||||
|
||||

|
||||
|
||||
## 📖 配套教程
|
||||
|
||||
想要自己从零开始实现这个项目或者深入理解的小伙伴,可以扫描下方二维码关注公众号『**飞天小牛肉**』,第一时间获取配套教程, 不仅会详细解释本项目涉及的各大技术点,还会汇总相关的常见面试题,目前尚在更新中。
|
||||
|
||||
<img src="https://gitee.com/veal98/images/raw/master/img/20210204145531.png" style="zoom:67%;" />
|
||||
|
||||
## 📞 联系我
|
||||
|
||||
有什么问题也可以添加我的微信,记得备注来意:格式 <u>(学校或公司 - 姓名或昵称 - 来意)</u>
|
||||
|
||||
<img width="260px" src="https://gitee.com/veal98/images/raw/master/img/微信图片_20210105121328.jpg" >
|
||||
|
||||
## 👏 鸣谢
|
||||
|
||||
本项目参考[牛客网](https://www.nowcoder.com/) — Java 高级工程师课程,感谢老师和平台
|
551
docs/README.md
551
docs/README.md
@ -1,16 +1,537 @@
|
||||
# Echo — 开源社区系统
|
||||
|
||||
---
|
||||
home: true
|
||||
heroImage: https://gitee.com/veal98/images/raw/master/img/20210211175136.png
|
||||
heroText: Great Community — Echo
|
||||
tagline: 🦄 开源社区系统
|
||||
actionText: 快速上手 →
|
||||
actionLink: /Guide
|
||||
features:
|
||||
- title: 主流技术栈
|
||||
details: 基于目前国内主流技术栈开发:SpringBoot + MyBatis + MySQL + Redis + Kafka + Elasticsearch + ...
|
||||
- title: 详细开发文档
|
||||
details: 包含详细文档以及大量图例,帮助读者快速掌握本项目
|
||||
- title: 配套友好教程
|
||||
details: 关注公众号『飞天小牛肉』第一时间获取教程更新,目前尚在连载中
|
||||
footer: MIT Licensed | Copyright © 2021-present 小牛肉
|
||||
---
|
||||
|
||||
## 📚 从本项目你能学到什么
|
||||
|
||||
- 学会主流的 Java Web 开发技术和框架(Spring、SpringBoot、Spring MVC、MyBatis、MySQL、Redis、Kafka、Elasticsearch、Spring Security 等)
|
||||
- 了解一个真实的 Web 项目从开发到部署的整个流程(本项目配套有大量图例和详细教程,以帮助小伙伴快速上手)
|
||||
- 掌握本项目中涉及的核心技术点以及常见面试题和解析
|
||||
|
||||
## 🏄 在线体验与文档地址
|
||||
|
||||
- 在线体验:项目已经部署到腾讯云服务器,各位小伙伴们可直接线上体验:[http://1.15.127.74/](http://1.15.127.74/)
|
||||
- 文档地址:文档通过 Docsify + Gitee Pages 生成,在线访问地址:
|
||||
|
||||
## 💻 核心技术栈
|
||||
|
||||
后端:
|
||||
|
||||
- Spring
|
||||
- Spring Boot 2.1.5 RELEASE
|
||||
- Spring MVC
|
||||
- ORM:MyBatis
|
||||
- 数据库:MySQL 5.7
|
||||
- 分布式缓存:Redis
|
||||
- 本地缓存:Caffeine
|
||||
- 消息队列:Kafka 2.13-2.7.0
|
||||
- 搜索引擎:Elasticsearch 6.4.3
|
||||
- 安全:Spring Security
|
||||
- 邮件任务:Spring Mail
|
||||
- 分布式定时任务:Spring Quartz
|
||||
- 日志:SLF4J(日志接口) + Logback(日志实现)
|
||||
|
||||
前端:
|
||||
|
||||
- Thymeleaf
|
||||
- Bootstrap 4.x
|
||||
- Jquery
|
||||
- Ajax
|
||||
|
||||
## 🔨 开发环境
|
||||
|
||||
- 操作系统:Windows 10
|
||||
- 构建工具:Apache Maven
|
||||
- 集成开发工具:Intellij IDEA
|
||||
- 应用服务器:Apache Tomcat
|
||||
- 接口测试工具:Postman
|
||||
- 压力测试工具:Apache JMeter
|
||||
- 版本控制工具:Git
|
||||
- Java 版本:8
|
||||
|
||||
## 🎀 界面展示
|
||||
|
||||
首页:
|
||||
|
||||

|
||||
|
||||
登录页:
|
||||
|
||||

|
||||
|
||||
帖子详情页:
|
||||
|
||||

|
||||
|
||||
个人主页:
|
||||
|
||||

|
||||
|
||||
朋友私信页:
|
||||
|
||||

|
||||
|
||||
私信详情页:
|
||||
|
||||

|
||||
|
||||
系统通知页:
|
||||
|
||||

|
||||
|
||||
通知详情页:
|
||||
|
||||

|
||||
|
||||
账号设置页:
|
||||
|
||||

|
||||
|
||||
数据统计页:
|
||||
|
||||

|
||||
|
||||
搜索详情页:
|
||||
|
||||

|
||||
|
||||
## 🎨 功能列表
|
||||
|
||||

|
||||
|
||||
- [x] **注册**
|
||||
|
||||
- 用户注册成功,将用户信息存入 MySQL,但此时该用户状态为未激活
|
||||
- 向用户发送激活邮件,用户点击链接则激活账号(Spring Mail)
|
||||
|
||||
- [x] **登录 | 登出**
|
||||
|
||||
- 进入登录界面,动态生成验证码,并将验证码短暂存入 Redis(60 秒)
|
||||
|
||||
- 用户登录成功(验证用户名、密码、验证码),生成登录凭证且设置状态为有效,并将登录凭证存入 Redis
|
||||
|
||||
注意:登录凭证存在有效期,在所有的请求执行之前,都会检查凭证是否有效和是否过期,只要该用户的凭证有效并在有效期时间内,本次请求就会一直持有该用户信息(使用 ThreadLocal 持有用户信息)
|
||||
|
||||
- 勾选记住我,则延长登录凭证有效时间
|
||||
|
||||
- 用户登录成功,将用户信息短暂存入 Redis(1 小时)
|
||||
|
||||
- 用户登出,将凭证状态设为无效,并更新 Redis 中该用户的登录凭证信息
|
||||
|
||||
- [x] **账号设置**
|
||||
|
||||
- 修改头像
|
||||
- 将用户选择的头像图片文件上传至七牛云服务器
|
||||
- 修改密码
|
||||
|
||||
- [x] **帖子模块**
|
||||
|
||||
- 发布帖子(过滤敏感词),将其存入 MySQL
|
||||
- 分页显示所有的帖子
|
||||
- 支持按照 “发帖时间” 显示
|
||||
- 支持按照 “热度排行” 显示(Spring Quartz)
|
||||
- 查看帖子详情
|
||||
- 权限管理(Spring Security + Thymeleaf Security)
|
||||
- 未登录用户无法发帖
|
||||
- “版主” 可以看到帖子的置顶和加精按钮并执行相应操作
|
||||
- “管理员” 可以看到帖子的删除按钮并执行相应操作
|
||||
- “普通用户” 无法看到帖子的置顶、加精、删除按钮,也无法执行相应操作
|
||||
|
||||
- [x] **评论模块**
|
||||
|
||||
- 发布对帖子的评论(过滤敏感词),将其存入 MySQL
|
||||
- 分页显示评论
|
||||
- 发布对评论的回复(过滤敏感词)
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用评论功能
|
||||
|
||||
- [x] **私信模块**
|
||||
|
||||
- 发送私信(过滤敏感词)
|
||||
- 私信列表
|
||||
- 查询当前用户的会话列表
|
||||
- 每个会话只显示一条最新的私信
|
||||
- 支持分页显示
|
||||
- 私信详情
|
||||
- 查询某个会话所包含的所有私信
|
||||
- 访问私信详情时,将显示的私信设为已读状态
|
||||
- 支持分页显示
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用私信功能
|
||||
|
||||
- [x] **统一处理 404 / 500 异常**
|
||||
|
||||
- 普通请求异常
|
||||
- 异步请求异常
|
||||
|
||||
- [x] **统一记录日志**
|
||||
|
||||
- [x] **点赞模块**
|
||||
|
||||
- 支持对帖子、评论/回复点赞
|
||||
- 第 1 次点赞,第 2 次取消点赞
|
||||
- 首页统计帖子的点赞数量
|
||||
- 详情页统计帖子和评论/回复的点赞数量
|
||||
- 详情页显示当前登录用户的点赞状态(赞过了则显示已赞)
|
||||
|
||||
- 统计我的获赞数量
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用点赞相关功能
|
||||
|
||||
- [x] **关注模块**
|
||||
|
||||
- 关注功能
|
||||
- 取消关注功能
|
||||
- 统计用户的关注数和粉丝数
|
||||
- 我的关注列表(查询某个用户关注的人),支持分页
|
||||
- 我的粉丝列表(查询某个用户的粉丝),支持分页
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用关注相关功能
|
||||
|
||||
- [x] **系统通知模块**
|
||||
|
||||
- 通知列表
|
||||
- 显示评论、点赞、关注三种类型的通知
|
||||
- 通知详情
|
||||
- 分页显示某一类主题所包含的通知
|
||||
- 进入某种类型的系统通知详情,则将该页的所有未读的系统通知状态设置为已读
|
||||
- 未读数量
|
||||
- 分别显示每种类型的系统通知的未读数量
|
||||
- 显示所有系统通知的未读数量
|
||||
- 导航栏显示所有消息的未读数量(未读私信 + 未读系统通知)
|
||||
- 权限管理(Spring Security)
|
||||
- 未登录用户无法使用系统通知功能
|
||||
|
||||
- [x] **搜索模块**
|
||||
|
||||
- 发布事件
|
||||
- 发布帖子时,通过消息队列将帖子异步地提交到 Elasticsearch 服务器
|
||||
- 为帖子增加评论时,通过消息队列将帖子异步地提交到 Elasticsearch 服务器
|
||||
- 搜索服务
|
||||
- 从 Elasticsearch 服务器搜索帖子
|
||||
- 从 Elasticsearch 服务器删除帖子(当帖子从数据库中被删除时)
|
||||
- 显示搜索结果
|
||||
|
||||
- [x] **网站数据统计**(管理员专属)
|
||||
|
||||
- 独立访客 UV
|
||||
- 存入 Redis 的 HyperLogLog
|
||||
- 支持单日查询和区间日期查询
|
||||
- 日活跃用户 DAU
|
||||
- 存入 Redis 的 Bitmap
|
||||
- 支持单日查询和区间日期查询
|
||||
- 权限管理(Spring Security)
|
||||
- 只有管理员可以查看网站数据统计
|
||||
|
||||
- [x] 优化网站性能
|
||||
|
||||
- 使用本地缓存 Caffeine 缓存热帖列表以及所有用户帖子的总数
|
||||
|
||||
## 🔐 待实现及优化
|
||||
|
||||
以下是我个人发现的本项目存在的问题,但是暂时没有头绪无法解决,集思广益,欢迎各位小伙伴提 PR 解决:
|
||||
|
||||
- [ ] 注册模块无法正常跳转到操作提示界面(本地运行没有问题)
|
||||
- [ ] 评论功能的前端显示部分存在 Bug
|
||||
- [ ] 查询我的评论(未完善)
|
||||
|
||||
以下是我觉得本项目还可以添加的功能,同样欢迎各位小伙伴提 issue 指出还可以增加哪些功能,或者直接提 PR 实现该功能:
|
||||
|
||||
- [ ] 忘记密码(发送邮件找回密码)
|
||||
- [ ] 查询我的点赞
|
||||
- [ ] 管理员对帖子的二次点击取消置顶功能
|
||||
- [ ] 管理员对已删除帖子的恢复功能(本项目中的删除帖子并未将其从数据库中删除,只是将其状态设置为了拉黑)
|
||||
|
||||
## 🌱 本地运行
|
||||
|
||||
各位如果需要将项目部署在本地进行测试,以下环境请提前备好:
|
||||
|
||||
- Java 8
|
||||
- MySQL 5.7
|
||||
- Redis
|
||||
- Kafka 2.13-2.7.0
|
||||
- Elasticsearch 6.4.3
|
||||
|
||||
然后**修改配置文件中的信息为你自己的本地环境,直接运行是运行不了的**,而且相关私密信息我全部用 xxxxxxx 代替了。
|
||||
|
||||
本地运行需要修改的配置文件信息如下:
|
||||
|
||||
1)`application-develop.properties`:
|
||||
|
||||
- MySQL
|
||||
- Spring Mail(邮箱需要开启 SMTP 服务)
|
||||
- Kafka:consumer.group-id(该字段见 Kafka 安装包中的 consumer.proerties,可自行修改, 修改完毕后需要重启 Kafka)
|
||||
- Elasticsearch:cluster-name(该字段见 Elasticsearch 安装包中的 elasticsearch.yml,可自行修改)
|
||||
- 七牛云(需要新建一个七牛云的对象存储空间,用来存放上传的头像图片)
|
||||
|
||||
2)`logback-spring-develop.xml`:
|
||||
|
||||
- LOG_PATH:日志存放的位置
|
||||
|
||||
每次运行需要打开:
|
||||
|
||||
- MySQL
|
||||
- Redis
|
||||
- Elasticsearch
|
||||
- Kafka
|
||||
|
||||
另外,还需要事件建好数据库表,详细见下文。
|
||||
|
||||
## 📜 数据库设计
|
||||
|
||||
用户 `user`:
|
||||
|
||||
```sql
|
||||
DROP TABLE IF EXISTS `user`;
|
||||
SET character_set_client = utf8mb4 ;
|
||||
CREATE TABLE `user` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`username` varchar(50) DEFAULT NULL,
|
||||
`password` varchar(50) DEFAULT NULL,
|
||||
`salt` varchar(50) DEFAULT NULL,
|
||||
`email` varchar(100) DEFAULT NULL,
|
||||
`type` int(11) DEFAULT NULL COMMENT '0-普通用户; 1-超级管理员; 2-版主;',
|
||||
`status` int(11) DEFAULT NULL COMMENT '0-未激活; 1-已激活;',
|
||||
`activation_code` varchar(100) DEFAULT NULL,
|
||||
`header_url` varchar(200) DEFAULT NULL,
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_username` (`username`(20)),
|
||||
KEY `index_email` (`email`(20))
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=101 DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
讨论帖 `discuss_post`:
|
||||
|
||||
```sql
|
||||
DROP TABLE IF EXISTS `discuss_post`;
|
||||
SET character_set_client = utf8mb4 ;
|
||||
CREATE TABLE `discuss_post` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`user_id` int(11) DEFAULT NULL,
|
||||
`title` varchar(100) DEFAULT NULL,
|
||||
`content` text,
|
||||
`type` int(11) DEFAULT NULL COMMENT '0-普通; 1-置顶;',
|
||||
`status` int(11) DEFAULT NULL COMMENT '0-正常; 1-精华; 2-拉黑;',
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
`comment_count` int(11) DEFAULT NULL,
|
||||
`score` double DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_user_id` (`user_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
评论(回复)`comment`:
|
||||
|
||||
```sql
|
||||
CREATE TABLE `comment` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`user_id` int(11) DEFAULT NULL,
|
||||
`entity_type` int(11) DEFAULT NULL COMMENT '评论目标的类别:1 帖子;2 评论 ',
|
||||
`entity_id` int(11) DEFAULT NULL COMMENT '评论目标的 id',
|
||||
`target_id` int(11) DEFAULT NULL COMMENT '指明对谁进行评论',
|
||||
`content` text,
|
||||
`status` int(11) DEFAULT NULL COMMENT '状态:0 正常;1 禁用',
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_user_id` (`user_id`),
|
||||
KEY `index_entity_id` (`entity_id`)
|
||||
) ENGINE=InnoDB AUTO_INCREMENT=247 DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
私信 `message`:
|
||||
|
||||
```sql
|
||||
DROP TABLE IF EXISTS `message`;
|
||||
SET character_set_client = utf8mb4 ;
|
||||
CREATE TABLE `message` (
|
||||
`id` int(11) NOT NULL AUTO_INCREMENT,
|
||||
`from_id` int(11) DEFAULT NULL,
|
||||
`to_id` int(11) DEFAULT NULL,
|
||||
`conversation_id` varchar(45) NOT NULL,
|
||||
`content` text,
|
||||
`status` int(11) DEFAULT NULL COMMENT '0-未读;1-已读;2-删除;',
|
||||
`create_time` timestamp NULL DEFAULT NULL,
|
||||
PRIMARY KEY (`id`),
|
||||
KEY `index_from_id` (`from_id`),
|
||||
KEY `index_to_id` (`to_id`),
|
||||
KEY `index_conversation_id` (`conversation_id`)
|
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
|
||||
```
|
||||
|
||||
## 🌌 理想的部署架构
|
||||
|
||||
我每个都只部署了一台,以下是理想的部署架构:
|
||||
|
||||

|
||||
|
||||
## 🎯 功能逻辑图
|
||||
|
||||
画了一些不是那么严谨的图帮助各位小伙伴理清思绪。
|
||||
|
||||
> 单向绿色箭头:
|
||||
>
|
||||
> - 前端模板 -> Controller:表示这个前端模板中有一个超链接是由这个 Controller 处理的
|
||||
> - Controller -> 前端模板:表示这个 Controller 会像该前端模板传递数据或者跳转
|
||||
>
|
||||
> 双向绿色箭头:表示 Controller 和前端模板之间进行参数的相互传递或使用
|
||||
>
|
||||
> 单向蓝色箭头: A -> B,表示 A 方法调用了 B 方法
|
||||
>
|
||||
> 单向红色箭头:数据库或缓存操作
|
||||
|
||||
### 注册
|
||||
|
||||
- 用户注册成功,将用户信息存入 MySQL,但此时该用户状态为未激活
|
||||
- 向用户发送激活邮件,用户点击链接则激活账号(Spring Mail)
|
||||
|
||||

|
||||
|
||||
### 登录 | 登出
|
||||
|
||||
- 进入登录界面,动态生成验证码,并将验证码短暂存入 Redis(60 秒)
|
||||
|
||||
- 用户登录成功(验证用户名、密码、验证码),生成登录凭证且设置状态为有效,并将登录凭证存入 Redis
|
||||
|
||||
注意:登录凭证存在有效期,在所有的请求执行之前,都会检查凭证是否有效和是否过期,只要该用户的凭证有效并在有效期时间内,本次请求就会一直持有该用户信息(使用 ThreadLocal 持有用户信息)
|
||||
|
||||
- 勾选记住我,则延长登录凭证有效时间
|
||||
|
||||
- 用户登录成功,将用户信息短暂存入 Redis(1 小时)
|
||||
|
||||
- 用户登出,将凭证状态设为无效,并更新 Redis 中该用户的登录凭证信息
|
||||
|
||||
下图是登录模块的功能逻辑图,并没有使用 Spring Security 提供的认证逻辑(我觉得这个模块是最复杂的,这张图其实很多细节还没有画全)
|
||||
|
||||

|
||||
|
||||
### 分页显示所有的帖子
|
||||
|
||||
- 支持按照 “发帖时间” 显示
|
||||
- 支持按照 “热度排行” 显示(Spring Quartz)
|
||||
- 将热帖列表和所有帖子的总数存入本地缓存 Caffeine(利用分布式定时任务 Spring Quartz 每隔一段时间就刷新计算帖子的热度/分数 — 见下文,而 Caffeine 里的数据更新不用我们操心,它天生就会自动的更新它拥有的数据,给它一个初始化方法就完事儿)
|
||||
|
||||

|
||||
|
||||
|
||||
|
||||
### 账号设置
|
||||
|
||||
- 修改头像(异步请求)
|
||||
- 将用户选择的头像图片文件上传至七牛云服务器
|
||||
- 修改密码
|
||||
|
||||
此处只画出修改头像:
|
||||
|
||||

|
||||
|
||||
### 发布帖子(异步请求)
|
||||
|
||||

|
||||
|
||||
### 显示评论及相关信息
|
||||
|
||||
> 评论部分前端的名称显示有些缺陷,有兴趣的小伙伴欢迎提 PR 解决~
|
||||
|
||||
关于评论模块需要注意的就是评论表的设计,把握其中字段的含义,才能透彻了解这个功能的逻辑。
|
||||
|
||||
评论 Comment 的目标类型(帖子,评论) entityType 和 entityId 以及对哪个用户进行评论/回复 targetId 是由前端传递给 DiscussPostController 的
|
||||
|
||||

|
||||
|
||||
一个帖子的详情页需要封装的信息大概如下:
|
||||
|
||||

|
||||
|
||||
### 添加评论(事务管理)
|
||||
|
||||

|
||||
|
||||
### 私信列表和详情页
|
||||
|
||||

|
||||
|
||||
### 发送私信(异步请求)
|
||||
|
||||

|
||||
|
||||
### 点赞(异步请求)
|
||||
|
||||
将点赞相关信息存入 Redis 的数据结构 set 中。其中,key 命名为 `like:entity:entityType:entityId`,value 即点赞用户的 id。比如 key = `like:entity:2:246` value = `11` 表示用户 11 对实体类型 2 即评论进行了点赞,该评论的 id 是 246
|
||||
|
||||
某个用户的获赞数量对应的存储在 Redis 中的 key 是 `like:user:userId`,value 就是这个用户的获赞数量
|
||||
|
||||

|
||||
|
||||
### 我的获赞数量
|
||||
|
||||

|
||||
|
||||
### 关注(异步请求)
|
||||
|
||||
- 若 A 关注了 B,则 A 是 B 的粉丝 Follower,B 是 A 的目标 Followee
|
||||
- 关注的目标可以是用户、帖子、题目等,在实现时将这些目标抽象为实体(目前只做了关注用户)
|
||||
|
||||
将某个用户关注的实体相关信息存储在 Redis 的数据结构 zset 中:key 是 `followee:userId:entityType` ,对应的 value 是 `zset(entityId, now)` ,以关注的时间进行排序。比如说 `followee:111:3` 对应的value `(20, 2020-02-03-xxxx)`,表明用户 111 关注了实体类型为 3 即人(用户),该帖子的 id 是 20,关注该帖子的时间是 2020-02-03-xxxx
|
||||
|
||||
同样的,将某个实体拥有的粉丝相关信息也存储在 Redis 的数据结构 zset 中:key 是 `follower:entityType:entityId`,对应的 value 是 `zset(userId, now)`,以关注的时间进行排序
|
||||
|
||||

|
||||
|
||||
### 关注列表
|
||||
|
||||

|
||||
|
||||
### 发送系统通知
|
||||
|
||||

|
||||
|
||||
### 显示系统通知
|
||||
|
||||

|
||||
|
||||
### 搜索
|
||||
|
||||

|
||||
|
||||
类似的,置顶、加精也会触发发帖事件,就不再图里面画出来了。
|
||||
|
||||
### 置顶加精删除(异步请求)
|
||||
|
||||

|
||||
|
||||
### 网站数据统计
|
||||
|
||||

|
||||
|
||||
### 帖子热度计算
|
||||
|
||||
每次发生点赞(给帖子点赞)、评论(给帖子评论)、加精的时候,就将这些帖子信息存入缓存 Redis 中,然后通过分布式的定时任务 Spring Quartz,每隔一段时间就从缓存中取出这些帖子进行计算分数。
|
||||
|
||||
帖子分数/热度计算公式:分数(热度) = 权重 + 发帖距离天数
|
||||
|
||||
```java
|
||||
// 计算权重
|
||||
double w = (wonderful ? 75 : 0) + commentCount * 10 + likeCount * 2;
|
||||
// 分数 = 权重 + 发帖距离天数
|
||||
double score = Math.log10(Math.max(w, 1))
|
||||
+ (post.getCreateTime().getTime() - epoch.getTime()) / (1000 * 3600 * 24);
|
||||
```
|
||||
|
||||

|
||||
|
||||
## 📖 配套教程
|
||||
|
||||
想要自己从零开始实现这个项目或者深入理解的小伙伴,可以扫描下方二维码关注公众号『**飞天小牛肉**』,第一时间获取配套教程, 不仅会详细解释本项目涉及的各大技术点,还会汇总相关的常见面试题,目前尚在更新中。
|
||||
|
||||
<img src="https://gitee.com/veal98/images/raw/master/img/20210204145531.png" style="zoom:67%;" />
|
||||
|
||||
## 📞 联系我
|
||||
|
||||
有什么问题也可以添加我的微信,记得备注来意:格式 <u>(学校或公司 - 姓名或昵称 - 来意)</u>
|
||||
|
||||
<img width="260px" src="https://gitee.com/veal98/images/raw/master/img/微信图片_20210105121328.jpg" >
|
||||
|
||||
## 👏 鸣谢
|
||||
|
||||
本项目参考[牛客网](https://www.nowcoder.com/) — Java 高级工程师课程,感谢老师和平台
|
21
docs/index.html
Normal file
21
docs/index.html
Normal file
@ -0,0 +1,21 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="UTF-8">
|
||||
<title>Document</title>
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1" />
|
||||
<meta name="description" content="Description">
|
||||
<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
|
||||
<link rel="stylesheet" href="//cdn.jsdelivr.net/npm/docsify/lib/themes/vue.css">
|
||||
</head>
|
||||
<body>
|
||||
<div id="app"></div>
|
||||
<script>
|
||||
window.$docsify = {
|
||||
name: '',
|
||||
repo: ''
|
||||
}
|
||||
</script>
|
||||
<script src="//cdn.jsdelivr.net/npm/docsify/lib/docsify.min.js"></script>
|
||||
</body>
|
||||
</html>
|
15
node_modules/.bin/acorn
generated
vendored
15
node_modules/.bin/acorn
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../acorn/bin/acorn" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../acorn/bin/acorn" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/acorn.cmd
generated
vendored
17
node_modules/.bin/acorn.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\acorn\bin\acorn" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/acorn.ps1
generated
vendored
18
node_modules/.bin/acorn.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../acorn/bin/acorn" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../acorn/bin/acorn" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/ansi-html
generated
vendored
15
node_modules/.bin/ansi-html
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../ansi-html/bin/ansi-html" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../ansi-html/bin/ansi-html" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/ansi-html.cmd
generated
vendored
17
node_modules/.bin/ansi-html.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\ansi-html\bin\ansi-html" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/ansi-html.ps1
generated
vendored
18
node_modules/.bin/ansi-html.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../ansi-html/bin/ansi-html" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../ansi-html/bin/ansi-html" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/atob
generated
vendored
15
node_modules/.bin/atob
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../atob/bin/atob.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../atob/bin/atob.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/atob.cmd
generated
vendored
17
node_modules/.bin/atob.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\atob\bin\atob.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/atob.ps1
generated
vendored
18
node_modules/.bin/atob.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../atob/bin/atob.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../atob/bin/atob.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/autoprefixer
generated
vendored
15
node_modules/.bin/autoprefixer
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../autoprefixer/bin/autoprefixer" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../autoprefixer/bin/autoprefixer" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/autoprefixer.cmd
generated
vendored
17
node_modules/.bin/autoprefixer.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\autoprefixer\bin\autoprefixer" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/autoprefixer.ps1
generated
vendored
18
node_modules/.bin/autoprefixer.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../autoprefixer/bin/autoprefixer" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../autoprefixer/bin/autoprefixer" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/browserslist
generated
vendored
15
node_modules/.bin/browserslist
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../browserslist/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../browserslist/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/browserslist.cmd
generated
vendored
17
node_modules/.bin/browserslist.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\browserslist\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/browserslist.ps1
generated
vendored
18
node_modules/.bin/browserslist.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../browserslist/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../browserslist/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/cssesc
generated
vendored
15
node_modules/.bin/cssesc
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../cssesc/bin/cssesc" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../cssesc/bin/cssesc" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/cssesc.cmd
generated
vendored
17
node_modules/.bin/cssesc.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\cssesc\bin\cssesc" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/cssesc.ps1
generated
vendored
18
node_modules/.bin/cssesc.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../cssesc/bin/cssesc" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../cssesc/bin/cssesc" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/envify
generated
vendored
15
node_modules/.bin/envify
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../envify/bin/envify" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../envify/bin/envify" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/envify.cmd
generated
vendored
17
node_modules/.bin/envify.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\envify\bin\envify" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/envify.ps1
generated
vendored
18
node_modules/.bin/envify.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../envify/bin/envify" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../envify/bin/envify" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/envinfo
generated
vendored
15
node_modules/.bin/envinfo
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../envinfo/dist/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../envinfo/dist/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/envinfo.cmd
generated
vendored
17
node_modules/.bin/envinfo.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\envinfo\dist\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/envinfo.ps1
generated
vendored
18
node_modules/.bin/envinfo.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../envinfo/dist/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../envinfo/dist/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/errno
generated
vendored
15
node_modules/.bin/errno
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../errno/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../errno/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/errno.cmd
generated
vendored
17
node_modules/.bin/errno.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\errno\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/errno.ps1
generated
vendored
18
node_modules/.bin/errno.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../errno/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../errno/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/esparse
generated
vendored
15
node_modules/.bin/esparse
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../esprima/bin/esparse.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../esprima/bin/esparse.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/esparse.cmd
generated
vendored
17
node_modules/.bin/esparse.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\esprima\bin\esparse.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/esparse.ps1
generated
vendored
18
node_modules/.bin/esparse.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../esprima/bin/esparse.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../esprima/bin/esparse.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/esvalidate
generated
vendored
15
node_modules/.bin/esvalidate
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../esprima/bin/esvalidate.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../esprima/bin/esvalidate.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/esvalidate.cmd
generated
vendored
17
node_modules/.bin/esvalidate.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\esprima\bin\esvalidate.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/esvalidate.ps1
generated
vendored
18
node_modules/.bin/esvalidate.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../esprima/bin/esvalidate.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../esprima/bin/esvalidate.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/he
generated
vendored
15
node_modules/.bin/he
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../he/bin/he" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../he/bin/he" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/he.cmd
generated
vendored
17
node_modules/.bin/he.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\he\bin\he" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/he.ps1
generated
vendored
18
node_modules/.bin/he.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../he/bin/he" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../he/bin/he" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/html-minifier
generated
vendored
15
node_modules/.bin/html-minifier
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../html-minifier/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../html-minifier/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/html-minifier.cmd
generated
vendored
17
node_modules/.bin/html-minifier.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\html-minifier\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/html-minifier.ps1
generated
vendored
18
node_modules/.bin/html-minifier.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../html-minifier/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../html-minifier/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/hulk
generated
vendored
15
node_modules/.bin/hulk
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../hogan.js/bin/hulk" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../hogan.js/bin/hulk" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/hulk.cmd
generated
vendored
17
node_modules/.bin/hulk.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\hogan.js\bin\hulk" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/hulk.ps1
generated
vendored
18
node_modules/.bin/hulk.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../hogan.js/bin/hulk" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../hogan.js/bin/hulk" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/import-local-fixture
generated
vendored
15
node_modules/.bin/import-local-fixture
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../import-local/fixtures/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../import-local/fixtures/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/import-local-fixture.cmd
generated
vendored
17
node_modules/.bin/import-local-fixture.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\import-local\fixtures\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/import-local-fixture.ps1
generated
vendored
18
node_modules/.bin/import-local-fixture.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../import-local/fixtures/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../import-local/fixtures/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/is-ci
generated
vendored
15
node_modules/.bin/is-ci
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../is-ci/bin.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../is-ci/bin.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/is-ci.cmd
generated
vendored
17
node_modules/.bin/is-ci.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\is-ci\bin.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/is-ci.ps1
generated
vendored
18
node_modules/.bin/is-ci.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../is-ci/bin.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../is-ci/bin.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/js-yaml
generated
vendored
15
node_modules/.bin/js-yaml
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../js-yaml/bin/js-yaml.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../js-yaml/bin/js-yaml.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/js-yaml.cmd
generated
vendored
17
node_modules/.bin/js-yaml.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\js-yaml\bin\js-yaml.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/js-yaml.ps1
generated
vendored
18
node_modules/.bin/js-yaml.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../js-yaml/bin/js-yaml.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../js-yaml/bin/js-yaml.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/jsesc
generated
vendored
15
node_modules/.bin/jsesc
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../jsesc/bin/jsesc" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../jsesc/bin/jsesc" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/jsesc.cmd
generated
vendored
17
node_modules/.bin/jsesc.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\jsesc\bin\jsesc" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/jsesc.ps1
generated
vendored
18
node_modules/.bin/jsesc.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../jsesc/bin/jsesc" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../jsesc/bin/jsesc" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/json5
generated
vendored
15
node_modules/.bin/json5
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../json5/lib/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../json5/lib/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/json5.cmd
generated
vendored
17
node_modules/.bin/json5.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\json5\lib\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/json5.ps1
generated
vendored
18
node_modules/.bin/json5.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../json5/lib/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../json5/lib/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/markdown-it
generated
vendored
15
node_modules/.bin/markdown-it
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../markdown-it/bin/markdown-it.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../markdown-it/bin/markdown-it.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/markdown-it.cmd
generated
vendored
17
node_modules/.bin/markdown-it.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\markdown-it\bin\markdown-it.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/markdown-it.ps1
generated
vendored
18
node_modules/.bin/markdown-it.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../markdown-it/bin/markdown-it.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../markdown-it/bin/markdown-it.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/miller-rabin
generated
vendored
15
node_modules/.bin/miller-rabin
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../miller-rabin/bin/miller-rabin" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../miller-rabin/bin/miller-rabin" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/miller-rabin.cmd
generated
vendored
17
node_modules/.bin/miller-rabin.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\miller-rabin\bin\miller-rabin" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/miller-rabin.ps1
generated
vendored
18
node_modules/.bin/miller-rabin.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../miller-rabin/bin/miller-rabin" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../miller-rabin/bin/miller-rabin" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/mime
generated
vendored
15
node_modules/.bin/mime
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../mime/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../mime/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/mime.cmd
generated
vendored
17
node_modules/.bin/mime.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\mime\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/mime.ps1
generated
vendored
18
node_modules/.bin/mime.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../mime/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../mime/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/mkdirp
generated
vendored
15
node_modules/.bin/mkdirp
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../mkdirp/bin/cmd.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../mkdirp/bin/cmd.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/mkdirp.cmd
generated
vendored
17
node_modules/.bin/mkdirp.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\mkdirp\bin\cmd.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/mkdirp.ps1
generated
vendored
18
node_modules/.bin/mkdirp.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../mkdirp/bin/cmd.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../mkdirp/bin/cmd.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/multicast-dns
generated
vendored
15
node_modules/.bin/multicast-dns
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../multicast-dns/cli.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../multicast-dns/cli.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/multicast-dns.cmd
generated
vendored
17
node_modules/.bin/multicast-dns.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\multicast-dns\cli.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/multicast-dns.ps1
generated
vendored
18
node_modules/.bin/multicast-dns.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../multicast-dns/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../multicast-dns/cli.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/nopt
generated
vendored
15
node_modules/.bin/nopt
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../nopt/bin/nopt.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../nopt/bin/nopt.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/nopt.cmd
generated
vendored
17
node_modules/.bin/nopt.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\nopt\bin\nopt.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/nopt.ps1
generated
vendored
18
node_modules/.bin/nopt.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../nopt/bin/nopt.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../nopt/bin/nopt.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/opencollective-postinstall
generated
vendored
15
node_modules/.bin/opencollective-postinstall
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../opencollective-postinstall/index.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../opencollective-postinstall/index.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/opencollective-postinstall.cmd
generated
vendored
17
node_modules/.bin/opencollective-postinstall.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\opencollective-postinstall\index.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/opencollective-postinstall.ps1
generated
vendored
18
node_modules/.bin/opencollective-postinstall.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../opencollective-postinstall/index.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../opencollective-postinstall/index.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/parser
generated
vendored
15
node_modules/.bin/parser
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../@babel/parser/bin/babel-parser.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../@babel/parser/bin/babel-parser.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/parser.cmd
generated
vendored
17
node_modules/.bin/parser.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\@babel\parser\bin\babel-parser.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/parser.ps1
generated
vendored
18
node_modules/.bin/parser.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../@babel/parser/bin/babel-parser.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../@babel/parser/bin/babel-parser.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
15
node_modules/.bin/prettier
generated
vendored
15
node_modules/.bin/prettier
generated
vendored
@ -1,15 +0,0 @@
|
||||
#!/bin/sh
|
||||
basedir=$(dirname "$(echo "$0" | sed -e 's,\\,/,g')")
|
||||
|
||||
case `uname` in
|
||||
*CYGWIN*|*MINGW*|*MSYS*) basedir=`cygpath -w "$basedir"`;;
|
||||
esac
|
||||
|
||||
if [ -x "$basedir/node" ]; then
|
||||
"$basedir/node" "$basedir/../prettier/bin-prettier.js" "$@"
|
||||
ret=$?
|
||||
else
|
||||
node "$basedir/../prettier/bin-prettier.js" "$@"
|
||||
ret=$?
|
||||
fi
|
||||
exit $ret
|
17
node_modules/.bin/prettier.cmd
generated
vendored
17
node_modules/.bin/prettier.cmd
generated
vendored
@ -1,17 +0,0 @@
|
||||
@ECHO off
|
||||
SETLOCAL
|
||||
CALL :find_dp0
|
||||
|
||||
IF EXIST "%dp0%\node.exe" (
|
||||
SET "_prog=%dp0%\node.exe"
|
||||
) ELSE (
|
||||
SET "_prog=node"
|
||||
SET PATHEXT=%PATHEXT:;.JS;=;%
|
||||
)
|
||||
|
||||
"%_prog%" "%dp0%\..\prettier\bin-prettier.js" %*
|
||||
ENDLOCAL
|
||||
EXIT /b %errorlevel%
|
||||
:find_dp0
|
||||
SET dp0=%~dp0
|
||||
EXIT /b
|
18
node_modules/.bin/prettier.ps1
generated
vendored
18
node_modules/.bin/prettier.ps1
generated
vendored
@ -1,18 +0,0 @@
|
||||
#!/usr/bin/env pwsh
|
||||
$basedir=Split-Path $MyInvocation.MyCommand.Definition -Parent
|
||||
|
||||
$exe=""
|
||||
if ($PSVersionTable.PSVersion -lt "6.0" -or $IsWindows) {
|
||||
# Fix case when both the Windows and Linux builds of Node
|
||||
# are installed in the same directory
|
||||
$exe=".exe"
|
||||
}
|
||||
$ret=0
|
||||
if (Test-Path "$basedir/node$exe") {
|
||||
& "$basedir/node$exe" "$basedir/../prettier/bin-prettier.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
} else {
|
||||
& "node$exe" "$basedir/../prettier/bin-prettier.js" $args
|
||||
$ret=$LASTEXITCODE
|
||||
}
|
||||
exit $ret
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
x
Reference in New Issue
Block a user