24.2.0 • Published 8 months ago

pipedrive v24.2.0

Weekly downloads
10,681
License
MIT
Repository
github
Last release
8 months ago

Pipedrive client for NodeJS based apps

Pipedrive is a sales pipeline software that gets you organized. It's a powerful sales CRM with effortless sales pipeline management. See www.pipedrive.com for details.

This is the official Pipedrive API wrapper-client for NodeJS based apps, distributed by Pipedrive Inc freely under the MIT license. It provides convenient access to the Pipedrive API, allowing you to operate with objects such as Deals, Persons, Organizations, Products and much more.

Installation

npm install pipedrive --save

API Reference

The Pipedrive RESTful API Reference can be found at https://developers.pipedrive.com/docs/api/v1. Pipedrive API’s core concepts for its usage can be found in our Developer documentation

API versions

This SDK supports two API versions, each with its own namespace:

Note: Each API version requires separate configuration specific to that version. Ensure you are using the correct namespace and setup for the version you intend to use.

How to use it?

With a pre-set API token

You can retrieve the api_token from your existing Pipedrive account’s settings page. A step-by-step guide is available here.

import express from "express";
import { Configuration, DealsApi } from "pipedrive/v1";

const app = express();

const PORT = 3000;

// Configure Client with API key authorization
const apiConfig = new Configuration({
  apiKey: "YOUR_API_TOKEN_HERE",
});

app.listen(PORT, () => {
  console.log(`Listening on port ${PORT}`);
});

app.get("/", async (req, res) => {
  const dealsApi = new DealsApi(apiConfig);
  const response = await dealsApi.getDeals();
  const { data: deals } = response;

  res.send(deals);
});

With OAuth 2

If you would like to use an OAuth access token for making API calls, then make sure the API key described in the previous section is not set or is set to an empty string. If both API token and OAuth access token are set, then the API token takes precedence.

To set up authentication in the API client, you need the following information. You can receive the necessary client tokens through a Sandbox account (get it here) and generate the tokens (detailed steps here).

ParameterDescription
clientIdOAuth 2 Client ID
clientSecretOAuth 2 Client Secret
redirectUriOAuth 2 Redirection endpoint or Callback Uri

Next, initialize the API client as follows:

import { OAuth2Configuration, Configuration } from 'pipedrive/v1';

// Configuration parameters and credentials
const oauth2 = new OAuth2Configuration({
  clientId: "clientId", // OAuth 2 Client ID
  clientSecret: "clientSecret",  // OAuth 2 Client Secret
  redirectUri: 'redirectUri' // OAuth 2 Redirection endpoint or Callback Uri
});

const apiConfig = new Configuration({
    accessToken: oauth2.getAccessToken,
    basePath: oauth2.basePath,
});

You must now authorize the client.

Authorizing your client

Your application must obtain user authorization before it can execute an endpoint call. The SDK uses OAuth 2.0 authorization to obtain a user's consent to perform an API request on the user's behalf. Details about how the OAuth2.0 flow works in Pipedrive, how long tokens are valid, and more, can be found here.

1. Obtaining user consent

To obtain user's consent, you must redirect the user to the authorization page. The authorizationUrl returns the URL to the authorization page.

// open up the authUrl in the browser
const authUrl = oauth2.authorizationUrl;

2. Handle the OAuth server response

Once the user responds to the consent request, the OAuth 2.0 server responds to your application's access request by using the URL specified in the request.

If the user approves the request, the authorization code will be sent as the code query string:

https://example.com/oauth/callback?code=XXXXXXXXXXXXXXXXXXXXXXXXX

If the user does not approve the request, the response contains an error query string:

https://example.com/oauth/callback?error=access_denied

3. Authorize the client using the code

After the server receives the code, it can exchange this for an access token. The access token is an object containing information for authorizing the client and refreshing the token itself. In the API client all the access token fields are held separately in the OAuth2Configuration class. Additionally access token expiration time as an OAuth2Configuration.expiresAt field is calculated. It is measured in the number of milliseconds elapsed since January 1, 1970 00:00:00 UTC.

const token = await oauth2.authorize(code);

The Node.js SDK supports only promises. So, the authorize call returns a promise.

Refreshing token

Access tokens may expire after sometime, if it necessary you can do it manually.

const newToken = await oauth2.tokenRefresh();

If the access token expires, the SDK will attempt to automatically refresh it before the next endpoint call which requires authentication.

Storing an access token for reuse

It is recommended that you store the access token for reuse.

This code snippet stores the access token in a session for an express application. It uses the cookie-parser and cookie-session npm packages for storing the access token.

import express from "express";
import cookieParse from "cookie-parser";
import cookeSession from "cookie-session";
import { Configuration, DealsApi, OAuth2Configuration } from "pipedrive/v1";

const app = express();

app.use(cookieParser());
app.use(cookieSession({
    name: "session",
    keys: ["key1"]
}));

...

// store access token in the session
// note that this is only the access token field value not the whole token object
req.session.accessToken = await oauth.getAccessToken();

However, since the SDK will attempt to automatically refresh the access token when it expires, it is recommended that you register a token update callback to detect any change to the access token.

oauth2.onTokenUpdate = function (token) {
  // getting the updated token
  // here the token is an object, you can store the whole object or extract fields into separate values
  req.session.token = token;
};

The token update callback will be fired upon authorization as well as token refresh.

Complete example

This example demonstrates an express application (which uses cookie-parser and cookie-session) for handling session persistence.

In this example, there are 2 endpoints. The base endpoint '/' first checks if the token is stored in the session. If it is, API endpoints can be called using the corresponding SDK controllers.

However, if the token is not set in the session, then authorization URL is built and opened up. The response comes back at the '/callback' endpoint, which uses the code to authorize the client and store the token in the session. It then redirects back to the base endpoint for calling endpoints from the SDK.

import express from "express";
import { Configuration, DealsApi, OAuth2Configuration } from "pipedrive/v1";
import cookieParser from "cookie-parser";
import cookieSession from "cookie-session";

const app = express();

app.use(cookieParser());
app.use(cookieSession({
    name: "session",
    keys: ["key1"]
}));

const PORT = 3000;


const oauth2 = new OAuth2Configuration({
    clientId: "clientId", // OAuth 2 Client ID
    clientSecret: "clientSecret",  // OAuth 2 Client Secret
    redirectUri: 'redirectUri' // OAuth 2 Redirection endpoint or Callback Uri
});

app.listen(PORT, () => {
  console.log(`Listening on port ${PORT}`);
});

app.get('/', async (req, res) => {
  try {
    // method will handle return null if token is not available in the session
    const token = oauth2.updateToken(req.session?.accessToken);

     if (!token) {
        const authUrl = oauth2.authorizationUrl;
        return res.redirect(authUrl);
    }


    const apiConfig = new Configuration({
        accessToken: oauth2.getAccessToken,
        basePath: oauth2.basePath,
    });

    // token is already set in the session
    // now make API calls as required
    // client will automatically refresh the token when it expires and call the token update callback
    const dealsApi = new DealsApi(apiConfig)

    const response = await dealsApi.getDeals();
    const { data: deals } = response;

    return res.send(deals);
  } catch (error){
      console.error(error)
      return res.status(500).send(error)
  }
});

app.get('/callback', async (req, res) => {
    try {
        const authCode = req.query.code as string;
        const newAccessToken = await oauth2.authorize(authCode);

        req.session.accessToken = newAccessToken;
        return res.redirect("/");
    }catch (error) {
        console.error(error)
        return res.status(500).send(error)
    }
});
23.4.2

12 months ago

23.4.3

11 months ago

24.2.0

8 months ago

23.3.0-rc.4

11 months ago

24.1.1

9 months ago

24.1.0

9 months ago

24.0.0

9 months ago

23.4.0

1 year ago

23.4.1

1 year ago

23.2.5-rc.2

1 year ago

23.2.5

1 year ago

23.3.0

1 year ago

22.10.1

1 year ago

22.10.0

1 year ago

22.8.2

1 year ago

22.8.1

1 year ago

22.8.0

1 year ago

22.9.0

1 year ago

23.0.0

1 year ago

23.1.0

1 year ago

23.2.2

1 year ago

23.2.1

1 year ago

23.2.4

1 year ago

23.2.3

1 year ago

23.0.0-rc.2

1 year ago

23.2.0

1 year ago

22.7.0

1 year ago

22.3.1-rc.5

2 years ago

22.6.1

2 years ago

22.6.0

2 years ago

22.3.1-rc.4

2 years ago

22.5.0

2 years ago

22.3.1-rc.3

2 years ago

22.4.0

2 years ago

22.3.1-rc.1

2 years ago

22.3.1-rc.0

2 years ago

22.3.1-rc.2

2 years ago

22.1.0

2 years ago

22.2.0

2 years ago

22.3.0

2 years ago

22.0.2

2 years ago

22.0.1

2 years ago

21.0.0

2 years ago

20.2.0

2 years ago

21.1.0

2 years ago

20.3.0

2 years ago

22.0.0

2 years ago

21.2.0

2 years ago

20.4.0

2 years ago

20.5.0

2 years ago

20.5.2

2 years ago

20.5.1

2 years ago

20.0.1

2 years ago

20.0.0

2 years ago

20.0.2

2 years ago

20.1.0

2 years ago

20.1.1

2 years ago

19.0.1

3 years ago

19.1.0

3 years ago

19.0.0

3 years ago

18.1.4

3 years ago

18.1.3

3 years ago

18.1.2

3 years ago

18.1.1

3 years ago

18.1.0

3 years ago

18.0.3

3 years ago

17.3.0

3 years ago

17.3.1

3 years ago

17.4.0

3 years ago

18.0.2

3 years ago

18.0.1

3 years ago

18.0.0

3 years ago

17.5.0

3 years ago

17.5.2

3 years ago

17.5.1

3 years ago

17.5.4

3 years ago

17.5.3

3 years ago

17.0.0

3 years ago

16.2.0

3 years ago

17.1.2

3 years ago

17.1.1

3 years ago

17.1.4

3 years ago

17.1.3

3 years ago

17.1.0

3 years ago

17.1.5

3 years ago

17.2.0

3 years ago

16.1.0

3 years ago

15.0.2

3 years ago

15.0.0

3 years ago

15.0.1

3 years ago

15.1.0

3 years ago

16.0.1

3 years ago

16.0.0

3 years ago

16.0.4

3 years ago

16.0.3

3 years ago

13.3.3

3 years ago

13.3.4

3 years ago

13.3.1

4 years ago

13.3.2

4 years ago

13.3.0

4 years ago

13.2.9

4 years ago

14.0.0

3 years ago

14.0.1

3 years ago

13.2.8

4 years ago

13.2.6

4 years ago

13.2.7

4 years ago

13.0.8

4 years ago

13.0.9

4 years ago

13.0.6

4 years ago

13.0.7

4 years ago

13.0.4

4 years ago

13.0.5

4 years ago

13.0.3

4 years ago

13.1.3

4 years ago

13.1.1

4 years ago

13.1.2

4 years ago

13.1.0

4 years ago

13.0.10

4 years ago

13.0.11

4 years ago

13.0.12

4 years ago

13.2.4

4 years ago

13.2.5

4 years ago

13.2.2

4 years ago

13.2.3

4 years ago

13.2.0

4 years ago

13.2.1

4 years ago

13.0.2

4 years ago

13.0.0

4 years ago

13.0.1

4 years ago

12.2.0

4 years ago

12.0.3

4 years ago

12.0.0

4 years ago

12.0.1

4 years ago

12.0.2

4 years ago

12.0.0-rc.7

4 years ago

12.0.0-rc.8

4 years ago

12.1.0

4 years ago

12.0.0-rc.6

4 years ago

12.0.0-rc.5

4 years ago

12.0.0-rc.4

4 years ago

12.0.0-rc.3

4 years ago

12.0.0-rc.1

4 years ago

12.0.0-rc.2

4 years ago

12.0.0-rc.0

4 years ago

11.0.0-rc.10

4 years ago

11.0.0-rc.11

4 years ago

11.0.0-rc.5

4 years ago

11.0.0-rc.6

4 years ago

11.0.0-rc.7

4 years ago

11.0.0-rc.8

4 years ago

11.0.0-rc.9

4 years ago

10.6.2

4 years ago

11.0.0

4 years ago

10.6.0

5 years ago

10.6.1

4 years ago

11.0.0-rc.2

4 years ago

11.0.0-rc.3

4 years ago

11.0.0-rc.4

4 years ago

10.5.0

5 years ago

11.0.0-rc.1

5 years ago

1.0.1-rc.0

5 years ago

11.0.0-rc.0

5 years ago

10.4.3

6 years ago

10.4.2

6 years ago

10.4.1

6 years ago

10.4.0

6 years ago

10.3.0

6 years ago

10.2.2

6 years ago

10.2.1

6 years ago

10.2.0

6 years ago

10.0.1

6 years ago

10.0.0

6 years ago

9.2.0

6 years ago

9.1.1

6 years ago

9.1.0

6 years ago

9.0.0

6 years ago

8.0.0

6 years ago

7.0.0

6 years ago

6.0.4

7 years ago

6.0.3

7 years ago

6.0.2

7 years ago

6.0.1

7 years ago

6.0.0

7 years ago

5.0.0

8 years ago

4.0.0

8 years ago

3.0.7

8 years ago

3.0.6

8 years ago

3.0.5

8 years ago

3.0.2

8 years ago

3.0.1

9 years ago

3.0.0

9 years ago

2.1.4

9 years ago

2.1.3

9 years ago

2.1.2

10 years ago

2.1.1

10 years ago

2.1.0

10 years ago

2.0.4

10 years ago

2.0.3

10 years ago

2.0.2

10 years ago

2.0.0

10 years ago

1.7.3

10 years ago

1.7.2

11 years ago

1.7.1

11 years ago

1.7.0

11 years ago

1.6.4

12 years ago

1.6.3

12 years ago

1.6.2

12 years ago

1.6.1

12 years ago

1.5.10

12 years ago

1.5.9

12 years ago

1.5.8

12 years ago

1.5.7

12 years ago

1.5.6

12 years ago

1.5.5

12 years ago

1.5.4

12 years ago

1.5.3

12 years ago

1.5.2

12 years ago

1.5.1

12 years ago

1.5.0

12 years ago

1.4.2

13 years ago

1.4.1

13 years ago

1.4.0

13 years ago

1.3.2

13 years ago

1.3.1

13 years ago

1.2.7

13 years ago

1.2.6

13 years ago

1.2.5

13 years ago

1.2.4

13 years ago

1.2.3

13 years ago

1.2.2

13 years ago

1.2.1

13 years ago

1.1.2

13 years ago

1.1.1

13 years ago

1.1.0

13 years ago

1.0.5

13 years ago

1.0.4

13 years ago

1.0.3

13 years ago

1.0.2

13 years ago

1.0.1

13 years ago

1.0.0

13 years ago