Chilkat HOME .NET Core C# Android™ AutoIt C C# C++ Chilkat2-Python CkPython Classic ASP DataFlex Delphi ActiveX Delphi DLL Go Java Lianja Mono C# Node.js Objective-C PHP ActiveX PHP Extension Perl PowerBuilder PowerShell PureBasic Ruby SQL Server Swift 2 Swift 3,4,5... Tcl Unicode C Unicode C++ VB.NET VBScript Visual Basic 6.0 Visual FoxPro Xojo Plugin
(Visual FoxPro) Sign Manifest File to Generate a Passbook .pkpass in MemoryDemonstrates how to create a Passbook .pkpass archive by creating a signature of a manifest file and then zipping to a .pkpass archive in memory
LOCAL lnSuccess LOCAL loManifest LOCAL loCrypt LOCAL loZip LOCAL lcDigestStr LOCAL loPngData LOCAL loEntry LOCAL lcPassJson LOCAL loCertVault LOCAL loAppleWwdrCert LOCAL loBdPfx LOCAL lcPfxPassword LOCAL loCert LOCAL loJsonSignedAttrs LOCAL lcSig LOCAL loBdSig LOCAL loBdZip * This requires the Chilkat API to have been previously unlocked. * See Global Unlock Sample for sample code. * --------------------------------------------------------------------------------------------- * This example is the same as Sign Manifest File to Generate a Passbook .pkpass file * except everything happens in memory (no input files, no output files) * --------------------------------------------------------------------------------------------- * First create the manifest.json * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loManifest = CreateObject('Chilkat.JsonObject') * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Crypt2') loCrypt = CreateObject('Chilkat.Crypt2') * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Zip') loZip = CreateObject('Chilkat.Zip') loZip.NewZip("notUsedAndNeverCreated.zip") loCrypt.HashAlgorithm = "sha1" * Return hashes as lowercase hex. loCrypt.EncodingMode = "hexlower" * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.BinData') loPngData = CreateObject('Chilkat.BinData') * Assume we load the pngData with bytes for "icon.png" from somewhere, such as a byte array in memory. loEntry = loZip.AppendBd("icon.png",loPngData) RELEASE loEntry lcDigestStr = loCrypt.HashBdENC(loPngData) loManifest.UpdateString('"icon.png"',lcDigestStr) loPngData.Clear() * Assume we load the pngData with bytes for "icon@2x.png" from somewhere... loEntry = loZip.AppendBd("icon@2x.png",loPngData) RELEASE loEntry lcDigestStr = loCrypt.HashBdENC(loPngData) loManifest.UpdateString('"icon@2x.png"',lcDigestStr) loPngData.Clear() * Assume we load the pngData with bytes for "logo.png" from somewhere... loEntry = loZip.AppendBd("logo.png",loPngData) RELEASE loEntry lcDigestStr = loCrypt.HashBdENC(loPngData) loManifest.UpdateString('"logo.png"',lcDigestStr) loPngData.Clear() * Assume we load the pngData with bytes for "logo@2x.png" from somewhere... loEntry = loZip.AppendBd("logo@2x.png",loPngData) RELEASE loEntry lcDigestStr = loCrypt.HashBdENC(loPngData) loManifest.UpdateString('"logo@2x.png"',lcDigestStr) lcPassJson = "{ .... }"* Contains the contents of pass.json loEntry = loZip.AppendString("pass.json",lcPassJson) RELEASE loEntry lcDigestStr = loCrypt.HashStringENC(lcPassJson) loManifest.UpdateString('"pass.json"',lcDigestStr) loEntry = loZip.AppendString("manifest.json",loManifest.Emit()) RELEASE loEntry * Make sure we have the Apple WWDR intermediate certificate available for * the cert chain in the signature. * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.XmlCertVault') loCertVault = CreateObject('Chilkat.XmlCertVault') * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Cert') loAppleWwdrCert = CreateObject('Chilkat.Cert') lnSuccess = loAppleWwdrCert.LoadByCommonName("Apple Worldwide Developer Relations Certification Authority") IF (lnSuccess <> 1) THEN ? "The Apple WWDR intermediate certificate is not installed." ? "It is available at https://developer.apple.com/certificationauthority/AppleWWDRCA.cer" ? "You may alternatively load the .cer like this..." lnSuccess = loAppleWwdrCert.LoadFromFile("qa_data/certs/AppleWWDRCA.cer") IF (lnSuccess <> 1) THEN ? loAppleWwdrCert.LastErrorText RELEASE loManifest RELEASE loCrypt RELEASE loZip RELEASE loPngData RELEASE loCertVault RELEASE loAppleWwdrCert CANCEL ENDIF ENDIF loCertVault.AddCert(loAppleWwdrCert) loCrypt.UseCertVault(loCertVault) * Use a digital certificate and private key from a PFX * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.BinData') loBdPfx = CreateObject('Chilkat.BinData') * Assume we loaded a PFX into bdPfx.... lcPfxPassword = "test123" * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.Cert') loCert = CreateObject('Chilkat.Cert') lnSuccess = loCert.LoadPfxBd(loBdPfx,lcPfxPassword) IF (lnSuccess <> 1) THEN ? loCert.LastErrorText RELEASE loManifest RELEASE loCrypt RELEASE loZip RELEASE loPngData RELEASE loCertVault RELEASE loAppleWwdrCert RELEASE loBdPfx RELEASE loCert CANCEL ENDIF * Provide the signing cert (with associated private key). lnSuccess = loCrypt.SetSigningCert(loCert) IF (lnSuccess <> 1) THEN ? loCrypt.LastErrorText RELEASE loManifest RELEASE loCrypt RELEASE loZip RELEASE loPngData RELEASE loCertVault RELEASE loAppleWwdrCert RELEASE loBdPfx RELEASE loCert CANCEL ENDIF * Specify the signed attributes to be included. * (These attributes appear to not be necessary, but we're including * them just in case they become necessary in the future.) * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.JsonObject') loJsonSignedAttrs = CreateObject('Chilkat.JsonObject') loJsonSignedAttrs.UpdateInt("contentType",1) loJsonSignedAttrs.UpdateInt("signingTime",1) loCrypt.SigningAttributes = loJsonSignedAttrs.Emit() * Sign the manifest JSON to produce a signature loCrypt.EncodingMode = "base64" lcSig = loCrypt.SignStringENC(loManifest.Emit()) * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.BinData') loBdSig = CreateObject('Chilkat.BinData') loBdSig.AppendEncoded(lcSig,"base64") loEntry = loZip.AppendBd("signature",loBdSig) RELEASE loEntry * --------------------------------------------------------------------------------------------- * Note: Chilkat also has the capability to do everything in-memory (no files would be involved). * If this is of interest, please send email to support@chilkatsoft.com * --------------------------------------------------------------------------------------------- * Create the .pkipass archive (which is a .zip archive containing the required files). * the .zip is written to bdZip * For versions of Chilkat < 10.0.0, use CreateObject('Chilkat_9_5_0.BinData') loBdZip = CreateObject('Chilkat.BinData') lnSuccess = loZip.WriteBd(loBdZip) IF (lnSuccess <> 1) THEN ? loZip.LastErrorText RELEASE loManifest RELEASE loCrypt RELEASE loZip RELEASE loPngData RELEASE loCertVault RELEASE loAppleWwdrCert RELEASE loBdPfx RELEASE loCert RELEASE loJsonSignedAttrs RELEASE loBdSig RELEASE loBdZip CANCEL ENDIF ? "Success." RELEASE loManifest RELEASE loCrypt RELEASE loZip RELEASE loPngData RELEASE loCertVault RELEASE loAppleWwdrCert RELEASE loBdPfx RELEASE loCert RELEASE loJsonSignedAttrs RELEASE loBdSig RELEASE loBdZip |
© 2000-2024 Chilkat Software, Inc. All Rights Reserved.