Golang实现的基于beego框架的接口在线文档管理系统
 
 
 
Go to file
玖亖伍 2dcffaf1fe
Update Dockerfile
修改calibre下载地址
2021-07-06 15:23:40 +08:00
.github Revert "Create go.yml" 2021-02-26 16:13:13 +08:00
cache fix(document): fail to count times when cache is enabled. 2021-04-25 16:05:05 +08:00
commands Merge pull request #694 from gsw945/master 2021-06-29 14:33:25 +08:00
conf update for init i18n 2021-04-21 22:00:03 +08:00
controllers Merge pull request #680 from shiqstone/master 2021-04-30 13:48:46 +08:00
converter chore!(all): update go import path 2021-03-23 15:09:17 +08:00
graphics 1、实现富文本编辑器 2018-01-26 17:17:38 +08:00
lib/time 集成时区包 2017-05-09 10:18:10 +08:00
mail chore: use core/logs 2021-03-26 14:26:19 +08:00
models fix(document): fail to count times when cache is enabled. 2021-04-25 16:05:05 +08:00
routers fix(all): don't use adapter in FuncMap and Filter etc. 2021-03-26 15:37:19 +08:00
static update for init i18n 2021-04-21 22:00:03 +08:00
uploads refactor:重构错误页,优化编辑器,上传新效果图 2018-08-17 18:05:04 +08:00
utils fix bug for i18n and beego v2 2021-04-21 20:44:19 +08:00
views fix bug for i18n and beego v2 2021-04-21 20:44:19 +08:00
.gitattributes perf:增加右键提示 2018-11-14 16:31:32 +08:00
.gitignore fix(login): judging ldap_enable logic error 2021-03-30 11:45:56 +08:00
.travis.yml chore(CI): update minimum go version to 1.13 for travis 2021-04-01 16:48:22 +08:00
Dockerfile Update Dockerfile 2021-07-06 15:23:40 +08:00
LICENSE.md Create LICENSE.md 2017-06-14 09:18:07 +08:00
README.md Update README.md 2021-06-30 16:25:30 +08:00
appveyor.yml Update appveyor.yml 2021-04-06 13:30:47 +08:00
docker-compose.yml Update docker-compose.yml 2019-01-11 14:19:29 +08:00
favicon.ico 添加favicon 2017-05-03 14:32:18 +08:00
go.mod merge from mindoc-org/mindoc and resolved conflict 2021-04-21 20:40:54 +08:00
go.sum fix bug for i18n and beego v2 2021-04-21 20:44:19 +08:00
main.go chore!(all): attempt to update beego to v2 2021-03-23 21:55:50 +08:00
simsun.ttc 增加中文字体 2018-07-18 17:53:49 +08:00
start.sh Docker镜像优化 2021-07-06 15:19:55 +08:00

README.md

MinDoc 简介

Build Status Build status

MinDoc 是一款针对IT团队开发的简单好用的文档管理系统。

MinDoc 的前身是 SmartWiki 文档系统。SmartWiki 是基于 PHP 框架 laravel 开发的一款文档管理系统。因 PHP 的部署对普通用户来说太复杂,所以改用 Golang 开发。可以方便用户部署和实用。

开发缘起是公司IT部门需要一款简单实用的项目接口文档管理和分享的系统。其功能和界面源于 kancloud 。

可以用来储存日常接口文档,数据库字典,手册说明等文档。内置项目管理,用户管理,权限管理等功能,能够满足大部分中小团队的文档管理需求。

演示站点:

开发&维护&使用 悉知

感谢作者 lifei6671 创造了MinDoc并持续维护了很久。

作者因工作等原因精力有限无法花费足够的时间来持续维护mindoc已于北京时间2021年3月23日将mindoc交给社区(github组织mindoc-org)维护,期待热心开发者加入mindoc-org一起来维护MinDoc。

遇到问题请提 Issues欢迎使用者和贡献者加入QQ群 1051164153 MinDoc使用&开发交流群

对开发感兴趣请关注 Development:


安装与使用

如果你的服务器上没有安装golang程序请手动设置一个环境变量如下键名为 ZONEINFO值为MinDoc跟目录下的/lib/time/zoneinfo.zip 。

更多信息请查看手册: MinDoc 使用手册

对于没有Golang使用经验的用户可以从 https://github.com/mindoc-org/mindoc/releases 这里下载编译完的程序。

如果有Golang开发经验建议通过编译安装要求golang版本不小于1.13(需支持CGOgo mod)。

# 克隆源码
git clone https://github.com/mindoc-org/mindoc.git
# go包安装
go mod tidy
# 编译(sqlite需要CGO支持)
go build -ldflags "-w"
# 数据库初始化(此步骤执行之前,需配置`conf/app.conf`)
./mindoc install
# 执行
./mindoc

MinDoc 如果使用MySQL储存数据则编码必须是utf8mb4_general_ci。请在安装前,把数据库配置填充到项目目录下的 conf/app.conf 中。

如果使用 SQLite 数据库,则直接在配置文件中配置数据库路径即可.

如果conf目录下不存在 app.conf 请重命名 app.conf.exampleapp.conf

默认程序会自动初始化一个超级管理员用户admin 密码123456 。请登录后重新设置密码。


#邮件配置-示例
#是否启用邮件
enable_mail=true
#smtp服务器的账号
smtp_user_name=admin@iminho.me
#smtp服务器的地址
smtp_host=smtp.ym.163.com
#密码
smtp_password=1q2w3e__ABC
#端口号
smtp_port=25
#邮件发送人的地址
form_user_name=admin@iminho.me
#邮件有效期30分钟
mail_expired=30

使用Docker部署

如果是Docker用户可参考项目内置的Dockerfile文件自行编译镜像(编译命令见Dockerfile文件底部注释仅供参考)。

在启动镜像时需要提供如下的常用环境变量(全部支持的环境变量请参考: conf/app.conf.example)

DB_ADAPTER                  指定DB类型(默认为sqlite)
MYSQL_PORT_3306_TCP_ADDR    MySQL地址
MYSQL_PORT_3306_TCP_PORT    MySQL端口号
MYSQL_INSTANCE_NAME         MySQL数据库名称
MYSQL_USERNAME              MySQL账号
MYSQL_PASSWORD              MySQL密码
HTTP_PORT                   程序监听的端口号
MINDOC_ENABLE_EXPORT        开启导出(默认为false)

举个栗子-当前(公开)镜像(信息页面: https://cr.console.aliyun.com/images/cn-hangzhou/mindoc-org/mindoc/detail)

docker run -it --name=mindoc --restart=always -v /mindoc:/mindoc -p 8181:8181 -e MINDOC_ENABLE_EXPORT=true -d registry.cn-hangzhou.aliyuncs.com/mindoc-org/mindoc:v2.1-beta.1

举个栗子-更多环境变量示例(镜像已过期,仅供参考,请以当前镜像为准)

docker run -p 8181:8181 --name mindoc -e DB_ADAPTER=mysql -e MYSQL_PORT_3306_TCP_ADDR=10.xxx.xxx.xxx -e MYSQL_PORT_3306_TCP_PORT=3306 -e MYSQL_INSTANCE_NAME=mindoc -e MYSQL_USERNAME=root -e MYSQL_PASSWORD=123456 -e httpport=8181 -d daocloud.io/lifei6671/mindoc:latest

docker-compose 一键安装

  1. 修改配置文件 修改docker-compose.yml中的配置信息,主要修改volumes节点,将宿主机的两个目录映射到容器内。 environment节点,配置自己的环境变量。

  2. 一键完成所有环境搭建

    docker-compose up -d

  3. 浏览器访问

    http://localhost:8181/

    整个部署完成了

  4. 常用命令参考

    • 启动

      docker-compose up -d

    • 停止

      docker-compose stop

    • 重启

      docker-compose restart

    • 停止删除容器,释放所有资源

      docker-compose down

    • 删除并重新创建

      docker-compose -f docker-compose.yml down && docker-compose up -d

      更多 docker-compose 的使用相关的内容 请查看官网文档或百度

项目截图

创建项目

创建项目

项目列表

项目列表

项目概述

项目概述

项目成员

项目成员

项目设置

项目设置

基于Editor.md开发的Markdown编辑器

基于Editor.md开发的Markdown编辑器

基于wangEditor开发的富文本编辑器

基于wangEditor开发的富文本编辑器

项目预览

项目预览

超级管理员后台

超级管理员后台

使用的技术(TODO: 最新技术栈整理中,使用的第三方库升级中)

主要功能

  • 项目管理,可以对项目进行编辑更改,成员添加等。
  • 文档管理,添加和删除文档等。
  • 评论管理,可以管理文档评论和自己发布的评论。
  • 用户管理,添加和禁用用户,个人资料更改等。
  • 用户权限管理 实现用户角色的变更。
  • 项目加密可以设置项目公开状态私有项目需要通过Token访问。
  • 站点配置,可开启匿名访问、验证码等。

参与开发

我们欢迎您在 MinDoc 项目的 GitHub 上报告 issue 或者 pull request。

如果您还不熟悉GitHub的Fork and Pull开发模式您可以阅读GitHub的文档https://help.github.com/articles/using-pull-requests 获得更多的信息。

关于作者lifei6671

一个不纯粹的PHPer一个不自由的 gopher 。

支持 MinDoc

支付宝 微信支付