Authentication Guide
1. Introduction to Authentication
Authentication is a critical component of integrating with the Newline API. It ensures that only authorized users and systems can access resources within your Program. Newline uses JSON Web Tokens (JWT) as the primary authentication mechanism for both its Sandbox and production environments, providing a consistent and secure approach across testing and production systems.
This guide outlines the authentication process, including required components, token generation, usage, and best practices for security and error handling.
Authentication Guide Sections:
- Introduction to Authentication
- Prerequisites
- Authentication Workflow
- Using the Bearer Token
- Trace ID Requirements
- Error Handling
- Sandbox Authentication
- Best Practices
2. Prerequisites
Before you start using the Newline API, ensure you have the following:
- Program UID: Provided by Newline. Used to generate signed tokens.
- HMAC Key: Provided by Newline. Used to generate signed tokens.
- Base URL:
- Sandbox:
[https://sandbox.api.newline53.com](https://sandbox.api.newline53.com/)
- Production:
[https://api.newline53.com](https://api.newline53.com/)
- Sandbox:
3. Authentication Workflow
The authentication workflow involves three key steps:
- Token Generation: Use the Program UID and HMAC Key to generate a signed token.
- Sending the Token: Send the signed token to the
/auth/token
endpoint to obtain a Bearer token. - Token Expiration: Monitor the Bearer token’s expiration and refresh it as needed.
Step 1: Token Generation
- Use the Program UID and HMAC Key with a predefined algorithm (HS512 / SHA-512) to create a signed token.
Step 2: Sending the Token
-
Send the signed token to the Authentication Endpoint
/auth/token
to receive a Bearer token.Example API Call:
curl -X POST [https://sandbox.api.newline53.com/auth/token](https://sandbox.api.newline53.com/auth/token) \ -H "Content-Type: application/json" \ -d '{ "program_uid": "YOUR_PROGRAM_UID", "signature": "GENERATED_SIGNATURE" }'
Step 3: Token Expiration
- Once expired, the token cannot be used and must be regenerated.
4. Using the Bearer Token
To use the Bearer token for authenticating API requests, follow these three steps:
- Receive the Bearer Token: Generate the token via the
/auth/token
endpoint. - Include the Token in API Requests: Use the
Authorization
header with the token. - Handle Expiration: Ensure tokens are refreshed before they expire.
Header Example:
plaintext
Copy code
Authorization: Bearer YOUR_BEARER_TOKEN
Example API Call:
`curl -X GET [https://sandbox.api.newline53.com/v1/accounts](https://sandbox.api.newline53.com/v1/accounts) \
-H "Authorization: Bearer YOUR_BEARER_TOKEN"
5. Trace ID Requirements
Using the X-Trace-ID
header involves three important steps:
- Generate a Unique Trace ID: Create a unique ID for every API request.
- Include Trace ID in Headers: Add the
X-Trace-ID
header to all API calls. - Handle Trace ID Errors: Ensure Trace IDs are unique per request to avoid API errors.
Example with Trace ID:
curl -X GET <https://sandbox.api.newline53.com/v1/accounts>
-H "Authorization: Bearer YOUR_BEARER_TOKEN"
-H "X-Trace-ID: UNIQUE_TRACE_ID"
6. Error Handling
Proper error handling requires three key actions:
- Understand Common Errors: Familiarize yourself with common authentication errors, such as
401 Unauthorized
or422 Missing Required Fields
. - Use Error Codes Reference: Leverage Newline’s detailed Error Codes Reference.
- Implement Logging: Log errors and debug responses for faster troubleshooting.
- Verification: Ensure that the correct IP address is being used during authentication.
7. Sandbox Authentication
Testing in the sandbox involves three main steps:
- Authenticate Using Sandbox URL: Generate a token via the
/auth/token
endpoint. - Simulate API Requests: Use test customers, accounts, and synthetic data to validate workflows.
- Monitor Testing: Review API responses for accuracy and completeness in the simulated environment.
Sandbox Key Features:
- Simulated testing environment with no real financial transactions.
- Same authentication and token processes as production.
8. Best Practices
To ensure secure and effective authentication, follow these four best practices:
- Secure Token Storage:
- Use environment variables or secrets managers for storing Program UID, HMAC Key, and tokens.
- Monitor Token Expiration:
- Implement a mechanism to refresh tokens before they expire.
- Enable HTTPS:
- Always use HTTPS to encrypt sensitive data during transmission.
- Use Unique Trace IDs:
- Avoid reusing
X-Trace-ID
values to prevent duplicate processing errors.
- Avoid reusing
9. Additional Resources
Explore the following resources for further guidance:
- Developer Documentation:
- Error Codes Reference:
- Support Channels:
- Email: [email protected]
Updated about 1 month ago