Skip to Content
Odoo मेन्यू
  • Sign in
  • मुफ़्त में आज़माएं
  • ऐप्लिकेशन
    फ़ाइनेंस
    • अकाउंटिंग
    • इनवॉइसिंग
    • एक्सपेंस
    • स्प्रेडशीट (बीआई)
    • डॉक्यूमेंट्स
    • साइन
    सेल्स
    • सीआरएम
    • सेल्स
    • पीओएस शॉप
    • पीओएस रेस्टोरेंट
    • सब्सक्रिप्शन
    • रेंटल
    वेबसाइट
    • वेबसाइट बिल्डर
    • ई-कॉमर्स
    • ब्लॉग
    • फ़ोरम
    • लाइव चैट
    • ई-लर्निंग
    सप्लाई चेन
    • इन्वेंट्री
    • मैन्युफ़ैक्चरिंग
    • पीएलएम
    • परचेज़
    • मेंटेनेंस
    • क्वालिटी
    मानव संसाधन
    • कर्मचारी
    • रिक्रूटमेंट
    • टाइम ऑफ़
    • अप्रेज़ल
    • रेफ़रल
    • फ़्लीट
    मार्केटिंग
    • सोशल मार्केटिंग
    • ईमेल मार्केटिंग
    • एसएमएस मार्केटिंग
    • इवेंट
    • मार्केटिंग ऑटोमेशन
    • सर्वे
    सेवाएं
    • प्रोजेक्ट
    • टाइमशीट
    • फ़ील्ड सर्विस
    • हेल्पडेस्क
    • प्लानिंग
    • अपॉइंटमेंट
    प्रॉडक्टिविटी
    • डिस्कस
    • अप्रूवल
    • आईओटी
    • वीओआईपी
    • नॉलेज
    • WhatsApp
    तीसरे पक्ष के ऐप्लिकेशन Odoo स्टूडियो Odoo क्लाउड प्लेटफ़ॉर्म
  • इंडस्ट्री
    रीटेल
    • बुक स्टोर
    • क्लोदिंग स्टोर
    • फ़र्नीचर स्टोर
    • ग्रॉसरी स्टोर
    • हार्डवेयर स्टोर
    • टॉय स्टोर
    Food & Hospitality
    • बार और पब
    • रेस्टोरेंट
    • फ़ास्ट फ़ूड
    • Guest House
    • बेवरिज डिस्ट्रीब्यूटर
    • होटल
    रियल एस्टेट
    • Real Estate Agency
    • आर्किटेक्चर फ़र्म
    • कंसट्रक्शन
    • एस्टेट मैनेजमेंट
    • गार्ड्निंग
    • प्रॉपर्टी ओनर असोसिएशन
    कंसल्टिंग
    • अकाउंटिंग फ़र्म
    • Odoo पार्टनर
    • मार्केटिंग एजेंसी
    • लॉ फ़र्म
    • टैलेंट ऐक्विज़िशन
    • ऑडिट & सर्टिफ़िकेशन
    मैन्युफ़ैक्चरिंग
    • टेक्सटाइल
    • Metal
    • फ़र्नीचर
    • फ़ूड
    • Brewery
    • कॉर्पोरेट गिफ़्ट
    हेल्थ & फिटनेस
    • स्पोर्ट्स क्लब
    • आईवियर स्टोर
    • फिटनेस सेंटर
    • वेलनेस प्रैक्टिशनर
    • फॉर्मेसी
    • हेयर सैलून
    Trades
    • Handyman
    • आईटी हॉर्डवेयर और सपोर्ट
    • Solar Energy Systems
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    अन्य
    • Nonprofit Organization
    • एन्वायरमेंटल एजेंसी
    • बिलबोर्ड रेंटल
    • फ़ोटोग्राफी
    • बाइक लीजिंग
    • सॉफ़्टवेयर रीसेलर
    Browse all Industries
  • कम्यूनिटी
    सीखें
    • ट्यूटोरियल्स
    • दस्तावेज़
    • सर्टिफ़िकेशन
    • ट्रेनिंग
    • ब्लॉग
    • पॉडकास्ट
    शिक्षा को बढ़ावा दें
    • एजुकेशन प्रोग्राम
    • स्केल अप! बिजनेस गेम
    • Odoo के ऑफ़िस में आएं
    सॉफ़्टवेयर पाएं
    • डाउनलोड
    • वर्शन की तुलना करें
    • रिलीज़
    साथ मिलकर काम करें
    • Github
    • फ़ोरम
    • इवेंट
    • अनुवाद
    • पार्टनर बनें
    • Services for Partners
    • अपना अकाउंटिंग फ़र्म रजिस्टर करें
    सेवाएं पाएं
    • पार्टनर ढूंढें
    • अकाउंटेंट खोजें
    • सलाहकार की मदद लें
    • इम्प्लिमेंटेशन सेवाएं
    • कस्टमर रेफ़रेंस
    • सहायता
    • अपग्रेड
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    डेमो देखें
  • कीमत
  • सहायता

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

  • सीआरएम
  • e-Commerce
  • लेखांकन
  • इन्वेंटरी
  • PoS
  • प्रोजेक्ट
  • MRP
All apps
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
You need to be registered to interact with the community.
All Posts People Badges
टैग (View all)
odoo accounting v14 pos v15
About this forum
Help

Login to my odoo 17 instance using api key generated from default settings in preferences. Thanks in advance.

Subscribe

Get notified when there's activity on this post

This question has been flagged
apitokenuser authenticationflask
3933 Views
Avatar
Sri Haari

Using flask library there is a python script where i get to run it from my local using python command: python odoo_login_via_api.py. Now with using static username and password variables, the endpoint /odoo_login is working fine But upon using the variable API_KEY instead of username and password, I get this error:

{"error":"Authentication failed"}

My Code:

import requests
from flask import Flask, redirect, jsonify, session, make_response
from flask_session import Session

app = Flask(__name__)

# Configure Flask session storage
app.config["SECRET_KEY"] = "supersecretkey"
app.config["SESSION_TYPE"] = "filesystem"
Session(app)

# Odoo Credentials
ODOO_URL = "https://my-odoo-instance.odoo-test.com"
DB = "test_db"
USERNAME = "admin"
PASSWORD = "admin"
API_KEY = "82f762b0dcae925432a9b553f77421ff28649076"

def authenticate():
    """Authenticate with Odoo and return the session ID."""
    auth_url = f"{ODOO_URL}/web/session/authenticate"
    auth_data = {
        "jsonrpc": "2.0",
        "params": {
            "db": DB,
            "login": USERNAME,
            "password": PASSWORD,
        }
    }
   

    session_req = requests.Session()
    response = session_req.post(auth_url, json=auth_data)
    print("Response------>", response)

    if response.status_code == 200 and response.json().get("result", {}).get("uid"):
        session_id = session_req.cookies.get("session_id")
        return session_id
    return None


def check_session(session_id):
    """Check if the session is still valid in Odoo."""
    session_check_url = f"{ODOO_URL}/web/session/ping"
    cookies = {"session_id": session_id}
   
    response = requests.get(session_check_url, cookies=cookies)
   
    # If response is valid, the session is active.
    return response.status_code == 200


@app.route("/odoo_login")
def login():
    """Handle login by checking stored session ID or authenticating again."""
    if "session_id" in session:
        stored_session_id = session["session_id"]
        print(f"Using stored session_id: {stored_session_id}")
       
        # Check if the session is still valid
        if check_session(stored_session_id):
            # Create response object and pass session_id in URL and cookies
            response = make_response(redirect(f"{ODOO_URL}/web?session_id={stored_session_id}"))
            response.set_cookie("session_id", stored_session_id, domain=".odoo-test.com", path="/", secure=True)
            print(f"Redirecting to {ODOO_URL}/web with session_id.")
            return response
        else:
            print("Session expired, Authenticating Again...")
   
    # First-time login or expired session
    new_session_id = authenticate()
    if new_session_id:
        session["session_id"] = new_session_id  # Store session ID
        print(f"New session_id created: {new_session_id}")
       
        # Create response object and set session cookie for Odoo
        response = make_response(redirect(f"{ODOO_URL}/web?session_id={new_session_id}"))
        response.set_cookie("session_id", new_session_id, domain=".odoo-test.com", path="/", secure=True)
        print(f"Redirecting to {ODOO_URL}/web with new session_id.")
        return response

    return jsonify({"error": "Authentication failed"}), 401


@app.route("/odoo_logout")
def logout():
    """Clear stored session ID."""
    session.pop("session_id", None)
    print("Logged out and session_id cleared.")
    return jsonify({"message": "Logged out"})


if __name__ == "__main__":
    app.run(debug=True)
0
Avatar
Discard
Enjoying the discussion? Don't just read, join in!

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

Sign up
Related Posts Replies Views Activity
Looking for help for good pratictices for external Token management
api token odoo
Avatar
0
मई 22
2594
Calling one controller method of one module to another controller of other module
api controllers token odoo odoo12
Avatar
Avatar
3
मई 21
14432
How do I get Product Prices with json API? Solved
api
Avatar
Avatar
1
नव॰ 25
3266
Has anyone integrated Helpdesk with Zoom for meeting scheduling?
api
Avatar
Avatar
1
अग॰ 25
1497
Using API check if Odoo is using Odoo sh or on-premises hosting. Solved
api
Avatar
Avatar
1
अग॰ 25
1945
कम्यूनिटी
  • ट्यूटोरियल्स
  • दस्तावेज़
  • फ़ोरम
ओपन सोर्स
  • डाउनलोड
  • Github
  • रनबॉट
  • अनुवाद
सेवाएं
  • Odoo.sh Hosting
  • सहायता
  • अपग्रेड
  • कस्टम डेवलपमेंट्स
  • शिक्षा
  • अकाउंटेंट खोजें
  • पार्टनर ढूंढें
  • पार्टनर बनें
हमारे बारे में
  • हमारी कंपनी
  • ब्रांड ऐसेट
  • संपर्क करें
  • नौकरियां
  • इवेंट
  • पॉडकास्ट
  • ब्लॉग
  • ग्राहक
  • लीगल • गोपनीयता
  • सुरक्षा
الْعَرَبيّة 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, बिज़नेस से जुड़े ऐप्लिकेशन का एक कलेक्शन है जो ओपन सोर्स पर आधारित है. इसमें आपकी कंपनी की हर ज़रूरत के लिए ऐप्लिकेशन हैं. जैसे, सीआरएम, ई-कॉमर्स, अकाउंटिंग, इन्वेंट्री, पॉइंट ऑफ़ सेल, प्रोजेक्ट मैनेजमेंट वगैरह.

Odoo की सबसे बड़ी खासियत है कि यह इस्तेमाल करने में बहुत आसान है और यह पूरी तरह से इंटिग्रेट किया हुआ है.

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