aboutsummaryrefslogtreecommitdiff
path: root/libjava/java/security/Security.java
diff options
context:
space:
mode:
authorWarren Levy <warrenl@cygnus.com>2000-03-10 02:43:57 +0000
committerWarren Levy <warrenl@gcc.gnu.org>2000-03-10 02:43:57 +0000
commit8560e49702603dcae44dfa161bc7eb04bd372bb7 (patch)
tree574fb7f4ddc6a81ad4e9d46c9a034ea9567ce220 /libjava/java/security/Security.java
parent7238ae533fb7bfc6155075acd058c335a40647a2 (diff)
downloadgcc-8560e49702603dcae44dfa161bc7eb04bd372bb7.zip
gcc-8560e49702603dcae44dfa161bc7eb04bd372bb7.tar.gz
gcc-8560e49702603dcae44dfa161bc7eb04bd372bb7.tar.bz2
AlgorithmParameterGeneratorSpi.java: New file.
* java/security/AlgorithmParameterGeneratorSpi.java: New file. * java/security/DigestException.java: New file. * java/security/GeneralSecurityException.java: New file. * java/security/InvalidAlgorithmParameterException.java: New file. * java/security/InvalidKeyException.java: New file. * java/security/InvalidParameterException.java: New file. * java/security/Key.java: New file. * java/security/KeyException.java: New file. * java/security/KeyPair.java: New file. * java/security/KeyPairGenerator.java: New file. * java/security/KeyPairGeneratorSpi.java: New file. * java/security/NoSuchProviderException.java: New file. * java/security/PrivateKey.java: New file. * java/security/Provider.java: New file. * java/security/PublicKey.java: New file. * java/security/SecureRandom.java: New file. * java/security/Security.java: New file. * java/security/Signature.java: New file. * java/security/SignatureException.java: New file. * java/security/interfaces/DSAKey.java: New file. * java/security/interfaces/DSAParams.java: New file. * java/security/interfaces/DSAPrivateKey.java: New file. * java/security/interfaces/DSAPublicKey.java: New file. * java/security/interfaces/RSAPrivateCrtKey.java: New file. * java/security/interfaces/RSAPrivateKey.java: New file. * java/security/interfaces/RSAPublicKey.java: New file. * java/security/spec/AlgorithmParameterSpec.java: New file. * java/security/spec/InvalidKeySpecException.java: New file. * java/security/spec/InvalidParameterSpecException.java: New file. * java/security/spec/KeySpec.java: New file. * java/security/spec/RSAPrivateCrtKeySpec.java: New file. * java/security/spec/RSAPrivateKeySpec.java: New file. * java/security/spec/RSAPublicKeySpec.java: New file. * Makefile.am: Added above java.security files. * Makefile.in: Rebuilt. * java/security/MessageDigest.java: Rewritten. * java/security/SecureClassLoader.java: Added JDK1.2 comment. From-SVN: r32461
Diffstat (limited to 'libjava/java/security/Security.java')
-rw-r--r--libjava/java/security/Security.java107
1 files changed, 107 insertions, 0 deletions
diff --git a/libjava/java/security/Security.java b/libjava/java/security/Security.java
new file mode 100644
index 0000000..87a0088
--- /dev/null
+++ b/libjava/java/security/Security.java
@@ -0,0 +1,107 @@
+/* Copyright (C) 2000 Free Software Foundation
+
+ This file is part of libgcj.
+
+This software is copyrighted work licensed under the terms of the
+Libgcj License. Please consult the file "LIBGCJ_LICENSE" for
+details. */
+
+package java.security;
+
+import java.util.Enumeration;
+import java.util.Properties;
+import java.util.Vector;
+
+/**
+ * @author Tom Tromey <tromey@cygnus.com>
+ * @date February 8, 2000.
+ */
+
+/**
+ * Written using on-line Java Platform 1.2 API Specification.
+ * Status: Still missing the deprecated getAlgorithmProperty method.
+ */
+
+public final class Security
+{
+ public static int insertProviderAt (Provider provider, int position)
+ {
+ SecurityManager sm = System.getSecurityManager ();
+ if (sm != null)
+ {
+ // FIXME: need SecurityPermission.
+ // sm.checkSecurityAccess ("insertProvider." + provider.getName ());
+ }
+ if (providers.indexOf (provider) != -1)
+ return -1;
+ if (position > providers.size ())
+ position = providers.size ();
+ providers.insertElementAt (provider, position);
+ return providers.indexOf (provider);
+ }
+
+ public static int addProvider (Provider provider)
+ {
+ return insertProviderAt (provider, providers.size ());
+ }
+
+ public static void removeProvider (String name)
+ {
+ SecurityManager sm = System.getSecurityManager ();
+ if (sm != null)
+ {
+ // FIXME: need SecurityPermission.
+ // sm.checkSecurityAccess ("removeProvider." + name);
+ }
+ Provider p = getProvider (name);
+ if (p != null)
+ providers.removeElement (p);
+ }
+
+ public static Provider[] getProviders ()
+ {
+ Provider[] r = new Provider[providers.size ()];
+ providers.copyInto (r);
+ return r;
+ }
+
+ public static Provider getProvider (String name)
+ {
+ Enumeration e = providers.elements ();
+ while (e.hasMoreElements ())
+ {
+ Provider p = (Provider) e.nextElement ();
+ if (name.equals (p.getName ()))
+ return p;
+ }
+ return null;
+ }
+
+ public static String getProperty (String key)
+ {
+ SecurityManager sm = System.getSecurityManager ();
+ if (sm != null)
+ {
+ // FIXME: need SecurityPermission.
+ // sm.checkSecurityAccess ("getProperty." + key);
+ }
+ return props.getProperty (key);
+ }
+
+ public static void setProperty (String key, String value)
+ {
+ SecurityManager sm = System.getSecurityManager ();
+ if (sm != null)
+ {
+ // FIXME: need SecurityPermission.
+ // sm.checkSecurityAccess ("setProperty." + key);
+ }
+ props.setProperty (key, value);
+ }
+
+ // The providers we list.
+ private static Vector providers = new Vector ();
+
+ // Security propertiesl
+ private static Properties props = new Properties ();
+}