npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

dynamics-crm-rest

v0.5.3

Published

dynamics-crm-rest is a node module for interfacing with the Microsoft Dynamics CRM REST API.

Downloads

3

Readme

#dynamics-crm-rest dynamics-crm-rest is a node module for interfacing with the Microsoft Dynamics CRM REST (Web) API. If you’ve had issues with Microsoft’s adal-node tool for authing against the API (The auth is handled by an Azure app) then this module will make you happy.

GET, POST, PATCH, PUT, and DELETE are supported.

Note: This module needs more error handling and tests. That said, it does work well. This module uses es6 classes, so you will need a version of NODE that supports them.

##Install npm install dynamics-crm-rest

##Setting Up Azure App for Authing Dynamics uses Azure AD Applications to get an OAuth token, so you will need to register a “Native” app with Azure and use the “Application ID” in dynamics-crm-rest. You will need to give the app rights to Dynamics CRM, and you will need an Azure AD user with rights to the app. You will be using the users creds to auth against the app. I don’t like having to use an AD user, but that’s the way Microsoft does it. If adal-node worked I would use it. Here is a link to a Microsoft article showing how to register an app with Azure AD. Scroll down to “App registration for OAuth authentication”. Also, make sure you choose “Native App” when registering. https://msdn.microsoft.com/en-us/library/mt622431.aspx.

##Module Usage

let DynamicsCrmRest = require('dynamics-crm-rest');

let crm = new DynamicsCrmRest({
    orgName: ‘exampleOrgName’,
    orgDomain: ‘example.onmicrosoft.com',
    clientId: ‘’, //This is the app id from the Azure app you registered
    username: '', //The Azure AD user with rights to the app
    password: '' //The user’s password
});

//crm.HTTPMethod("endPoint", {dataObject}, callback(err, res) {}); 
//There is not dataObject for the GET or DELETE methods. 

crm.get("contacts", function(err, res) {
    if(err) {
        console.error(err);
    }
    else {
        console.log(res);
    }
});

crm.post("contacts", {
    firstname: ‘John’,
    lastname: ‘Smith’,
    mobilephone: ‘555-555-5555’,
    emailaddress1: ‘[email protected]’,
}, function(err, res) {
    if(err) {
        console.error(err);
    }
    else {
        console.log(res);
    }
});  

##To Do

  • Add better error handling
  • Add tests
  • Add token refresh so it doesn't have to get a new token every time.