PageRenderTime 57ms CodeModel.GetById 29ms RepoModel.GetById 1ms app.codeStats 0ms

/src/Server/DeviceHive.API/Controllers/UserController.cs

https://github.com/oryol/devicehive-.net
C# | 125 lines | 69 code | 14 blank | 42 comment | 18 complexity | 134706bade22e257d68aefca1949c3e4 MD5 | raw file
Possible License(s): MIT
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Net;
  5. using System.Web.Http;
  6. using DeviceHive.API.Filters;
  7. using DeviceHive.API.Mapping;
  8. using DeviceHive.Data.Model;
  9. using DeviceHive.Data.Repositories;
  10. using Newtonsoft.Json.Linq;
  11. namespace DeviceHive.API.Controllers
  12. {
  13. /// <resource cref="User" />
  14. [AuthorizeUser(Roles = "Administrator")]
  15. public class UserController : BaseController
  16. {
  17. /// <name>list</name>
  18. /// <summary>
  19. /// Gets list of users.
  20. /// </summary>
  21. /// <returns cref="User">If successful, this method returns array of <see cref="User"/> resources in the response body.</returns>
  22. public JArray Get()
  23. {
  24. return new JArray(DataContext.User.GetAll().Select(n => Mapper.Map(n)));
  25. }
  26. /// <name>get</name>
  27. /// <summary>
  28. /// Gets information about user and its assigned networks.
  29. /// </summary>
  30. /// <param name="id">User identifier.</param>
  31. /// <returns cref="User">If successful, this method returns a <see cref="User"/> resource in the response body.</returns>
  32. /// <response>
  33. /// <parameter name="networks" type="array" cref="UserNetwork">Array of networks associated with the user</parameter>
  34. /// </response>
  35. public JObject Get(int id)
  36. {
  37. var user = DataContext.User.Get(id);
  38. if (user == null)
  39. ThrowHttpResponse(HttpStatusCode.NotFound, "User not found!");
  40. var jUser = Mapper.Map(user);
  41. var userNetworkMapper = GetMapper<UserNetwork>();
  42. var userNetworks = DataContext.UserNetwork.GetByUser(id);
  43. jUser["networks"] = new JArray(userNetworks.Select(un => userNetworkMapper.Map(un)));
  44. return jUser;
  45. }
  46. /// <name>insert</name>
  47. /// <summary>
  48. /// Creates new user.
  49. /// </summary>
  50. /// <param name="json" cref="User">In the request body, supply a <see cref="User"/> resource.</param>
  51. /// <returns cref="User">If successful, this method returns a <see cref="User"/> resource in the response body.</returns>
  52. /// <request>
  53. /// <parameter name="password" type="string" required="true">User password</parameter>
  54. /// </request>
  55. [HttpCreatedResponse]
  56. public JObject Post(JObject json)
  57. {
  58. if (json["password"] == null || json["password"].Type != JTokenType.String)
  59. ThrowHttpResponse(HttpStatusCode.BadRequest, "Required 'password' property was not specified!");
  60. var user = Mapper.Map(json);
  61. user.SetPassword((string)json["password"]);
  62. Validate(user);
  63. if (DataContext.User.Get(user.Login) != null)
  64. ThrowHttpResponse(HttpStatusCode.Forbidden, "User with such login already exists!");
  65. DataContext.User.Save(user);
  66. return Mapper.Map(user);
  67. }
  68. /// <name>update</name>
  69. /// <summary>
  70. /// Updates an existing user.
  71. /// </summary>
  72. /// <param name="id">User identifier.</param>
  73. /// <param name="json" cref="User">In the request body, supply a <see cref="User"/> resource.</param>
  74. /// <returns cref="Network">If successful, this method returns a <see cref="User"/> resource in the response body.</returns>
  75. /// <request>
  76. /// <parameter name="password" type="string">User password</parameter>
  77. /// <parameter name="login" required="false" />
  78. /// <parameter name="role" required="false" />
  79. /// <parameter name="status" required="false" />
  80. /// </request>
  81. public JObject Put(int id, JObject json)
  82. {
  83. var user = DataContext.User.Get(id);
  84. if (user == null)
  85. ThrowHttpResponse(HttpStatusCode.NotFound, "User not found!");
  86. Mapper.Apply(user, json);
  87. if (json["password"] != null && json["password"].Type == JTokenType.String)
  88. user.SetPassword((string)json["password"]);
  89. Validate(user);
  90. var existing = DataContext.User.Get(user.Login);
  91. if (existing != null && existing.ID != user.ID)
  92. ThrowHttpResponse(HttpStatusCode.Forbidden, "User with such name already exists!");
  93. DataContext.User.Save(user);
  94. return Mapper.Map(user);
  95. }
  96. /// <name>delete</name>
  97. /// <summary>
  98. /// Deletes an existing user.
  99. /// </summary>
  100. /// <param name="id">User identifier.</param>
  101. [HttpNoContentResponse]
  102. public void Delete(int id)
  103. {
  104. DataContext.User.Delete(id);
  105. }
  106. private IJsonMapper<User> Mapper
  107. {
  108. get { return GetMapper<User>(); }
  109. }
  110. }
  111. }