roles_controller.rb 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145
  1. # Copyright (C) 2012-2014 Zammad Foundation, http://zammad-foundation.org/
  2. class RolesController < ApplicationController
  3. before_filter :authentication_check
  4. =begin
  5. Format:
  6. JSON
  7. Example:
  8. {
  9. "id":1,
  10. "name":"some role",
  11. "note":"some note",
  12. "updated_at":"2012-09-14T17:51:53Z",
  13. "created_at":"2012-09-14T17:51:53Z",
  14. "updated_by_id":2,
  15. "created_by_id":2,
  16. }
  17. =end
  18. =begin
  19. Resource:
  20. GET /api/v1/roles.json
  21. Response:
  22. [
  23. {
  24. "id": 1,
  25. "name": "some_name1",
  26. ...
  27. },
  28. {
  29. "id": 2,
  30. "name": "some_name2",
  31. ...
  32. }
  33. ]
  34. Test:
  35. curl http://localhost/api/v1/roles.json -v -u #{login}:#{password}
  36. =end
  37. def index
  38. model_index_render(Role, params)
  39. end
  40. =begin
  41. Resource:
  42. GET /api/v1/roles/#{id}.json
  43. Response:
  44. {
  45. "id": 1,
  46. "name": "name_1",
  47. ...
  48. }
  49. Test:
  50. curl http://localhost/api/v1/roles/#{id}.json -v -u #{login}:#{password}
  51. =end
  52. def show
  53. model_show_render(Role, params)
  54. end
  55. =begin
  56. Resource:
  57. POST /api/v1/roles.json
  58. Payload:
  59. {
  60. "name": "some name",
  61. "note": "",
  62. "active":true,
  63. }
  64. Response:
  65. {
  66. "id": 1,
  67. "name": "some_name",
  68. ...
  69. }
  70. Test:
  71. curl http://localhost/api/v1/roles.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X POST -d '{"name": "some_name","active": true, "note": "some note"}'
  72. =end
  73. def create
  74. return if deny_if_not_role('Admin')
  75. model_create_render(Role, params)
  76. end
  77. =begin
  78. Resource:
  79. PUT /api/v1/roles/{id}.json
  80. Payload:
  81. {
  82. "name": "some name",
  83. "note": "",
  84. "active":true,
  85. }
  86. Response:
  87. {
  88. "id": 1,
  89. "name": "some_name",
  90. ...
  91. }
  92. Test:
  93. curl http://localhost/api/v1/roles.json -v -u #{login}:#{password} -H "Content-Type: application/json" -X PUT -d '{"name": "some_name","active": true, "note": "some note"}'
  94. =end
  95. def update
  96. return if deny_if_not_role('Admin')
  97. model_update_render(Role, params)
  98. end
  99. =begin
  100. Resource:
  101. Response:
  102. Test:
  103. =end
  104. def destroy
  105. return if deny_if_not_role('Admin')
  106. model_destory_render(Role, params)
  107. end
  108. end