Skip to Content
Odoo Menu
  • Log ind
  • Prøv gratis
  • apps
    Økonomi
    • Bogføring
    • Fakturering
    • Udgifter
    • Regneark (BI)
    • Dokumenter
    • e-Signatur
    Salg
    • CRM
    • Salg
    • POS Butik
    • POS Restaurant
    • Abonnementer
    • Udlejning
    Hjemmeside
    • Hjemmesidebygger
    • e-Handel
    • Blog
    • Forum
    • LiveChat
    • e-Læring
    Forsyningskæde
    • Lagerbeholdning
    • Produktion
    • PLM
    • Indkøb
    • Vedligeholdelse
    • Kvalitet
    HR
    • Medarbejdere
    • Rekruttering
    • Fravær
    • Medarbejdersamtaler
    • Anbefalinger
    • Flåde
    Marketing
    • Markedsføring på sociale medier
    • E-mailmarketing
    • SMS-marketing
    • Arrangementer
    • Automatiseret marketing
    • Spørgeundersøgelser
    Tjenester
    • Projekt
    • Timesedler
    • Udkørende Service
    • Kundeservice
    • Planlægning
    • Aftaler
    Produktivitet
    • Dialog
    • Godkendelser
    • IoT
    • VoIP
    • Vidensdeling
    • WhatsApp
    Tredjepartsapps Odoo Studio Odoo Cloud-platform
  • Brancher
    Detailhandel
    • Boghandel
    • Tøjforretning
    • Møbelforretning
    • Dagligvarebutik
    • Byggemarked
    • Legetøjsforretning
    Mad og værtsskab
    • Bar og pub
    • Restaurant
    • Fastfood
    • Gæstehus
    • Drikkevareforhandler
    • Hotel
    Ejendom
    • Ejendomsmægler
    • Arkitektfirma
    • Byggeri
    • Ejendomsadministration
    • Havearbejde
    • Boligejerforening
    Rådgivning
    • Regnskabsfirma
    • Odoo-partner
    • Marketingbureau
    • Advokatfirma
    • Rekruttering
    • Audit & certificering
    Produktion
    • Tekstil
    • Metal
    • Møbler
    • Fødevareproduktion
    • Bryggeri
    • Firmagave
    Heldbred & Fitness
    • Sportsklub
    • Optiker
    • Fitnesscenter
    • Kosmetolog
    • Apotek
    • Frisør
    Håndværk
    • Handyman
    • IT-hardware og support
    • Solenergisystemer
    • Skomager
    • Rengøringsservicer
    • VVS- og ventilationsservice
    Andet
    • Nonprofitorganisation
    • Miljøagentur
    • Udlejning af billboards
    • Fotografi
    • Cykeludlejning
    • Softwareforhandler
    Gennemse alle brancher
  • Community
    Få mere at vide
    • Tutorials
    • Dokumentation
    • Certificeringer
    • Oplæring
    • Blog
    • Podcast
    Bliv klogere
    • Udannelselsesprogram
    • Scale Up!-virksomhedsspillet
    • Besøg Odoo
    Få softwaren
    • Download
    • Sammenlign versioner
    • Udgaver
    Samarbejde
    • Github
    • Forum
    • Arrangementer
    • Oversættelser
    • Bliv partner
    • Tjenester til partnere
    • Registrér dit regnskabsfirma
    Modtag tjenester
    • Find en partner
    • Find en bogholder
    • Kontakt en rådgiver
    • Implementeringstjenester
    • Kundereferencer
    • Support
    • Opgraderinger
    Github Youtube Twitter LinkedIn Instagram Facebook Spotify
    +1 (650) 691-3277
    Få en demo
  • Prissætning
  • Hjælp

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Bogføring
  • Lager
  • PoS
  • Projekt
  • MRP
All apps
Du skal være registreret for at interagere med fællesskabet.
All Posts People Emblemer
Tags (View all)
odoo accounting v14 pos v15
Om dette forum
Du skal være registreret for at interagere med fællesskabet.
All Posts People Emblemer
Tags (View all)
odoo accounting v14 pos v15
Om dette forum
Hjælp

Error 400: redirect_uri_mismatch

Tilmeld

Få besked, når der er aktivitet på dette indlæg

Dette spørgsmål er blevet anmeldt
oauth2v18
4 Besvarelser
5584 Visninger
Avatar
Martin Riley

Hi,


I'd greatly appreciate any help with the following.


Problem

I'm trying to enable "login with Google" on my website but I keep getting the above error. 


Setup

  • Odoo version: v18 Community Edition
  • Server: Cloud server
  • Web Protocol: HTTPS, using NGINX as a reverse proxy
  • web.base.url: https://my-domain.com
  • web.base.url.freeze: True

Nginx Configuration

server {
    server_name my-domain.com www.my-domain.com subdomain.my-domain.com;

    proxy_buffers 16 64k;
    proxy_buffer_size 128k;

    # Proxy requests to Odoo
    location / {
        proxy_pass http://127.0.0.1:8069;
        proxy_set_header Host $host;
        proxy_set_header X-Forwarded-Host $host;
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header X-Forwarded-Proto $scheme;
​}

# Gzip configuration
    gzip_types text/css text/less text/plain text/xml application/xml application/json application/javascript;
    gzip on;

    listen 443 ssl; # managed by Certbot
    ssl_certificate /etc/letsencrypt/live/my-domain.com/fullchain.pem; # managed by Certbot
    ssl_certificate_key /etc/letsencrypt/live/my-domain.com/privkey.pem; # managed by Certbot
    include /etc/letsencrypt/options-ssl-nginx.conf; # managed by Certbot
    ssl_dhparam /etc/letsencrypt/ssl-dhparams.pem; # managed by Certbot
}

​server {
    if ($host = subdomain.my-domain.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    if ($host = www.my-domain.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    if ($host = my-domain.com) {
        return 301 https://$host$request_uri;
    } # managed by Certbot


    listen 80;
    server_name my-domain.com www.my-domain.com subdomain.my-domain.com;
    return 404; # managed by Certbot
}


Odoo Config File

[options]
admin_passwd = ********
db_host = False
db_port = False
db_user = odoo
db_password = False
addons_path = /opt/odoo/odoo/addons,/opt/odoo/custom-addons
logfile = /var/log/odoo/odoo.log
proxy_mode = True


Oauth2 Error

Error 400: redirect_uri_mismatch

You can't sign in to this app because it doesn't comply with Google's OAuth 2.0 policy.

If you're the app developer, register the redirect URI in the Google Cloud Console.

Request details: redirect_uri=http://www.my-domain/auth_oauth/signin flowName=GeneralOAuthFlow


Observations

It appears that, despite https working correctly on the site, NGINX is still passing http to Google.


Temporary Workaround

If I add the http version of my domain to my Google cloud project, it works correctly and allows test users to sign up and log in, but the drawback is that you can't publish the app with http URIs and I need external users to have this functionality.


Other Things I've Tried

I saw on one of the thousands of posts I've googled that what's being passed to Google is a Werkzeug variable that's picked up automatically from the sitemap. I don't know how accurate this information is but I acted on it and manually edited the sitemap, replacing http with https. This made no difference.


Conclusion

I have no idea why ths isn't working as expected and I don't understand why it's so difficult.

I'm already bald but if I had any hair, I would have pulled it all out by now!

Please help 🙏🏾

1
Avatar
Kassér
Avatar
Nikolay Kolesnyk
Bedste svar

Change Nginx Parameter

 proxy_set_header Host $host;

To proxy_set_header X-Forwarded-Host $host;

0
Avatar
Kassér
Avatar
Diego Naranjo
Bedste svar

Hi everyone!

In my case, with Odoo 18 with Nginx and despite having the web.base.url set to HTTPS, the Google OAuth authentication wasn't working. After analyzing and updating the code to make it more flexible, I've created a fixed version of the auth_oauth module that solves the common issues.


🔧 Issues Resolved:

🔒 HTTP URLs being sent to Google OAuth2

👤 Authentication failure with existing users

🌐 Google's redirect_uri_mismatch error

✉️ Duplicate email handling


💻 Code Improvements and changes made:

In controllers/main.py - list_providers method:


Added logic to force HTTPS on redirect URL Prevents Google rejection for HTTP use Maintains compatibility with existing configurations


  • Changes made in file main.py


  def list_providers(self):

      try:

          providers = request.env['auth.oauth.provider'].sudo().search_read([('enabled', '=', True)])

      except Exception:

          providers = []

      for provider in providers:

          # Force HTTPS in redirect URL

          base_url = request.httprequest.url_root

          if base_url.startswith('http://'):

              base_url = base_url.replace('http://', 'https://', 1)

          return_url = base_url + 'auth_oauth/signin'

          state = self.get_state(provider)

          params = dict(

              response_type='token',

              client_id=provider['client_id'],

              redirect_uri=return_url,

              scope=provider['scope'],

              state=json.dumps(state),

              # nonce=base64.urlsafe_b64encode(os.urandom(16)),

          )

          provider['auth_link'] = "%s?%s" % (provider['auth_endpoint'], werkzeug.urls.url_encode(params))

      return providers


  • Changes made in /models/res_users.py

 _auth_oauth_validate method:

Added detailed logging of the validation process Better error handling and response validation Clearer information about the authentication process


 _auth_oauth_signin method:

User search by email was implemented in addition to oauth_uid Automatic management of existing users Updating OAuth credentials for existing users Improved logging for diagnostics


@api.model

  def _auth_oauth_validate(self, provider, access_token):

          """ return the validation data corresponding to the access token """

          oauth_provider = self.env['auth.oauth.provider'].browse(provider)

          validation = self._auth_oauth_rpc(oauth_provider.validation_endpoint, access_token)

          if validation.get("error"):

              _logger.error("OAuth validation error: %s", validation['error'])

              raise Exception(validation['error'])

          if oauth_provider.data_endpoint:

              data = self._auth_oauth_rpc(oauth_provider.data_endpoint, access_token)

              validation.update(data)

          # Logging the validation data

          subject = next(filter(None, [

              validation.pop(key, None)

              for key in [

                  'sub',  # standard

                  'id',  # google v1 userinfo, facebook opengraph

                  'user_id',  # google tokeninfo, odoo (tokeninfo)

              ]

          ]), None)

          if not subject:

              _logger.error("Missing subject identity in validation data")

              raise AccessDenied('Missing subject identity')

          validation['user_id'] = subject

          return validation


  @api.model

  def _auth_oauth_signin(self, provider, validation, params):

          """ retrieve and sign in the user corresponding to provider and validated access token

              :param provider: oauth provider id (int)

              :param validation: result of validation of access token (dict)

              :param params: oauth parameters (dict)

              :return: user login (str)

              :raise: AccessDenied if signin failed

              This method can be overridden to add alternative signin methods.

          """

          oauth_uid = validation['user_id']

          email = validation.get('email')

          try:

              # First search for oauth_uid

              oauth_user = self.search([("oauth_uid", "=", oauth_uid), ('oauth_provider_id', '=', provider)])

              if not oauth_user and email:

                  # If not found, search by email.

                  oauth_user = self.search([("login", "=", email)])

                  if oauth_user:

                      # If the user with that email exists, we update their OAuth data

                      oauth_user.write({

                          'oauth_provider_id': provider,

                          'oauth_uid': oauth_uid,

                          'oauth_access_token': params['access_token']

                      })

              if not oauth_user:

                  raise AccessDenied()

              assert len(oauth_user) == 1

              oauth_user.write({'oauth_access_token': params['access_token']})

              return oauth_user.login

          except AccessDenied as access_denied_exception:

              if self.env.context.get('no_user_creation'):

                  return None

              state = json.loads(params['state'])

              token = state.get('t')

              values = self._generate_signup_values(provider, validation, params)

              try:

                  login, _ = self.signup(values, token)

                  return login

              except (SignupError, UserError) as e:

                  _logger.error("Failed to create new user: %s", str(e))

                  raise access_denied_exception

You can find it on github:

(Sorry but I can't post links yet.)


diegonaranjo/odoo-addons-auth_oauth


Please make sure to backup your existing module before making any changes. If you encounter any issues or need help, feel free to open an issue on the GitHub repository.

Hope this helps!

0
Avatar
Kassér
Avatar
Martin Riley
Forfatter Bedste svar

I've found a solution.

he issue stems from a bug in Odoo's code. The code uses an HTTP request to get your website's URL, but this function relies on a Werkzeug variable, and it completely ignores the web.base.url parameter that you've set in Odoo's settings. If you're running Odoo behind a proxy(like NGINX), the resulting URL will always be wrong.


I corrected this error by rewriting the code to use the web.base.url parameter as a means of retrieving the site's URL, thus bypassing Werkzeug completely. Here's an example of the code I used:


request.env['ir.config_parameter'].sudo().get_param('web.base.url')


Please note that the function MUST be run as sudo. If not, you'll get "403 - access denied" errors".


My advice to you is to be this:


search the Odoo repository on GitHub for references to "base_URL".


Where they appear in files relating to Google authentication, edit the corresponding file on your server by replacing those lines with the code example above.


Good luck!


0
Avatar
Kassér
Avatar
Madhur
Bedste svar

I am facing this error. Tried all solution on the forums. Please help.

0
Avatar
Kassér
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Tilmeld dig
Related Posts Besvarelser Visninger Aktivitet
Change Sign & Pay Button on Quotation E-mails
v18
Avatar
Avatar
Avatar
Avatar
3
nov. 25
374
Problem including JS asset in v18
v18
Avatar
Avatar
Avatar
3
nov. 25
8461
Is it possible to sell on credit directly at the point of sale and leave the order pending payment?
v18
Avatar
Avatar
2
sep. 25
775
Is OAuth2 supported in the Odoo 18 Community Edition?
oauth2
Avatar
Avatar
Avatar
2
sep. 25
3325
How to segrigate a product into multiple products & at the same time i have to manufacture that product also with separate BOM? Løst
v18
Avatar
Avatar
1
jun. 25
1923
Community
  • Tutorials
  • Dokumentation
  • Forum
Open Source
  • Download
  • Github
  • Runbot
  • Oversættelser
Tjenester
  • Odoo.sh-hosting
  • Support
  • Opgradere
  • Individuelt tilpasset udvikling
  • Uddannelse
  • Find en bogholder
  • Find en partner
  • Bliv partner
Om os
  • Vores virksomhed
  • Brandaktiver
  • Kontakt os
  • Stillinger
  • Arrangementer
  • Podcast
  • Blog
  • Kunder
  • Juridiske dokumenter • Privatlivspolitik
  • Sikkerhedspolitik
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo er en samling open source-forretningsapps, der dækker alle dine virksomhedsbehov – lige fra CRM, e-handel og bogføring til lagerstyring, POS, projektledelse og meget mere.

Det unikke ved Odoo er, at systemet både er brugervenligt og fuldt integreret.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now