How to: Develop an Extension
You can build extension packages that add functionality to a Microsoft Dynamics NAV deployment. Unlike the familiar development and deployment of Microsoft Dynamics NAV functionality, building an extension relies on the exported version of an application to .TXT files. You can export the application from the development environment, or use the Windows PowerShell function that is available in the Microsoft Dynamics NAV 2016 Development Shell, Export-NAVApplicationObject
.
Tip
We recommend that you create a folder structure that can be leveraged by the cmdlets that you use when you build the extension package. That structure should contain folders for the ORIGINAL object files, MODIFIED object files, and DELTA files. These names match those used as parameters in the application merge utilities. For more information, see Comparing and Merging Application Object Source Files.
To create an extension
Establish the BASE as TXT files.
The foundation for your extension is the exported .txt files of the objects you are modifying. You can export just the objects that you want to modify, or you can export the entire Microsoft Dynamics NAV application. In the Microsoft Dynamics NAV 2016 Development Shell, the
Export-NAVApplicationObject
function can automate this process or you can use the export functionality in the development environment. The following example uses this function to export objects to establish the base for the planned modifications.Export-NAVApplicationObject -Path ORIGINAL -DatabaseName MyDatabase -DatabaseServer MyDatabaseServer
Important
Objects must be exported as .TXT files. You cannot build an extension based on a .FOB file.
If you use a source control system, you may want to pull the base .TXT files from there.
Create functionality in the development environment.
Use the development environment as usual to create new objects or modify ones to the extent your license allows you. Keep in mind the following rules:
DO NOT make C/AL code modifications
DO use subscribing to events to execute code.
DO NOT create new or modified XMLPorts, Queries, or Report. For more information, see Extension Packages Capability Support Matrix.
DO NOT change restricted page and table properties. For more information, see Extension Packages Capability Support Matrix.
In order to get an easy upgrade experience for your extensions, you cannot modify code the way you do in the traditional customization process. Instead, you extend Microsoft Dynamics NAV functionality by subscribing to programming events that are raised either explicitly in code, or implicitly by the platform. For more information, see Events in Microsoft Dynamics NAV.
Add upgrade code for new or modified tables.
The purpose of the upgrade code is to handle table data that is related to the extension when the extension is uninstalled and reinstalled. You add the code to two global functions, one named OnNavAppUpgradePerDatabase and the other named OnNavAppUpgradePerCompany. For more information, see How to: Write Extension Upgrade Code.
Test your application with the extension added.
Export your changed and added application objects to .TXT files.
Export all objects that you added or modified to .TXT files. Use the same export function from step 1 or manually export within the development environment. They must also be exported as .TXT files and should be placed in a separate directory so that the packaging process can be pointed at them.
Export-NAVApplicationObject -Path MODIFIED -DatabaseName MyDatabase -DatabaseServer MyDatabaseServer
Create DELTA files using the Microsoft Dynamics NAV 2016 Development Shell cmdlets.
Extension packages are based on application object deltas. Again, you use the application merge utilities in the Microsoft Dynamics NAV 2016 Development Shell to distill the changes in the form of application object differences that are stored in DELTA files. Creating an extension uses many of the same concepts and tools as you know from application object deltas. You use the
Compare-NAVApplicationObject
cmdlet to create these delta files.Compare-NAVApplicationObject -OriginalPath ORIGINAL -ModifiedPath MODIFIED -DeltaPath DELTA
Note
Your delta files must be one-to-one with the objects you have added or modified. You cannot include a single merged delta file. If you output your export file as a single file use the
Split-NAVAppplicationObjectFile
cmdlet to create the individual files.
Build the extension package.
For more information, see How to: Create an Extension Package.
Extending Other Extensions
You can extend the functionality that another extension has made available. When you do that, you create a dependency between the original extension and the one extending it. This dependency must be verified and compiled when the new extension is published.
You must have the source code for the extension that you want to extend available in the development environment to use as the base of your app. The steps for creating a dependent app, or, in other words, extending another extension, are outlined below.
Note
If you do not identify a dependency when you build your extension package, publishing your extension results in errors that are caused by base objects missing, and the publish operation will fail.
To create a dependent extension
Import and compile the source code for the extension that you want to extend.
Use the Export-NAVApplicationObjectLanguage cmdlet to establish the new base for your app deltas.
Extend the functionality with your modifications and additions using the development environment.
Use the Export-NAVApplicationObjectLanguage and the Compare-NAVApplicationObject cmdlets to export and create the deltas for your app. Since you are comparing against a base that has the functionality that you are extending, you should only see deltas for your changes.
Create the package for your extension using the
New-NAVAppManifest
,Get-NAVAppInfo
, andNew-NAVAppPackage
cmdlets making sure to use the –Dependencies parameter on theNew-NAVAppManifest
to identify the NAV extensions that you dependent on.
See Also
Tasks
How to: Create an Extension Package
How to: Publish and Install an Extension
Concepts
Extending Microsoft Dynamics NAV Using Extension Packages
Other Resources
Comparing and Merging Application Object Source Files
Microsoft Dynamics NAV Windows PowerShell Cmdlets
Development Cmdlets for Microsoft Dynamics NAV