ORCA
Orca is a Payment Switch that lets you connect with multiple payment processors with a single API integration. Once integrated, you can add new payment processors and route traffic effortlessly. Using Orca, you can:
- Reduce dependency on a single processor like Stripe
- Control & customize your payment flow with 100% visibility
- Reduce processing fees through smart routing
- Improve conversion rate with dynamic routing
- Expand your business reach with new payment methods
- Reduce development & testing efforts of adding new processors
Orca is wire-compatible with top processors like Stripe making it easy to integrate.
Table of Contents
- Quick Start Guide
- Supported Features
- What's Included
- Join us in building ORCA
- Bugs and feature requests
- Versioning
- Copyright and License
Quick Start Guide
Try It Out
Step 1: Use Orca Sandbox to create your account and test payments. Please save the API key for the next step.
Step 2: Import our Postman Collection using the link below. (Please use the API key auth type.)
https://www.getpostman.com/collections/63d0d419ce1d1140fc9f
Installation Options
Option 1: Self-hosting with Docker Image. (This option is coming soon!!)
Option 2: Setup dev environment using Docker Compose:
- 
Clone the repository: git clone https://github.com/juspay/orca.gitYou might need to create a Personal Access Token (PAT) if you are prompted to authenticate. Use the generated PAT as the password. 
- 
[Optional] Configure your settings in docker_compose.toml 
- 
Run the application and create an account: - 
Build and run Orca using Docker Compose: docker compose up -d
- 
Run database migrations: docker compose run orca-server bash -c "cargo install diesel_cli && diesel migration --database-url postgres://db_user:db_pass@pg:5432/orca_db run"
- 
Verify that the Orca server is up by checking your local server health: curl --location --request GET 'http://localhost:8080/health'
- 
Create your Merchant Account and get your account information: bash ./scripts/create_merchant_account.sh
 
- 
Configure & Test
- 
Configure & test using your API key: - 
Add your Connector API keys in keys.conffile. You can fetch API keys from the Connector's Dashboard (say Stripe/Adyen/Checkout dashboard).
- 
Configure the connector in your dev environment: bash ./scripts/create_connector_account.sh <connector_name> <your Orca merchant_id>Use the Orca merchant ID generated from the previous step. 
- 
Run a health check for your local server: curl --location --request GET 'http://localhost:8080/health'
- 
Update the below command with your Orca API key and perform a test transaction. Refer our Postman collection to test more features (refunds, customers, payment methods etc.,) export API_KEY="<your api-key>" curl --location --request POST "http://localhost:8080/payments" \ --header "Content-Type: application/json" \ --header "Accept: application/json" \ --header "api-key: ${API_KEY}" \ --data-raw '{ "amount": 6540, "currency": "USD", "confirm" :true, "return_url": "https://juspay.io", "payment_method": "card", "payment_method_data": { "card": { "card_number": "4000056655665556", "card_exp_month": "10", "card_exp_year": "25", "card_holder_name": "John Doe", "card_cvc": "123" } } }'
 
- 
Option 3: Local setup:
a. For MacOS
b. For Linux
Fast Integration for Stripe Users
If you are already using Stripe, integrating with Orca is fun, fast & easy. Try the steps below to get a feel for how quick the setup is:
- Download Stripe's demo app
- Change server and client SDK dependencies in your app
- Change API keys in your App
- Configure & Test
Supported Features
| Features | Stripe | Adyen | Checkout | Authorize.net | ACI | 
|---|---|---|---|---|---|
| Payments - CRUD, Confirm | ✅ | ✅ | ✅ | ✅ | ✅ | 
| Customers - CRUD | ✅ | ✅ | ✅ | ✅ | ✅ | 
| Refunds | ✅ | ✅ | ✅ | ✅ | WIP | 
| Mandates | ✅ | WIP | WIP | WIP | WIP | 
| PCI Compliance | ✅ | ✅ | ✅ | ✅ | ✅ | 
The hosted version provides the following additional features:
- 
System Performance & Reliability - Scalable to support 50000 tps
- System uptime of upto 99.99%
- Low latency service
- Hosting option with AWS, GCP
 
- 
Value Added Services - Compliance Support incl. PCI, GDPR etc
- Support for processors / gateways not currently available as part of OSS (E.g. Chase Payments)
- Integration with Risk Management Solutions
- Support for Subscription
 
- 
Payment Operations Support - 24x7 Support
- Dashboards with deep analytics
- Experts team to consult and improve business metrics
 
What's Included
Within the repositories you'll find the following directories and files, logically grouping common assets and providing both compiled and minified variations.
Repositories
The current setup contains a single repo, which contains the core payment router and the various connector integrations under the src/connector sub-directory.
Files Tree Layout
├── config                       : config files for router. This stores the initial startup config and separate configs can be provided for debug/release builds.
├── crates                       : sub-crates
│   ├── masking                  : making pii information for pci and gdpr compliance
│   ├── router                   : the main crate
│   └── router_derive            : utility macros for the router crate
├── docs                         : hand written documentation
├── examples                     : examples
├── logs                         : logs generated at runtime
├── migrations                   : diesel db setup
├── openapi                      : API definition
├── postman                      : postman scenarios for API
└── target                       : generated files
Join us in building ORCA
Our Belief
We believe payments should be open, fast and cheap.
Orca would allow everyone to quickly customize and set up an open payment switch, while giving a unified experience to your users, abstracting away the ever shifting payments landscape.
The Orca journey starts with a payment orchestrator. It was born from our struggle to understand and integrate various payment options/payment processors/networks and banks, with varying degrees of documentation and inconsistent API semantics.
Contributing
This project is created and currently maintained by Juspay.
We welcome contributions from the open source community. Please read through our contributing guidelines. Included are directions for opening issues, coding standards, and notes on development.
Important note for Rust developers: We aim for contributions from the community across a broad range of tracks.
Hence, we have prioritized simplicity and code readability over purely idiomatic code.
For example, some of the code in core functions (e.g. payments_core) is written to be more readable rather than being pure-idiomatic.
Bugs and feature requests
Please read the issue guidelines and search for existing and closed issues. If your problem or idea is not addressed yet, please open a new issue.
Versioning
Check the CHANGELOG.md file for details.
Copyright and License
This product is licensed under the Apache 2.0 License.
 
			