-
Notifications
You must be signed in to change notification settings - Fork 152
Expand file tree
/
Copy pathbuilder.rb
More file actions
116 lines (109 loc) · 4.67 KB
/
builder.rb
File metadata and controls
116 lines (109 loc) · 4.67 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
# encoding: utf-8
# Copyright (c) 2012, HipByte SPRL and contributors
# All rights reserved.
#
# Redistribution and use in source and binary forms, with or without
# modification, are permitted provided that the following conditions are met:
#
# 1. Redistributions of source code must retain the above copyright notice, this
# list of conditions and the following disclaimer.
# 2. Redistributions in binary form must reproduce the above copyright notice,
# this list of conditions and the following disclaimer in the documentation
# and/or other materials provided with the distribution.
#
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
# ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
# WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
# DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
# ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
# (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
# LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
# ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
# SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
require 'motion/project/builder'
module Motion; module Project
class Builder
def archive(config)
# Create .pkg archive.
app_bundle = config.app_bundle_raw('MacOSX')
archive = config.archive
if !File.exist?(archive) or File.mtime(app_bundle) > File.mtime(archive)
App.info 'Create', archive
codesign = begin
if config.distribution_mode
"--sign \"" + config.codesign_certificate.sub(/Application/, "Installer") + "\""
end
end || ""
sh "/usr/bin/productbuild --quiet --component \"#{app_bundle}\" /Applications \"#{archive}\" #{codesign}"
end
end
# First signs all frameworks (and the individual versions therein) that it
# finds in the `Frameworks` directory of the application bundle in the build
# directory and then signs the application bundle itself.
#
# @param [OSXConfig] config
# The configuration for this build.
#
# @param [String] platform
# The platform for which to build, which in this case should always
# be `MacOSX`.
#
# @return [void]
#
# @todo Do we really need the platform parameter when it's always the same?
#
def codesign(config, platform)
app_bundle = config.app_bundle(platform)
framework_versions = 'Frameworks/*.framework/Versions/*'
Dir.glob(File.join(app_bundle, framework_versions)) do |version|
unless version == File.basename('Current')
codesign_bundle(config, version, true)
end
end
codesign_bundle(config, config.app_bundle_raw(platform)) do
build_dir = config.versionized_build_dir(platform)
entitlements = File.join(build_dir, "Entitlements.plist")
File.open(entitlements, 'w') { |io| io.write(config.entitlements_data) }
entitlements
end
end
private
# Signs an individual bundle.
#
# @param [OSXConfig] config
# The configuration for this build.
#
# @param [String] bundle
# The path to the bundle on disk. In case of a framework, this should
# be to the specific version directory inside the `Versions`
# directory of the bundle.
#
# @param [Boolean] deep
# Indicates whether to include the `--deep` flag for codesign.
# Any extra code in frameworks (such as an XPC service) must
# also be signed. `--deep` ensures it's signed with the same
# identity as the bundle
#
# @yield If a block is given, this will be yielded to allow the generation
# of an entitlements file, only when needed.
#
# @yieldreturn [String] the path to the entitlements file.
#
# @return [void]
#
def codesign_bundle(config, bundle, deep = false)
if File.mtime(config.project_file) > File.mtime(bundle) \
or !system("/usr/bin/codesign --verify '#{bundle}' >& /dev/null")
App.info 'Codesign', bundle
entitlements_path = yield if block_given?
command = "/usr/bin/codesign --force --sign '#{config.codesign_certificate}' "
command << "--deep " if deep
command << "--entitlements '#{entitlements_path}' " if entitlements_path
command << "--timestamp=none " if config.codesign_disable_timestamp
command << "'#{bundle}'"
sh(command)
end
end
end
end; end