GetUserPowerExcutor.cs 1.7 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Data.SqlClient;
  4. using System.Linq;
  5. using System.Text;
  6. using JLHHJSvr.BLL;
  7. using JLHHJSvr.Com;
  8. using JLHHJSvr.Com.Model;
  9. using LJLib.Net.SPI.Server;
  10. namespace JLHHJSvr.Excutor
  11. {
  12. internal sealed class GetUserPowerExcutor : ExcutorBase<GetUserPowerRequest, GetUserPowerResponse>
  13. {
  14. protected override void ExcuteInternal(GetUserPowerRequest request, object state, GetUserPowerResponse rslt)
  15. {
  16. var tokendata = BllHelper.GetToken(request.token);
  17. if (tokendata == null)
  18. {
  19. rslt.ErrMsg = "会话已经中断,请重新登录";
  20. return;
  21. }
  22. var powers = new List<int>();
  23. if (request.userid > 0)
  24. {
  25. using (var con = new SqlConnection(GlobalVar.ConnectionString))
  26. using (var cmd = con.CreateCommand())
  27. {
  28. con.Open();
  29. cmd.CommandText = "SELECT funid FROM st_user_power WHERE userid = " + request.userid;
  30. using (var reader = cmd.ExecuteReader())
  31. {
  32. while (reader.Read())
  33. {
  34. powers.Add(Convert.ToInt32(reader["funid"]));
  35. }
  36. }
  37. }
  38. }
  39. rslt.powerList = new Power().GetAllPowers();
  40. foreach (var powerItem in rslt.powerList)
  41. {
  42. if (powers.Contains(powerItem.funid.Value))
  43. {
  44. powerItem.inuse = 1;
  45. }
  46. else
  47. {
  48. powerItem.inuse = 0;
  49. }
  50. }
  51. }
  52. }
  53. }