SystemController.cs 41 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059
  1. using System.Collections;
  2. using static OpenAI.GPT3.ObjectModels.SharedModels.IOpenAiModels;
  3. namespace OASystem.API.Controllers
  4. {
  5. /// <summary>
  6. /// 系统设置
  7. /// </summary>
  8. //[Authorize]
  9. [Route("api/[controller]/[action]")]
  10. public class SystemController : ControllerBase
  11. {
  12. private readonly CompanyRepository _syscomRep;
  13. private readonly DepartmentRepository _sysDepRep;
  14. private readonly UsersRepository _userRep;
  15. private readonly IMapper _mapper;
  16. private readonly SetDataRepository _setDataRepository;
  17. private readonly SystemMenuPermissionRepository _SystemMenuPermissionRepository;
  18. private readonly CompanyRepository _CompanyRepository;
  19. private readonly PageFunctionPermissionRepository _PageFunctionPermissionRepository;
  20. private readonly SystemMenuAndFunctionRepository _SystemMenuAndFunctionRepository;
  21. private readonly JobPostAuthorityRepository _JobPostAuthorityRepository;
  22. private readonly JobPostRepository _jobRep;
  23. private readonly UserAuthorityRepository _UserAuthorityRepository;
  24. public SystemController( CompanyRepository syscom, DepartmentRepository sysDepRep, UsersRepository userRep,
  25. IMapper mapper, SetDataRepository setDataRepository, CompanyRepository companyRepository,
  26. SystemMenuPermissionRepository systemMenuPermissionRepository, PageFunctionPermissionRepository pageFunctionPermissionRepository,
  27. SystemMenuAndFunctionRepository systemMenuAndFunctionRepository, JobPostAuthorityRepository jobPostAuthorityRepository, JobPostRepository jobRep
  28. , UserAuthorityRepository userAuthorityRepository)
  29. {
  30. _syscomRep = syscom;
  31. _sysDepRep = sysDepRep;
  32. _userRep = userRep;
  33. _mapper = mapper;
  34. _setDataRepository = setDataRepository;
  35. _CompanyRepository = companyRepository;
  36. _SystemMenuPermissionRepository = systemMenuPermissionRepository;
  37. _PageFunctionPermissionRepository = pageFunctionPermissionRepository;
  38. _SystemMenuAndFunctionRepository = systemMenuAndFunctionRepository;
  39. _JobPostAuthorityRepository = jobPostAuthorityRepository;
  40. _UserAuthorityRepository = userAuthorityRepository;
  41. }
  42. #region 企业操作
  43. /// <summary>
  44. /// 查询企业数据
  45. /// </summary>
  46. /// <param name="dto"></param>
  47. /// <returns></returns>
  48. [HttpPost]
  49. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  50. public async Task<IActionResult> getCompanyList(DtoBase dto)
  51. {
  52. try
  53. {
  54. if (dto.PortType == 1)
  55. {
  56. var CompanyDataResult = _CompanyRepository.GetCompanyData();
  57. if (CompanyDataResult.Code != 0)
  58. {
  59. return Ok(JsonView(CompanyDataResult.Msg));
  60. }
  61. List<CompanyView> companyListView = _mapper.Map<List<CompanyView>>(CompanyDataResult.Data);
  62. for (int i = 0; i < companyListView.Count; i++)
  63. {
  64. if (companyListView[i].ParentCompanyId != 0)
  65. {
  66. companyListView[i].ParentCompanyName = companyListView.Find(x => x.Id == companyListView[i].ParentCompanyId).CompanyName;
  67. }
  68. if (companyListView[i].ContactUserId!=0)
  69. {
  70. var user = _userRep.QueryDto<Sys_Users,UserInfoWebView>(x => x.Id == companyListView[i].ContactUserId).ToList();
  71. if (user.Count!=0)
  72. {
  73. companyListView[i].ContactUserName = user[0].CnName;
  74. }
  75. }
  76. }
  77. return Ok(JsonView(true, "查询成功!", companyListView));
  78. }
  79. else if (dto.PortType == 2)
  80. {
  81. var CompanyDataResult = _CompanyRepository.GetCompanyData();
  82. if (CompanyDataResult.Code != 0)
  83. {
  84. return Ok(JsonView(CompanyDataResult.Msg));
  85. }
  86. return Ok(JsonView(true,"查询成功!", CompanyDataResult.Data));
  87. }
  88. else if (dto.PortType == 3)
  89. {
  90. return Ok(JsonView(false, "暂无数据!"));
  91. }
  92. else
  93. {
  94. return Ok(JsonView(false, "暂无数据!"));
  95. }
  96. }
  97. catch (Exception ex)
  98. {
  99. return Ok(JsonView(false, "程序错误!"));
  100. throw;
  101. }
  102. }
  103. /// <summary>
  104. /// 添加企业数据
  105. /// </summary>
  106. /// <param name="dto"></param>
  107. /// <returns></returns>
  108. [HttpPost]
  109. [ProducesResponseType(typeof(JsonView),StatusCodes.Status200OK)]
  110. public async Task<IActionResult> AddCompany(AddCompanyDto dto)
  111. {
  112. try
  113. {
  114. if (string.IsNullOrWhiteSpace(dto.CompanyName) || dto.CreateUserId == 0 || string.IsNullOrWhiteSpace(dto.CompanyCode))
  115. {
  116. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  117. }
  118. else if (string.IsNullOrWhiteSpace(dto.Tel))
  119. {
  120. return Ok(JsonView(false, "请检查联系方式是否输入正确!"));
  121. }
  122. else
  123. {
  124. Sys_Company _Company = _mapper.Map<Sys_Company>(dto);
  125. int id = await _syscomRep.AddAsyncReturnId(_Company);
  126. if (id == 0)
  127. {
  128. return Ok(JsonView(false, "添加失败!"));
  129. }
  130. return Ok(JsonView(true,"添加成功", new { Id = id }));
  131. }
  132. }
  133. catch (Exception)
  134. {
  135. return Ok(JsonView(false, "程序错误!"));
  136. throw;
  137. }
  138. }
  139. /// <summary>
  140. /// 企业修改
  141. /// </summary>
  142. /// <param name="dto"></param>
  143. /// <returns></returns>
  144. [HttpPost]
  145. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  146. public async Task<IActionResult>EditCompany(EditCompanyDto dto)
  147. {
  148. try
  149. {
  150. if (string.IsNullOrWhiteSpace(dto.CompanyName) || string.IsNullOrWhiteSpace(dto.CompanyCode) || string.IsNullOrWhiteSpace(dto.Address) || dto.ContactUserId == 0)
  151. {
  152. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  153. }
  154. else if (string.IsNullOrWhiteSpace(dto.Tel))
  155. {
  156. return Ok(JsonView(false, "请检查联系方式是否输入正确!"));
  157. }
  158. else
  159. {
  160. bool res = await _syscomRep.UpdateAsync(a => a.Id == dto.Id, a => new Sys_Company
  161. {
  162. CompanyName = dto.CompanyName,
  163. CompanyCode = dto.CompanyCode,
  164. Address = dto.Address,
  165. ParentCompanyId = dto.ParentCompanyId,
  166. Tel = dto.Tel,
  167. ContactUserId = dto.ContactUserId,
  168. Remark=dto.Remark,
  169. });
  170. if (!res) { return Ok(JsonView(false, "修改失败")); }
  171. return Ok(JsonView(true,"修改成功!"));
  172. }
  173. }
  174. catch (Exception)
  175. {
  176. return Ok(JsonView(false, "程序错误!"));
  177. throw;
  178. }
  179. }
  180. /// <summary>
  181. /// 企业删除
  182. /// </summary>
  183. /// <param name="dto"></param>
  184. /// <returns></returns>
  185. [HttpPost]
  186. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  187. public async Task<IActionResult> DelCompany(DelCompanyDto dto)
  188. {
  189. try
  190. {
  191. bool res = await _syscomRep.SoftDeleteAsync<Sys_Company>(dto.Id.ToString());
  192. if (!res) { return Ok(JsonView(false, "删除失败")); }
  193. return Ok(JsonView(true, "删除成功"));
  194. }
  195. catch (Exception)
  196. {
  197. return Ok(JsonView(false, "程序错误!"));
  198. throw;
  199. }
  200. }
  201. #endregion
  202. #region 部门操作
  203. /// <summary>
  204. /// 查询部门数据
  205. /// </summary>
  206. /// <param name="dto"></param>
  207. /// <returns></returns>
  208. [HttpPost]
  209. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  210. public async Task<IActionResult> QueryDepartmentList(DepartmentDto dto)
  211. {
  212. try
  213. {
  214. if (dto.PortType==1)
  215. {
  216. if (dto.CompanyId!=0)
  217. {
  218. var result = _sysDepRep.QueryDto<Sys_Department, DepartmentIView>(s => s.CompanyId == dto.CompanyId).ToList();
  219. if (result.Count == 0)
  220. {
  221. return Ok(JsonView(false, "暂无数据!"));
  222. }
  223. for (int i = 0; i < result.Count; i++)
  224. {
  225. if (result[i].ParentDepId != 0)
  226. {
  227. result[i].ParentDepName = result.Find(x => x.Id == result[i].ParentDepId).ParentDepName;
  228. }
  229. var company = _sysDepRep.QueryDto<Sys_Company, CompanyView>(s => s.Id == result[i].CompanyId).ToList();
  230. if (company.Count != 0)
  231. {
  232. result[i].CompanyName = company[0].CompanyName;
  233. }
  234. return Ok(JsonView(true, "查询成功!", result));
  235. }
  236. }
  237. else
  238. {
  239. var result = _sysDepRep.QueryDto<Sys_Department, DepartmentIView>(s => s.IsDel <=1).ToList();
  240. if (result.Count == 0)
  241. {
  242. return Ok(JsonView(false, "暂无数据!"));
  243. }
  244. for (int i = 0; i < result.Count; i++)
  245. {
  246. if (result[i].ParentDepId != 0)
  247. {
  248. result[i].ParentDepName = result.Find(x => x.Id == result[i].ParentDepId).ParentDepName;
  249. }
  250. var company = _sysDepRep.QueryDto<Sys_Company, CompanyView>(s => s.Id == result[i].CompanyId).ToList();
  251. if (company.Count != 0)
  252. {
  253. result[i].CompanyName = company[0].CompanyName;
  254. }
  255. }
  256. return Ok(JsonView(true, "查询成功!", result));
  257. }
  258. return Ok(JsonView(false, "暂无数据!"));
  259. }
  260. else if (dto.PortType==2)
  261. {
  262. var result = _sysDepRep.QueryDto<Sys_Department, DepartmentIView>(s => s.CompanyId == dto.CompanyId).ToList();
  263. if (result.Count == 0)
  264. {
  265. return Ok(JsonView(false, "暂无数据!"));
  266. }
  267. return Ok(JsonView(true,"查询成功!",result));
  268. }
  269. else if (dto.PortType == 3)
  270. {
  271. return Ok(JsonView(false, "暂无数据!"));
  272. }
  273. else
  274. {
  275. return Ok(JsonView(false, "暂无数据!"));
  276. }
  277. }
  278. catch (Exception ex)
  279. {
  280. return Ok(JsonView(false, "程序错误!"));
  281. throw;
  282. }
  283. }
  284. /// <summary>
  285. /// 部门添加
  286. /// </summary>
  287. /// <param name="dto"></param>
  288. /// <returns></returns>
  289. [HttpPost]
  290. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  291. public async Task<IActionResult> AddDepartment(AddDepartmentDto dto)
  292. {
  293. try
  294. {
  295. if (dto.CreateUserId == 0 || string.IsNullOrWhiteSpace(dto.DepName) || dto.CompanyId == 0 || string.IsNullOrWhiteSpace(dto.DepCode))
  296. {
  297. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  298. }
  299. else
  300. {
  301. Sys_Department _Department = _mapper.Map<Sys_Department>(dto);
  302. int id = await _sysDepRep.AddAsyncReturnId(_Department);
  303. if (id == 0)
  304. {
  305. return Ok(JsonView(false, "添加失败!"));
  306. }
  307. return Ok(JsonView(true, "添加成功!", new { Id = id }));
  308. }
  309. }
  310. catch (Exception)
  311. {
  312. return Ok(JsonView(false, "程序错误!"));
  313. throw;
  314. }
  315. }
  316. /// <summary>
  317. /// 部门修改
  318. /// </summary>
  319. /// <param name="dto"></param>
  320. /// <returns></returns>
  321. [HttpPost]
  322. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  323. public async Task<IActionResult> EditDepartment(EditDepartmentDto dto)
  324. {
  325. try
  326. {
  327. if (dto.Id==0 || string.IsNullOrWhiteSpace(dto.DepName) || dto.CompanyId == 0 || string.IsNullOrWhiteSpace(dto.DepCode))
  328. {
  329. return Ok(JsonView(false, "请检查信息是否输入完整!"));
  330. }
  331. else
  332. {
  333. bool res = await _sysDepRep.UpdateAsync<Sys_Department>(a => a.Id == dto.Id, a => new Sys_Department
  334. {
  335. CompanyId=dto.CompanyId,
  336. DepCode=dto.DepCode,
  337. DepName=dto.DepName,
  338. ParentDepId=dto.ParentDepId,
  339. Remark=dto.Remark,
  340. });
  341. if (!res)
  342. {
  343. return Ok(JsonView(false, "修改失败!"));
  344. }
  345. return Ok(JsonView(true, "修改成功!"));
  346. }
  347. }
  348. catch (Exception)
  349. {
  350. return Ok(JsonView(false, "程序错误!"));
  351. throw;
  352. }
  353. }
  354. /// <summary>
  355. /// 部门删除
  356. /// </summary>
  357. /// <param name="dto"></param>
  358. /// <returns></returns>
  359. [HttpPost]
  360. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  361. public async Task<IActionResult> DelDepartment(DelDepartmentDto dto)
  362. {
  363. try
  364. {
  365. if (dto.Id == 0)
  366. {
  367. return Ok(JsonView(-1, "请检查信息是否输入完整!", null));
  368. }
  369. else
  370. {
  371. bool res =await _sysDepRep.SoftDeleteAsync<Sys_Department>(dto.Id.ToString());
  372. if (!res)
  373. {
  374. return Ok(JsonView(false, "删除失败!"));
  375. }
  376. return Ok(JsonView(true, "删除成功!"));
  377. }
  378. }
  379. catch (Exception)
  380. {
  381. return Ok(JsonView(false, "程序错误!"));
  382. throw;
  383. }
  384. }
  385. #endregion
  386. #region 岗位板块
  387. /// <summary>
  388. /// 岗位查询
  389. /// </summary>
  390. /// <param name="dto"></param>
  391. /// <returns></returns>
  392. [HttpPost]
  393. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  394. public async Task<IActionResult> QueryJobPost(QueryJobPostDto dto)
  395. {
  396. try
  397. {
  398. if (dto.PortType == 1)
  399. {
  400. var result = _sysDepRep.QueryDto<Sys_JobPost, JobPostView>(s => s.CompanyId == dto.CompanyId && s.DepId == dto.DepId).ToList();
  401. if (result.Count == 0)
  402. {
  403. return Ok(JsonView(false, "暂无数据!"));
  404. }
  405. return Ok(JsonView(true, "查询成功!", result));
  406. }
  407. else if (dto.PortType == 2)
  408. {
  409. var result = _jobRep.QueryDto<Sys_JobPost, JobPostView>(s => s.CompanyId == dto.CompanyId && s.DepId==dto.DepId).ToList();
  410. if (result.Count == 0)
  411. {
  412. return Ok(JsonView(false, "暂无数据!"));
  413. }
  414. return Ok(JsonView(true, "查询成功!", result));
  415. }
  416. else if (dto.PortType == 3)
  417. {
  418. return Ok(JsonView(false, "暂无数据!"));
  419. }
  420. else
  421. {
  422. return Ok(JsonView(false, "暂无数据!"));
  423. }
  424. }
  425. catch (Exception ex)
  426. {
  427. return Ok(JsonView(false, "程序错误!"));
  428. throw;
  429. }
  430. }
  431. /// <summary>
  432. /// 添加岗位
  433. /// </summary>
  434. /// <param name="dto"></param>
  435. /// <returns></returns>
  436. [HttpPost]
  437. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  438. public async Task<IActionResult> AddJobPost(AddJobPostDto dto)
  439. {
  440. try
  441. {
  442. Sys_JobPost sys_Job = _mapper.Map<Sys_JobPost>(dto);
  443. int id = await _jobRep.AddAsyncReturnId(sys_Job);
  444. if (id == 0)
  445. {
  446. return Ok(JsonView(false, "添加失败"));
  447. }
  448. return Ok(JsonView(true, "添加成功", new { Id = id }));
  449. }
  450. catch (Exception ex)
  451. {
  452. return Ok(JsonView(false, "程序错误!"));
  453. throw;
  454. }
  455. }
  456. /// <summary>
  457. /// 修改岗位
  458. /// </summary>
  459. /// <param name="dto"></param>
  460. /// <returns></returns>
  461. [HttpPost]
  462. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  463. public async Task<IActionResult> EditJobPost(EditJobPostDto dto)
  464. {
  465. try
  466. {
  467. bool res = await _jobRep.UpdateAsync<Sys_JobPost>(a=>a.Id==dto.Id,a =>new Sys_JobPost
  468. {
  469. CompanyId=dto.CompanyId,
  470. DepId=dto.DepId,
  471. JobName=dto.JobName,
  472. Remark=dto.Remark,
  473. });
  474. if (!res)
  475. {
  476. return Ok(JsonView(false, "修改失败"));
  477. }
  478. return Ok(JsonView(true, "修改成功"));
  479. }
  480. catch (Exception ex)
  481. {
  482. return Ok(JsonView(false, "程序错误!"));
  483. throw;
  484. }
  485. }
  486. /// <summary>
  487. /// 删除岗位
  488. /// </summary>
  489. /// <param name="dto"></param>
  490. /// <returns></returns>
  491. [HttpPost]
  492. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  493. public async Task<IActionResult> DelJobPost(DelJobPostDto dto)
  494. {
  495. try
  496. {
  497. bool res = await _jobRep.SoftDeleteAsync<Sys_JobPost>(dto.Id.ToString());
  498. if (!res)
  499. {
  500. return Ok(JsonView(false, "删除失败!"));
  501. }
  502. return Ok(JsonView(true, "删除成功"));
  503. }
  504. catch (Exception)
  505. {
  506. return Ok(JsonView(false, "程序错误!"));
  507. throw;
  508. }
  509. }
  510. #endregion
  511. #region 用户操作
  512. /// <summary>
  513. /// 查询所有员工(web)
  514. /// </summary>
  515. /// <param name="dto"></param>
  516. /// <returns></returns>
  517. //[OASystemAuthentication]
  518. [HttpPost]
  519. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  520. public async Task<IActionResult> GetUserList(DtoBase dto)
  521. {
  522. try
  523. {
  524. var result = _userRep.GetUserList(dto.PortType, string.Empty);
  525. if (result.Result.Code != 0)
  526. {
  527. return Ok(JsonView(false, "暂无数据!"));
  528. }
  529. return Ok(JsonView(true, "查询成功!", result.Result.Data));
  530. }
  531. catch (Exception)
  532. {
  533. return Ok(JsonView(false, "程序错误!"));
  534. throw;
  535. }
  536. }
  537. /// <summary>
  538. /// 查询用户数据
  539. /// </summary>
  540. /// <param name="dto"></param>
  541. /// <returns></returns>
  542. [HttpPost]
  543. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  544. public async Task<IActionResult> QueryUserList(UserDto dto)
  545. {
  546. try
  547. {
  548. string sqlWhere = string.Empty;
  549. if (dto.CompanyId!=0)
  550. {
  551. sqlWhere += string.Format(@" And su.CompanyId={0}", dto.CompanyId);
  552. }
  553. if (dto.DepId != 0)
  554. {
  555. sqlWhere += string.Format(@" And su.DepId={0}", dto.DepId);
  556. }
  557. if (dto.JobPostId != 0)
  558. {
  559. sqlWhere += string.Format(@" And su.JobPostId={0}", dto.JobPostId);
  560. }
  561. if (!string.IsNullOrEmpty(sqlWhere.Trim()))
  562. {
  563. Regex r = new Regex("And");
  564. sqlWhere = r.Replace(sqlWhere, "Where", 1);
  565. }
  566. string userSqlWhere = string.Format(@"Select sc.CompanyName,sd.DepName,sjp.JobName,su.* From Sys_Users su
  567. Inner Join Sys_Company sc On su.CompanyId = sc.Id
  568. Inner Join Sys_Department sd On su.DepId = sd.Id
  569. Inner Join Sys_JobPost sjp On su.JobPostId = sjp.Id {0}", sqlWhere);
  570. var _userList =_userRep.GetListBySqlWithNolock(userSqlWhere);
  571. if (_userList.Count == 0)
  572. {
  573. return Ok(JsonView(false, "暂无数据!"));
  574. }
  575. List<UserInfoWebView> userList = _mapper.Map<List<UserInfoWebView>>(_userList);
  576. return Ok(JsonView(true,"查询成功!", userList));
  577. }
  578. catch (Exception)
  579. {
  580. return Ok(JsonView(false, "程序错误!"));
  581. throw;
  582. }
  583. }
  584. /// <summary>
  585. /// 修改用户信息(上级修改/分配 公司、部门、岗位、工号等信息)
  586. /// </summary>
  587. /// <param name="dto"></param>
  588. /// <returns></returns>
  589. [HttpPost]
  590. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  591. public async Task<IActionResult> EditUser(EditUserDto dto)
  592. {
  593. try
  594. {
  595. bool res = await _userRep.UpdateAsync<Sys_Users>(a => a.Id == dto.Id, a => new Sys_Users
  596. {
  597. Number = dto.Number,
  598. CompanyId = dto.CompanyId,
  599. DepId = dto.DepId,
  600. JobPostId = dto.JobPostId,
  601. Ext = dto.Ext,
  602. UsePeriod = dto.UsePeriod,
  603. HrAudit = dto.HrAudit
  604. });
  605. if (!res)
  606. {
  607. return Ok(JsonView(false, "修改失败!"));
  608. }
  609. return Ok(JsonView(true, "修改成功!"));
  610. }
  611. catch (Exception)
  612. {
  613. return Ok(JsonView(false, "程序错误!"));
  614. throw;
  615. }
  616. }
  617. /// <summary>
  618. /// 修改用户信息(登录用户修改个人信息)
  619. /// </summary>
  620. /// <param name="dto"></param>
  621. /// <returns></returns>
  622. [HttpPost]
  623. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  624. public async Task<IActionResult> EditMyUser(EditMyUserDto dto)
  625. {
  626. try
  627. {
  628. if (string.IsNullOrWhiteSpace(dto.CnName) || string.IsNullOrWhiteSpace(dto.Address) || string.IsNullOrWhiteSpace(dto.IDCard) || dto.Sex != 0 && dto.Sex != 1 ||
  629. string.IsNullOrWhiteSpace(dto.MaritalStatus) || string.IsNullOrWhiteSpace(dto.HomeAddress)|| dto.Birthday>=DateTime.Now.AddYears(-1))
  630. {
  631. return Ok(JsonView(false, "请完善你的个人信息!"));
  632. }
  633. else if (string.IsNullOrWhiteSpace(dto.GraduateInstitutions) || string.IsNullOrWhiteSpace(dto.Professional) || dto.Education == 0 || string.IsNullOrWhiteSpace(dto.GraduateInstitutions))
  634. {
  635. return Ok(JsonView(false, "请完善你的学历信息!"));
  636. }
  637. else if (string.IsNullOrWhiteSpace(dto.Phone) || string.IsNullOrWhiteSpace(dto.UrgentPhone) || string.IsNullOrWhiteSpace(dto.Email))
  638. {
  639. return Ok(JsonView(false, "请检查联系方式、紧急联系人及邮箱输写是否正确!"));
  640. }
  641. else
  642. {
  643. bool res = await _userRep.UpdateAsync<Sys_Users>(a => a.Id == dto.Id, a => new Sys_Users
  644. {
  645. CnName = dto.CnName,
  646. EnName = dto.EnName,
  647. Sex = dto.Sex,
  648. Phone = dto.Phone,
  649. UrgentPhone = dto.UrgentPhone,
  650. Email = dto.Email,
  651. Address = dto.Address,
  652. Edate = dto.Edate,
  653. Birthday = dto.Birthday,
  654. IDCard = dto.IDCard,
  655. GraduateInstitutions = dto.GraduateInstitutions,
  656. Professional = dto.Professional,
  657. Education = dto.Education,
  658. TheOrAdultEducation = dto.TheOrAdultEducation,
  659. MaritalStatus = dto.MaritalStatus,
  660. HomeAddress = dto.HomeAddress,
  661. WorkExperience = dto.WorkExperience,
  662. Certificate = dto.Certificate
  663. });
  664. if (!res)
  665. {
  666. return Ok(JsonView(false, "修改失败!"));
  667. }
  668. return Ok(JsonView(true, "修改成功!"));
  669. }
  670. }
  671. catch (Exception)
  672. {
  673. return Ok(JsonView(false, "程序错误!"));
  674. throw;
  675. }
  676. }
  677. #endregion
  678. #region 权限模块
  679. /// <summary>
  680. /// 权限数据页面初始化
  681. /// </summary>
  682. /// <param name="dto"></param>
  683. /// <returns></returns>
  684. //[Authorize]
  685. [HttpPost]
  686. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  687. public async Task<IActionResult> GetAuth(AuthDto dto)
  688. {
  689. Result result = new Result();
  690. //模块数据
  691. var setDataResult = await _setDataRepository.GetSySDefultModule(_setDataRepository);
  692. if (setDataResult.Code != 0)
  693. {
  694. return Ok(JsonView(setDataResult.Msg));
  695. }
  696. //操作方式
  697. var PageOperation = _PageFunctionPermissionRepository.QueryDto<Sys_PageFunctionPermission, Sys_PageFunctionPermission>().ToList();
  698. //获取所有关联页面
  699. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  700. //页面数据
  701. var SystemMenuPermissionData = _SystemMenuPermissionRepository.QueryDto<Sys_SystemMenuPermission, SystemMenuPermissionView>(x=>x.Mid == dto.moduleId).ToList();
  702. if (SystemMenuPermissionData == null || SystemMenuPermissionData.Count() == 0)
  703. {
  704. return Ok(JsonView("暂无数据"));
  705. }
  706. ArrayList viewData = new ArrayList();
  707. //组合页面数据
  708. foreach (var item in SystemMenuPermissionData)
  709. {
  710. ArrayList ids = new ArrayList();
  711. foreach (var viewop in PageOperation)
  712. {
  713. var op = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.SmId == item.Id && x.FId == viewop.Id);
  714. if (op != null)
  715. {
  716. ids.Add(viewop.Id);
  717. }
  718. }
  719. viewData.Add(new
  720. {
  721. Id = item.Id,
  722. Mid = item.Mid,
  723. Name = item.Name,
  724. SystemMenuCode = item.SystemMenuCode,
  725. opList = ids,
  726. selList = new string[0]
  727. }) ;
  728. }
  729. //公司数据
  730. var CompanyDataResult = _CompanyRepository.GetCompanyData();
  731. if (CompanyDataResult.Code != 0)
  732. {
  733. return Ok(JsonView(CompanyDataResult.Msg));
  734. }
  735. result.Code = 0;
  736. result.Msg = "成功!";
  737. var Dyresult = new
  738. {
  739. setDataResult = setDataResult.Data,
  740. CompanyDataResult = CompanyDataResult.Data,
  741. SystemMenuPermissionData = viewData,
  742. PageOperation = PageOperation,
  743. };
  744. return Ok(JsonView(200, "成功!", Dyresult));
  745. }
  746. /// <summary>
  747. /// 获取职务权限
  748. /// </summary>
  749. /// <param name="dto"></param>
  750. /// <returns></returns>
  751. [HttpPost]
  752. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  753. public IActionResult QueryJobAuth(QueryJobAuthDto dto)
  754. {
  755. //选中的操作权限
  756. var DBdata = _JobPostAuthorityRepository.QueryDto<Sys_JobPostAuthority, JobPostAuthorityView>(x=>x.JpId == dto.jobid).ToList();
  757. var SystemMenuPermissionData = _SystemMenuPermissionRepository.QueryDto<Sys_SystemMenuPermission, SystemMenuPermissionView>(x => x.Mid == dto.moduleId).ToList();
  758. if (SystemMenuPermissionData == null || SystemMenuPermissionData.Count() == 0)
  759. {
  760. return Ok(JsonView("暂无数据"));
  761. }
  762. //所有操作
  763. var PageOperation = _PageFunctionPermissionRepository.QueryDto<Sys_PageFunctionPermission, Sys_PageFunctionPermission>().ToList();
  764. //获取所有关联页面
  765. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  766. ArrayList viewData = new ArrayList();
  767. //组合页面数据
  768. foreach (var item in SystemMenuPermissionData)
  769. {
  770. ArrayList ids = new ArrayList();
  771. foreach (var viewop in PageOperation)
  772. {
  773. var op = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.SmId == item.Id && x.FId == viewop.Id);
  774. if (op != null)
  775. {
  776. ids.Add(viewop.Id);
  777. }
  778. }
  779. //获取本职务的页面拥有的权限
  780. var DBwhere = DBdata.Where(x => x.SmId == item.Id && x.JpId == dto.jobid).ToList();
  781. viewData.Add(new
  782. {
  783. Id = item.Id,
  784. Mid = item.Mid,
  785. Name = item.Name,
  786. SystemMenuCode = item.SystemMenuCode,
  787. opList = ids,
  788. selList = DBwhere.Select(x => x.FId)
  789. }) ;
  790. }
  791. return Ok(JsonView(200, "成功!", viewData));
  792. }
  793. /// <summary>
  794. /// 保存岗位权限
  795. /// </summary>
  796. /// <param name="dto"></param>
  797. /// <returns></returns>
  798. [HttpPost]
  799. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  800. public async Task<IActionResult> SaveJobAuth(SaveJobDto dto)
  801. {
  802. //获取所有关联页面
  803. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  804. List<Sys_JobPostAuthority> adds = new List<Sys_JobPostAuthority>();
  805. foreach (var item in dto.Savejobs)
  806. {
  807. foreach (var fid in item.FIds)
  808. {
  809. var whereobj = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.FId == fid && x.SmId == item.SmId);
  810. if (whereobj != null)
  811. {
  812. adds.Add(new Sys_JobPostAuthority
  813. {
  814. CreateTime = DateTime.Now,
  815. CreateUserId = 245,
  816. FId = fid,
  817. JpId = dto.Jpid,
  818. SmId = item.SmId
  819. });
  820. }
  821. }
  822. }
  823. _JobPostAuthorityRepository.BeginTran();
  824. try
  825. { //删除岗位
  826. bool isdel = await _JobPostAuthorityRepository.DeleteAsync<Sys_JobPostAuthority>(x => x.JpId == dto.Jpid);
  827. int UpRows = _JobPostAuthorityRepository.Adds<Sys_JobPostAuthority>(adds);
  828. //获取所有职位员工
  829. var jobUserAll = await QueryUserList(new UserDto { PortType = 2, JobPostId = dto.Jpid });
  830. List<UserInfoWebView> users = null;
  831. var QueryUserListApiResult = (((jobUserAll as OkObjectResult).Value) as OASystem.Domain.ViewModels.JsonView);
  832. if (QueryUserListApiResult != null)
  833. {
  834. if (QueryUserListApiResult.Code == 200)
  835. {
  836. users = QueryUserListApiResult.Data as List<UserInfoWebView>;
  837. }
  838. }
  839. if (users != null && users.Count > 0)
  840. {
  841. List<Sys_UserAuthority> userAuth = null;
  842. foreach (var user in users)
  843. {
  844. //删除个人级岗位权限
  845. isdel = await _UserAuthorityRepository.DeleteAsync<Sys_UserAuthority>(x => x.IsTemp == 1 &&
  846. x.UId == user.Id);
  847. userAuth = adds.Select(x=> new Sys_UserAuthority
  848. {
  849. CreateTime = DateTime.Now,
  850. CreateUserId = 235,
  851. FId = x.FId,
  852. SmId = x.SmId,
  853. UId = user.Id,
  854. IsTemp = 1,
  855. }).ToList();
  856. //添加个人级别岗位
  857. int AddRows = _UserAuthorityRepository.Adds<Sys_UserAuthority>(userAuth);
  858. }
  859. }
  860. }
  861. catch (Exception ex)
  862. {
  863. _JobPostAuthorityRepository.RollbackTran();
  864. return Ok(JsonView("系统错误!"));
  865. }
  866. _JobPostAuthorityRepository.CommitTran();
  867. return Ok(JsonView(200, "成功", new { }));
  868. }
  869. /// <summary>
  870. /// 获取员工权限
  871. /// </summary>
  872. /// <param name="dto"></param>
  873. /// <returns></returns>
  874. [HttpPost]
  875. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  876. public IActionResult QueryUserAuth(QueryUserAuthDto dto)
  877. {
  878. //选中的员工操作权限
  879. var DBdata = _UserAuthorityRepository.QueryDto<Sys_UserAuthority, UserAuthorityView>(x => x.UId == dto.Userid).ToList();
  880. var SystemMenuPermissionData = _SystemMenuPermissionRepository.QueryDto<Sys_SystemMenuPermission, SystemMenuPermissionView>(x => x.Mid == dto.moduleId).ToList();
  881. if (SystemMenuPermissionData == null || SystemMenuPermissionData.Count() == 0)
  882. {
  883. return Ok(JsonView("暂无数据"));
  884. }
  885. //所有操作
  886. var PageOperation = _PageFunctionPermissionRepository.QueryDto<Sys_PageFunctionPermission, Sys_PageFunctionPermission>().ToList();
  887. //获取所有关联页面
  888. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  889. ArrayList viewData = new ArrayList();
  890. //组合页面数据
  891. foreach (var item in SystemMenuPermissionData)
  892. {
  893. ArrayList ids = new ArrayList();
  894. foreach (var viewop in PageOperation)
  895. {
  896. var op = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.SmId == item.Id && x.FId == viewop.Id);
  897. if (op != null)
  898. {
  899. ids.Add(viewop.Id);
  900. }
  901. }
  902. //获取本员工拥有的权限
  903. var DBwhere = DBdata.Where(x => x.SmId == item.Id && x.UId == dto.Userid).ToList();
  904. viewData.Add(new
  905. {
  906. Id = item.Id,
  907. Mid = item.Mid,
  908. Name = item.Name,
  909. SystemMenuCode = item.SystemMenuCode,
  910. opList = ids,
  911. selList = DBwhere.Select(x => x.FId)
  912. });
  913. }
  914. return Ok(JsonView(200, "成功!", viewData));
  915. }
  916. /// <summary>
  917. /// 保存员工权限
  918. /// </summary>
  919. /// <param name="dto"></param>
  920. /// <returns></returns>
  921. [HttpPost]
  922. [ProducesResponseType(typeof(JsonView), StatusCodes.Status200OK)]
  923. public async Task<IActionResult> SaveUserAuth(SaveUserDto dto)
  924. {
  925. //获取所有关联页面
  926. var Sys_SystemMenuAndFunction = _SystemMenuAndFunctionRepository.QueryDto<Sys_SystemMenuAndFunction, SystemMenuAndFunctionView>().ToList();
  927. List<Sys_UserAuthority> adds = new List<Sys_UserAuthority>();
  928. foreach (var item in dto.Savejobs)
  929. {
  930. foreach (var fid in item.FIds)
  931. {
  932. var whereobj = Sys_SystemMenuAndFunction.FirstOrDefault(x => x.FId == fid && x.SmId == item.SmId);
  933. if (whereobj != null)
  934. {
  935. adds.Add(new Sys_UserAuthority
  936. {
  937. CreateTime = DateTime.Now,
  938. CreateUserId = 235,
  939. FId = fid,
  940. UId = dto.uid,
  941. SmId = item.SmId,
  942. IsTemp = 0
  943. });
  944. }
  945. }
  946. }
  947. _JobPostAuthorityRepository.BeginTran();
  948. try
  949. {
  950. List<Sys_UserAuthority> userAuth = null;
  951. //删除个人级岗位权限
  952. bool isdel = await _UserAuthorityRepository.DeleteAsync<Sys_UserAuthority>(x => x.IsTemp == 0 &&
  953. x.UId == dto.uid);
  954. userAuth = adds.Select(x => new Sys_UserAuthority
  955. {
  956. CreateTime = DateTime.Now,
  957. CreateUserId = 235,
  958. FId = x.FId,
  959. SmId = x.SmId,
  960. UId = dto.uid,
  961. IsTemp = 0,
  962. }).ToList();
  963. //添加个人级别岗位
  964. int AddRows = _UserAuthorityRepository.Adds<Sys_UserAuthority>(userAuth);
  965. }
  966. catch (Exception ex)
  967. {
  968. _JobPostAuthorityRepository.RollbackTran();
  969. return Ok(JsonView("系统错误!"));
  970. }
  971. _JobPostAuthorityRepository.CommitTran();
  972. return Ok(JsonView(200, "成功", new { }));
  973. }
  974. #endregion
  975. }
  976. }