A lovely little utility to get your web resources into Dynamics 365 quicker.
- Nodejs (v.7.10.1 max, at time of writing)
- Visual Studio with Visual C++ enabled/installed.
- From an administrative command prompt, run
npm i -g --production windows-build-tools
for windows or ensure prerequisites fornode-gyp
are installed another way.
- If you receive an error something to the effect of "cannot find 'CL.EXE'" this is likely because your Visual Studio install did not include C++. Please try going to add/remove programs, Visual Studio, Change, and ensure the C++ feature set is checked off.
- If you receive an error from edge.js about not having the right node version, just check the npm page for the edge package. The version number of edge should match the version number of node that is required. You can check the current version of node that is installed by running
node -v
from a command prompt. - If #3 from the prerequisites fails on Windows, make sure you're command prompt is running as an administrator.
From a command prompt set to the same directory as your psh.json
file, run psh
. For more control, see the optional arguments below. Note that any of the following optional arguments can be combined.
psh [init] [reset] [test] [verbose] [f=[file list]]
Arguments:
init
[Optional]
: if nopsh.json
file exists at the current working directory,psh
will attempt to create one and guide you through specifying the required settings. Ex.psh init test
.reset
[Optional]
: allows you to update the stored connection string. Ex.psh reset
.test
[Optional]
: reports exactly what the utility plans to do, without actually creating, updating, or publishing anything in Dynamics. Ex.psh test
.verbose
[Optional]
: displays the configuration object to be passed to the C# module. Helpful to check your settings, but note that your connection string will be displayed (may include your password). Ex.psh verbose
.f=[file]
orf=[file1],[file2]
[Optional]
: allows you to push only a subset of files to Dynamics 365. For example, if you only wanted to push the filedist\js\bundle.js
and your root folder was set todist
you would runpsh f=js\bundle.js
.
An example with everything combined would be entirely valid and would be:
psh init test verbose f=contact.js reset
This would first prompt you to update your connection string, then log out the configuration object, and then a log would display showing that the utility is trying to create/update only contact.js
from your root folder.
- Navigate to the root directory of your project
- Create a new file called
psh.json
- The file should contain a json object with these three properties:
root
: The root folder, relative to the current folder, that you wish to push web resources from. Ex.dist
.rootNamespace
[Optional]
: The root namespace to be used for all web resources. For example, if your resource would normally be namednew_/test.js
and you want it to benew_/CustomUI/test.js
you would specifyCustomUI
for therootNamespace
option.connectionName
: Unique identifier of the connection string that will be stored in your credential manager. This can be reused across projects. The first time you runpsh
it will prompty you to specify a valid D365 connection string to store under this name. Example value to be entered when prompted: AuthType=Office365;Url=https://orgname.crm.dynamics.com/;[email protected];Password=somethingsecure;RequireNewInstance=true. Note that in VS Code you can paste this setting directly into the terminal when prompted.solutionName
: The unique name of the solution the associated web resources will be pushed to.ignore
[Optional]
: An array of file path fragments to ignore, fragments are paths that are relative to theroot
folder. Ex.[ "test\\text.xml" ]
.overrides
[Optional]
: An array of overrides so you don't have to create individual.psh
files if you have a long list of files to ignore. See the section on "Individual Overrides" for details.
{
"root": "dist",
"connectionName": "FryDev",
"solutionName": "SlurmFactory"
}
By default the utility will build the names of your web resources based on their relative paths to the root directory specified in the configuration file. If you'd like to override this default name, follow the steps below.
- Adjacent to the file you want to override settings for, create a file with the same name, but with
.psh
added to the end. So if your file iscontact.js
your override file would becontact.js.psh
. - The file should contain a json object with these properties:
namespace
: This should be the desiredname
for your web resource. For example, if by default your file would have been pushed asnibbler_/contact.js
and you wanted it to benibbler_/Scripts/Forms/contact.js
, your value fornamespace
would be/Scripts/Forms/contact.js
.description
[Optional]
: A description to be attached to the web resource record in Dynamics.file
[Special]
: This should contain a file path fragment, pointing to the file you wish to ignore. This property is required but only when you are declaring your override in the mainpsh.json
file, otherwise it is ignored.