Redistribution to Clients

From PDF XChange PDF SDK
Jump to: navigation, search
(Using the C-export Method.)
 
(44 intermediate revisions by 3 users not shown)
Line 3: Line 3:
 
{{#customTitle:Redistribution to Clients}}
 
{{#customTitle:Redistribution to Clients}}
 
{{#parentPage:Main_Page}}
 
{{#parentPage:Main_Page}}
{{ToWrite}}
+
 
 
{{ToReview}}
 
{{ToReview}}
  
There are several ways to install required SDK on the user-user system and get it work there.
+
Redistributing and installing the required components onto a target users system is a relatively straight forward process and we provide several ways to do so - dependent on the functionality that has been used within your application, below you will find detailed instructions on doing so - please do not simply redistribute our 'developers SDK' in its entirety - this will simply clutter your users system, bloat your own installer and most likely confuse your clients as to what applications are available for their use.
  
First of all, your installer should save the SDK DLL file ('''PDFXCoreAPI.x86.dll''' or '''PDFXCoreAPI.x64.dll''' for the PDF-XChange Core API SDK; '''PDFXEditCore.x86.dll''' or '''PDFXEditCore.x64.dll''' for the PDF-XChange Editor SDK). Also for the PDF-XChange Editor SDK the file '''Resources.dat''' must be saved into the same folder.
+
'''Option 1.'''
  
Next, the installer should prepare the SDK. There are several methods:
+
If you have used the UI based functionality contained in the '''PDF-XChange Editor SDK''' - your installer must include the following two files (note the 32/64 bit dependency of specific DLL's and locate both into one common folder on the users system
 +
 
 +
Installation of the PDFXEditCorexxx.dll incorporates all PDF-XChange Core API SDK functionality and negates the need to install the PDFXCoreAPIxxx.dll file subsequently detailed.
 +
 
 +
:<tt>PDFXEditCore.x86.dll</tt>
 +
:(for 32-bit applications)
 +
'''or'''
 +
:<tt>PDFXEditCore.x64.dll</tt>
 +
:(for 64-bit applications)
 +
'''and'''
 +
:<tt>Resources.dat</tt> - this file is not 32/64 bit dependent and always the same.
 +
 
 +
 
 +
'''NOTE:''' If wish to include different language localizations for the Editor's UI - please also include the entire '''Languages''' folder we provide and relevant language files as installed by your initial SDK development system installed from us. These files should be located in the same directory as the files detailed above.
 +
 
 +
'''''Do you have any improvements to our Localization files''''' or perhaps a new one you would like us to include? If so we would be pleased to add them to our official releases in coming updates, see [http://www.tracker-software.com/editor_lang here] for more info.
 +
 
 +
'''Option 2.'''
 +
 
 +
If your application makes use only of 'non UI' based functionality as available in the '''PDF-XChange Core API SDK''' you need copy only a single file to your clients target system - again please note the specific version will be 32/64 bit dependent...
 +
 
 +
:<tt>PDFXCoreAPI.x86.dll</tt>
 +
:(for 32-bit applications)
 +
'''or'''
 +
:<tt>PDFXCoreAPI.x64.dll</tt>
 +
:(for 64-bit applications)
 +
 
 +
 
 +
Your installer must then prepare your clients system for use of the installed components, the installer should prepare the SDK for use - there are several methods of doing so and you should choose that which is most appropriate for your needs and clients most likely circumstances;
  
 
== COM-Server Method. ==
 
== COM-Server Method. ==
COM-server should be registered on the destination system. To do that, run the following command:
+
COM-server to be registered on the target system. To do so, run the following command:
 
:<tt>regsvr32 <SDKLibName>.x86.DLL</tt>  
 
:<tt>regsvr32 <SDKLibName>.x86.DLL</tt>  
 
:(for 32-bit apps)
 
:(for 32-bit apps)
Line 19: Line 47:
 
:<tt>regsvr32 <SDKLibName>.x64.DLL</tt>
 
:<tt>regsvr32 <SDKLibName>.x64.DLL</tt>
 
:(for 64-bit apps)
 
:(for 64-bit apps)
The installer should execute this command. Additional command line option <tt>/S</tt> can be passed to <tt>regsvr32</tt> to remove the message box reporting the result of registration.
 
With this method it does not matter where COM-server files are located relative to the files of your application, as the COM-server are registered globally in the system (using registry) and it become available for all applications in the system. This can cause a potential problem. The following sample shows that problem. Let we have the system where an application called '''AppA''' and that uses the SDK version '''5.5.313'''. During the installation of this app, the SDK was globally registered as a COM-server. Than another application '''AppB''', that also uses the SDK is installing on the system, but the installer of this app contains older build of the SDK. When this installer will register SDK’s COM-server, it will '''override''' existing COM-server registration and now '''all''' applications will use the last installed SDK. If '''AppA''' requires newer SDK, it may cause serious issues when it will try to use older version of the SDK.
 
  
== Registration-free, Click-Once Method. ==
+
Additional command line options <tt>/S</tt> may be passed to <tt>regsvr32</tt> to suppress registration confirmation status message box .
Application’s installer should save executable file of the application and SDK’s files in the same folder, and additional two XML files with special names should be placed in that folder:
+
 
 +
Using this method ensures that irrespective of the COM server files location relative to your application files the SDK functionality will work correctly, as the COM-server are registered globally within the target system as relationships are managed by the system registry.
 +
 
 +
'''IMPORTANT:''' One potential problem this can cause however is where a user has multiple applications using our Editor SDK functionality (perhaps from you or from one or more 3rd party developers) but each relies on differing releases/builds of our SDK (for example one developer used Version 5.5.313 when creating his application - but you have used a subsequent, later release) here an issue may arise should each developer's installer use the COM global registration method. Whichever installer ran last will be the COM server available to all applications. Should new functionality be available in a later release and one applications is dependent on this functionality - but subsequently another installer is used to install an older version - the new functionality is no longer available and one application or more will cease to function correctly...
 +
 
 +
Good installation management will therefore be essential and you may prefer to resist using the global registration method on users system for this reason.
 +
 
 +
== Registration-Free(Click-Once) Method. ==
 +
Your application installer should locate all application executable files and the require '''PDF-XChange Editor SDK''' files in a single common folder along with 2 additional XML files with prescribed file names as follows:
 
:<tt><YourProgramName>.exe.manifest</tt>
 
:<tt><YourProgramName>.exe.manifest</tt>
 
:<tt><SDKLibName>.x86.X.manifest (or <SDKLibName>.x64.X.manifest)</tt>
 
:<tt><SDKLibName>.x86.X.manifest (or <SDKLibName>.x64.X.manifest)</tt>
Where,
+
Where, <tt><YourProgramName></tt> - is the name of the application’s executable file without a file extension.  
<tt><YourProgramName></tt> - name of the application’s executable file without extension.  
+
Sample XML files:
 +
 
 +
'''<YourProgramName>.exe.manifest''' source:
 +
<pre class="brush:xml;gutter:false;collapse:true">
 +
<?xml version="1.0" encoding="utf-8" standalone="yes"?>
 +
<assembly manifestVersion="1.0"
 +
xmlns="urn:schemas-microsoft-com:asm.v1"
 +
xmlns:asmv2="urn:schemas-microsoft-com:asm.v2"
 +
xmlns:asmv3="urn:schemas-microsoft-com:asm.v3" >
 +
 
 +
<assemblyIdentity version="1.0.0.0" name="<YourProgramName>" />
 +
 
 +
<trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
 +
<security>
 +
<requestedPrivileges xmlns="urn:schemas-microsoft-com:asm.v3">
 +
<requestedExecutionLevel level="asInvoker" uiAccess="false" />
 +
</requestedPrivileges>
 +
</security>
 +
</trustInfo>
 +
 
 +
<!-- Registration-Free Redistribution part -->
 +
<dependency>
 +
<dependentAssembly>
 +
<assemblyIdentity type="win32" name="PDFXEditCore.x86.X" version="1.0.0.0" />
 +
</dependentAssembly>
 +
</dependency>
 +
 
 +
<!-- Optional: enable themes for Windows common controls and dialogs (Windows XP and later) -->
 +
<dependency>
 +
<dependentAssembly>
 +
<assemblyIdentity
 +
type="win32"
 +
name="Microsoft.Windows.Common-Controls"
 +
version="6.0.0.0"
 +
processorArchitecture="*"
 +
publicKeyToken="6595b64144ccf1df"
 +
language="*" />
 +
</dependentAssembly>
 +
</dependency>
 +
 
 +
<!-- Optional: enable DPI-Aware mode to prevent automatical DPI-scaling to avoid 'blurring' of UI -->
 +
<asmv3:application>
 +
<asmv3:windowsSettings xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">
 +
<dpiAware>true</dpiAware>
 +
</asmv3:windowsSettings>
 +
</asmv3:application>
 +
 
 +
</assembly>
 +
</pre>
 +
 
 +
'''PDFXEditCore.x86.X.manifest''' source:
 +
<pre class="brush:xml;gutter:false;collapse:true">
 +
<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
 +
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">
 +
 
 +
<assemblyIdentity
 +
type="win32"
 +
name="PDFXEditCore.x86.X"
 +
version="1.0.0.0" />
 +
 
 +
<file name = "PDFXEditCore.x86.dll">
 +
<typelib
 +
tlbid="{0AAFF38C-CB91-4424-A8B9-F8B504ACBE0C}"
 +
version="1.0"
 +
helpdir=""/>
 +
       
 +
<comClass
 +
clsid="{973BF60B-4CC6-4be0-B408-3D80E07FC2E6}"
 +
threadingModel="Apartment" />
 +
       
 +
<comClass
 +
clsid="{A1149909-4EDC-4421-B9E5-E93C25A000A1}"
 +
threadingModel="Apartment" />
 +
</file>
 +
 
 +
<comInterfaceExternalProxyStub
 +
name="IPXV_Inst"
 +
iid="{D726366D-34D6-49fc-A341-7B84C54CCA3E}"
 +
proxyStubClsid32="{00020424-0000-0000-C000-000000000046}"
 +
baseInterface="{00000000-0000-0000-C000-000000000046}"
 +
tlbid="{0AAFF38C-CB91-4424-A8B9-F8B504ACBE0C}" />
 +
   
 +
<comInterfaceExternalProxyStub
 +
name="IPXV_Control"
 +
iid="{71300D43-687F-436A-A699-2B37448D0803}"
 +
proxyStubClsid32="{00020424-0000-0000-C000-000000000046}"
 +
baseInterface="{00000000-0000-0000-C000-000000000046}"
 +
tlbid="{0AAFF38C-CB91-4424-A8B9-F8B504ACBE0C}" />
 +
   
 +
</assembly>
 +
</pre>
  
Sample XML files for Click-Once can be found there: <link>
+
That method ensures that sharing our SDK’s DLLs with other applications is avoided as are version conflicts described previously. Each application uses its own unique version of our SDK DLL's etc.
  
That method allows avoiding sharing SDK’s DLLs with other applications and conflicts with different versions. Each application that use this method will use own independent version of the SDK.
+
More detailed information regarding Registration-Free technology can be found [https://msdn.microsoft.com/en-us/library/ms973913.aspx here].
  
'''NOTE:''' In your development environment you have to change settings of your project to use external manifest files instead of built-in.
+
'''IMPORTANT:''' In your development environment you will also need to change the settings of your project to use external manifest files as opposed to those built-in by default.
  
 
== Using the C-export Method. ==
 
== Using the C-export Method. ==
This method differs in that it does not require any global registration of COM-server and no additional manifest files. However, this method requires to manually loading SDK’s DLL using Windows API function '''LoadLibrary'''. Than a special function should be retrieved and called from this DLL to create and receive a pointer to the main SDK’s object that will provide an access to the entire SDK functionality.
+
This method differs in that it does not require any global COM-server registration or additional manifest files. Instead, this method requires manually loading the SDK’s DLL by use of the Windows API function '''LoadLibrary'''. Then a special function should be retrieved and called from this DLL to create and receive a pointer to the main SDK’s object that will provide access to the entire SDK functionality.
For more information, please refer to sections '''How to Instantiate''' in the [[PXV:PXV_Inst|PXV_Inst]] and [[PXV:PXC_Inst|PXC_Inst]] objects’ descriptions.
+
For more information, please refer to the topics; '''How to Instantiate''' [[PXV:PXV_Inst|PXV_Inst]] and [[PXV:PXC_Inst|PXС_Inst]] ActiveX-objects’ description.
 
 

Latest revision as of 07:04, 13 June 2016


Redistributing and installing the required components onto a target users system is a relatively straight forward process and we provide several ways to do so - dependent on the functionality that has been used within your application, below you will find detailed instructions on doing so - please do not simply redistribute our 'developers SDK' in its entirety - this will simply clutter your users system, bloat your own installer and most likely confuse your clients as to what applications are available for their use.

Option 1.

If you have used the UI based functionality contained in the PDF-XChange Editor SDK - your installer must include the following two files (note the 32/64 bit dependency of specific DLL's and locate both into one common folder on the users system

Installation of the PDFXEditCorexxx.dll incorporates all PDF-XChange Core API SDK functionality and negates the need to install the PDFXCoreAPIxxx.dll file subsequently detailed.

PDFXEditCore.x86.dll
(for 32-bit applications)

or

PDFXEditCore.x64.dll
(for 64-bit applications)

and

Resources.dat - this file is not 32/64 bit dependent and always the same.


NOTE: If wish to include different language localizations for the Editor's UI - please also include the entire Languages folder we provide and relevant language files as installed by your initial SDK development system installed from us. These files should be located in the same directory as the files detailed above.

Do you have any improvements to our Localization files or perhaps a new one you would like us to include? If so we would be pleased to add them to our official releases in coming updates, see here for more info.

Option 2.

If your application makes use only of 'non UI' based functionality as available in the PDF-XChange Core API SDK you need copy only a single file to your clients target system - again please note the specific version will be 32/64 bit dependent...

PDFXCoreAPI.x86.dll
(for 32-bit applications)

or

PDFXCoreAPI.x64.dll
(for 64-bit applications)


Your installer must then prepare your clients system for use of the installed components, the installer should prepare the SDK for use - there are several methods of doing so and you should choose that which is most appropriate for your needs and clients most likely circumstances;

COM-Server Method.

COM-server to be registered on the target system. To do so, run the following command:

regsvr32 <SDKLibName>.x86.DLL
(for 32-bit apps)

or

regsvr32 <SDKLibName>.x64.DLL
(for 64-bit apps)

Additional command line options /S may be passed to regsvr32 to suppress registration confirmation status message box .

Using this method ensures that irrespective of the COM server files location relative to your application files the SDK functionality will work correctly, as the COM-server are registered globally within the target system as relationships are managed by the system registry.

IMPORTANT: One potential problem this can cause however is where a user has multiple applications using our Editor SDK functionality (perhaps from you or from one or more 3rd party developers) but each relies on differing releases/builds of our SDK (for example one developer used Version 5.5.313 when creating his application - but you have used a subsequent, later release) here an issue may arise should each developer's installer use the COM global registration method. Whichever installer ran last will be the COM server available to all applications. Should new functionality be available in a later release and one applications is dependent on this functionality - but subsequently another installer is used to install an older version - the new functionality is no longer available and one application or more will cease to function correctly...

Good installation management will therefore be essential and you may prefer to resist using the global registration method on users system for this reason.

Registration-Free(Click-Once) Method.

Your application installer should locate all application executable files and the require PDF-XChange Editor SDK files in a single common folder along with 2 additional XML files with prescribed file names as follows:

<YourProgramName>.exe.manifest
<SDKLibName>.x86.X.manifest (or <SDKLibName>.x64.X.manifest)

Where, <YourProgramName> - is the name of the application’s executable file without a file extension. Sample XML files:

<YourProgramName>.exe.manifest source:

<?xml version="1.0" encoding="utf-8" standalone="yes"?>
<assembly manifestVersion="1.0" 
	xmlns="urn:schemas-microsoft-com:asm.v1"
	xmlns:asmv2="urn:schemas-microsoft-com:asm.v2"
	xmlns:asmv3="urn:schemas-microsoft-com:asm.v3" >

	<assemblyIdentity version="1.0.0.0" name="<YourProgramName>" />

	<trustInfo xmlns="urn:schemas-microsoft-com:asm.v2">
		<security>
			<requestedPrivileges xmlns="urn:schemas-microsoft-com:asm.v3">
				<requestedExecutionLevel level="asInvoker" uiAccess="false" />
			</requestedPrivileges>
		</security>
	</trustInfo>

	<!-- Registration-Free Redistribution part -->
	<dependency>
		<dependentAssembly>
			<assemblyIdentity type="win32" name="PDFXEditCore.x86.X" version="1.0.0.0" />
		</dependentAssembly>
	</dependency>

	<!-- Optional: enable themes for Windows common controls and dialogs (Windows XP and later) -->
	<dependency>
		<dependentAssembly>
			<assemblyIdentity
				type="win32"
				name="Microsoft.Windows.Common-Controls"
				version="6.0.0.0"
				processorArchitecture="*"
				publicKeyToken="6595b64144ccf1df"
				language="*" />
		</dependentAssembly>
	</dependency>

	<!-- Optional: enable DPI-Aware mode to prevent automatical DPI-scaling to avoid 'blurring' of UI -->
	<asmv3:application>
		<asmv3:windowsSettings xmlns="http://schemas.microsoft.com/SMI/2005/WindowsSettings">
			<dpiAware>true</dpiAware>
		</asmv3:windowsSettings>
	</asmv3:application>

</assembly>

PDFXEditCore.x86.X.manifest source:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<assembly xmlns="urn:schemas-microsoft-com:asm.v1" manifestVersion="1.0">

	<assemblyIdentity
		type="win32"
		name="PDFXEditCore.x86.X"
		version="1.0.0.0" />

	<file name = "PDFXEditCore.x86.dll">
		<typelib 
			tlbid="{0AAFF38C-CB91-4424-A8B9-F8B504ACBE0C}"
			version="1.0"
			helpdir=""/>
         
		<comClass
			clsid="{973BF60B-4CC6-4be0-B408-3D80E07FC2E6}"
			threadingModel="Apartment" />
        
		<comClass
			clsid="{A1149909-4EDC-4421-B9E5-E93C25A000A1}"
			threadingModel="Apartment" />
	</file>

	<comInterfaceExternalProxyStub 
		name="IPXV_Inst" 
		iid="{D726366D-34D6-49fc-A341-7B84C54CCA3E}"
		proxyStubClsid32="{00020424-0000-0000-C000-000000000046}"
		baseInterface="{00000000-0000-0000-C000-000000000046}"
		tlbid="{0AAFF38C-CB91-4424-A8B9-F8B504ACBE0C}" />
    
	<comInterfaceExternalProxyStub 
		name="IPXV_Control" 
		iid="{71300D43-687F-436A-A699-2B37448D0803}"
		proxyStubClsid32="{00020424-0000-0000-C000-000000000046}"
		baseInterface="{00000000-0000-0000-C000-000000000046}"
		tlbid="{0AAFF38C-CB91-4424-A8B9-F8B504ACBE0C}" />
    
</assembly>

That method ensures that sharing our SDK’s DLLs with other applications is avoided as are version conflicts described previously. Each application uses its own unique version of our SDK DLL's etc.

More detailed information regarding Registration-Free technology can be found here.

IMPORTANT: In your development environment you will also need to change the settings of your project to use external manifest files as opposed to those built-in by default.

Using the C-export Method.

This method differs in that it does not require any global COM-server registration or additional manifest files. Instead, this method requires manually loading the SDK’s DLL by use of the Windows API function LoadLibrary. Then a special function should be retrieved and called from this DLL to create and receive a pointer to the main SDK’s object that will provide access to the entire SDK functionality. For more information, please refer to the topics; How to Instantiate PXV_Inst and PXС_Inst ActiveX-objects’ description.