[译] 轻松发布私有 App

来自插图 Virginia Poltrackhtml

不论你的团队拥有 5 个仍是 100 个 App,你总能找到帮你管理 Play Store 列表的自动化工具。Google Play 容许你经过其开发者 API 来管理你的 Play Store 列表、打包好的 APK 等。2017 年 1 月的时候,Google 从 Twitter 收购了名为 Fabric 的开发者套件,其中包含了能够自动化截图、管理测试版部署、签名并将 App 推送到 Play Store 的 fastlane前端

除此以外,私有 App 发布 API 容许拥有管理权限的 Google Play 用户在跳过 最低版本检查 的状况下建立并发布私有的 App。Managed Google Play 是为企业版 Android 用户提供私有应用程序支持的应用商店。私有 App 只会被分发给内部用户而不会被大众获取。私有 App 的部署能够在被建立后的几分钟内完成。Jan Piotrowskifastlane 提出的这个 pull request,让零代码部署 App 成为可能。对此特性的请求历史能够在 这里 看到。若是想要更多了解 Managed Google Play 和 Google Play 项目,请看看这篇 博客java

这为何很重要:私有 App 发布 API 或者 fastlane 大大简化了迁移到 Managed Google Play 的流程,而且能够方便地被集成到 CI 工具中。node

配置私有 App 功能

重要:在建立用于调试或产品的 keystore 时,请确保使用最佳的 app 签名方式。千万别丢失您用于生产的 keystore!由于一旦你将它应用于 Google Play 上的某一个 App ID(包括私有 App),你将永远不能在不建立新的应用程序列表及修改其 App ID 的状况下更换 keystore。python

推荐:利用 Google Play App Signing 来为你的 APK 文件签名。这是保管的 keystore 的一个好方法。你能够在 这里 看到此方法的细节。android

重要:在 Google Play 上的全部 App(包括私有 App)必须具备一个惟一的且不可重用的 App ID。ios

在发布你的私有 App 以前,你只须要三步。git

跟着这篇 指导说明 进行以下三步:github

  1. 在 Cloud API 控制台中启用 Google Play 的 私有 App 发布 API;
  2. 建立一个服务帐户,并下载其 JSON 格式的私钥;
  3. 启用私有 App 功能。

配置 fastlane

  • 请阅读这篇 文档 来安装 fastlane 。其中包含了 Managed Google Play 支持。

启用私有 App — 获取你的开发者帐户 ID

这篇 指南 将告诉你如何建立一个须要经过 OAuth 回调来获取开发者帐户 ID 的私有 App。有两种方法来启用私有 App 功能:使用 fastlane 或者使用 API。下面将向你展现如何使用这两种方法并比较其复杂程度:shell

使用 fastlane — 很是简单

> fastlane run get_managed_play_store_publishing_rights
复制代码

样例输出:

[13:20:46]: To obtain publishing rights for custom apps on Managed Play Store, open the following URL and log in:

[13:20:46]: https://play.google.com/apps/publish/delegatePrivateApp?service_account=SERVICE-ACCOUNT-EMAIL.iam.gserviceaccount.com&continueUrl=https://fastlane.github.io/managed_google_play-callback/callback.html

[13:20:46]: ([Cmd/Ctrl] + [Left click] lets you open this URL in many consoles/terminals/shells)

[13:20:46]: After successful login you will be redirected to a page which outputs some information that is required for usage of the `create_app_on_managed_play_store` action.
复制代码

把这个连接粘贴到你的浏览器中你就能够向这个 Managed Google Play 的帐户全部者发起受权请求了。

使用 API — 有点复杂

若是 你不打算为了管理你的 App 作一个基于 Web 的前端页面,你可使用下面的 node 脚本以及 Firebase 的功能来快速获取你的开发者帐户 ID。若是你不在乎跳转的 URL(continueUrl)的话,你能够把它设置成相似于 foo.bar 这样的假 URL。可是出于安全的考虑,这么作是不被推荐的。

配置 Firebase 的云功能

这篇 指南 将告诉你怎样去配置 Firebase 的云功能。下面的代码可被用于你的终端。

const functions = require('firebase-functions');

exports.oauthcallback = functions.https.onRequest((request, response) => {
  response.send(request.query.developerAccount);
});
复制代码

functions/index.js

建立私有 App 列表

使用 fastlane — 很是简单

ENV['SUPPLY_JSON_KEY'] = 'key.json'
  ENV['SUPPLY_DEVELOPER_ACCOUNT_ID'] = '111111111111000000000'
  ENV['SUPPLY_APP_TITLE'] = 'APP TITLE'
  desc "Create the private app on the Google Play store"
  lane :create_private_app do
      gradle(
        task: 'assemble',
        build_type: 'Release'
      )

      # Finds latest APK
      apk_path = Actions.lane_context[SharedValues::GRADLE_APK_OUTPUT_PATH]

      create_app_on_managed_play_store(
        json_key: ENV['SUPPLY_JSON_KEY'],
        developer_account_id: ENV['SUPPLY_DEVELOPER_ACCOUNT_ID'],
        app_title: ENV['SUPPLY_APP_TITLE'],
        language: "en_US",
        apk: apk_path
      )
    end
复制代码

样例 Fastfile

> fastlane create_private_app
复制代码

使用 API — 有点复杂

或许你应当先读读 API 文档。Google 提供了 JavaPythonC#Ruby 的用户端库文件。

API 样例

下面这段 Ruby 代码在使用 Google 服务帐户 的 JSON 格式密钥文件认证以后,经过调用 Play Custom App 服务建立了一个私有 App 并上传了其初版 APK 文件。这段代码只应当在第一次建立 App 时使用,后续更新应使用 Google Play 的发布 API 中的上传 APK 功能。

require "google/apis/playcustomapp_v1"

# Auth Info
KEYFILE = "KEYFILE.json" # PATH TO JSON KEYFILE
DEVELOPER_ACCOUNT = "DEVELOPER_ACCOUNT_ID" # DEVELOPER ACCOUNT ID

# App Info
APK_PATH = "FILE_NAME.apk" # PATH TO SIGNED APK WITH V1+V2 SIGNATURES
APP_TITLE = "APP TITLE"
LANGUAGE_CODE = "EN_US"

scope = "https://www.googleapis.com/auth/androidpublisher"
credentials = JSON.parse(File.open(KEYFILE, "rb").read)
authorization = Signet::OAuth2::Client.new(
 :token_credential_uri => "https://oauth2.googleapis.com/token",
 :audience => "https://oauth2.googleapis.com/token",
 :scope => scope,
 :issuer => credentials["client_id"],
 :signing_key => OpenSSL::PKey::RSA.new(credentials["private_key"], nil),
)
authorization.fetch_access_token!

custom_app = Google::Apis::PlaycustomappV1::CustomApp.new title: APP_TITLE, language_code: LANGUAGE_CODE
play_custom_apps = Google::Apis::PlaycustomappV1::PlaycustomappService.new
play_custom_apps.authorization = authorization

play_custom_apps.create_account_custom_app(
 DEVELOPER_ACCOUNT,
 custom_app,
 upload_source: APK_PATH,
) do |created_app, error|
 unless error.nil?
   puts "Error: #{error}"
 else
   puts "Success: #{created_app}."
 end
end
复制代码

更新私有 App

建立 Play Store 列表以后,一旦你建立了一个私有 App,你就可使用 Google Play 发布 API 来推送你的新 APK 文件。fastlane 支持这个功能。你能够在 这里 找到更多信息。

部署到用户

Managed Google Play 须要 EMM (Enterprise Mobility Management)系统将 App 分发给用户。了解更多请戳这里

部署和管理企业私有 App 从未变得如此容易。这两种使用 Managed Google Play 来部署 App 的方法都是可行的。使用哪种取决于你的持续集成系统以及你是否想要写代码。试试 fastlane 吧,你会省下不少时间的。

若是你在使用 fastlane 的时候遇到任何问题或者 bug,请在 github 上给咱们提 issue。

若是发现译文存在错误或其余须要改进的地方,欢迎到 掘金翻译计划 对译文进行修改并 PR,也可得到相应奖励积分。文章开头的 本文永久连接 即为本文在 GitHub 上的 MarkDown 连接。


掘金翻译计划 是一个翻译优质互联网技术文章的社区,文章来源为 掘金 上的英文分享文章。内容覆盖 AndroidiOS前端后端区块链产品设计人工智能等领域,想要查看更多优质译文请持续关注 掘金翻译计划官方微博知乎专栏

相关文章
相关标签/搜索