This project is a payment processing API built using Go (Golang) and Stripe. It provides a set of RESTful endpoints for handling various aspects of payment processing, such as creating payment intents, confirming payment intents, capturing payments, creating refunds, and retrieving a list of payment intents.
Welcome to Portone! This section will guide you through the process of setting up and using the project.
Before you begin, ensure you have the following prerequisites installed:
- Go
- Docker
- Stripe Account - Create a sandbox account to obtain API keys.
Follow these steps to install and run the project:
-
Clone the repository:
git clone https://github.com/AshiqurRahaman02/portone.git
-
Navigate to the project directory:
cd portone
-
Set up your environment variables by creating a
.env
file in the root directory. Example content:STRIPE_API_KEY=your_stripe_api_key
-
Build and run the Docker containers:
docker-compose up -d
Before running the application, make sure to configure the necessary environment variables in the .env
file.
To use the project, follow these steps:
-
Create a payment intent:
curl -X POST -d '{"amount": 2000, "currency": "usd"}' http://localhost:8080/api/v1/create_intent
-
Confirm a payment intent:
curl -X POST http://localhost:8080/api/v1/confirm_payment_intent/{payment_intent_id}
-
Capture the created intent:
curl -X POST http://localhost:8080/api/v1/capture_intent/{payment_intent_id}
-
Create a refund for the created intent:
curl -X POST http://localhost:8080/api/v1/create_refund/{payment_intent_id}
-
Get a list of all payment intents:
curl http://localhost:8080/api/v1/get_intents
For more details on each endpoint and additional options, refer to the Endpoints section.
Document the available API endpoints and their functionality.
- Create Intent
- Endpoint:
POST /api/v1/create_intent
- Description: Creates a payment intent.
- Request:
- Example:
{ "amount": 2000, "currency": "usd" }
- Parameters:
amount
(required): The amount of the payment in the smallest currency unit (e.g., cents).currency
(required): The currency in which the payment is made (e.g., "usd").
- Example:
- Response:
- Example:
{ "success": true, "payment_intent_id": "pi_3MtwBwLkdIwHu7ix28a3tqPa", "payment": { "id": "pi_3MtwBwLkdIwHu7ix28a3tqPa", "object": "payment_intent", "amount": 2000, "currency": "usd", "status": "requires_confirmation", "created": 1680800504, "client_secret": "pi_3MtwBwLkdIwHu7ix28a3tqPa_secret_YrKJUKribcBjcG8HVhfZluoGH" // ... other payment intent properties } }
- Response Properties:
success
: A boolean indicating the success of the operation.payment_intent_id
: The ID of the created payment intent.payment
: Details of the created payment intent.
- Example:
- Error Responses:
400 Bad Request
: If the request is malformed or missing required parameters.500 Internal Server Error
: If there is an internal error during payment intent creation.
- Usage:
curl -X POST -H "Content-Type: application/json" -d '{"amount": 2000, "currency": "usd"}' http://localhost:8080/api/v1/create_intent
- Notes:
- Ensure that the
STRIPE_API_KEY
environment variable is set before making the request.
- Ensure that the
- Endpoint:
- Confirm Intent
- Endpoint:
POST /api/v1/confirm_payment_intent/{id}
- Description: Confirm a payment intent.
- Request:
- Example:
// No request body required
- Path Parameters:
id
(required): The ID of the payment intent to confirm.
- Example:
- Response:
- Example:
{ "success": true, "payment_intent_id": "pi_3MtwBwLkdIwHu7ix28a3tqPa", "status": "requires_action", "client_secret": "pi_3MtwBwLkdIwHu7ix28a3tqPa_secret_YrKJUKribcBjcG8HVhfZluoGH" }
- Response Properties:
success
: A boolean indicating the success of the operation.payment_intent_id
: The ID of the confirmed payment intent.status
: The updated status of the payment intent (e.g., "requires_capture").client_secret
: The updated client secret of the payment intent.
- Example:
- Error Responses:
400 Bad Request
: If the request is malformed or missing required parameters.500 Internal Server Error
: If there is an internal error during payment intent confirmation.
- Usage:
curl -X POST http://localhost:8080/api/v1/confirm_payment_intent/pi_3MtwBwLkdIwHu7ix28a3tqPa
- Notes:
- Ensure that the
STRIPE_API_KEY
environment variable is set before making the request.
- Ensure that the
- Endpoint:
- Capture Intent
- Endpoint:
POST /api/v1/capture_intent/{id}
- Description: Captures a payment intent.
- Request:
- Example:
// No request body required
- Path Parameters:
id
(required): The ID of the payment intent to capture.
- Example:
- Response:
- Example:
{ "success": true, "payment_intent_id": "pi_3MtwBwLkdIwHu7ix28a3tqPa", "status": "succeeded" }
- Response Properties:
success
: A boolean indicating the success of the operation.payment_intent_id
: The ID of the captured payment intent.status
: The updated status of the payment intent after capture (e.g., "succeeded").
- Example:
- Error Responses:
400 Bad Request
: If the request is malformed or missing required parameters.500 Internal Server Error
: If there is an internal error during payment intent capture.
- Usage:
curl -X POST http://localhost:8080/api/v1/capture_intent/pi_3MtwBwLkdIwHu7ix28a3tqPa
- Notes:
- Ensure that the
STRIPE_API_KEY
environment variable is set before making the request.
- Ensure that the
- Endpoint:
- Create Refund
- Endpoint:
POST /api/v1/create_refund/{id}
- Description: Creates a refund for a payment intent.
- Request:
- Example:
// No request body required
- Path Parameters:
id
(required): The ID of the payment intent for which to create a refund.
- Example:
- Response:
- Example:
{ "success": true, "refund_id": "re_1234567890abcdef", "status": "refunded", "amount_refunded": 2000 }
- Response Properties:
success
: A boolean indicating the success of the refund creation.refund_id
: The ID of the created refund.status
: The status of the refund (e.g., "succeeded").amount_refunded
: The amount refunded in cents.
- Example:
- Error Responses:
400 Bad Request
: If the request is malformed or missing required parameters.500 Internal Server Error
: If there is an internal error during refund creation.
- Usage:
curl -X POST http://localhost:8080/api/v1/create_refund/pi_3MtwBwLkdIwHu7ix28a3tqPa
- Notes:
- Ensure that the
STRIPE_API_KEY
environment variable is set before making the request.
- Ensure that the
- Endpoint:
- Get Intents
- Endpoint:
GET /api/v1/get_intents
- Description: Gets a list of all payment intents.
- Request:
- Example:
// No request body required
- Example:
- Response:
- Example:
{ "success": true, "paymentIntents": [ { "id": "pi_1234567890abcdef", "amount": 2000, "currency": "usd", "status": "requires_confirmation", "created": 1680800504, "clientSecret": "pi_1234567890abcdef_secret_YrKJUKribcBjcG8HVhfZluoGH" } // ... (more payment intents) ] }
- Response Properties:
success
: A boolean indicating the success of fetching payment intents.paymentIntents
: An array of payment intents, each containing relevant information.id
: The ID of the payment intent.amount
: The amount in cents.currency
: The currency code (e.g., "usd").status
: The current status of the payment intent.created
: The timestamp of when the payment intent was created.clientSecret
: The client secret associated with the payment intent.
- Example:
- Error Responses:
500 Internal Server Error
: If there is an internal error during payment intent retrieval.
- Usage:
curl http://localhost:8080/api/v1/get_intents
- Notes:
- Ensure that the
STRIPE_API_KEY
environment variable is set before making the request.
- Ensure that the
- Endpoint:
To run the tests for this project, follow these steps:
-
Make sure you have Go installed on your machine.
-
Navigate to the project's root directory in your terminal.
-
Run the following command to execute the tests:
go test ./tests
This command will run all the tests in the project.
-
Review the test results to ensure that all tests pass successfully.
Note: Ensure that you have set up the necessary environment variables, such as STRIPE_API_KEY
, before running the tests. You can use a .env
file to manage your environment variables.
Thank you for considering contributing to our project! Whether you're reporting a bug, proposing a feature, or submitting code changes, your contributions are highly appreciated.
If you find a bug, have a question, or want to propose a new feature, check our issue tracker for existing topics. If not found, feel free to open a new issue and provide details such as a clear title, steps to reproduce, and your environment.
Have a feature in mind? We welcome new ideas and enhancements. Open an issue on our GitHub repository to discuss and share your thoughts with the community.
Contributions through pull requests are welcome. To contribute:
-
Fork the repository.
-
Create a new branch for your changes: git checkout -b feature/your-feature.
-
Make changes following our coding standards.
-
Write tests and run existing tests.
-
Push changes to your fork: git push origin feature/your-feature.
-
Open a pull request on GitHub with a clear description of your changes.
-
Indentation and Formatting:
- Use tabs for indentation.
- Follow the standard Go formatting guidelines. You can use the gofmt tool to automatically format your code.
- Variable Naming:
-
Variable Naming
- Use meaningful and descriptive names for variables.
- Follow the camelCase naming convention for variables.
-
Function Naming:
- Use camelCase for function names.
- Choose function names that clearly indicate their purpose.
-
Comments:
- Include comments to explain complex sections of code or to provide context.
- Write clear and concise comments.
-
Error Handling:
- Properly handle errors using the if err != nil pattern.
- Avoid generic error messages; provide specific details when handling errors.
-
Testing:
- Write comprehensive unit tests for your code.
- Ensure that tests cover different scenarios and edge cases.
-
Documentation:
- Provide documentation for public functions and packages.
- Use GoDoc-style comments for documenting functions and packages.
-
Imports:
- Group imports into standard library packages, third-party packages, and local packages.
- Avoid unused imports.
-
Concurrency and Goroutines:
- Use goroutines and channels responsibly.
- Ensure proper synchronization to avoid race conditions.
-
Code Modularity:
- Encapsulate functionality into modular functions and packages.
- Aim for a clear separation of concerns.
-
Security:
- Follow security best practices, especially when dealing with user input.
- Be mindful of potential vulnerabilities and address them promptly.
-
Version Control:
- Make small, meaningful commits with clear commit messages.
- Avoid committing large binary files or sensitive information.
For questions or assistance, open an issue or join community discussions.
Thank you for contributing! Feel free to customize it based on your project's specifics.