UserSource.js 5.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193
  1. /*
  2. Copyright (C) 2017 Cloudbase Solutions SRL
  3. This program is free software: you can redistribute it and/or modify
  4. it under the terms of the GNU Affero General Public License as
  5. published by the Free Software Foundation, either version 3 of the
  6. License, or (at your option) any later version.
  7. This program is distributed in the hope that it will be useful,
  8. but WITHOUT ANY WARRANTY; without even the implied warranty of
  9. MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  10. GNU Affero General Public License for more details.
  11. You should have received a copy of the GNU Affero General Public License
  12. along with this program. If not, see <http://www.gnu.org/licenses/>.
  13. */
  14. import cookie from 'js-cookie'
  15. import Api from '../utils/ApiCaller'
  16. import { servicesUrl } from '../config'
  17. class UserModel {
  18. static parseUserData(response) {
  19. let data = {
  20. id: response.data.token.user.id,
  21. name: response.data.token.user.name,
  22. project: response.data.token.project,
  23. }
  24. return data
  25. }
  26. }
  27. class UserSource {
  28. static login(userData) {
  29. let auth = {
  30. auth: {
  31. identity: {
  32. methods: ['password'],
  33. password: {
  34. user: {
  35. name: userData.name,
  36. domain: { name: 'default' },
  37. password: userData.password,
  38. },
  39. },
  40. },
  41. scope: 'unscoped',
  42. },
  43. }
  44. Api.setDefaultHeader('X-Auth-Token', null)
  45. return new Promise((resolve, reject) => {
  46. Api.sendAjaxRequest({
  47. url: servicesUrl.identity,
  48. method: 'POST',
  49. data: auth,
  50. }).then((response) => {
  51. let token = response.headers['X-Subject-Token'] || response.headers['x-subject-token']
  52. Api.setDefaultHeader('X-Auth-Token', token)
  53. cookie.set('unscopedToken', token, { expires: 1 / 24 })
  54. resolve(response)
  55. }, reject).catch(reject)
  56. })
  57. }
  58. static loginScoped(projectId, skipCookie) {
  59. let useProjectId = skipCookie ? projectId : cookie.get('projectId') || projectId
  60. let token = cookie.get('unscopedToken')
  61. let auth = {
  62. auth: {
  63. identity: {
  64. methods: ['token'],
  65. token: {
  66. id: token,
  67. },
  68. },
  69. scope: {
  70. project: {
  71. id: useProjectId,
  72. },
  73. },
  74. },
  75. }
  76. Api.setDefaultHeader({ 'X-Auth-Token': null })
  77. return new Promise((resolve, reject) => {
  78. Api.sendAjaxRequest({
  79. url: servicesUrl.identity,
  80. method: 'POST',
  81. data: auth,
  82. }).then((response) => {
  83. let token = response.headers['X-Subject-Token'] || response.headers['x-subject-token']
  84. let data = UserModel.parseUserData(response)
  85. data = { ...data, token }
  86. cookie.set('token', data.token, { expires: 1 / 24 })
  87. cookie.set('projectId', data.project.id, { expires: 1 * 30 })
  88. Api.setDefaultHeader('X-Auth-Token', data.token)
  89. resolve(data)
  90. }, response => {
  91. if (!skipCookie) {
  92. UserSource.loginScoped(projectId, true).then(resolve, reject)
  93. } else {
  94. reject(response)
  95. }
  96. }).catch(reject)
  97. })
  98. }
  99. static tokenLogin() {
  100. let token = cookie.get('token')
  101. let projectId = cookie.get('projectId')
  102. if (token) {
  103. Api.setDefaultHeader('X-Auth-Token', token)
  104. }
  105. return new Promise((resolve, reject) => {
  106. if (!token || !projectId) {
  107. reject()
  108. return
  109. }
  110. Api.sendAjaxRequest({
  111. url: servicesUrl.identity,
  112. method: 'GET',
  113. headers: { 'X-Subject-Token': token },
  114. }).then(response => {
  115. let data = UserModel.parseUserData(response)
  116. data = { ...data, token }
  117. resolve(data)
  118. }, () => {
  119. cookie.remove('token')
  120. cookie.remove('projectId')
  121. Api.resetHeaders()
  122. reject()
  123. }).catch(() => {
  124. cookie.remove('token')
  125. cookie.remove('projectId')
  126. Api.resetHeaders()
  127. reject()
  128. })
  129. })
  130. }
  131. static switchProject() {
  132. let token = cookie.get('unscopedToken')
  133. return new Promise((resolve, reject) => {
  134. if (token) {
  135. cookie.remove('projectId')
  136. resolve()
  137. } else {
  138. reject()
  139. }
  140. })
  141. }
  142. static logout() {
  143. let token = cookie.get('token')
  144. return new Promise((resolve, reject) => {
  145. Api.sendAjaxRequest({
  146. url: servicesUrl.identity,
  147. method: 'DELETE',
  148. headers: { 'X-Subject-Token': token },
  149. }).then(() => {
  150. cookie.remove('token')
  151. window.location.href = '/'
  152. resolve()
  153. }, reject).catch(() => {
  154. cookie.remove('token')
  155. window.location.href = '/'
  156. reject()
  157. })
  158. Api.resetHeaders()
  159. })
  160. }
  161. static getUserInfo(user) {
  162. return new Promise((resolve, reject) => {
  163. Api.sendAjaxRequest({
  164. url: `${servicesUrl.users}/${user.id}`,
  165. method: 'GET',
  166. }).then((response) => {
  167. resolve(response.data.user)
  168. }, reject).catch(reject)
  169. })
  170. }
  171. }
  172. export default UserSource