petergate_api 0.2.2 → 0.2.3
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.gitignore +1 -0
- data/lib/generators/petergate_api/install_generator.rb +5 -0
- data/lib/generators/petergate_api/templates/app/controllers/api/base_controller.rb +7 -9
- data/lib/generators/petergate_api/templates/app/controllers/api/v1/auth_controller.rb +1 -1
- data/lib/generators/petergate_api/templates/app/models/api/connection.rb +2 -17
- data/lib/generators/petergate_api/templates/lib/api_user.rb +23 -0
- data/lib/petergate_api/version.rb +1 -1
- metadata +3 -2
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA1:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: a8bf0f6469cf43e2abaad4bcc7012ae9a49a12f2
|
4
|
+
data.tar.gz: d6eeda324dcdce64075d466bc9b053af2d5efb50
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 566fe11a2cf616aec852a21fe8d9838ab911a37ecac1f8d59c4d704e393763a1a37fe48211d7ec9dab2e5f14ba234e7ef8a777f0de7b1cc211625637cd0d45f4
|
7
|
+
data.tar.gz: 495cebe9cd821721f36e3e2dc4a659f8f354816133a03a9c359e5d05dcb5596f228f7e5687cbc94ba68f88a024b45fc71c8e5bc51b1933d8bb7fce5f5b87bcbd
|
data/.gitignore
CHANGED
@@ -15,6 +15,7 @@ module PetergateApi
|
|
15
15
|
|
16
16
|
def add_to_gemfile
|
17
17
|
gem "apipie-rails"
|
18
|
+
gem "jwt"
|
18
19
|
end
|
19
20
|
|
20
21
|
def insert_into_user_model
|
@@ -39,6 +40,10 @@ module PetergateApi
|
|
39
40
|
run "cp -rf #{self.class.source_root}/app/ app/"
|
40
41
|
end
|
41
42
|
|
43
|
+
def copy_lib
|
44
|
+
run "cp -rf #{self.class.source_root}/lib/ lib/"
|
45
|
+
end
|
46
|
+
|
42
47
|
def copy_initializers
|
43
48
|
run "cp -rf #{self.class.source_root}/initializers config/"
|
44
49
|
end
|
@@ -1,18 +1,16 @@
|
|
1
|
-
|
1
|
+
require 'api_user'
|
2
2
|
|
3
|
+
class Api::BaseController < ActionController::Base
|
3
4
|
def current_user
|
4
5
|
@user ||= begin
|
5
|
-
if
|
6
|
-
|
6
|
+
if request.headers["Authorization"]
|
7
|
+
# you might want to check redis or memcache to for cache invalidation
|
8
|
+
::ApiUser.new(request.headers["Authorization"])
|
7
9
|
else
|
8
|
-
nil
|
10
|
+
nil
|
9
11
|
end
|
10
12
|
end
|
11
13
|
end
|
12
14
|
|
13
|
-
|
14
|
-
@current_city ||= current_user.try(:city)
|
15
|
-
end
|
16
|
-
|
17
|
-
helper_method :current_user, :current_city
|
15
|
+
helper_method :current_user
|
18
16
|
end
|
@@ -12,7 +12,7 @@ class Api::V1::AuthController < Api::BaseController
|
|
12
12
|
}"
|
13
13
|
def create
|
14
14
|
if params[:email] && (@user = User.find_by_email(params[:email])) && @user.valid_password?(auth_params[:password])
|
15
|
-
connection = @user.api_connections.create
|
15
|
+
connection = @user.api_connections.create
|
16
16
|
render json: {id: @user.id, auth_token: connection.token, email: @user.email}.to_json, status: :ok
|
17
17
|
else
|
18
18
|
render status: :unauthorized, nothing: true
|
@@ -1,22 +1,7 @@
|
|
1
|
-
# == Schema Information
|
2
|
-
#
|
3
|
-
# Table name: api_connections
|
4
|
-
#
|
5
|
-
# id :integer not null, primary key
|
6
|
-
# user_id :integer
|
7
|
-
# token :string(255)
|
8
|
-
# meta_data :text(65535)
|
9
|
-
# device_type :string(255)
|
10
|
-
# created_at :datetime not null
|
11
|
-
# updated_at :datetime not null
|
12
|
-
#
|
13
|
-
|
14
1
|
class Api::Connection < ActiveRecord::Base
|
15
2
|
belongs_to :user, class_name: "::User"
|
16
3
|
before_create do
|
17
|
-
|
18
|
-
self.token = Base64.strict_encode64(Devise.friendly_token + user.email).strip
|
19
|
-
end while self.class.find_by(token: self.token).present?
|
4
|
+
self.token = ::ApiUser.create_token(user)
|
20
5
|
end
|
21
|
-
scope :push_tokens, -> { where(meta_data: 'push_notifications_token')}
|
22
6
|
end
|
7
|
+
|
@@ -0,0 +1,23 @@
|
|
1
|
+
require 'jwt'
|
2
|
+
|
3
|
+
class ApiUser
|
4
|
+
JWT_SECRET = "$ecr3t_tok3n!"
|
5
|
+
|
6
|
+
def initialize(token)
|
7
|
+
@jwt = JWT.decode(token, JWT_SECRET, true, {algorithm: 'HS256'}).first
|
8
|
+
@jwt.each do |k, v|
|
9
|
+
v = v.map(&:to_sym) if v.is_a?(Array)
|
10
|
+
define_singleton_method(k){v}
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
def method_missing(sym, *args, &block)
|
15
|
+
@user ||= (User.find(id) || User.first)
|
16
|
+
return @user.send(sym, *args, &block)
|
17
|
+
end
|
18
|
+
|
19
|
+
def self.create_token(user)
|
20
|
+
payload = {id: user.id, name: user.name, roles: user.roles, email: user.email}
|
21
|
+
JWT.encode(payload, JWT_SECRET, 'HS256')
|
22
|
+
end
|
23
|
+
end
|
metadata
CHANGED
@@ -1,14 +1,14 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: petergate_api
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.2.
|
4
|
+
version: 0.2.3
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Isaac Sloan
|
8
8
|
autorequire:
|
9
9
|
bindir: exe
|
10
10
|
cert_chain: []
|
11
|
-
date: 2017-
|
11
|
+
date: 2017-04-25 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: bundler
|
@@ -85,6 +85,7 @@ files:
|
|
85
85
|
- lib/generators/petergate_api/templates/app/controllers/api/v1/auth_controller.rb
|
86
86
|
- lib/generators/petergate_api/templates/app/models/api/connection.rb
|
87
87
|
- lib/generators/petergate_api/templates/initializers/apipie.rb
|
88
|
+
- lib/generators/petergate_api/templates/lib/api_user.rb
|
88
89
|
- lib/generators/petergate_api/templates/migrations/add_mobile_reset_token_to_user.rb
|
89
90
|
- lib/generators/petergate_api/templates/migrations/create_api_connections.rb
|
90
91
|
- lib/petergate_api.rb
|