質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

87.37%

【rails】omniauth(Twitter)で「/auth/failure」が返ってくる

受付中

回答 0

投稿

  • 評価
  • クリップ 2
  • VIEW 932

score 59

CentOS7
rails6
nginx
unicorn

上記の環境でアプリを作っています。
TwitterのAPIを使用してログイン機能を作ったのですが、SSL化した本番環境でうまく動きません。

Twitterでログインをすると、
「auth/failure?message=invalid_credentials&strategy=twitter」
と返ってきます。しかし、認証はうまくできているのです。
正直自分でもどういう状況かよく分からないのですが、
「auth/failure?message=invalid_credentials&strategy=twitter」と「/auth/twitter/callback」が
同時に返ってきてる(?)という状況です。
ssl化をする前には正常に動いていたので、nginxに問題があるのかと思うのですが、分からないです。
以下はnginxの設定です。

user user;
worker_processes auto;
error_log /var/log/nginx/error.log;
pid /run/nginx.pid;

# Load dynamic modules. See /usr/share/nginx/README.dynamic.
include /usr/share/nginx/modules/*.conf;

events {
    worker_connections 1024;
}

http {
    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile            on;
    tcp_nopush          on;
    tcp_nodelay         on;
    keepalive_timeout   65;
    types_hash_max_size 2048;

    include             /etc/nginx/mime.types;
    default_type        application/octet-stream;

    include /etc/nginx/conf.d/*.conf;

    upstream unicorn {
        server unix:/home/user/app/tmp/unicorn.sock;
    }

    server {
        listen       80;
        server_name  app.com;
        return 301 https://$host$request_uri;        
    }

    server {
        listen       443 ssl;
        server_name  app.com;
        # root         /usr/share/nginx/html;
        root         /home/user/app/public;
        client_max_body_size 70m;

        ssl on;
        ssl_certificate "/etc/nginx/ssl.crt/server.crt";
        ssl_certificate_key "/etc/nginx/ssl.key/server.key";
        ssl_session_cache shared:SSL:1m;
        ssl_session_timeout  10m;
        ssl_ciphers HIGH:!aNULL:!MD5;
        ssl_prefer_server_ciphers on;

        try_files $uri/index.html $uri @unicorn;

        # Load configuration files for the default server block.
        include /etc/nginx/default.d/*.conf;

        location ~ ^/assets/ {
            root /home/user/app/public;
        }

        location @unicorn {
            root /home/user/app/public;

            proxy_set_header Host $http_host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-Proto https;
            proxy_set_header X-Forwarded-Host $host;
            proxy_set_header X-Forwarded-Server $host;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_redirect http:// https://;
            proxy_pass http://unicorn;
        }

        error_page   404 500 502 503 504  /error.html;
        location = /error.html {
            root   /usr/share/nginx/html;
        }
    }
}


対処法をご存じの方はご教授願います。
不足している情報等あれば教えてください。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 過去に投稿した質問と同じ内容の質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

まだ回答がついていません

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 87.37%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

関連した質問

同じタグがついた質問を見る