Support Article
Mobile build for Android hangs
Summary
Building a mobile app for Android hangs. It has been running for over 12 hours.
Error Messages
On the screen user sees the message Downloading Build for ever.
data:image/s3,"s3://crabby-images/8f372/8f37266a802b5998f06e22bae8590d02d61b1ef3" alt=""
When we enable SSL debug through JVM flag -Djavax.net.debug=all, we notice the following error in the application server log
2016-10-25 17:14:14,758 [.PegaWorkManager : 1] [ STANDARD] [ ] [ SSL:01.01.01] (.ssl.CompositeX509TrustManager) DEBUG Admin@GCS - certificate not trusted by TrustManager: com.ibm.jsse2.yc@6b3a0fe7
com.ibm.jsse2.util.h: PKIX path building failed: java.security.cert.CertPathBuilderException: PKIXCertPathBuilderImpl could not build a valid CertPath.; internal cause is:
java.security.cert.CertPathValidatorException: The certificate issued by CN=Go Daddy Root Certificate Authority - G2, O="GoDaddy.com, Inc.", L=Scottsdale, ST=Arizona, C=US is not trusted; internal cause is:
java.security.cert.CertPathValidatorException: Certificate chaining error
...
Caused by:
java.security.cert.CertPathBuilderException: PKIXCertPathBuilderImpl could not build a valid CertPath.; internal cause is:
....
com.pega.pegarules.pub.services.ConnectorException: Caught unhandled exception: javax.net.ssl.SSLPeerUnverifiedException: peer not authenticated
at com.pegarules.generated.activity.ra_action_pyinvokerestconnector_28ccb2185309b8c9c6d59a05ed51acae.step5_circum0(ra_action_pyinvokerestconnector_28ccb2185309b8c9c6d59a05ed51acae.java:1631)
Steps to Reproduce
- Log on to Pega.
- Open any application.
- Go to the Mobile Tab.
- Fill in the values for "Unique application identifier", "Description" and "Release version:"
- Add and Select "Distribution P12 file"
- Click Create Build button.
- Notice the Build finishes with 100% and displays downloading and it hangs there.
Root Cause
From September 2016 onwards, the build Server operates via SSL only. Production Build Server uses certificate issued by Go Daddy - in order to establish connection with it, Java trust store (cacerts) on Pega server needs to contain entry for Go Daddy Root CA. CN = Go Daddy Root Certificate Authority - G2 O = GoDaddy.com, Inc. L = Scottsdale S = Arizona C = US
Resolution
Perform the following local-change:
To delete the hanged mobile build, Create and run an activity that does Obj-Delete-By-Handle in order to remove a stuck mobile build. The handle would be like this
DATA-MOBILE-BUILD RULE-APPLICATION <ApplicationName> <ApplicationVersion>!PRPC-HYBRID-<ANDROID/IOS>
For e.g.
ATA-MOBILE-BUILD RULE-APPLICATION MYAPP 01.01.01!PRPC-HYBRID-ANDROID)
Make sure to check the 'Immediate' checkbox with Obj-Delete-By-Handle.
In this case my application name is "MYAPP" and version is "01.01.01" . You can also view the column "PZINSKEY" of the Database table "PR_DATA_MOBILE_BUILD" for the handle
Run the activity To delete the hanged mobile build.
Next step is to import the Pega Mobile build server certificates.
Download the certificates from the Pega Mobile buildserver URL https://mobilebuildserver.pega.com/buildserver
data:image/s3,"s3://crabby-images/3f132/3f132b8f9e004ada7c4a1765b63419eb7eb50e8c" alt=""
Import the certificates in the application server truststore and restart the application server.
Published November 4, 2016 - Updated October 8, 2020
Have a question? Get answers now.
Visit the Collaboration Center to ask questions, engage in discussions, share ideas, and help others.