snf_core 0.3.6 → 0.3.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: c44ee26535ca2c3687a171ccd8643aca7d5c93b70430801f1f3345b2c2735e34
4
- data.tar.gz: 366988a00ed4ee227d3c1c5d5f08f6077da7f13a2d85a3b2ce9fa7884f1d1729
3
+ metadata.gz: a35328a0021c1e91dd51f13689b198090fa04a2118d333f42bc4e856652bce46
4
+ data.tar.gz: 7df51380a96c5f9ad7abc4778438756b9b0af94cfc2c17ee6aa2b2ad07e7344e
5
5
  SHA512:
6
- metadata.gz: 3a8babd301598eb87c0efaa128c8f77dc55c6df08b4ea218f01073ab55fd0210182b3ac10fc15d218bde46f5f344a9df03366673c324909970517c1ba95fe714
7
- data.tar.gz: 581aea9808a0d4499306ecf90d5881e756cf03fe41982406b4e2330f6386bf43f0575a1b8576cd8de09019a6af61afe1d440b187244a8e339dc166b2286f28f4
6
+ metadata.gz: bb3c7dc5d5cf944cb52bdecb170fe9aa3f40e3e037ea8d7c4be6e316279d2191e464c74bcdd701973c5cd6359befaaa9aef070d5f1adc15a8b2e2dbfafadb7f0
7
+ data.tar.gz: 5803f1fa54fe16ed11370fb0494490cc1ee820b8a27b430b9ad05ae408b24c70778163e61d75b3a4a10b91ef124b1fc8515b7326dbf68cea0516486bb30e387e
@@ -81,6 +81,21 @@ module SnfCore
81
81
  render json: { success: true, token: token, user: user.as_json(except: [ :password_digest ]), role: role.name }
82
82
  end
83
83
 
84
+ def admin_login
85
+ user = User.find_by(phone_number: auth_params[:phone_number])
86
+ return render json: { success: false, error: "User doesn't exist" }, status: :unauthorized unless user
87
+ return render json: { success: false, error: "Invalid email or password" }, status: :unauthorized unless user.authenticate(auth_params[:password])
88
+
89
+ user_role = UserRole.find_by(user: user)
90
+ return render json: { success: false, error: "No role was assigned to your user" }, status: :unauthorized unless user_role
91
+
92
+ role = Role.find(user_role.role_id)
93
+ return render json: { success: false, error: "Unauthorized access" }, status: :unauthorized unless role.name == "Admin"
94
+
95
+ token = @token_service.encode({ user: user.as_json.except("password_digest", "created_at", "updated_at"), role: role.name })
96
+ render json: { success: true, token: token, user: user.as_json(except: [ :password_digest ]), role: role.name }
97
+ end
98
+
84
99
  private
85
100
 
86
101
  def token_service
data/config/routes.rb CHANGED
@@ -1,6 +1,6 @@
1
1
  SnfCore::Engine.routes.draw do
2
- mount SnfCore::Engine => "/snf_core"
3
2
  post "auth/login"
3
+ post "auth/admin/login", to: "auth#admin_login"
4
4
  post "auth/signup"
5
5
  post "auth/validate_token"
6
6
  end
@@ -1,3 +1,3 @@
1
1
  module SnfCore
2
- VERSION = "0.3.6"
2
+ VERSION = "0.3.7"
3
3
  end