Users model and integration
This commit is contained in:
parent
93130968fd
commit
49f1fba33a
|
@ -14,6 +14,18 @@ class UserController < ApplicationController
|
||||||
|
|
||||||
if Digest::MD5.hexdigest(hash) == params[:sig]
|
if Digest::MD5.hexdigest(hash) == params[:sig]
|
||||||
@res[:status] = 'hello'
|
@res[:status] = 'hello'
|
||||||
|
user = User.find_by_vkid(params[:mid])
|
||||||
|
if user.nil?
|
||||||
|
user = User.new
|
||||||
|
user.vkid = params[:mid]
|
||||||
|
user.save
|
||||||
|
end
|
||||||
|
if user.name.nil? and not params[:name].nil?
|
||||||
|
user.name = params[:name]
|
||||||
|
user.save
|
||||||
|
end
|
||||||
|
@res[:id] = user.id
|
||||||
|
@res[:username] = user.name
|
||||||
else
|
else
|
||||||
@res[:status] = 'bad signature'
|
@res[:status] = 'bad signature'
|
||||||
end
|
end
|
||||||
|
|
|
@ -0,0 +1,2 @@
|
||||||
|
class User < ActiveRecord::Base
|
||||||
|
end
|
|
@ -0,0 +1,15 @@
|
||||||
|
class CreateUsers < ActiveRecord::Migration
|
||||||
|
def self.up
|
||||||
|
create_table :users do |t|
|
||||||
|
t.string :name
|
||||||
|
t.string :email
|
||||||
|
t.integer :vkid
|
||||||
|
|
||||||
|
t.timestamps
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
def self.down
|
||||||
|
drop_table :users
|
||||||
|
end
|
||||||
|
end
|
10
db/schema.rb
10
db/schema.rb
|
@ -10,7 +10,7 @@
|
||||||
#
|
#
|
||||||
# It's strongly recommended to check this file into your version control system.
|
# It's strongly recommended to check this file into your version control system.
|
||||||
|
|
||||||
ActiveRecord::Schema.define(:version => 20110618191349) do
|
ActiveRecord::Schema.define(:version => 20110621001100) do
|
||||||
|
|
||||||
create_table "albums", :force => true do |t|
|
create_table "albums", :force => true do |t|
|
||||||
t.string "name"
|
t.string "name"
|
||||||
|
@ -62,4 +62,12 @@ ActiveRecord::Schema.define(:version => 20110618191349) do
|
||||||
t.string "country"
|
t.string "country"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
create_table "users", :force => true do |t|
|
||||||
|
t.string "name"
|
||||||
|
t.string "email"
|
||||||
|
t.integer "vkid"
|
||||||
|
t.datetime "created_at"
|
||||||
|
t.datetime "updated_at"
|
||||||
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
|
@ -19,6 +19,7 @@
|
||||||
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/audio.js"></script>
|
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/audio.js"></script>
|
||||||
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/player.js"></script>
|
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/player.js"></script>
|
||||||
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/vkontakte.js"></script>
|
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/vkontakte.js"></script>
|
||||||
|
<script type="text/javascript" charset="utf-8" src="/javascripts/beathaven/session.js"></script>
|
||||||
<script type="text/javascript" charset="windows-1251" src="http://vkontakte.ru/js/api/openapi.js"></script>
|
<script type="text/javascript" charset="windows-1251" src="http://vkontakte.ru/js/api/openapi.js"></script>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
|
|
|
@ -0,0 +1,5 @@
|
||||||
|
var Session = {
|
||||||
|
|
||||||
|
user_id: null,
|
||||||
|
vkid: null
|
||||||
|
}
|
|
@ -5,8 +5,18 @@ function authInfo(response) {
|
||||||
if ($('#search_field').length > 0) {
|
if ($('#search_field').length > 0) {
|
||||||
$('#search_field').focus();
|
$('#search_field').focus();
|
||||||
}
|
}
|
||||||
|
$.post('/user/auth', response.session, function(ar){
|
||||||
|
if (!ar.username) {
|
||||||
VK.Api.call('getVariable', {key: 1281}, function(r) {
|
VK.Api.call('getVariable', {key: 1281}, function(r) {
|
||||||
$('#header-container .hello').text('Hi there, '+ r.response +'!');
|
response.session.name = r.response;
|
||||||
|
$.post('/user/auth', response.session, function(ar2) {
|
||||||
|
$('#header-container .hello').text('Hi there, '+ ar2.username +'!');
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
$('#header-container .hello').text('Hi there, '+ (ar.username ? ar.username : '%username%') +'!');
|
||||||
|
Session.user_id = ar.id;
|
||||||
|
Session.vkid = response.session.mid;
|
||||||
});
|
});
|
||||||
} else {
|
} else {
|
||||||
$('#vk_login, .auth_notice').css('display', 'block');
|
$('#vk_login, .auth_notice').css('display', 'block');
|
||||||
|
|
|
@ -0,0 +1,11 @@
|
||||||
|
# Read about fixtures at http://ar.rubyonrails.org/classes/Fixtures.html
|
||||||
|
|
||||||
|
one:
|
||||||
|
name: MyString
|
||||||
|
email: MyString
|
||||||
|
vkid: 1
|
||||||
|
|
||||||
|
two:
|
||||||
|
name: MyString
|
||||||
|
email: MyString
|
||||||
|
vkid: 1
|
|
@ -0,0 +1,8 @@
|
||||||
|
require 'test_helper'
|
||||||
|
|
||||||
|
class UserTest < ActiveSupport::TestCase
|
||||||
|
# Replace this with your real tests.
|
||||||
|
test "the truth" do
|
||||||
|
assert true
|
||||||
|
end
|
||||||
|
end
|
Loading…
Reference in New Issue