Skip to main content

Oracle Fusion Cloud ERP — read-only MCP server (STDIO transport)

Project description

mcp-oraclefusion

An MCP (Model Context Protocol) server for Oracle Fusion Cloud ERP. Gives any MCP-compatible AI client (Claude, Cursor, Windsurf, etc.) read-only access to your Oracle Fusion data via STDIO transport.

Quick start

Install and run via uvx:

{
  "mcpServers": {
    "oracle-fusion": {
      "command": "uvx",
      "args": ["mcp-oraclefusion"],
      "env": {
        "ORACLE_FUSION_BASE_URL": "https://your-oracle-instance.fa.ocs.oraclecloud.com",
        "ORACLE_USERNAME": "your.name@example.com",
        "ORACLE_PASSWORD": "your_oracle_password"
      }
    }
  }
}

Or run directly:

pip install mcp-oraclefusion
export ORACLE_FUSION_BASE_URL=https://your-oracle-instance.fa.ocs.oraclecloud.com
export ORACLE_USERNAME=your.name@example.com
export ORACLE_PASSWORD=your_oracle_password
mcp-oraclefusion

What you can do

Ask natural-language questions about your Oracle Fusion data:

  • "Show me all invoices from Google in Q1 2025"
  • "Find open purchase orders from Dell over $50,000"
  • "What's the USD to EUR corporate exchange rate for January 2025?"
  • "Search requisitions pending approval in US Operations"
  • "Look up supplier details for ACME Corp including sites and contacts"
  • "Show AR invoices for customer XYZ"
  • "Test the Oracle connection and show record counts"

Tools (24 read + 7 write)

Accounts Payable

search_invoices, get_invoice_details, search_payments, get_payment_details, list_payment_terms

Procurement

search_purchase_orders, get_po_details, search_suppliers, get_supplier_details, search_requisitions, search_receiving_receipts, search_approved_suppliers, search_categories

General Ledger

search_journal_batches, search_gl_balances, list_ledgers, list_chart_of_accounts, search_currency_rates

Accounts Receivable

search_ar_invoices, get_ar_invoice_details, search_receipts

Expenses & HCM

search_expense_reports, search_user_accounts

Infrastructure

test_oracle_connection

Write tools (set MCP_MODE=full to enable)

create_purchase_order, update_po_distribution, change_po_status, create_invoice, change_invoice_status, create_requisition, change_requisition_status

Configuration

Env var Required Description
ORACLE_FUSION_BASE_URL Yes Your Oracle Fusion instance URL
ORACLE_USERNAME Yes Your Oracle Fusion username (email)
ORACLE_PASSWORD If no JWT Your Oracle Fusion password
ORACLE_FUSION_API_VERSION No REST API version (default 11.13.18.05)
MCP_MODE No readonly (default) or full (enables write tools)
LOG_LEVEL No WARNING (default), INFO, DEBUG — logs go to stderr

JWT authentication (alternative to password)

Instead of a password you can authenticate with an RSA private key + certificate registered in Oracle's Security Console (API Authentication). Set these env vars and omit ORACLE_PASSWORD:

Env var Description
ORACLE_JWT_PRIVATE_KEY_PATH Path to the RSA private key PEM file
ORACLE_JWT_PRIVATE_KEY Inline PEM key (alternative to path, useful in containers)
ORACLE_JWT_CERT_PATH Path to the matching X.509 certificate PEM file
ORACLE_JWT_ISSUER Trusted issuer value configured in Oracle

The server tries JWT first and falls back to Basic Auth if the JWT vars are not set.

Oracle REST API notes

  • Query filters use Oracle syntax: conditions joined with ; (AND), string matching with LIKE '*term*'
  • Some fields are not queryable (x-queryable: false) — the server uses finders or client-side filtering
  • CLOB fields are excluded from collection projections to avoid Oracle 500 errors
  • The server auto-retries Oracle 500s by progressively stripping totalResults and fields params
  • Status changes use Oracle action endpoints (POST /resource/{id}/action/{name}), not PATCH
  • Supplier names are UPPERCASE in Oracle
  • Pagination via limit/offset; hasMore indicates additional pages

Requirements

  • Python 3.10+
  • Oracle Fusion Cloud instance with REST API access and a user account

Author

Wanis Elabbar

License

MIT

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_oraclefusion-0.1.1.tar.gz (52.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_oraclefusion-0.1.1-py3-none-any.whl (33.4 kB view details)

Uploaded Python 3

File details

Details for the file mcp_oraclefusion-0.1.1.tar.gz.

File metadata

  • Download URL: mcp_oraclefusion-0.1.1.tar.gz
  • Upload date:
  • Size: 52.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mcp_oraclefusion-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a0c4c0f0708f68db283f31d77bb4e1711d633810511c996e3b0c953e12b795b3
MD5 fa036be82c36229d688cddc49d182b2b
BLAKE2b-256 6d80c981a20cdede8c172d7a2a86d33a23b048aa84b0e8a159a1002c11cd0429

See more details on using hashes here.

File details

Details for the file mcp_oraclefusion-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: mcp_oraclefusion-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 33.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.3 {"installer":{"name":"uv","version":"0.10.3","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"macOS","version":null,"id":null,"libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for mcp_oraclefusion-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d8cd40d32bc3e0f9836b7e5ffb4b1515779cec19c790258a15443891608e6f33
MD5 25f9b7de83036bd1adededcc8913f98d
BLAKE2b-256 b012f51cd930d7fb9251891bb00f006e4e2c804e2aa333c70b6048b8f9750e28

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page