Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
PojavLauncherTeam
GitHub Repository: PojavLauncherTeam/mobile
Path: blob/master/src/java.base/share/classes/sun/security/provider/VerificationProvider.java
41159 views
1
/*
2
* Copyright (c) 1996, 2021, 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
26
package sun.security.provider;
27
28
import java.util.*;
29
import java.security.*;
30
31
import sun.security.rsa.SunRsaSignEntries;
32
import static sun.security.util.SecurityConstants.PROVIDER_VER;
33
34
35
/**
36
* Provider used for verification of signed JAR files *if* the Sun and
37
* SunRsaSign main classes have been removed. Otherwise, this provider is not
38
* necessary and registers no algorithms. This functionality only exists to
39
* support a use case required by a specific customer and is not generally
40
* supported.
41
*
42
* @since 1.7
43
* @author Andreas Sterbenz
44
*/
45
public final class VerificationProvider extends Provider {
46
47
@java.io.Serial
48
private static final long serialVersionUID = 7482667077568930381L;
49
50
private static final boolean ACTIVE;
51
52
static {
53
boolean b;
54
try {
55
Class.forName("sun.security.provider.Sun");
56
Class.forName("sun.security.rsa.SunRsaSign");
57
b = false;
58
} catch (ClassNotFoundException e) {
59
b = true;
60
}
61
ACTIVE = b;
62
}
63
64
@SuppressWarnings("removal")
65
public VerificationProvider() {
66
super("SunJarVerification", PROVIDER_VER, "Jar Verification Provider");
67
// register all algorithms normally registered by the Sun and SunRsaSign
68
// providers, but only if they are missing
69
if (ACTIVE == false) {
70
return;
71
}
72
73
Provider p = this;
74
Iterator<Provider.Service> sunIter = new SunEntries(p).iterator();
75
Iterator<Provider.Service> rsaIter =
76
new SunRsaSignEntries(p).iterator();
77
78
// if there is no security manager installed, put directly into
79
// the provider
80
if (System.getSecurityManager() == null) {
81
putEntries(sunIter);
82
putEntries(rsaIter);
83
} else {
84
AccessController.doPrivileged(new PrivilegedAction<Object>() {
85
public Void run() {
86
putEntries(sunIter);
87
putEntries(rsaIter);
88
return null;
89
}
90
});
91
}
92
}
93
94
void putEntries(Iterator<Provider.Service> i) {
95
while (i.hasNext()) {
96
putService(i.next());
97
}
98
}
99
100
}
101
102