You can quickly see how the Voice API works by calling yourself using the API.
In this guide you will learn how to:
Before you can get started, you need the following already set up:
- Set all Fax API configuration settings.
- Node.js and a familiarity with how to create a new app.
First we'll create a Node project using npm. This creates a package.json and the core dependencies necessary to start coding.
To create the project, do the following steps:
- Create a folder called fax-send
- Navigate into the folder you created and run the following command.
npm initThis command adds the node_modules folder and the package.json file. You will be prompted to provide values for the fields. For this tutorial, you can simply accept the default values and press enter at each stage.
- Add the axios package with npm to generate the necessary dependencies.
npm install 'axios'Create a new file named index.js in the project and paste the provided "Index.js" code into the file.
This tutorial uses basic authentication for testing purposes. We recommend using OAuth token-based authentication for production.
// Find your application key and secret at dashboard.sinch.com/settings/access-keys
// Find your Sinch numbers at dashboard.sinch.com/numbers/your-numbers/numbers
const ACCESS_KEY = "YOUR_access_key";
const ACCESS_SECRET = "YOUR_access_secret";
const PROJECT_ID = "YOUR_project_id";
const TO_NUMBER = "YOUR_to_number";
const CONTENT_URL = "YOUR_content_url";
const CALLBACK_URL = "YOUR_callback_url";
let config = {
  baseURL: "https://fax.api.sinch.com/v3/projects/" + PROJECT_ID,
  auth: {
      username: ACCESS_KEY,
      password: ACCESS_SECRET
  }
};
const apiClient = require('axios').create(config);
const faxBody = {
to:  TO_NUMBER,
contentUrl: CONTENT_URL,
callbackUrl: CALLBACK_URL
};
apiClient
  .post('/faxes/', faxBody)
  .then((response) => console.log(response));This code sends a fax to a specified number using the Sinch Fax API.
In this example you want to fax a phone number which is configured to receive faxes. Change the value of the to parameter to the Sinch phone number you purchased and configured for Fax in your dashboard in E.164 format.
The Fax API can send either files directly or the URL of a web page or other online resource. For the purposes of this tutorial, we have provided a PDF file you can use to test, or feel free to use a web page of your choosing. Change the value of YOUR_content_url to one of the following URLs:
- https://developers.sinch.com/fax/fax.pdf
- The URL of the web page you want to send.
You can use any URL on the Internet (including ones with basic authentication), and we'll pull it down and make it a fax. This might be useful to you if you're using a web framework for templates and creating fax files.
If you are passing fax a secure URL (starting with https://), make sure that your SSL certificate (including your intermediate cert, if you have one) is installed properly, valid, and up-to-date.
If you provide a callback URL on your Fax service, the Fax API can send notification events to your server about your outgoing fax, such as when or if the fax was delivered. You can set that callback URL in your request body. Change the value of YOUR_callback_url to the URL of your server that's listening to incoming requests.
Before you can run the code, you need to update some more values in the Index.js file so you can connect to your Sinch account. Update the following parameters with your own values:
| Parameter | Your value | 
|---|---|
| YOUR_project_id | The project ID found on your Sinch dashboard. | 
| YOUR_access_key | The access key found on your Sinch dashboard. | 
| YOUR_access_secret | The access secret found on your Sinch dashboard. Note: Access secrets are only available during initial key creation. | 
Save the file.
Now you can execute the code and send your fax. Run the following command:
node index.jsYou should receive a fax to the number you specified with the web page that you configured.
If after running your app you receive a 5000 error response, you may have forgotten to save your file after adding your authentication values. This is an easy mistake to make! Try saving the file and running the app again.
Now that you know how to send a fax, now it's time to learn how to receive a fax sent to your Sinch number.