class Fastlane::Actions::DingTalkAction
Public Class Methods
available_options()
click to toggle source
# File lib/fastlane/plugin/ding_talk/actions/ding_talk_action.rb, line 84 def self.available_options [ FastlaneCore::ConfigItem.new(key: :api_key, env_name: "PGYER_API_KEY", description: "api_key in your pgyer account", optional: false, type: String), FastlaneCore::ConfigItem.new(key: :app_key, env_name: "PGYER_APP_KEY", description: "app_key for your app", optional: false, type: String), FastlaneCore::ConfigItem.new(key: :access_token, env_name: "DING_TALK_ROBOT_ACCESS_TOKEN", description: "access_token for your ding talk robot", optional: false, type: String), FastlaneCore::ConfigItem.new(key: :markdown_desc, env_name: "DING_TALK_APP_DESCRIPTION", description: "description for your app", optional: true, type: String) ] end
description()
click to toggle source
# File lib/fastlane/plugin/ding_talk/actions/ding_talk_action.rb, line 67 def self.description "Send the packaging information to the ding talk." end
details()
click to toggle source
# File lib/fastlane/plugin/ding_talk/actions/ding_talk_action.rb, line 79 def self.details # Optional: "Send the packaging information to the ding talk, and provide the qr code for others to install." end
is_supported?(platform)
click to toggle source
# File lib/fastlane/plugin/ding_talk/actions/ding_talk_action.rb, line 109 def self.is_supported?(platform) # Adjust this if your plugin only works for a particular platform (iOS vs. Android, for example) # See: https://docs.fastlane.tools/advanced/#control-configuration-by-lane-and-by-platform # [:ios, :mac, :android].include?(platform) true end
return_value()
click to toggle source
# File lib/fastlane/plugin/ding_talk/actions/ding_talk_action.rb, line 75 def self.return_value # If your method provides a return value, you can describe here what it does end
run(params)
click to toggle source
# File lib/fastlane/plugin/ding_talk/actions/ding_talk_action.rb, line 7 def self.run(params) UI.message("The ding_talk plugin is working!") api_key = params[:api_key] app_key = params[:app_key] access_token = params[:access_token] markdown_desc = params[:markdown_desc] params = { '_api_key' => api_key, 'appKey' => app_key } UI.message("Start get app information from pgyer...") # 获取App详细信息 response = Net::HTTP.post_form URI('https://www.pgyer.com/apiv2/app/view'), params result = JSON.parse(response.body) status_code = result["code"] status_message = result["message"] if status_code != 0 UI.error('pgyer error message: ' + status_message) return end UI.success("Successfully get app information!") # 应用二维码地址 buildQRCodeURL = result["data"]["buildQRCodeURL"] # 将应用信息发送到钉钉 uri = URI.parse("https://oapi.dingtalk.com/robot/send?access_token=#{access_token}") https = Net::HTTP.new(uri.host, uri.port) https.use_ssl = true req = Net::HTTP::Post.new(uri.request_uri) req.body = { 'msgtype' => 'markdown', 'markdown' => { 'title': 'A new app update from fastlane.', 'text': "#{markdown_desc} <br> " }, 'at': { 'atMobiles': [], 'isAtAll': false } }.to_json req.content_type = 'application/json' resp = https.request(req) json = JSON.parse(resp.body) if json["errcode"] != 0 UI.error('ding talk error message: ' + json["errmsg"]) return end UI.success("Successfully send qr code to ding talk!") end