OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-dev/] [or1k-gcc/] [libjava/] [classpath/] [org/] [ietf/] [jgss/] [GSSManager.java] - Blame information for rev 775

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 775 jeremybenn
/* GSSManager.java -- manager class for the GSS-API.
2
   Copyright (C) 2004 Free Software Foundation, Inc.
3
 
4
This file is part of GNU Classpath.
5
 
6
GNU Classpath is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2, or (at your option)
9
any later version.
10
 
11
GNU Classpath is distributed in the hope that it will be useful, but
12
WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
14
General Public License for more details.
15
 
16
You should have received a copy of the GNU General Public License
17
along with GNU Classpath; see the file COPYING.  If not, write to the
18
Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
19
02110-1301 USA.
20
 
21
Linking this library statically or dynamically with other modules is
22
making a combined work based on this library.  Thus, the terms and
23
conditions of the GNU General Public License cover the whole
24
combination.
25
 
26
As a special exception, the copyright holders of this library give you
27
permission to link this library with independent modules to produce an
28
executable, regardless of the license terms of these independent
29
modules, and to copy and distribute the resulting executable under
30
terms of your choice, provided that you also meet, for each linked
31
independent module, the terms and conditions of the license of that
32
module.  An independent module is a module which is not derived from
33
or based on this library.  If you modify this library, you may extend
34
this exception to your version of the library, but you are not
35
obligated to do so.  If you do not wish to do so, delete this
36
exception statement from your version.
37
 
38
   The documentation comments of this class are derived from the text
39
   of RFC 2853:  Generic Security Service API Version 2: Java Bindings.
40
   That document is covered under the following license notice:
41
 
42
Copyright (C) The Internet Society (2000).  All Rights Reserved.
43
 
44
This document and translations of it may be copied and furnished to
45
others, and derivative works that comment on or otherwise explain it
46
or assist in its implementation may be prepared, copied, published and
47
distributed, in whole or in part, without restriction of any kind,
48
provided that the above copyright notice and this paragraph are
49
included on all such copies and derivative works.  However, this
50
document itself may not be modified in any way, such as by removing
51
the copyright notice or references to the Internet Society or other
52
Internet organizations, except as needed for the purpose of developing
53
Internet standards in which case the procedures for copyrights defined
54
in the Internet Standards process must be followed, or as required to
55
translate it into languages other than English.
56
 
57
The limited permissions granted above are perpetual and will not be
58
revoked by the Internet Society or its successors or assigns.
59
 
60
This document and the information contained herein is provided on an
61
"AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
62
TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING BUT
63
NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION HEREIN
64
WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
65
MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. */
66
 
67
 
68
package org.ietf.jgss;
69
 
70
import java.security.Provider;
71
import java.security.Security;
72
 
73
/**
74
 * <p>The GSSManager class is an abstract class that serves as a factory
75
 * for three GSS interfaces: {@link GSSName}, {@link GSSCredential}, and
76
 * {@link GSSContext}. It also provides methods for applications to determine
77
 * what mechanisms are available from the GSS implementation and what
78
 * nametypes these mechanisms support. An instance of the default GSSManager
79
 * subclass may be obtained through the static method {@link #getInstance()},
80
 * but applications are free to instantiate other subclasses of GSSManager.</p>
81
 *
82
 * <p>All but one method in this class are declared abstract. This means
83
 * that subclasses have to provide the complete implementation for those
84
 * methods. The only exception to this is the static method {@link
85
 * #getInstance()} which will have platform specific code to return an
86
 * instance of the default subclass.</p>
87
 *
88
 * <p>Platform providers of GSS are required not to add any constructors to
89
 * this class, private, public, or protected. This will ensure that all
90
 * subclasses invoke only the default constructor provided to the base
91
 * class by the compiler.</p>
92
 *
93
 * <p>A subclass extending the GSSManager abstract class may be implemented
94
 * as a modular provider based layer that utilizes some well known
95
 * service provider specification. The GSSManager API provides the
96
 * application with methods to set provider preferences on such an
97
 * implementation. These methods also allow the implementation to throw
98
 * a well-defined exception in case provider based configuration is not
99
 * supported. Applications that expect to be portable should be aware of
100
 * this and recover cleanly by catching the exception.</p>
101
 *
102
 * <p>It is envisioned that there will be three most common ways in which
103
 * providers will be used:</p>
104
 *
105
 * <ol>
106
 * <li>The application does not care about what provider is used (the
107
 * default case).</li>
108
 *
109
 * <li>The application wants a particular provider to be used
110
 * preferentially, either for a particular mechanism or all the
111
 * time, irrespective of mechanism.</li>
112
 *
113
 * <li>The application wants to use the locally configured providers
114
 * as far as possible but if support is missing for one or more
115
 * mechanisms then it wants to fall back on its own provider.</li>
116
 * </ol>
117
 *
118
 * <p>The GSSManager class has two methods that enable these modes of
119
 * usage: {@link #addProviderAtFront(java.security.Provider,org.ietf.jgss.Oid)}
120
 * and {@link #addProviderAtEnd(java.security.Provider,org.ietf.jgss.Oid)}.
121
 * These methods have the effect of creating an ordered list of
122
 * (<i>provider</i>, <i>oid</i>) pairs where each pair indicates a preference
123
 * of provider for a given oid.</p>
124
 *
125
 * <p>The use of these methods does not require any knowledge of whatever
126
 * service provider specification the GSSManager subclass follows. It is
127
 * hoped that these methods will serve the needs of most applications.
128
 * Additional methods may be added to an extended GSSManager that could
129
 * be part of a service provider specification that is standardized
130
 * later.</p>
131
 *
132
 * <h3>Example Code</h3>
133
 *
134
 * <pre>
135
GSSManager mgr = GSSManager.getInstance();
136
 
137
// What mechs are available to us?
138
Oid[] supportedMechs = mgr.getMechs();
139
 
140
// Set a preference for the provider to be used when support is needed
141
// for the mechanisms "1.2.840.113554.1.2.2" and "1.3.6.1.5.5.1.1".
142
 
143
Oid krb = new Oid("1.2.840.113554.1.2.2");
144
Oid spkm1 = new Oid("1.3.6.1.5.5.1.1");
145
 
146
Provider p = (Provider) (new com.foo.security.Provider());
147
 
148
mgr.addProviderAtFront(p, krb);
149
mgr.addProviderAtFront(p, spkm1);
150
 
151
// What name types does this spkm implementation support?
152
Oid[] nameTypes = mgr.getNamesForMech(spkm1);
153
</pre>
154
 */
155
public abstract class GSSManager
156
{
157
 
158
  // Constructor.
159
  // -------------------------------------------------------------------------
160
 
161
  public GSSManager()
162
  {
163
  }
164
 
165
  // Class method.
166
  // -------------------------------------------------------------------------
167
 
168
  /**
169
   * Returns the default GSSManager implementation.
170
   *
171
   * @return The default GSSManager implementation.
172
   */
173
  public static synchronized GSSManager getInstance()
174
  {
175
    String impl = Security.getProperty("org.ietf.jgss.GSSManager");
176
    if (impl == null)
177
      impl = "gnu.crypto.gssapi.GSSManagerImpl";
178
    try
179
      {
180
        ClassLoader loader = GSSManager.class.getClassLoader();
181
        if (loader == null)
182
          loader = ClassLoader.getSystemClassLoader();
183
        Class<?> c = loader.loadClass(impl);
184
        return (GSSManager) c.newInstance();
185
      }
186
    catch (Exception x)
187
      {
188
        throw new RuntimeException(x.toString());
189
      }
190
  }
191
 
192
  // Abstract methods.
193
  // -------------------------------------------------------------------------
194
 
195
  /**
196
   * <p>This method is used to indicate to the GSSManager that the
197
   * application would like a particular provider to be used if no other
198
   * provider can be found that supports the given mechanism. When a value
199
   * of null is used instead of an Oid for the mechanism, the GSSManager
200
   * must use the indicated provider for any mechanism.</p>
201
   *
202
   * <p>Calling this method repeatedly preserves the older settings but
203
   * raises them above newer ones in preference thus forming an ordered
204
   * list of providers and Oid pairs that grows at the bottom. Thus the
205
   * older provider settings will be utilized first before this one is.</p>
206
   *
207
   * <p>If there are any previously existing preferences that conflict with
208
   * the preference being set here, then the GSSManager should ignore this
209
   * request.</p>
210
   *
211
   * <p>If the GSSManager implementation does not support an SPI with a
212
   * pluggable provider architecture it should throw a GSSException with
213
   * the status code {@link GSSException#UNAVAILABLE} to indicate that the
214
   * operation is unavailable.</p>
215
   *
216
   * @param p    The provider instance that should be used whenever
217
   *             support is needed for <i>mech</i>.
218
   * @param mech The mechanism for which the provider is being set.
219
   * @throws GSSException If this service is unavailable.
220
   */
221
  public abstract void addProviderAtEnd(Provider p, Oid mech)
222
    throws GSSException;
223
 
224
  /**
225
   * <p>This method is used to indicate to the GSSManager that the
226
   * application would like a particular provider to be used ahead of all
227
   * others when support is desired for the given mechanism. When a value
228
   * of null is used instead of an Oid for the mechanism, the GSSManager
229
   * must use the indicated provider ahead of all others no matter what
230
   * the mechanism is. Only when the indicated provider does not support
231
   * the needed mechanism should the GSSManager move on to a different
232
   * provider.</p>
233
   *
234
   * <p>Calling this method repeatedly preserves the older settings but
235
   * lowers them in preference thus forming an ordered list of provider
236
   * and Oid pairs that grows at the top.</p>
237
   *
238
   * <p>Calling addProviderAtFront with a null Oid will remove all previous
239
   * preferences that were set for this provider in the GSSManager
240
   * instance. Calling addProviderAtFront with a non-null Oid will remove
241
   * any previous preference that was set using this mechanism and this
242
   * provider together.</p>
243
   *
244
   * <p>If the GSSManager implementation does not support an SPI with a
245
   * pluggable provider architecture it should throw a GSSException with
246
   * the status code {@link GSSException#UNAVAILABLE} to indicate that the
247
   * operation is unavailable.</p>
248
   *
249
   * @param p    The provider instance that should be used whenever
250
   *             support is needed for <i>mech</i>.
251
   * @param mech The mechanism for which the provider is being set.
252
   * @throws GSSException If this service is unavailable.
253
   */
254
  public abstract void addProviderAtFront(Provider p, Oid mech)
255
    throws GSSException;
256
 
257
  /**
258
   * Factory method for creating a previously exported context.  The
259
   * context properties will be determined from the input token and can't
260
   * be modified through the set methods.
261
   *
262
   * @param interProcessToken The token previously emitted from the
263
   *                          export method.
264
   * @return The context.
265
   * @throws GSSException If this operation fails.
266
   */
267
  public abstract GSSContext createContext(byte[] interProcessToken)
268
    throws GSSException;
269
 
270
  /**
271
   * Factory method for creating a context on the acceptor' side.  The
272
   * context's properties will be determined from the input token supplied
273
   * to the accept method.
274
   *
275
   * @param myCred Credentials for the acceptor.  Use <code>null</code> to
276
   *               act as a default acceptor principal.
277
   * @return The context.
278
   * @throws GSSException If this operation fails.
279
   */
280
  public abstract GSSContext createContext(GSSCredential myCred)
281
    throws GSSException;
282
 
283
  /**
284
   * Factory method for creating a context on the initiator's side.
285
   * Context flags may be modified through the mutator methods prior to
286
   * calling {@link
287
   * GSSContext#initSecContext(java.io.InputStream,java.io.OutputStream)}.
288
   *
289
   * @param peer     Name of the target peer.
290
   * @param mech     Oid of the desired mechanism.  Use <code>null</code>
291
   *                 to request default mechanism.
292
   * @param myCred   Credentials of the initiator.  Use <code>null</code>
293
   *                 default initiator principal.
294
   * @param lifetime The request lifetime, in seconds, for the context.
295
   *                 Use {@link GSSContext#INDEFINITE_LIFETIME} and
296
   *                 {@link GSSContext#DEFAULT_LIFETIME} to request
297
   *                 indefinite or default context lifetime.
298
   * @return The context.
299
   * @throws GSSException If this operation fails.
300
   */
301
  public abstract GSSContext createContext(GSSName peer, Oid mech,
302
                                           GSSCredential myCred, int lifetime)
303
    throws GSSException;
304
 
305
  /**
306
   * Factory method for acquiring default credentials.  This will cause
307
   * the GSS-API to use system specific defaults for the set of
308
   * mechanisms, name, and a DEFAULT lifetime.
309
   *
310
   * @param usage The intended usage for this credential object.  The
311
   *              value of this parameter must be one of:
312
   *              {@link GSSCredential#ACCEPT_AND_INITIATE},
313
   *              {@link GSSCredential#ACCEPT_ONLY},
314
   *              {@link GSSCredential#INITIATE_ONLY}.
315
   * @return The credential.
316
   * @throws GSSException If this operation fails.
317
   */
318
  public abstract GSSCredential createCredential(int usage) throws GSSException;
319
 
320
  /**
321
   * Factory method for acquiring a single mechanism credential.
322
   *
323
   * @param aName    Name of the principal for whom this credential is to
324
   *                 be acquired.  Use <code>null</code> to specify the
325
   *                 default principal.
326
   * @param lifetime The number of seconds that credentials should remain
327
   *                 valid.  Use {@link GSSCredential#INDEFINITE_LIFETIME}
328
   *                 to request that the credentials have the maximum
329
   *                 permitted lifetime.  Use {@link
330
   *                 GSSCredential#DEFAULT_LIFETIME} to request default
331
   *                 credential lifetime.
332
   * @param mech     The oid of the desired mechanism.  Use <code>null</code>
333
   *                 to request the default mechanism(s).
334
   * @param usage    The intended usage for this credential object.  The
335
   *                 value of this parameter must be one of:
336
   *                 {@link GSSCredential#ACCEPT_AND_INITIATE},
337
   *                 {@link GSSCredential#ACCEPT_ONLY},
338
   *                 {@link GSSCredential#INITIATE_ONLY}.
339
   * @return The credential.
340
   * @throws GSSException If this operation fails.
341
   */
342
  public abstract GSSCredential createCredential(GSSName aName, int lifetime,
343
                                                 Oid mech, int usage)
344
    throws GSSException;
345
 
346
  /**
347
   * Factory method for acquiring credentials over a set of mechanisms.
348
   * Acquires credentials for each of the mechanisms specified in the
349
   * array called mechs.  To determine the list of mechanisms' for which
350
   * the acquisition of credentials succeeded, the caller should use the
351
   * {@link GSSCredential#getMechs()} method.
352
   *
353
   * @param aName    Name of the principal for whom this credential is to
354
   *                 be acquired.  Use <code>null</code> to specify the
355
   *                 default principal.
356
   * @param lifetime The number of seconds that credentials should remain
357
   *                 valid.  Use {@link GSSCredential#INDEFINITE_LIFETIME}
358
   *                 to request that the credentials have the maximum
359
   *                 permitted lifetime.  Use {@link
360
   *                 GSSCredential#DEFAULT_LIFETIME} to request default
361
   *                 credential lifetime.
362
   * @param mechs    The array of mechanisms over which the credential is
363
   *                 to be acquired.  Use <code>null</code> for requesting
364
   *                 a system specific default set of mechanisms.
365
   * @param usage    The intended usage for this credential object.  The
366
   *                 value of this parameter must be one of:
367
   *                 {@link GSSCredential#ACCEPT_AND_INITIATE},
368
   *                 {@link GSSCredential#ACCEPT_ONLY},
369
   *                 {@link GSSCredential#INITIATE_ONLY}.
370
   * @return The credential.
371
   * @throws GSSException If this operation fails.
372
   */
373
  public abstract GSSCredential createCredential(GSSName aName, int lifetime,
374
                                                 Oid[] mechs, int usage)
375
    throws GSSException;
376
 
377
  /**
378
   * Factory method to convert a contiguous byte array containing a name
379
   * from the specified namespace to a {@link GSSName} object.  In general,
380
   * the {@link GSSName} object created will not be an MN; two examples that
381
   * are exceptions to this are when the namespace type parameter indicates
382
   * {@link GSSName#NT_EXPORT_NAME} or when the GSS-API implementation is not
383
   * multi-mechanism.
384
   *
385
   * @param name     The byte array containing the name to create.
386
   * @param nameType The Oid specifying the namespace of the name supplied
387
   *                 in the byte array.  Note that nameType serves to
388
   *                 describe and qualify the interpretation of the input
389
   *                 name byte array, it does not necessarily imply a type
390
   *                 for the output GSSName implementation. "null" value
391
   *                 can be used to specify that a mechanism specific
392
   *                 default syntax should be assumed by each mechanism
393
   *                 that examines the byte array.
394
   * @return The name.
395
   * @throws GSSException If this operation fails.
396
   */
397
  public abstract GSSName createName(byte[] name, Oid nameType)
398
    throws GSSException;
399
 
400
  /**
401
   * Factory method to convert a contiguous byte array containing a name
402
   * from the specified namespace to a GSSName object that is an MN.  In
403
   * other words, this method is a utility that does the equivalent of two
404
   * steps: {@link #createName(byte[],org.ietf.jgss.Oid)} and then also
405
   * {@link GSSName#canonicalize(org.ietf.jgss.Oid)}.
406
   *
407
   * @param name     The byte array representing the name to create.
408
   * @param nameType The Oid specifying the namespace of the name supplied
409
   *                 in the byte array.  Note that nameType serves to
410
   *                 describe and qualify the interpretation of the input
411
   *                 name byte array, it does not necessarily imply a type
412
   *                 for the output GSSName implementation. "null" value
413
   *                 can be used to specify that a mechanism specific
414
   *                 default syntax should be assumed by each mechanism
415
   *                 that examines the byte array.
416
   * @param mech     Oid specifying the mechanism for which this name
417
   *                 should be created.
418
   * @return The name.
419
   * @throws GSSException If this operation fails.
420
   */
421
  public abstract GSSName createName(byte[] name, Oid nameType, Oid mech)
422
    throws GSSException;
423
 
424
  /**
425
   * Factory method to convert a contiguous string name from the specified
426
   * namespace to a {@link GSSName} object.  In general, the {@link GSSName}
427
   * object created will not be an MN; two examples that are exceptions to
428
   * this are when the namespace type parameter indicates {@link
429
   * GSSName#NT_EXPORT_NAME} or when the GSS-API implementation is not
430
   * multi-mechanism.
431
   *
432
   * @param nameStr  The string representing a printable form of the name
433
   *                 to create.
434
   * @param nameType The Oid specifying the namespace of the printable name
435
   *                 supplied. Note that nameType serves to describe and
436
   *                 qualify the interpretation of the input nameStr, it
437
   *                 does not necessarily imply a type for the output
438
   *                 GSSName implementation. "null" value can be used to
439
   *                 specify that a mechanism specific default printable
440
   *                 syntax should be assumed by each mechanism that
441
   *                 examines nameStr.
442
   * @return The name.
443
   * @throws GSSException If this operation fails.
444
   */
445
  public abstract GSSName createName(String nameStr, Oid nameType)
446
    throws GSSException;
447
 
448
  /**
449
   * Factory method to convert a contiguous string name from the specified
450
   * namespace to an GSSName object that is a mechanism name (MN).  In
451
   * other words, this method is a utility that does the equivalent of two
452
   * steps: the {@link #createName(java.lang.String,org.ietf.jgss.Oid)}
453
   * and then also {@link GSSName#canonicalize(org.ietf.jgss.Oid)}.
454
   *
455
   * @param nameStr  The string representing a printable form of the name
456
   *                 to create.
457
   * @param nameType The Oid specifying the namespace of the printable name
458
   *                 supplied.  Note that nameType serves to describe and
459
   *                 qualify the interpretation of the input nameStr, it
460
   *                 does not necessarily imply a type for the output
461
   *                 GSSName implementation. "null" value can be used to
462
   *                 specify that a mechanism specific default printable
463
   *                 syntax should be assumed when the mechanism examines
464
   *                 nameStr.
465
   * @param mech     Oid specifying the mechanism for which this name
466
   *                 should be created.
467
   * @return The name.
468
   * @throws GSSException If this operation fails.
469
   */
470
  public abstract GSSName createName(String nameStr, Oid nameType, Oid mech)
471
    throws GSSException;
472
 
473
  /**
474
   * Returns an array of {@link Oid} objects indicating mechanisms available
475
   * to GSS-API callers.  A <code>null</code> value is returned when no
476
   * mechanism are available (an example of this would be when mechanism are
477
   * dynamically configured, and currently no mechanisms are installed).
478
   *
479
   * @return The array of available mechanisms, or <code>null</code>.
480
   */
481
  public abstract Oid[] getMechs();
482
 
483
  /**
484
   * Returns an array of {@link Oid} objects corresponding to the mechanisms
485
   * that support the specific name type. <code>null</code> is returned when
486
   * no mechanisms are found to support the specified name type.
487
   *
488
   * @param name The Oid object for the name type.
489
   * @return The array of mechanisms, or <code>null</code>.
490
   */
491
  public abstract Oid[] getMechsForName(Oid name);
492
 
493
  /**
494
   * Returns name type Oid's supported by the specified mechanism.
495
   *
496
   * @param mechanism The Oid object for the mechanism to query.
497
   * @return The name type Oid's supported by the mechanism.
498
   * @throws GSSException If this operation fails.
499
   */
500
  public abstract Oid[] getNamesForMech(Oid mechanism) throws GSSException;
501
}

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.