mirror of
https://github.com/internetee/registry.git
synced 2025-05-16 09:27:19 +02:00
Add EppSession for custom session management
This commit is contained in:
parent
3a57126e69
commit
e9f23ba348
9 changed files with 92 additions and 2 deletions
|
@ -3,6 +3,7 @@ module Epp::Common
|
||||||
|
|
||||||
included do
|
included do
|
||||||
protect_from_forgery with: :null_session
|
protect_from_forgery with: :null_session
|
||||||
|
helper_method :current_epp_user
|
||||||
end
|
end
|
||||||
|
|
||||||
def proxy
|
def proxy
|
||||||
|
@ -12,4 +13,12 @@ module Epp::Common
|
||||||
def parsed_frame
|
def parsed_frame
|
||||||
Nokogiri::XML(params[:frame]).remove_namespaces!
|
Nokogiri::XML(params[:frame]).remove_namespaces!
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def epp_session
|
||||||
|
EppSession.find_or_initialize_by(session_id: cookies['session'])
|
||||||
|
end
|
||||||
|
|
||||||
|
def current_epp_user
|
||||||
|
@current_epp_user ||= EppUser.find(epp_session[:epp_user_id]) if epp_session[:epp_user_id]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -11,6 +11,7 @@ class Epp::SessionsController < ApplicationController
|
||||||
@epp_user = EppUser.find_by(login_params)
|
@epp_user = EppUser.find_by(login_params)
|
||||||
|
|
||||||
if @epp_user.try(:active)
|
if @epp_user.try(:active)
|
||||||
|
epp_session[:epp_user_id] = @epp_user.id
|
||||||
render 'login_success'
|
render 'login_success'
|
||||||
else
|
else
|
||||||
response.headers['X-EPP-Returncode'] = '2200'
|
response.headers['X-EPP-Returncode'] = '2200'
|
||||||
|
@ -19,6 +20,7 @@ class Epp::SessionsController < ApplicationController
|
||||||
end
|
end
|
||||||
|
|
||||||
def logout
|
def logout
|
||||||
|
epp_session[:epp_user_id] = nil
|
||||||
response.headers['X-EPP-Returncode'] = '1500'
|
response.headers['X-EPP-Returncode'] = '1500'
|
||||||
render 'logout'
|
render 'logout'
|
||||||
end
|
end
|
||||||
|
|
|
@ -8,7 +8,7 @@ module Epp::DomainsHelper
|
||||||
cp = command_params
|
cp = command_params
|
||||||
{
|
{
|
||||||
name: cp[:name],
|
name: cp[:name],
|
||||||
registrar: nil, #well come from current_epp_user
|
registrar_id: current_epp_user.registrar.try(:id),
|
||||||
registered_at: Time.now,
|
registered_at: Time.now,
|
||||||
valid_from: Date.today,
|
valid_from: Date.today,
|
||||||
valid_to: Date.today + cp[:period].to_i.years,
|
valid_to: Date.today + cp[:period].to_i.years,
|
||||||
|
|
31
app/models/epp_session.rb
Normal file
31
app/models/epp_session.rb
Normal file
|
@ -0,0 +1,31 @@
|
||||||
|
class EppSession < ActiveRecord::Base
|
||||||
|
before_save :marshal_data!
|
||||||
|
|
||||||
|
def data
|
||||||
|
@data ||= self.class.unmarshal(read_attribute(:data)) || {}
|
||||||
|
end
|
||||||
|
|
||||||
|
def [](key)
|
||||||
|
data[key.to_sym]
|
||||||
|
end
|
||||||
|
|
||||||
|
def []=(key, value)
|
||||||
|
data[key.to_sym] = value
|
||||||
|
save!
|
||||||
|
end
|
||||||
|
|
||||||
|
def marshal_data!
|
||||||
|
self.data = self.class.marshal(data)
|
||||||
|
end
|
||||||
|
|
||||||
|
class << self
|
||||||
|
def marshal(data)
|
||||||
|
::Base64.encode64(Marshal.dump(data)) if data
|
||||||
|
end
|
||||||
|
|
||||||
|
def unmarshal(data)
|
||||||
|
return data unless data.is_a? String
|
||||||
|
Marshal.load(::Base64.decode64(data)) if data
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
12
db/migrate/20140627082711_create_epp_sessions.rb
Normal file
12
db/migrate/20140627082711_create_epp_sessions.rb
Normal file
|
@ -0,0 +1,12 @@
|
||||||
|
class CreateEppSessions < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
create_table :epp_sessions do |t|
|
||||||
|
t.string :session_id
|
||||||
|
t.text :data
|
||||||
|
t.timestamps
|
||||||
|
end
|
||||||
|
|
||||||
|
add_index :epp_sessions, :session_id, :unique => true
|
||||||
|
add_index :epp_sessions, :updated_at
|
||||||
|
end
|
||||||
|
end
|
12
db/schema.rb
12
db/schema.rb
|
@ -11,7 +11,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended that you check this file into your version control system.
|
# It's strongly recommended that you check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(version: 20140620130107) do
|
ActiveRecord::Schema.define(version: 20140627082711) do
|
||||||
|
|
||||||
# These are extensions that must be enabled in order to support this database
|
# These are extensions that must be enabled in order to support this database
|
||||||
enable_extension "plpgsql"
|
enable_extension "plpgsql"
|
||||||
|
@ -61,6 +61,16 @@ ActiveRecord::Schema.define(version: 20140620130107) do
|
||||||
t.datetime "updated_at"
|
t.datetime "updated_at"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
create_table "epp_sessions", force: true do |t|
|
||||||
|
t.string "session_id"
|
||||||
|
t.text "data"
|
||||||
|
t.datetime "created_at"
|
||||||
|
t.datetime "updated_at"
|
||||||
|
end
|
||||||
|
|
||||||
|
add_index "epp_sessions", ["session_id"], name: "index_epp_sessions_on_session_id", unique: true, using: :btree
|
||||||
|
add_index "epp_sessions", ["updated_at"], name: "index_epp_sessions_on_updated_at", using: :btree
|
||||||
|
|
||||||
create_table "epp_users", force: true do |t|
|
create_table "epp_users", force: true do |t|
|
||||||
t.integer "registrar_id"
|
t.integer "registrar_id"
|
||||||
t.string "username"
|
t.string "username"
|
||||||
|
|
|
@ -10,6 +10,7 @@ describe 'EPP Domain', epp: true do
|
||||||
response = epp_request('create_domain.xml')
|
response = epp_request('create_domain.xml')
|
||||||
expect(response[:result_code]).to eq('1000')
|
expect(response[:result_code]).to eq('1000')
|
||||||
expect(response[:msg]).to eq('Command completed successfully')
|
expect(response[:msg]).to eq('Command completed successfully')
|
||||||
|
expect(Domain.first.registrar.name).to eq('Zone Media OÜ')
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
4
spec/fabricators/epp_session_fabricator.rb
Normal file
4
spec/fabricators/epp_session_fabricator.rb
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
Fabricator(:epp_session) do
|
||||||
|
session_id 'test'
|
||||||
|
data { {epp_user_id: 1} }
|
||||||
|
end
|
21
spec/models/epp_session.rb
Normal file
21
spec/models/epp_session.rb
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
require "rails_helper"
|
||||||
|
|
||||||
|
describe EppSession do
|
||||||
|
let(:epp_session) { Fabricate(:epp_session) }
|
||||||
|
|
||||||
|
it 'has encrypted data' do
|
||||||
|
expect(epp_session.read_attribute(:data)).to_not be_blank
|
||||||
|
expect(epp_session.read_attribute(:data).class).to eq(String)
|
||||||
|
expect(epp_session.data.class).to eq(Hash)
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'stores data' do
|
||||||
|
expect(epp_session[:epp_user_id]).to eq(1)
|
||||||
|
|
||||||
|
epp_session[:epp_user_id] = 3
|
||||||
|
expect(epp_session[:epp_user_id]).to eq(3)
|
||||||
|
|
||||||
|
epp_session = EppSession.find_by(session_id: 'test')
|
||||||
|
expect(epp_session[:epp_user_id]).to eq(3)
|
||||||
|
end
|
||||||
|
end
|
Loading…
Add table
Add a link
Reference in a new issue