ManagerController.go 28 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161
  1. package controllers
  2. import (
  3. "encoding/json"
  4. "html/template"
  5. "regexp"
  6. "strings"
  7. "math"
  8. "path/filepath"
  9. "strconv"
  10. "io/ioutil"
  11. "os"
  12. "github.com/beego/beego/v2/client/orm"
  13. "github.com/beego/beego/v2/core/logs"
  14. "github.com/beego/beego/v2/server/web"
  15. "github.com/beego/i18n"
  16. "github.com/mindoc-org/mindoc/conf"
  17. "github.com/mindoc-org/mindoc/models"
  18. "github.com/mindoc-org/mindoc/utils"
  19. "github.com/mindoc-org/mindoc/utils/filetil"
  20. "github.com/mindoc-org/mindoc/utils/pagination"
  21. "github.com/russross/blackfriday/v2"
  22. )
  23. type ManagerController struct {
  24. BaseController
  25. }
  26. func (c *ManagerController) Prepare() {
  27. c.BaseController.Prepare()
  28. if !c.Member.IsAdministrator() {
  29. c.Abort("403")
  30. }
  31. }
  32. func (c *ManagerController) Index() {
  33. c.TplName = "manager/index.tpl"
  34. c.Data["Model"] = models.NewDashboard().Query()
  35. c.Data["Action"] = "index"
  36. }
  37. // 用户列表.
  38. func (c *ManagerController) Users() {
  39. c.Prepare()
  40. c.TplName = "manager/users.tpl"
  41. c.Data["Action"] = "users"
  42. pageIndex, _ := c.GetInt("page", 0)
  43. members, totalCount, err := models.NewMember().FindToPager(pageIndex, conf.PageSize)
  44. if err != nil {
  45. c.Data["ErrorMessage"] = err.Error()
  46. return
  47. }
  48. if totalCount > 0 {
  49. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  50. c.Data["PageHtml"] = pager.HtmlPages()
  51. for _, item := range members {
  52. item.Avatar = conf.URLForWithCdnImage(item.Avatar)
  53. }
  54. } else {
  55. c.Data["PageHtml"] = ""
  56. }
  57. b, err := json.Marshal(members)
  58. if err != nil {
  59. c.Data["Result"] = template.JS("[]")
  60. } else {
  61. c.Data["Result"] = template.JS(string(b))
  62. }
  63. }
  64. // 添加用户.
  65. func (c *ManagerController) CreateMember() {
  66. c.Prepare()
  67. account := strings.TrimSpace(c.GetString("account"))
  68. password1 := strings.TrimSpace(c.GetString("password1"))
  69. password2 := strings.TrimSpace(c.GetString("password2"))
  70. email := strings.TrimSpace(c.GetString("email"))
  71. phone := strings.TrimSpace(c.GetString("phone"))
  72. role, _ := c.GetInt("role", 1)
  73. status, _ := c.GetInt("status", 0)
  74. if ok, err := regexp.MatchString(conf.RegexpAccount, account); account == "" || !ok || err != nil {
  75. c.JsonResult(6001, i18n.Tr(c.Lang, "message.username_invalid_format"))
  76. }
  77. if l := strings.Count(password1, ""); password1 == "" || l > 50 || l < 6 {
  78. c.JsonResult(6002, i18n.Tr(c.Lang, "message.pwd_length_tips"))
  79. }
  80. if password1 != password2 {
  81. c.JsonResult(6003, i18n.Tr(c.Lang, "message.wrong_confirm_pwd"))
  82. }
  83. if ok, err := regexp.MatchString(conf.RegexpEmail, email); !ok || err != nil || email == "" {
  84. c.JsonResult(6004, i18n.Tr(c.Lang, "message.email_invalid_format"))
  85. }
  86. if role != 0 && role != 1 && role != 2 {
  87. role = 1
  88. }
  89. if status != 0 && status != 1 {
  90. status = 0
  91. }
  92. member := models.NewMember()
  93. if _, err := member.FindByAccount(account); err == nil && member.MemberId > 0 {
  94. c.JsonResult(6005, i18n.Tr(c.Lang, "message.account_existed"))
  95. }
  96. member.Account = account
  97. member.Password = password1
  98. member.Role = conf.SystemRole(role)
  99. member.Avatar = conf.GetDefaultAvatar()
  100. member.CreateAt = c.Member.MemberId
  101. member.Email = email
  102. member.RealName = strings.TrimSpace(c.GetString("real_name", ""))
  103. if phone != "" {
  104. member.Phone = phone
  105. }
  106. if err := member.Add(); err != nil {
  107. c.JsonResult(6006, err.Error())
  108. }
  109. c.JsonResult(0, "ok", member)
  110. }
  111. //更新用户状态.
  112. func (c *ManagerController) UpdateMemberStatus() {
  113. c.Prepare()
  114. member_id, _ := c.GetInt("member_id", 0)
  115. status, _ := c.GetInt("status", 0)
  116. if member_id <= 0 {
  117. c.JsonResult(6001, i18n.Tr(c.Lang, "message.param_error"))
  118. }
  119. if status != 0 && status != 1 {
  120. status = 0
  121. }
  122. member := models.NewMember()
  123. if _, err := member.Find(member_id); err != nil {
  124. c.JsonResult(6002, i18n.Tr(c.Lang, "message.user_not_existed"))
  125. }
  126. if member.MemberId == c.Member.MemberId {
  127. c.JsonResult(6004, i18n.Tr(c.Lang, "message.cannot_change_own_status"))
  128. }
  129. if member.Role == conf.MemberSuperRole {
  130. c.JsonResult(6005, i18n.Tr(c.Lang, "message.cannot_change_super_status"))
  131. }
  132. member.Status = status
  133. if err := member.Update(); err != nil {
  134. logs.Error("", err)
  135. c.JsonResult(6003, i18n.Tr(c.Lang, "message.failed"))
  136. }
  137. c.JsonResult(0, "ok", member)
  138. }
  139. //变更用户权限.
  140. func (c *ManagerController) ChangeMemberRole() {
  141. c.Prepare()
  142. memberId, _ := c.GetInt("member_id", 0)
  143. role, _ := c.GetInt("role", 0)
  144. if memberId <= 0 {
  145. c.JsonResult(6001, i18n.Tr(c.Lang, "message.param_error"))
  146. }
  147. if role != int(conf.MemberAdminRole) && role != int(conf.MemberGeneralRole) {
  148. c.JsonResult(6001, i18n.Tr(c.Lang, "message.no_permission"))
  149. }
  150. member := models.NewMember()
  151. if _, err := member.Find(memberId); err != nil {
  152. c.JsonResult(6002, i18n.Tr(c.Lang, "message.user_not_existed"))
  153. }
  154. if member.MemberId == c.Member.MemberId {
  155. c.JsonResult(6004, i18n.Tr(c.Lang, "message.cannot_change_own_priv"))
  156. }
  157. if member.Role == conf.MemberSuperRole {
  158. c.JsonResult(6005, i18n.Tr(c.Lang, "message.cannot_change_super_priv"))
  159. }
  160. member.Role = conf.SystemRole(role)
  161. if err := member.Update(); err != nil {
  162. c.JsonResult(6003, i18n.Tr(c.Lang, "message.failed"))
  163. }
  164. member.Lang = c.Lang
  165. member.ResolveRoleName()
  166. c.JsonResult(0, "ok", member)
  167. }
  168. //编辑用户信息.
  169. func (c *ManagerController) EditMember() {
  170. c.Prepare()
  171. c.TplName = "manager/edit_users.tpl"
  172. c.Data["Action"] = "users"
  173. member_id, _ := c.GetInt(":id", 0)
  174. if member_id <= 0 {
  175. c.Abort("404")
  176. }
  177. member, err := models.NewMember().Find(member_id)
  178. if err != nil {
  179. logs.Error(err)
  180. c.Abort("404")
  181. }
  182. if c.Ctx.Input.IsPost() {
  183. password1 := c.GetString("password1")
  184. password2 := c.GetString("password2")
  185. email := c.GetString("email")
  186. phone := c.GetString("phone")
  187. description := c.GetString("description")
  188. member.Email = email
  189. member.Phone = phone
  190. member.Description = description
  191. member.RealName = c.GetString("real_name")
  192. if password1 != "" && password2 != password1 {
  193. c.JsonResult(6001, i18n.Tr(c.Lang, "message.wrong_confirm_pwd"))
  194. }
  195. if password1 != "" && member.AuthMethod != conf.AuthMethodLDAP {
  196. member.Password = password1
  197. }
  198. if err := member.Valid(password1 == ""); err != nil {
  199. c.JsonResult(6002, err.Error())
  200. }
  201. if password1 != "" {
  202. password, err := utils.PasswordHash(password1)
  203. if err != nil {
  204. logs.Error(err)
  205. c.JsonResult(6003, i18n.Tr(c.Lang, "message.pwd_encrypt_failed"))
  206. }
  207. member.Password = password
  208. }
  209. if err := member.Update(); err != nil {
  210. c.JsonResult(6004, err.Error())
  211. }
  212. c.JsonResult(0, "ok")
  213. }
  214. c.Data["Model"] = member
  215. }
  216. //删除一个用户,并将该用户的所有信息转移到超级管理员上.
  217. func (c *ManagerController) DeleteMember() {
  218. c.Prepare()
  219. member_id, _ := c.GetInt("id", 0)
  220. if member_id <= 0 {
  221. c.JsonResult(404, i18n.Tr(c.Lang, "message.param_error"))
  222. }
  223. member, err := models.NewMember().Find(member_id)
  224. if err != nil {
  225. logs.Error(err)
  226. c.JsonResult(500, i18n.Tr(c.Lang, "message.user_not_existed"))
  227. }
  228. if member.Role == conf.MemberSuperRole {
  229. c.JsonResult(500, "不能删除超级管理员")
  230. }
  231. superMember, err := models.NewMember().FindByFieldFirst("role", 0)
  232. if err != nil {
  233. logs.Error(err)
  234. c.JsonResult(5001, "未能找到超级管理员")
  235. }
  236. err = models.NewMember().Delete(member_id, superMember.MemberId)
  237. if err != nil {
  238. logs.Error(err)
  239. c.JsonResult(5002, i18n.Tr(c.Lang, "message.failed"))
  240. }
  241. c.JsonResult(0, "ok")
  242. }
  243. //项目列表.
  244. func (c *ManagerController) Books() {
  245. c.Prepare()
  246. c.TplName = "manager/books.tpl"
  247. c.Data["Action"] = "books"
  248. pageIndex, _ := c.GetInt("page", 1)
  249. books, totalCount, err := models.NewBookResult().FindToPager(pageIndex, conf.PageSize)
  250. if err != nil {
  251. c.Abort("500")
  252. }
  253. if totalCount > 0 {
  254. //html := utils.GetPagerHtml(c.Ctx.Request.RequestURI, pageIndex, 8, totalCount)
  255. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  256. c.Data["PageHtml"] = pager.HtmlPages()
  257. } else {
  258. c.Data["PageHtml"] = ""
  259. }
  260. for i, book := range books {
  261. books[i].Description = utils.StripTags(string(blackfriday.Run([]byte(book.Description))))
  262. books[i].ModifyTime = book.ModifyTime.Local()
  263. books[i].CreateTime = book.CreateTime.Local()
  264. }
  265. c.Data["Lists"] = books
  266. }
  267. //编辑项目.
  268. func (c *ManagerController) EditBook() {
  269. c.Prepare()
  270. c.TplName = "manager/edit_book.tpl"
  271. c.Data["Action"] = "books"
  272. identify := c.GetString(":key")
  273. if identify == "" {
  274. c.Abort("404")
  275. }
  276. book, err := models.NewBook().FindByFieldFirst("identify", identify)
  277. if err != nil {
  278. c.Abort("500")
  279. }
  280. if c.Ctx.Input.IsPost() {
  281. bookName := strings.TrimSpace(c.GetString("book_name"))
  282. description := strings.TrimSpace(c.GetString("description", ""))
  283. commentStatus := c.GetString("comment_status")
  284. tag := strings.TrimSpace(c.GetString("label"))
  285. orderIndex, _ := c.GetInt("order_index", 0)
  286. isDownload := strings.TrimSpace(c.GetString("is_download")) == "on"
  287. enableShare := strings.TrimSpace(c.GetString("enable_share")) == "on"
  288. isUseFirstDocument := strings.TrimSpace(c.GetString("is_use_first_document")) == "on"
  289. autoRelease := strings.TrimSpace(c.GetString("auto_release")) == "on"
  290. publisher := strings.TrimSpace(c.GetString("publisher"))
  291. historyCount, _ := c.GetInt("history_count", 0)
  292. itemId, _ := c.GetInt("itemId")
  293. if strings.Count(description, "") > 500 {
  294. c.JsonResult(6004, i18n.Tr(c.Lang, "message.project_desc_tips"))
  295. }
  296. if commentStatus != "open" && commentStatus != "closed" && commentStatus != "group_only" && commentStatus != "registered_only" {
  297. commentStatus = "closed"
  298. }
  299. if tag != "" {
  300. tags := strings.Split(tag, ";")
  301. if len(tags) > 10 {
  302. c.JsonResult(6005, "最多允许添加10个标签")
  303. }
  304. }
  305. if !models.NewItemsets().Exist(itemId) {
  306. c.JsonResult(6006, i18n.Tr(c.Lang, "message.project_space_not_exist"))
  307. }
  308. book.Publisher = publisher
  309. book.HistoryCount = historyCount
  310. book.BookName = bookName
  311. book.Description = description
  312. book.CommentStatus = commentStatus
  313. book.Label = tag
  314. book.OrderIndex = orderIndex
  315. book.ItemId = itemId
  316. book.BookPassword = strings.TrimSpace(c.GetString("bPassword"))
  317. if autoRelease {
  318. book.AutoRelease = 1
  319. } else {
  320. book.AutoRelease = 0
  321. }
  322. if isDownload {
  323. book.IsDownload = 0
  324. } else {
  325. book.IsDownload = 1
  326. }
  327. if enableShare {
  328. book.IsEnableShare = 0
  329. } else {
  330. book.IsEnableShare = 1
  331. }
  332. if isUseFirstDocument {
  333. book.IsUseFirstDocument = 1
  334. } else {
  335. book.IsUseFirstDocument = 0
  336. }
  337. if err := book.Update(); err != nil {
  338. c.JsonResult(6006, i18n.Tr(c.Lang, "message.failed"))
  339. }
  340. c.JsonResult(0, "ok")
  341. }
  342. if book.PrivateToken != "" {
  343. book.PrivateToken = conf.URLFor("DocumentController.Index", ":key", book.Identify, "token", book.PrivateToken)
  344. }
  345. bookResult := models.NewBookResult()
  346. bookResult.ToBookResult(*book)
  347. c.Data["Model"] = bookResult
  348. }
  349. // 删除项目.
  350. func (c *ManagerController) DeleteBook() {
  351. c.Prepare()
  352. bookId, _ := c.GetInt("book_id", 0)
  353. if bookId <= 0 {
  354. c.JsonResult(6001, i18n.Tr(c.Lang, "message.param_error"))
  355. }
  356. book := models.NewBook()
  357. err := book.ThoroughDeleteBook(bookId)
  358. if err == orm.ErrNoRows {
  359. c.JsonResult(6002, i18n.Tr(c.Lang, "message.item_not_exist"))
  360. }
  361. if err != nil {
  362. logs.Error("删除失败 -> ", err)
  363. c.JsonResult(6003, i18n.Tr(c.Lang, "message.failed"))
  364. }
  365. c.JsonResult(0, "ok")
  366. }
  367. // CreateToken 创建访问来令牌.
  368. func (c *ManagerController) CreateToken() {
  369. c.Prepare()
  370. action := c.GetString("action")
  371. identify := c.GetString("identify")
  372. book, err := models.NewBook().FindByFieldFirst("identify", identify)
  373. if err != nil {
  374. c.JsonResult(6001, i18n.Tr(c.Lang, "message.item_not_exist"))
  375. }
  376. if action == "create" {
  377. if book.PrivatelyOwned == 0 {
  378. c.JsonResult(6001, "公开项目不能创建阅读令牌")
  379. }
  380. book.PrivateToken = string(utils.Krand(conf.GetTokenSize(), utils.KC_RAND_KIND_ALL))
  381. if err := book.Update(); err != nil {
  382. logs.Error("生成阅读令牌失败 => ", err)
  383. c.JsonResult(6003, i18n.Tr(c.Lang, "message.failed"))
  384. }
  385. c.JsonResult(0, "ok", conf.URLFor("DocumentController.Index", ":key", book.Identify, "token", book.PrivateToken))
  386. } else {
  387. book.PrivateToken = ""
  388. if err := book.Update(); err != nil {
  389. logs.Error("CreateToken => ", err)
  390. c.JsonResult(6004, i18n.Tr(c.Lang, "message.failed"))
  391. }
  392. c.JsonResult(0, "ok", "")
  393. }
  394. }
  395. //项目设置.
  396. func (c *ManagerController) Setting() {
  397. c.Prepare()
  398. c.TplName = "manager/setting.tpl"
  399. c.Data["Action"] = "setting"
  400. options, err := models.NewOption().All()
  401. if c.Ctx.Input.IsPost() {
  402. for _, item := range options {
  403. item.OptionValue = c.GetString(item.OptionName)
  404. item.InsertOrUpdate()
  405. }
  406. c.JsonResult(0, "ok")
  407. }
  408. if err != nil {
  409. c.Abort("500")
  410. }
  411. c.Data["SITE_TITLE"] = c.Option["SITE_NAME"]
  412. for _, item := range options {
  413. c.Data[item.OptionName] = item.OptionValue
  414. }
  415. }
  416. // Transfer 转让项目.
  417. func (c *ManagerController) Transfer() {
  418. c.Prepare()
  419. account := c.GetString("account")
  420. if account == "" {
  421. c.JsonResult(6004, i18n.Tr(c.Lang, "message.receive_account_empty"))
  422. }
  423. member, err := models.NewMember().FindByAccount(account)
  424. if err != nil {
  425. logs.Error("FindByAccount => ", err)
  426. c.JsonResult(6005, i18n.Tr(c.Lang, "message.receive_account_not_exist"))
  427. }
  428. if member.Status != 0 {
  429. c.JsonResult(6006, i18n.Tr(c.Lang, "message.receive_account_disabled"))
  430. }
  431. if !c.Member.IsAdministrator() {
  432. c.Abort("403")
  433. }
  434. identify := c.GetString("identify")
  435. book, err := models.NewBook().FindByFieldFirst("identify", identify)
  436. if err != nil {
  437. c.JsonResult(6001, err.Error())
  438. }
  439. rel, err := models.NewRelationship().FindFounder(book.BookId)
  440. if err != nil {
  441. logs.Error("FindFounder => ", err)
  442. c.JsonResult(6009, "查询项目创始人失败")
  443. }
  444. if member.MemberId == rel.MemberId {
  445. c.JsonResult(6007, "不能转让给自己")
  446. }
  447. err = models.NewRelationship().Transfer(book.BookId, rel.MemberId, member.MemberId)
  448. if err != nil {
  449. logs.Error("Transfer => ", err)
  450. c.JsonResult(6008, err.Error())
  451. }
  452. c.JsonResult(0, "ok")
  453. }
  454. func (c *ManagerController) Comments() {
  455. c.Prepare()
  456. c.TplName = "manager/comments.tpl"
  457. if !c.Member.IsAdministrator() {
  458. c.Abort("403")
  459. }
  460. }
  461. //DeleteComment 标记评论为已删除
  462. func (c *ManagerController) DeleteComment() {
  463. c.Prepare()
  464. comment_id, _ := c.GetInt("comment_id", 0)
  465. if comment_id <= 0 {
  466. c.JsonResult(6001, i18n.Tr(c.Lang, "message.param_error"))
  467. }
  468. comment := models.NewComment()
  469. if _, err := comment.Find(comment_id); err != nil {
  470. c.JsonResult(6002, "评论不存在")
  471. }
  472. comment.Approved = 3
  473. if err := comment.Update("approved"); err != nil {
  474. c.JsonResult(6003, "删除评论失败")
  475. }
  476. c.JsonResult(0, "ok", comment)
  477. }
  478. //设置项目私有状态.
  479. func (c *ManagerController) PrivatelyOwned() {
  480. c.Prepare()
  481. status := c.GetString("status")
  482. identify := c.GetString("identify")
  483. if status != "open" && status != "close" {
  484. c.JsonResult(6003, i18n.Tr(c.Lang, "message.param_error"))
  485. }
  486. state := 0
  487. if status == "open" {
  488. state = 0
  489. } else {
  490. state = 1
  491. }
  492. if !c.Member.IsAdministrator() {
  493. c.Abort("403")
  494. }
  495. book, err := models.NewBook().FindByFieldFirst("identify", identify)
  496. if err != nil {
  497. c.JsonResult(6001, err.Error())
  498. }
  499. book.PrivatelyOwned = state
  500. logs.Info("", state, status)
  501. err = book.Update()
  502. if err != nil {
  503. logs.Error("PrivatelyOwned => ", err)
  504. c.JsonResult(6004, i18n.Tr(c.Lang, "message.failed"))
  505. }
  506. c.JsonResult(0, "ok")
  507. }
  508. //附件列表.
  509. func (c *ManagerController) AttachList() {
  510. c.Prepare()
  511. c.TplName = "manager/attach_list.tpl"
  512. c.Data["Action"] = "attach"
  513. pageIndex, _ := c.GetInt("page", 1)
  514. attachList, totalCount, err := models.NewAttachment().FindToPager(pageIndex, conf.PageSize)
  515. if err != nil {
  516. c.Abort("500")
  517. }
  518. if totalCount > 0 {
  519. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  520. c.Data["PageHtml"] = pager.HtmlPages()
  521. } else {
  522. c.Data["PageHtml"] = ""
  523. }
  524. for _, item := range attachList {
  525. p := filepath.Join(conf.WorkingDirectory, item.FilePath)
  526. item.IsExist = filetil.FileExists(p)
  527. }
  528. c.Data["Lists"] = attachList
  529. }
  530. //附件详情.
  531. func (c *ManagerController) AttachDetailed() {
  532. c.Prepare()
  533. c.TplName = "manager/attach_detailed.tpl"
  534. c.Data["Action"] = "attach"
  535. attach_id, _ := strconv.Atoi(c.Ctx.Input.Param(":id"))
  536. if attach_id <= 0 {
  537. c.Abort("404")
  538. }
  539. attach, err := models.NewAttachmentResult().Find(attach_id)
  540. if err != nil {
  541. logs.Error("AttachDetailed => ", err)
  542. if err == orm.ErrNoRows {
  543. c.Abort("404")
  544. } else {
  545. c.Abort("500")
  546. }
  547. }
  548. attach.FilePath = filepath.Join(conf.WorkingDirectory, attach.FilePath)
  549. attach.HttpPath = conf.URLForWithCdnImage(attach.HttpPath)
  550. attach.IsExist = filetil.FileExists(attach.FilePath)
  551. c.Data["Model"] = attach
  552. }
  553. //删除附件.
  554. func (c *ManagerController) AttachDelete() {
  555. c.Prepare()
  556. attachId, _ := c.GetInt("attach_id")
  557. if attachId <= 0 {
  558. c.Abort("404")
  559. }
  560. attach, err := models.NewAttachment().Find(attachId)
  561. if err != nil {
  562. logs.Error("AttachDelete => ", err)
  563. c.JsonResult(6001, err.Error())
  564. }
  565. attach.FilePath = filepath.Join(conf.WorkingDirectory, attach.FilePath)
  566. if err := attach.Delete(); err != nil {
  567. logs.Error("AttachDelete => ", err)
  568. c.JsonResult(6002, err.Error())
  569. }
  570. c.JsonResult(0, "ok")
  571. }
  572. //标签列表
  573. func (c *ManagerController) LabelList() {
  574. c.Prepare()
  575. c.TplName = "manager/label_list.tpl"
  576. c.Data["Action"] = "label"
  577. pageIndex, _ := c.GetInt("page", 1)
  578. labels, totalCount, err := models.NewLabel().FindToPager(pageIndex, conf.PageSize)
  579. if err != nil {
  580. c.ShowErrorPage(50001, err.Error())
  581. }
  582. if totalCount > 0 {
  583. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  584. c.Data["PageHtml"] = pager.HtmlPages()
  585. } else {
  586. c.Data["PageHtml"] = ""
  587. }
  588. c.Data["TotalPages"] = int(math.Ceil(float64(totalCount) / float64(conf.PageSize)))
  589. c.Data["Lists"] = labels
  590. }
  591. //删除标签
  592. func (c *ManagerController) LabelDelete() {
  593. labelId, err := strconv.Atoi(c.Ctx.Input.Param(":id"))
  594. if err != nil {
  595. logs.Error("获取删除标签参数时出错:", err)
  596. c.JsonResult(50001, i18n.Tr(c.Lang, "message.param_error"))
  597. }
  598. if labelId <= 0 {
  599. c.JsonResult(50001, i18n.Tr(c.Lang, "message.param_error"))
  600. }
  601. label, err := models.NewLabel().FindFirst("label_id", labelId)
  602. if err != nil {
  603. logs.Error("查询标签时出错:", err)
  604. c.JsonResult(50001, "查询标签时出错:"+err.Error())
  605. }
  606. if err := label.Delete(); err != nil {
  607. c.JsonResult(50002, "删除失败:"+err.Error())
  608. } else {
  609. c.JsonResult(0, "ok")
  610. }
  611. }
  612. func (c *ManagerController) Config() {
  613. c.Prepare()
  614. c.TplName = "manager/config.tpl"
  615. c.Data["Action"] = "config"
  616. if c.Ctx.Input.IsPost() {
  617. content := strings.TrimSpace(c.GetString("configFileTextArea"))
  618. if content == "" {
  619. c.JsonResult(500, "配置文件不能为空")
  620. }
  621. tf, err := ioutil.TempFile(os.TempDir(), "mindoc")
  622. if err != nil {
  623. logs.Error("创建临时文件失败 ->", err)
  624. c.JsonResult(5001, "创建临时文件失败")
  625. }
  626. defer tf.Close()
  627. tf.WriteString(content)
  628. err = web.LoadAppConfig("ini", tf.Name())
  629. if err != nil {
  630. logs.Error("加载配置文件失败 ->", err)
  631. c.JsonResult(5002, "加载配置文件失败")
  632. }
  633. err = filetil.CopyFile(tf.Name(), conf.ConfigurationFile)
  634. if err != nil {
  635. logs.Error("保存配置文件失败 ->", err)
  636. c.JsonResult(5003, "保存配置文件失败")
  637. }
  638. c.JsonResult(0, "保存成功")
  639. }
  640. c.Data["ConfigContent"] = ""
  641. if b, err := ioutil.ReadFile(conf.ConfigurationFile); err == nil {
  642. c.Data["ConfigContent"] = string(b)
  643. }
  644. }
  645. func (c *ManagerController) Team() {
  646. c.Prepare()
  647. c.TplName = "manager/team.tpl"
  648. c.Data["Action"] = "team"
  649. pageIndex, _ := c.GetInt("page", 0)
  650. teams, totalCount, err := models.NewTeam().FindToPager(pageIndex, conf.PageSize)
  651. if err != nil && err != orm.ErrNoRows {
  652. c.ShowErrorPage(500, err.Error())
  653. }
  654. if err == orm.ErrNoRows || len(teams) <= 0 {
  655. c.Data["Result"] = template.JS("[]")
  656. c.Data["PageHtml"] = ""
  657. return
  658. }
  659. if totalCount > 0 {
  660. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  661. c.Data["PageHtml"] = pager.HtmlPages()
  662. } else {
  663. c.Data["PageHtml"] = ""
  664. }
  665. b, err := json.Marshal(teams)
  666. if err != nil {
  667. c.Data["Result"] = template.JS("[]")
  668. } else {
  669. c.Data["Result"] = template.JS(string(b))
  670. }
  671. }
  672. func (c *ManagerController) TeamCreate() {
  673. c.Prepare()
  674. teamName := c.GetString("teamName")
  675. if teamName == "" {
  676. c.JsonResult(5001, i18n.Tr(c.Lang, "message.team_name_empty"))
  677. }
  678. team := models.NewTeam()
  679. team.MemberId = c.Member.MemberId
  680. team.TeamName = teamName
  681. if err := team.Save(); err == nil {
  682. c.JsonResult(0, "OK", team)
  683. } else {
  684. c.JsonResult(5002, err.Error())
  685. }
  686. }
  687. func (c *ManagerController) TeamEdit() {
  688. c.Prepare()
  689. teamName := c.GetString("teamName")
  690. teamId, _ := c.GetInt("teamId")
  691. if teamName == "" {
  692. c.JsonResult(5001, i18n.Tr(c.Lang, "message.team_name_empty"))
  693. }
  694. if teamId <= 0 {
  695. c.JsonResult(5002, i18n.Tr(c.Lang, "message.team_id_empty"))
  696. }
  697. team, err := models.NewTeam().First(teamId)
  698. c.CheckJsonError(5003, err)
  699. team.TeamName = teamName
  700. err = team.Save()
  701. c.CheckJsonError(5004, err)
  702. c.JsonResult(0, "OK", team)
  703. }
  704. func (c *ManagerController) TeamDelete() {
  705. c.Prepare()
  706. teamId, _ := c.GetInt("teamId")
  707. if teamId <= 0 {
  708. c.JsonResult(5002, i18n.Tr(c.Lang, "message.team_id_empty"))
  709. }
  710. err := models.NewTeam().Delete(teamId)
  711. c.CheckJsonError(5001, err)
  712. c.JsonResult(0, "OK")
  713. }
  714. func (c *ManagerController) TeamMemberList() {
  715. c.Prepare()
  716. c.TplName = "manager/team_member_list.tpl"
  717. c.Data["Action"] = "team"
  718. teamId, _ := strconv.Atoi(c.Ctx.Input.Param(":id"))
  719. if teamId <= 0 {
  720. c.ShowErrorPage(500, i18n.Tr(c.Lang, "message.param_error"))
  721. }
  722. pageIndex, _ := c.GetInt("page", 0)
  723. team, err := models.NewTeam().First(teamId)
  724. if err == orm.ErrNoRows {
  725. c.ShowErrorPage(404, "团队不存在")
  726. }
  727. c.CheckErrorResult(500, err)
  728. c.Data["Model"] = team
  729. teams, totalCount, err := models.NewTeamMember().SetLang(c.Lang).FindToPager(teamId, pageIndex, conf.PageSize)
  730. if err != nil && err != orm.ErrNoRows {
  731. c.ShowErrorPage(500, err.Error())
  732. }
  733. if err == orm.ErrNoRows || len(teams) <= 0 {
  734. c.Data["Result"] = template.JS("[]")
  735. c.Data["PageHtml"] = ""
  736. return
  737. }
  738. if totalCount > 0 {
  739. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  740. c.Data["PageHtml"] = pager.HtmlPages()
  741. } else {
  742. c.Data["PageHtml"] = ""
  743. }
  744. b, err := json.Marshal(teams)
  745. if err != nil {
  746. logs.Error("编码 JSON 结果失败 ->", err)
  747. c.Data["Result"] = template.JS("[]")
  748. } else {
  749. c.Data["Result"] = template.JS(string(b))
  750. }
  751. }
  752. //搜索团队用户.
  753. func (c *ManagerController) TeamSearchMember() {
  754. c.Prepare()
  755. teamId, _ := c.GetInt("teamId")
  756. keyword := strings.TrimSpace(c.GetString("q"))
  757. if teamId <= 0 {
  758. c.JsonResult(500, i18n.Tr(c.Lang, "message.param_error"))
  759. }
  760. searchResult, err := models.NewTeamMember().FindNotJoinMemberByAccount(teamId, keyword, 10)
  761. if err != nil {
  762. c.JsonResult(500, err.Error())
  763. }
  764. c.JsonResult(0, "OK", searchResult)
  765. }
  766. func (c *ManagerController) TeamMemberAdd() {
  767. c.Prepare()
  768. teamId, _ := c.GetInt("teamId")
  769. memberId, _ := c.GetInt("memberId")
  770. roleId, _ := c.GetInt("roleId")
  771. if teamId <= 0 || memberId <= 0 || roleId <= 0 || roleId > int(conf.BookObserver) {
  772. c.JsonResult(5001, i18n.Tr(c.Lang, "message.system_error"))
  773. }
  774. teamMember := models.NewTeamMember()
  775. teamMember.MemberId = memberId
  776. teamMember.TeamId = teamId
  777. teamMember.RoleId = conf.BookRole(roleId)
  778. if err := teamMember.Save(); err != nil {
  779. c.CheckJsonError(5001, err)
  780. }
  781. teamMember.Include()
  782. c.JsonResult(0, "OK", teamMember)
  783. }
  784. func (c *ManagerController) TeamMemberDelete() {
  785. c.Prepare()
  786. memberId, _ := c.GetInt("memberId")
  787. teamId, _ := c.GetInt("teamId")
  788. teamMember, err := models.NewTeamMember().FindFirst(teamId, memberId)
  789. if err != nil {
  790. c.JsonResult(5001, "用户不存在或已禁用")
  791. }
  792. err = teamMember.Delete(teamMember.TeamMemberId)
  793. if err != nil {
  794. c.JsonResult(5002, i18n.Tr(c.Lang, "message.failed"))
  795. }
  796. c.JsonResult(0, "ok")
  797. }
  798. func (c *ManagerController) TeamChangeMemberRole() {
  799. c.Prepare()
  800. memberId, _ := c.GetInt("memberId")
  801. roleId, _ := c.GetInt("roleId")
  802. teamId, _ := c.GetInt("teamId")
  803. if memberId <= 0 || roleId <= 0 || teamId <= 0 || roleId > int(conf.BookObserver) {
  804. c.JsonResult(5001, i18n.Tr(c.Lang, "message.param_error"))
  805. }
  806. teamMember, err := models.NewTeamMember().ChangeRoleId(teamId, memberId, conf.BookRole(roleId))
  807. if err != nil {
  808. c.JsonResult(5002, err.Error())
  809. } else {
  810. c.JsonResult(0, "OK", teamMember)
  811. }
  812. }
  813. //团队项目列表.
  814. func (c *ManagerController) TeamBookList() {
  815. c.Prepare()
  816. c.TplName = "manager/team_book_list.tpl"
  817. c.Data["Action"] = "team"
  818. teamId, _ := strconv.Atoi(c.Ctx.Input.Param(":id"))
  819. pageIndex, _ := c.GetInt("page", 0)
  820. if teamId <= 0 {
  821. c.JsonResult(5002, i18n.Tr(c.Lang, "message.team_id_empty"))
  822. }
  823. team, err := models.NewTeam().First(teamId)
  824. if err == orm.ErrNoRows {
  825. c.ShowErrorPage(404, "团队不存在")
  826. }
  827. c.CheckErrorResult(500, err)
  828. c.Data["Model"] = team
  829. teams, totalCount, err := models.NewTeamRelationship().FindToPager(teamId, pageIndex, conf.PageSize)
  830. if err != nil && err != orm.ErrNoRows {
  831. c.ShowErrorPage(500, err.Error())
  832. }
  833. if err == orm.ErrNoRows || len(teams) <= 0 {
  834. c.Data["Result"] = template.JS("[]")
  835. c.Data["PageHtml"] = ""
  836. return
  837. }
  838. if totalCount > 0 {
  839. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  840. c.Data["PageHtml"] = pager.HtmlPages()
  841. } else {
  842. c.Data["PageHtml"] = ""
  843. }
  844. b, err := json.Marshal(teams)
  845. if err != nil {
  846. logs.Error("编码 JSON 结果失败 ->", err)
  847. c.Data["Result"] = template.JS("[]")
  848. } else {
  849. c.Data["Result"] = template.JS(string(b))
  850. }
  851. }
  852. //给团队增加项目.
  853. func (c *ManagerController) TeamBookAdd() {
  854. c.Prepare()
  855. teamId, _ := c.GetInt("teamId")
  856. bookId, _ := c.GetInt("bookId")
  857. if teamId <= 0 || bookId <= 0 {
  858. c.JsonResult(500, i18n.Tr(c.Lang, "message.param_error"))
  859. }
  860. teamRel := models.NewTeamRelationship()
  861. teamRel.BookId = bookId
  862. teamRel.TeamId = teamId
  863. err := teamRel.Save()
  864. if err != nil {
  865. c.JsonResult(5001, err.Error())
  866. } else {
  867. teamRel.Include()
  868. c.JsonResult(0, "OK", teamRel)
  869. }
  870. }
  871. //搜索未参与的项目.
  872. func (c *ManagerController) TeamSearchBook() {
  873. c.Prepare()
  874. teamId, _ := c.GetInt("teamId")
  875. keyword := strings.TrimSpace(c.GetString("q"))
  876. if teamId <= 0 {
  877. c.JsonResult(500, i18n.Tr(c.Lang, "message.param_error"))
  878. }
  879. searchResult, err := models.NewTeamRelationship().FindNotJoinBookByName(teamId, keyword, 10)
  880. if err != nil {
  881. c.JsonResult(500, err.Error())
  882. }
  883. c.JsonResult(0, "OK", searchResult)
  884. }
  885. //删除团队项目.
  886. func (c *ManagerController) TeamBookDelete() {
  887. c.Prepare()
  888. teamRelationshipId, _ := c.GetInt("teamRelId")
  889. if teamRelationshipId <= 0 {
  890. c.JsonResult(500, i18n.Tr(c.Lang, "message.param_error"))
  891. }
  892. err := models.NewTeamRelationship().Delete(teamRelationshipId)
  893. if err != nil {
  894. c.JsonResult(5001, i18n.Tr(c.Lang, "message.failed"))
  895. }
  896. c.JsonResult(0, "OK")
  897. }
  898. //项目空间列表.
  899. func (c *ManagerController) Itemsets() {
  900. c.Prepare()
  901. c.TplName = "manager/itemsets.tpl"
  902. c.Data["Action"] = "itemsets"
  903. pageIndex, _ := c.GetInt("page", 0)
  904. items, totalCount, err := models.NewItemsets().FindToPager(pageIndex, conf.PageSize)
  905. if err != nil && err != orm.ErrNoRows {
  906. c.ShowErrorPage(500, err.Error())
  907. }
  908. if err == orm.ErrNoRows || len(items) <= 0 {
  909. c.Data["Lists"] = items
  910. c.Data["PageHtml"] = ""
  911. return
  912. }
  913. if totalCount > 0 {
  914. pager := pagination.NewPagination(c.Ctx.Request, totalCount, conf.PageSize, c.BaseUrl())
  915. c.Data["PageHtml"] = pager.HtmlPages()
  916. } else {
  917. c.Data["PageHtml"] = ""
  918. }
  919. c.Data["Lists"] = items
  920. }
  921. //编辑或添加项目空间.
  922. func (c *ManagerController) ItemsetsEdit() {
  923. c.Prepare()
  924. itemId, _ := c.GetInt("itemId")
  925. itemName := strings.TrimSpace(c.GetString("itemName"))
  926. itemKey := strings.TrimSpace(c.GetString("itemKey"))
  927. if itemName == "" || itemKey == "" {
  928. c.JsonResult(5001, i18n.Tr(c.Lang, "message.param_error"))
  929. }
  930. var item *models.Itemsets
  931. var err error
  932. if itemId > 0 {
  933. if item, err = models.NewItemsets().First(itemId); err != nil {
  934. if err == orm.ErrNoRows {
  935. c.JsonResult(5002, i18n.Tr(c.Lang, "message.project_space_not_exist"))
  936. } else {
  937. c.JsonResult(5003, "查询项目空间出错")
  938. }
  939. }
  940. } else {
  941. item = models.NewItemsets()
  942. }
  943. item.ItemKey = itemKey
  944. item.ItemName = itemName
  945. item.MemberId = c.Member.MemberId
  946. item.ModifyAt = c.Member.MemberId
  947. if err := item.Save(); err != nil {
  948. c.JsonResult(5004, err.Error())
  949. }
  950. c.JsonResult(0, "OK")
  951. }
  952. //删除项目空间.
  953. func (c *ManagerController) ItemsetsDelete() {
  954. c.Prepare()
  955. itemId, _ := c.GetInt("itemId")
  956. if err := models.NewItemsets().Delete(itemId); err != nil {
  957. c.JsonResult(5001, err.Error())
  958. }
  959. c.JsonResult(0, "OK")
  960. }