On Tue, Jun 14, 2016 at 5:53 PM, Thomas Mortagne <[email protected]>
wrote:

> On Mon, Jun 13, 2016 at 3:34 PM, fitz <[email protected]> wrote:
> > Release Android App Automatically and Securely
> >
> > There are mainly two steps:  (1) Generate the signed apk  (2) Release to
> the
> > google play store.
> > Generate the signed apk automatically:
> >
> > 1. (Need Help) Generate keystore file
> >
> > Use Command Line:
> >
> https://developer.android.com/studio/publish/app-signing.html#signing-manually
> > keytool -genkey -v -keystore my-release-key.keystore -alias alias_name
> > -keyalg RSA -keysize 2048 -validity 10000
> > Or use Android studio:
> >
> https://developer.android.com/studio/publish/app-signing.html#release-mode
> >
> > Maybe we should generate a new, secure and stable private key for the
> future
> > android development and release.  WDYT?
> >
> > 2. (Need Help) Define gradle global values:
> >
> > (Gradle user home: /home/hudsonagent/.gradle in
> > jenkins)(
> http://stackoverflow.com/questions/18328730/how-to-create-a-release-signed-apk-file-using-gradle
> )
> > To ensure the security of the keystore, we can’t directly put the
> > key_password, key_alias, store_password values in the github source.  So
> > where do we define these values?  The gradle global properties may be a
> good
> > choice. First we should define some global properties for all Gradle
> builds
> > in the USER_HOME/.gradle/gradle.properties. For the jenkins server,
> > GRADLE_USER_HOME = /home/hudsonagent/.gradle.  If no gradle.properties
> file,
> > just create a new file and add the following properties.
> >
> > # android release key username and password
> > RELEASE_STORE_FILE=F:\\xwiki\\AndroidAuthKey.jks
> > RELEASE_STORE_PASSWORD=android
> > RELEASE_KEY_ALIAS=authenticator
> > RELEASE_KEY_PASSWORD=android
> >
> > I have no right to login and access the jenkins agent-1, so could you
> help
> > me create the global gradle.properties file in /home/hudsonagent/.gradle
> and
> > correctly set the four properties.  Thanks in advance.  :)
> >
> > 3. Add the following code to build.gradle
> >
> >
> > if(project.hasProperty("RELEASE_STORE_FILE")) {
> >     signingConfigs {
> >        release {
> >            storeFile file(RELEASE_STORE_FILE)
> >            storePassword RELEASE_STORE_PASSWORD
> >            keyAlias RELEASE_KEY_ALIAS
> >            keyPassword RELEASE_KEY_PASSWORD
> >        }
> >     }
> > }
> >
> > buildTypes {
> >     if(project.hasProperty("RELEASE_STORE_FILE")) {
> >         release {
> >             signingConfig signingConfigs.release
> >         }
> >     }
> > }
> >
> > 4. Gradle clean build
> >   -> then we can generate app-release.apk signed by the keystore in
> jenkins.
>
> Will do as soon as I get back access to agent 1-1.
>
> >
> >
> > Release automatically in Google play store:
> >
> >
> > 1. (Need Help) Setup for Google API access:
> >
> > Following this link:
> >
> https://github.com/codepath/android_guides/wiki/Automating-Publishing-to-the-Play-Store
> .
> > Set the google api access and download the p12 key file.
> > But I have no permission to configure API access. It shows in the google
> > play console:
> > <http://xwiki.475771.n2.nabble.com/file/n7599946/api_access.png>
> >
> > So could you help me configure the API access? Or maybe should download
> the
> > p12 key file. Thank you in advance. :)
> >
> > 2. (Need Help) Jenkins plugin Settings:
> >
> > (1) Install the jenkins plugin "Google Play Android Publisher plugin"
> > (2) Add Credentials and import the p12 key file downloaded during the
> first
> > step of setting up Google API access.
> > <http://xwiki.475771.n2.nabble.com/file/n7599946/add_credentials.png>
> >
> > 3. Add a post-build step to your existing Jenkins project.
> >
> > <http://xwiki.475771.n2.nabble.com/file/n7599946/post_build.png>
> >
> > That’s all I can think of right now.  I have tried and generated the
> release
> > apk in the jenkins server on my local computer. As I have no permission
> to
> > configure the google play api, so now I haven’t tried the automated
> release.
> > I don't know if this method is the best for the automated and secure
> release
> > of the android open source project, but it should be feasible.
> >
> > What do you think? :)
>
> I'm not sure "automated release" is such a need.
>
> Configure agent 1-1 to do release from it, sure. Agent 1-1 is XWiki's
> release agent so why not making it Android Authenticator release agent
> (we have to put the key somewhere). But a release of Android
> Authenticator should be a conscious decision IMO and you should do
> that only when you are sure the branch is OK.
>


Thank you so much for helping me ! :)

Yes, (1) maybe it's not needed :) , (2) or I should only and manually start
a building job in jenkins once I finished a version.  Because I should
write "What's new in this version?" in the google play console or in the
jenkins post build each time when releasing a new version app.  (3) or
Maybe I can start a new dev branch in the github repository. And the master
branch can be only used as the release branch. When I finish a version,
merge the dev branch to master so that I can set the periodic build job in
jenkins. :)

Thanks,
Fitz


>
> >
> > Thanks,
> > Fitz
> >
> >
> >
> >
> > --
> > View this message in context:
> http://xwiki.475771.n2.nabble.com/contrib-android-authenticator-About-Releasing-Android-App-Automatically-and-Securely-tp7599946.html
> > Sent from the XWiki- Dev mailing list archive at Nabble.com.
> > _______________________________________________
> > devs mailing list
> > [email protected]
> > http://lists.xwiki.org/mailman/listinfo/devs
>
>
>
> --
> Thomas Mortagne
> _______________________________________________
> devs mailing list
> [email protected]
> http://lists.xwiki.org/mailman/listinfo/devs
>
_______________________________________________
devs mailing list
[email protected]
http://lists.xwiki.org/mailman/listinfo/devs

Reply via email to