mirror of
https://git.openldap.org/openldap/openldap.git
synced 2025-01-12 10:54:48 +08:00
564 lines
14 KiB
Plaintext
564 lines
14 KiB
Plaintext
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Network Working Group V. Ryan
|
|||
|
Request for Comments: 2714 R. Lee
|
|||
|
Category: Informational S. Seligman
|
|||
|
Sun Microsystems, Inc.
|
|||
|
October 1999
|
|||
|
|
|||
|
|
|||
|
Schema for Representing CORBA Object References in an LDAP Directory
|
|||
|
|
|||
|
Status of this Memo
|
|||
|
|
|||
|
This memo provides information for the Internet community. It does
|
|||
|
not specify an Internet standard of any kind. Distribution of this
|
|||
|
memo is unlimited.
|
|||
|
|
|||
|
Copyright Notice
|
|||
|
|
|||
|
Copyright (C) The Internet Society (1999). All Rights Reserved.
|
|||
|
|
|||
|
Abstract
|
|||
|
|
|||
|
CORBA [CORBA] is the Common Object Request Broker Architecture
|
|||
|
defined by the Object Management Group. This document defines the
|
|||
|
schema for representing CORBA object references in an LDAP directory
|
|||
|
[LDAPv3].
|
|||
|
|
|||
|
1. Introduction
|
|||
|
|
|||
|
This document assumes that the reader has a general understanding of
|
|||
|
CORBA.
|
|||
|
|
|||
|
Traditionally, LDAP directories have been used to store data. Users
|
|||
|
and programmers think of the directory as a hierarchy of directory
|
|||
|
entries, each containing a set of attributes. You look up an entry
|
|||
|
from the directory and extract the attribute(s) of interest. For
|
|||
|
example, you can look up a person's telephone number from the
|
|||
|
directory. Alternatively, you can search the directory for entries
|
|||
|
with a particular set of attributes. For example, you can search for
|
|||
|
all persons in the directory with the surname "Smith".
|
|||
|
|
|||
|
CORBA applications require access to CORBA objects. Traditionally,
|
|||
|
CORBA applications have used the COS Naming service for storage and
|
|||
|
retrieval of CORBA object references. When deployed in environments
|
|||
|
with a directory, CORBA applications should be able to use the
|
|||
|
directory as a repository for CORBA object references. The directory
|
|||
|
provides a centrally administered, and possibly replicated, service
|
|||
|
for use by CORBA applications distributed across the network.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 1]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
For example, an application server may use the directory for
|
|||
|
"registering" CORBA objects representing the services that it
|
|||
|
manages, so that a client can later search the directory to locate
|
|||
|
those services as it needs.
|
|||
|
|
|||
|
The motivation for this document is to define a common way for
|
|||
|
applications to store and retrieve CORBA object references from the
|
|||
|
directory. Using this common schema, any CORBA application that
|
|||
|
needs to read or store CORBA object references in the directory can
|
|||
|
do so in an interoperable way.
|
|||
|
|
|||
|
Note that this schema is defined for storing CORBA "object
|
|||
|
references," not CORBA objects in general. There might be other ways
|
|||
|
to store CORBA objects in an LDAP directory but they are not covered
|
|||
|
by this schema.
|
|||
|
|
|||
|
2. Representation of CORBA Object References
|
|||
|
|
|||
|
This document defines schema elements to represent a CORBA object
|
|||
|
reference in LDAP directory. Applications in possession of a
|
|||
|
reference to an object can invoke calls on that object. Such a
|
|||
|
reference is termed an "interoperable object reference," or IOR.
|
|||
|
Access to CORBA objects by using IORs is achieved transparently to
|
|||
|
the application, by means of the General Inter-ORB Protocol.
|
|||
|
|
|||
|
A CORBA object reference is represented in the directory by the
|
|||
|
object class corbaObjectReference. corbaObjectReference is a subclass
|
|||
|
of the abstract corbaObject object class. corbaObjectReference is an
|
|||
|
auxiliary object class, which means that it needs to be mixed in with
|
|||
|
a structural object class.
|
|||
|
|
|||
|
The object class corbaContainer is used in a directory entry which
|
|||
|
represents a CORBA object or object reference. It is a structural
|
|||
|
object class, and when representing an object reference, the
|
|||
|
corbaObjectReference object class would also need to be present in
|
|||
|
the entry. corbaContainer is not required when a subclass of
|
|||
|
corbaObject (such as corbaObjectReference) is mixed in with another
|
|||
|
structural object class.
|
|||
|
|
|||
|
The definitions for the object classes corbaObject,
|
|||
|
corbaObjectReference, and corbaContainer are presented in Section 4.
|
|||
|
|
|||
|
The corbaObject class has two optional attributes: corbaRepositoryId
|
|||
|
and description. corbaRepositoryId is a multivalued attribute that
|
|||
|
is used to store the repository ids of the interfaces implemented by
|
|||
|
a CORBA object. description is used to store a textual description
|
|||
|
of a CORBA object.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 2]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
The corbaObjectReference class has one mandatory attribute: corbaIor.
|
|||
|
corbaIor is used to store the object's stringified IOR.
|
|||
|
|
|||
|
corbaIor and corbaRepositoryId are defined in Section 3; description
|
|||
|
is defined in [v3Schema].
|
|||
|
|
|||
|
3. Attribute Type Definitions
|
|||
|
|
|||
|
The following attribute types are defined in this document:
|
|||
|
|
|||
|
corbaIor
|
|||
|
corbaRepositoryId
|
|||
|
|
|||
|
3.1 corbaIor
|
|||
|
|
|||
|
This attribute stores the string representation of the interoperable
|
|||
|
object reference (IOR) for a CORBA object. An IOR is an opaque handle
|
|||
|
for the object which contains the information necessary to locate the
|
|||
|
object, even if the object is in another ORB.
|
|||
|
|
|||
|
This attribute's syntax is 'IA5 String' and its case is
|
|||
|
insignificant.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.1.14
|
|||
|
NAME 'corbaIor'
|
|||
|
DESC 'Stringified interoperable object reference of a CORBA object'
|
|||
|
EQUALITY caseIgnoreIA5Match
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.26
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
3.2 corbaRepositoryId
|
|||
|
|
|||
|
Each CORBA interface has a unique "repository id" (also called "type
|
|||
|
id") that identifies the interface. A CORBA object has one or more
|
|||
|
repository ids, one for each interface that it implements.
|
|||
|
|
|||
|
The format of a repository id can be any string, but the OMG
|
|||
|
specifies four standard formats:
|
|||
|
|
|||
|
a. IDL-style
|
|||
|
|
|||
|
IDL:Prefix/ModuleName/InterfaceName:VersionNumber
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 3]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
For example, the repository id for the "NamingContext" in OMG's COS
|
|||
|
Naming module is: "IDL:omg.org/CosNaming/NamingContext:1.0".
|
|||
|
|
|||
|
b. RMI-style
|
|||
|
|
|||
|
RMI:ClassName:HashCode[:SUID]
|
|||
|
|
|||
|
This format is used by RMI-IIOP remote objects [RMI-IIOP].
|
|||
|
"ClassName" is the fully qualified name of the class (for example,
|
|||
|
"java.lang.String"). "HashCode" is the object's hash code (that is,
|
|||
|
that obtained by invoking the "hashCode()" method). "SUID" is the
|
|||
|
"stream unique identifier", which is a 64-bit number that uniquely
|
|||
|
identifies the serialization version of the class; SUID is optional
|
|||
|
in the repository id.
|
|||
|
|
|||
|
c. DCE-style
|
|||
|
|
|||
|
DCE:UUID
|
|||
|
|
|||
|
This format is used for DCE/CORBA interoperability [CORBA-DCE].
|
|||
|
"UUID" represents a DCE UUID.
|
|||
|
|
|||
|
d. "local"
|
|||
|
|
|||
|
This format is defined by the local Object Request Broker (ORB).
|
|||
|
|
|||
|
The corbaRepositoryId attribute is a multivalued attribute; each
|
|||
|
value records a single repository id of an interface implemented by
|
|||
|
the CORBA object. This attribute need not contain a complete list of
|
|||
|
the interfaces implemented by the CORBA object.
|
|||
|
|
|||
|
This attribute's syntax is 'Directory String' and its case is
|
|||
|
significant. The values of this attribute are encoded using UTF-8.
|
|||
|
Some values may require translation from their native representation
|
|||
|
in order to be correctly encoded using UTF-8.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.1.15
|
|||
|
NAME 'corbaRepositoryId'
|
|||
|
DESC 'Repository ids of interfaces implemented by a CORBA object'
|
|||
|
EQUALITY caseExactMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
)
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 4]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
4. Object Class Definitions
|
|||
|
|
|||
|
The following object classes are defined in this document:
|
|||
|
|
|||
|
corbaContainer
|
|||
|
corbaObject
|
|||
|
corbaObjectReference
|
|||
|
|
|||
|
4.1 corbaContainer
|
|||
|
|
|||
|
This structural object class represents a container for a CORBA
|
|||
|
object.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.2.10
|
|||
|
NAME 'corbaContainer'
|
|||
|
DESC 'Container for a CORBA object'
|
|||
|
SUP top
|
|||
|
STRUCTURAL
|
|||
|
MUST ( cn )
|
|||
|
)
|
|||
|
|
|||
|
4.2 corbaObject
|
|||
|
|
|||
|
This abstract object class is the root class for representing a CORBA
|
|||
|
object.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.2.9
|
|||
|
NAME 'corbaObject'
|
|||
|
DESC 'CORBA object representation'
|
|||
|
SUP top
|
|||
|
ABSTRACT
|
|||
|
MAY ( corbaRepositoryId $ description )
|
|||
|
)
|
|||
|
|
|||
|
4.3 corbaObjectReference
|
|||
|
|
|||
|
This auxiliary object class represents a CORBA object reference. It
|
|||
|
must be mixed in with a structural object class.
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.2.11
|
|||
|
NAME 'corbaObjectReference'
|
|||
|
DESC 'CORBA interoperable object reference'
|
|||
|
SUP corbaObject
|
|||
|
AUXILIARY
|
|||
|
MUST ( corbaIor )
|
|||
|
)
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 5]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
5. Security Considerations
|
|||
|
|
|||
|
Obtaining a reference to an object and storing it in the directory
|
|||
|
may make a handle to the object available to a wider audience. This
|
|||
|
may have security implications.
|
|||
|
|
|||
|
6. Acknowledgements
|
|||
|
|
|||
|
We would like to thank Sanjeev Krishnan of Sun Microsystems, Simon
|
|||
|
Nash of IBM, and Jeffrey Spirn of Oracle for their comments and
|
|||
|
suggestions.
|
|||
|
|
|||
|
7. References
|
|||
|
|
|||
|
[CORBA] The Object Management Group, "Common Object Request
|
|||
|
Broker Architecture Specification 2.2",
|
|||
|
http://www.omg.org
|
|||
|
|
|||
|
[CORBA-DCE] Distributed Systems Technology Center and Digital
|
|||
|
Equipment Corporation, "DCE/CORBA Interworking
|
|||
|
Specification", May 1998.
|
|||
|
http://www.omg.org/library/schedule/
|
|||
|
DCE_CORBA_Interworking_RFP.html
|
|||
|
|
|||
|
[LDAPv3] Wahl, M., Howes, T. and S. Kille, "Lightweight Directory
|
|||
|
Access Protocol (v3)", RFC 2251, December 1997.
|
|||
|
|
|||
|
[RMI-IIOP] IBM and Java Software, Sun Microsystems, Inc., "RMI over
|
|||
|
IIOP", June 1999. http://java.sun.com/products/rmi-
|
|||
|
iiop/index.html
|
|||
|
|
|||
|
[v3Schema] Wahl, M., "A Summary of the X.500(96) User Schema for use
|
|||
|
with LDAPv3", RFC 2256, December 1997.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 6]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
8. Authors' Addresses
|
|||
|
|
|||
|
Vincent Ryan
|
|||
|
Sun Microsystems, Inc.
|
|||
|
Mail Stop EDUB03
|
|||
|
901 San Antonio Road
|
|||
|
Palo Alto, CA 94303
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +353 1 819 9151
|
|||
|
EMail: vincent.ryan@ireland.sun.com
|
|||
|
|
|||
|
|
|||
|
Rosanna Lee
|
|||
|
Sun Microsystems, Inc.
|
|||
|
Mail Stop UCUP02-206
|
|||
|
901 San Antonio Road
|
|||
|
Palo Alto, CA 94303
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +1 408 863 3221
|
|||
|
EMail: rosanna.lee@eng.sun.com
|
|||
|
|
|||
|
|
|||
|
Scott Seligman
|
|||
|
Sun Microsystems, Inc.
|
|||
|
Mail Stop UCUP02-209
|
|||
|
901 San Antonio Road
|
|||
|
Palo Alto, CA 94303
|
|||
|
USA
|
|||
|
|
|||
|
Phone: +1 408 863 3222
|
|||
|
EMail: scott.seligman@eng.sun.com
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 7]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
9. Appendix - LDAP Schema
|
|||
|
|
|||
|
-- Attribute types --
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.1.14
|
|||
|
NAME 'corbaIor'
|
|||
|
DESC 'Stringified interoperable object reference of a CORBA object'
|
|||
|
EQUALITY caseIgnoreIA5Match
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.26
|
|||
|
SINGLE-VALUE
|
|||
|
)
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.1.15
|
|||
|
NAME 'corbaRepositoryId'
|
|||
|
DESC 'Repository ids of interfaces implemented by a CORBA object'
|
|||
|
EQUALITY caseExactMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
)
|
|||
|
|
|||
|
-- from RFC-2256 --
|
|||
|
|
|||
|
( 2.5.4.13
|
|||
|
NAME 'description'
|
|||
|
EQUALITY caseIgnoreMatch
|
|||
|
SUBSTR caseIgnoreSubstringsMatch
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15{1024}
|
|||
|
)
|
|||
|
|
|||
|
-- Object classes --
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.2.9
|
|||
|
NAME 'corbaObject'
|
|||
|
DESC 'CORBA object representation'
|
|||
|
SUP top
|
|||
|
ABSTRACT
|
|||
|
MAY ( corbaRepositoryId $ description )
|
|||
|
)
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.2.10
|
|||
|
NAME 'corbaContainer'
|
|||
|
DESC 'Container for a CORBA object'
|
|||
|
SUP top
|
|||
|
STRUCTURAL
|
|||
|
MUST ( cn )
|
|||
|
)
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 8]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
( 1.3.6.1.4.1.42.2.27.4.2.11
|
|||
|
NAME 'corbaObjectReference'
|
|||
|
DESC 'CORBA interoperable object reference'
|
|||
|
SUP corbaObject
|
|||
|
AUXILIARY
|
|||
|
MUST ( corbaIor )
|
|||
|
)
|
|||
|
|
|||
|
-- Matching rule from ISO X.520 --
|
|||
|
|
|||
|
( 2.5.13.5
|
|||
|
NAME 'caseExactMatch'
|
|||
|
SYNTAX 1.3.6.1.4.1.1466.115.121.1.15
|
|||
|
)
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 9]
|
|||
|
|
|||
|
RFC 2714 Schema for CORBA Object References October 1999
|
|||
|
|
|||
|
|
|||
|
10. Full Copyright Statement
|
|||
|
|
|||
|
Copyright (C) The Internet Society (1999). All Rights Reserved.
|
|||
|
|
|||
|
This document and translations of it may be copied and furnished to
|
|||
|
others, and derivative works that comment on or otherwise explain it
|
|||
|
or assist in its implementation may be prepared, copied, published
|
|||
|
and distributed, in whole or in part, without restriction of any
|
|||
|
kind, provided that the above copyright notice and this paragraph are
|
|||
|
included on all such copies and derivative works. However, this
|
|||
|
document itself may not be modified in any way, such as by removing
|
|||
|
the copyright notice or references to the Internet Society or other
|
|||
|
Internet organizations, except as needed for the purpose of
|
|||
|
developing Internet standards in which case the procedures for
|
|||
|
copyrights defined in the Internet Standards process must be
|
|||
|
followed, or as required to translate it into languages other than
|
|||
|
English.
|
|||
|
|
|||
|
The limited permissions granted above are perpetual and will not be
|
|||
|
revoked by the Internet Society or its successors or assigns.
|
|||
|
|
|||
|
This document and the information contained herein is provided on an
|
|||
|
"AS IS" basis and THE INTERNET SOCIETY AND THE INTERNET ENGINEERING
|
|||
|
TASK FORCE DISCLAIMS ALL WARRANTIES, EXPRESS OR IMPLIED, INCLUDING
|
|||
|
BUT NOT LIMITED TO ANY WARRANTY THAT THE USE OF THE INFORMATION
|
|||
|
HEREIN WILL NOT INFRINGE ANY RIGHTS OR ANY IMPLIED WARRANTIES OF
|
|||
|
MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE.
|
|||
|
|
|||
|
Acknowledgement
|
|||
|
|
|||
|
Funding for the RFC Editor function is currently provided by the
|
|||
|
Internet Society.
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
|
|||
|
Ryan, et al. Informational [Page 10]
|
|||
|
|