Mozilla Add при попытке войти в приложение Rails, которое использует Devise - PullRequest
1 голос
/ 31 марта 2012

У меня есть приложение Rails, которое использует Devise для аутентификации пользователя.Я разрабатываю надстройку и с помощью ajax отправляю сообщение в свой маршрут входа, отправляя параметры имени пользователя и пароля (user [email] и user [password]).

Я пытаюсь отправить сообщение на маршрут xml (users / sign_in.xml), чтобы получить ответ XML.Сервер Rails работает нормально и создает сеанс.

Я выполняю это из ajax, и он возвращает успех.После этого, если я пытаюсь выполнить другой сервис, требующий аутентификации, он возвращает ошибку, которая говорит о том, что я не вошел в систему. Возможно, мне придется сохранить куки или отправить куки в следующих вызовах на сервер Rails.* Из скрипта контента я звоню:

function signInSubmit(){
    var email = $('#sign_in_email').val();
    var password = $('#sign_in_password').val();
    signIn(email, password);
}

function signIn(email, password){
    var sign_in_data = {
        'user[email]' : email,
        "user[password]" : password
    }
    var params = EncodeQueryData(sign_in_data);
    invoke("/users/sign_in", params, signInCallBack);
}

function invoke(url_method, parameters, callback){
    var url = url_api + url_method + ".xml?" + parameters;
    var req = new XMLHttpRequest();
    type = 'POST';

    req.open("POST", url, true);
    req.overrideMimeType('text/xml');
    req.onreadystatechange = function () {
        if (req.readyState == 4) {
            if (req.status == 200) {
                callback(req.responseXML);
            }else if(req.status == 201){ 
                callback(req.responseXML);
            }
        }
    };
    req.send();
}

function signInCallBack(doc){
    //This returns an XML saying that authentication was successfull.  
    // Session was created in the server
    login_session_key = doc.getElementsByTagName("email")[0].childNodes[0].nodeValue
    callMethodThatNeedsAuthentication();
}


function callMethodThatNeedsAuthentication(){
    // This method call returns a not authenticated error.
    invoke("/api/methodthatneedsauthentication", "", NeedsAuthenticationCallBack);
}

Как вы думаете?

1 Ответ

1 голос
/ 31 марта 2012

Вы правы - если вам нужно установить и использовать сеанс с приложением rails из кода SDK, и поддерживать сеанс, передавая все данные cookie, установленные приложением rails.

Я не знаюНе знаю, как работает сеанс Rails, но вам, вероятно, понадобится перехватить файл cookie сеанса, используемый rails, и повторно отправить его с последующими запросами.Я не думаю, что модуль Request позволит вам управлять cookie-файлами для этого (см. Эту ошибку: https://bugzilla.mozilla.org/show_bug.cgi?id=741156), однако я знаю, что с PHP вы можете вместо этого предоставить ключ сеанса в качестве параметра запроса.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...