Skip to content

Commit 3e651f1

Browse files
All but "SigningPackageTest.test(false, false, true, UNICODE_INDEX)" signing tests pass
1 parent b166b40 commit 3e651f1

File tree

8 files changed

+140
-19
lines changed

8 files changed

+140
-19
lines changed

src/jdk.jpackage/macosx/classes/jdk/jpackage/internal/MacDmgPackageBuilder.java

Lines changed: 7 additions & 7 deletions
Original file line numberDiff line numberDiff line change
@@ -32,11 +32,10 @@
3232
import jdk.jpackage.internal.model.MacApplication;
3333
import jdk.jpackage.internal.model.MacDmgPackage;
3434
import jdk.jpackage.internal.model.MacDmgPackageMixin;
35-
import jdk.jpackage.internal.model.MacPackage;
3635

3736
final class MacDmgPackageBuilder {
3837

39-
MacDmgPackageBuilder(PackageBuilder pkgBuilder) {
38+
MacDmgPackageBuilder(MacPackageBuilder pkgBuilder) {
4039
this.pkgBuilder = Objects.requireNonNull(pkgBuilder);
4140
}
4241

@@ -55,15 +54,16 @@ List<Path> validatedDmgContent() {
5554
}
5655

5756
MacDmgPackage create() throws ConfigException {
58-
pkgBuilder.installDir().ifPresent(installDir -> {
59-
final var defaultInstallDirLocation = pkgBuilder.defaultInstallDir().map(Path::getParent).orElseThrow();
57+
final var superPkgBuilder = pkgBuilder.pkgBuilder();
58+
superPkgBuilder.installDir().ifPresent(installDir -> {
59+
final var defaultInstallDirLocation = superPkgBuilder.defaultInstallDir().map(Path::getParent).orElseThrow();
6060
if (!defaultInstallDirLocation.equals(installDir)) {
6161
Log.info(I18N.format("message.install-dir-ignored", defaultInstallDirLocation));
62-
pkgBuilder.installDir(defaultInstallDirLocation);
62+
superPkgBuilder.installDir(defaultInstallDirLocation);
6363
}
6464
});
6565

66-
final var pkg = MacPackage.create(pkgBuilder.create());
66+
final var pkg = pkgBuilder.create();
6767

6868
return MacDmgPackage.create(pkg, new MacDmgPackageMixin.Stub(
6969
Optional.ofNullable(icon).or(((MacApplication)pkg.app())::icon),
@@ -72,5 +72,5 @@ MacDmgPackage create() throws ConfigException {
7272

7373
private Path icon;
7474
private List<Path> dmgContent;
75-
private final PackageBuilder pkgBuilder;
75+
private final MacPackageBuilder pkgBuilder;
7676
}

src/jdk.jpackage/macosx/classes/jdk/jpackage/internal/MacFromParams.java

Lines changed: 16 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,7 @@
6767
import jdk.jpackage.internal.model.MacFileAssociation;
6868
import jdk.jpackage.internal.model.MacLauncher;
6969
import jdk.jpackage.internal.model.MacPkgPackage;
70+
import jdk.jpackage.internal.model.PackageType;
7071
import jdk.jpackage.internal.model.RuntimeLayout;
7172

7273

@@ -154,12 +155,25 @@ private static MacApplication createMacApplication(
154155
return appBuilder.create();
155156
}
156157

158+
private static MacPackageBuilder createMacPackageBuilder(
159+
Map<String, ? super Object> params, MacApplication app,
160+
PackageType type) throws ConfigException {
161+
final var builder = new MacPackageBuilder(createPackageBuilder(params, app, type));
162+
163+
PREDEFINED_APP_IMAGE_FILE.findIn(params)
164+
.map(MacAppImageFileExtras::new)
165+
.map(MacAppImageFileExtras::signed)
166+
.ifPresent(builder::predefinedAppImageSigned);
167+
168+
return builder;
169+
}
170+
157171
private static MacDmgPackage createMacDmgPackage(
158172
Map<String, ? super Object> params) throws ConfigException, IOException {
159173

160174
final var app = APPLICATION.fetchFrom(params);
161175

162-
final var superPkgBuilder = createPackageBuilder(params, app, MAC_DMG);
176+
final var superPkgBuilder = createMacPackageBuilder(params, app, MAC_DMG);
163177

164178
final var pkgBuilder = new MacDmgPackageBuilder(superPkgBuilder);
165179

@@ -173,7 +187,7 @@ private static MacPkgPackage createMacPkgPackage(
173187

174188
final var app = APPLICATION.fetchFrom(params);
175189

176-
final var superPkgBuilder = createPackageBuilder(params, app, MAC_PKG);
190+
final var superPkgBuilder = createMacPackageBuilder(params, app, MAC_PKG);
177191

178192
final var pkgBuilder = new MacPkgPackageBuilder(superPkgBuilder);
179193

Lines changed: 54 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,54 @@
1+
/*
2+
* Copyright (c) 2025, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation. Oracle designates this
8+
* particular file as subject to the "Classpath" exception as provided
9+
* by Oracle in the LICENSE file that accompanied this code.
10+
*
11+
* This code is distributed in the hope that it will be useful, but WITHOUT
12+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14+
* version 2 for more details (a copy is included in the LICENSE file that
15+
* accompanied this code).
16+
*
17+
* You should have received a copy of the GNU General Public License version
18+
* 2 along with this work; if not, write to the Free Software Foundation,
19+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20+
*
21+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22+
* or visit www.oracle.com if you need additional information or have any
23+
* questions.
24+
*/
25+
package jdk.jpackage.internal;
26+
27+
import java.util.Objects;
28+
import jdk.jpackage.internal.model.ConfigException;
29+
import jdk.jpackage.internal.model.MacPackage;
30+
import jdk.jpackage.internal.model.MacPackageMixin;
31+
32+
final class MacPackageBuilder {
33+
34+
MacPackageBuilder(PackageBuilder pkgBuilder) {
35+
this.pkgBuilder = Objects.requireNonNull(pkgBuilder);
36+
}
37+
38+
MacPackageBuilder predefinedAppImageSigned(boolean v) {
39+
predefinedAppImageSigned = v;
40+
return this;
41+
}
42+
43+
PackageBuilder pkgBuilder() {
44+
return pkgBuilder;
45+
}
46+
47+
MacPackage create() throws ConfigException {
48+
final var pkg = pkgBuilder.create();
49+
return MacPackage.create(pkg, new MacPackageMixin.Stub(pkg.predefinedAppImage().map(v -> predefinedAppImageSigned)));
50+
}
51+
52+
private final PackageBuilder pkgBuilder;
53+
private boolean predefinedAppImageSigned;
54+
}

src/jdk.jpackage/macosx/classes/jdk/jpackage/internal/MacPackagingPipeline.java

Lines changed: 2 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -61,6 +61,7 @@
6161
import jdk.jpackage.internal.PackagingPipeline.TaskID;
6262
import jdk.jpackage.internal.model.AppImageLayout;
6363
import jdk.jpackage.internal.model.Application;
64+
import jdk.jpackage.internal.model.MacPackage;
6465
import jdk.jpackage.internal.model.ApplicationLayout;
6566
import jdk.jpackage.internal.model.FileAssociation;
6667
import jdk.jpackage.internal.model.MacApplication;
@@ -164,7 +165,7 @@ static PackagingPipeline.Builder build(Optional<Package> pkg) {
164165
disabledTasks.add(PackageTaskID.RUN_POST_IMAGE_USER_SCRIPT);
165166
builder.task(MacCopyAppImageTaskID.REPLACE_APP_IMAGE_FILE).applicationAction(createWriteAppImageFileAction()).add();
166167
builder.appImageLayoutForPackaging(Package::appImageLayout);
167-
} else if (p.isRuntimeInstaller() || (p.predefinedAppImage().isPresent() && ((MacApplication)p.app()).sign())) {
168+
} else if (p.isRuntimeInstaller() || ((MacPackage)p).predefinedAppImageSigned().orElse(false)) {
168169
// If this is a runtime package or a signed predefined app image,
169170
// don't create ".package" file and don't sign it.
170171
disabledTasks.add(MacCopyAppImageTaskID.COPY_PACKAGE_FILE);

src/jdk.jpackage/macosx/classes/jdk/jpackage/internal/MacPkgPackageBuilder.java

Lines changed: 3 additions & 5 deletions
Original file line numberDiff line numberDiff line change
@@ -27,14 +27,13 @@
2727
import java.util.Objects;
2828
import java.util.Optional;
2929
import jdk.jpackage.internal.model.ConfigException;
30-
import jdk.jpackage.internal.model.MacPackage;
3130
import jdk.jpackage.internal.model.MacPkgPackage;
3231
import jdk.jpackage.internal.model.MacPkgPackageMixin;
3332
import jdk.jpackage.internal.model.SigningConfig;
3433

3534
final class MacPkgPackageBuilder {
3635

37-
MacPkgPackageBuilder(PackageBuilder pkgBuilder) {
36+
MacPkgPackageBuilder(MacPackageBuilder pkgBuilder) {
3837
this.pkgBuilder = Objects.requireNonNull(pkgBuilder);
3938
}
4039

@@ -44,8 +43,7 @@ MacPkgPackageBuilder signingBuilder(SigningConfigBuilder v) {
4443
}
4544

4645
MacPkgPackage create() throws ConfigException {
47-
return MacPkgPackage.create(MacPackage.create(pkgBuilder.create()),
48-
new MacPkgPackageMixin.Stub(createSigningConfig()));
46+
return MacPkgPackage.create(pkgBuilder.create(), new MacPkgPackageMixin.Stub(createSigningConfig()));
4947
}
5048

5149
private Optional<SigningConfig> createSigningConfig() throws ConfigException {
@@ -56,6 +54,6 @@ private Optional<SigningConfig> createSigningConfig() throws ConfigException {
5654
}
5755
}
5856

59-
private final PackageBuilder pkgBuilder;
57+
private final MacPackageBuilder pkgBuilder;
6058
private SigningConfigBuilder signingBuilder;
6159
}

src/jdk.jpackage/macosx/classes/jdk/jpackage/internal/model/MacPackage.java

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -27,7 +27,7 @@
2727
import java.nio.file.Path;
2828
import jdk.jpackage.internal.util.CompositeProxy;
2929

30-
public interface MacPackage extends Package {
30+
public interface MacPackage extends Package, MacPackageMixin {
3131

3232
@Override
3333
default AppImageLayout appImageLayout() {
@@ -42,8 +42,8 @@ default Path installDir() {
4242
return Path.of("/").resolve(relativeInstallDir());
4343
}
4444

45-
public static MacPackage create(Package pkg) {
46-
return CompositeProxy.create(MacPackage.class, pkg);
45+
public static MacPackage create(Package pkg, MacPackageMixin mixin) {
46+
return CompositeProxy.create(MacPackage.class, pkg, mixin);
4747
}
4848

4949
public final static RuntimeLayout RUNTIME_PACKAGE_LAYOUT = RuntimeLayout.create(Path.of("Contents/Home"));
Lines changed: 49 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,49 @@
1+
/*
2+
* Copyright (c) 2024, Oracle and/or its affiliates. All rights reserved.
3+
* DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
4+
*
5+
* This code is free software; you can redistribute it and/or modify it
6+
* under the terms of the GNU General Public License version 2 only, as
7+
* published by the Free Software Foundation. Oracle designates this
8+
* particular file as subject to the "Classpath" exception as provided
9+
* by Oracle in the LICENSE file that accompanied this code.
10+
*
11+
* This code is distributed in the hope that it will be useful, but WITHOUT
12+
* ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
13+
* FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
14+
* version 2 for more details (a copy is included in the LICENSE file that
15+
* accompanied this code).
16+
*
17+
* You should have received a copy of the GNU General Public License version
18+
* 2 along with this work; if not, write to the Free Software Foundation,
19+
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
20+
*
21+
* Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
22+
* or visit www.oracle.com if you need additional information or have any
23+
* questions.
24+
*/
25+
package jdk.jpackage.internal.model;
26+
27+
import java.util.Optional;
28+
29+
public interface MacPackageMixin {
30+
31+
/**
32+
* Gets sign status of the predefined app image.
33+
* <p>
34+
* Returns {@code Optional.of(Boolean.TRUE)} if the predefined app image is
35+
* available and is signed.
36+
* <p>
37+
* Returns {@code Optional.of(Boolean.FALSE)} if the predefined app image is
38+
* available and is unsigned.
39+
* <p>
40+
* Returns any empty {@link Optional} instance if the predefined app image is
41+
* unavailable.
42+
*
43+
* @return sign status of the predefined app image if any
44+
*/
45+
Optional<Boolean> predefinedAppImageSigned();
46+
47+
record Stub(Optional<Boolean> predefinedAppImageSigned) implements MacPackageMixin {
48+
}
49+
}

src/jdk.jpackage/macosx/classes/jdk/jpackage/internal/model/MacPkgPackage.java

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -28,8 +28,13 @@
2828

2929
public interface MacPkgPackage extends MacPackage, MacPkgPackageMixin {
3030

31+
/**
32+
* Returns {@code true} if this PKG installer should be signed.
33+
*
34+
* @return {@code true} if this PKG installer should be signed
35+
*/
3136
default boolean sign() {
32-
return signingConfig().flatMap(SigningConfig::identity).isPresent();
37+
return signingConfig().isPresent();
3338
}
3439

3540
public static MacPkgPackage create(MacPackage pkg, MacPkgPackageMixin mixin) {

0 commit comments

Comments
 (0)