1corba(3)                   Erlang Module Definition                   corba(3)
2
3
4

NAME

6       corba - The functions on CORBA module level
7

DESCRIPTION

9       This  module  contains functions that are specified on the CORBA module
10       level. It also contains  some  functions  for  creating  and  disposing
11       objects.
12

EXPORTS

14       create(Module, TypeID) -> Object
15       create(Module, TypeID, Env) -> Object
16       create(Module, TypeID, Env, Optons1) -> Object
17       create_link(Module, TypeID) -> Object
18       create_link(Module, TypeID, Env) -> Object
19       create_link(Module, TypeID, Env, Options2) -> Reply
20
21              Types:
22
23                 Module = atom()
24                 TypeID = string()
25                 Env = term()
26                 Options1   =  [{persistent,  Bool}  |  {regname,  RegName}  |
27                 {local_typecheck, Bool}]
28                 Options2 = [{sup_child, Bool} | {persistent,  Bool}  |  {reg‐
29                 name, RegName} | {pseudo, Bool} | {local_typecheck, Bool}]
30                 RegName = {local, atom()} | {global, term()}
31                 Reply = #objref | {ok, Pid, #objref}
32                 Bool = true | false
33                 Object = #objref
34
35              These functions start a new server object. If you start it with‐
36              out RegName it can only be accessed through the returned  object
37              key.  Started  with  a RegName the name is registered locally or
38              globally.
39
40              TypeID is the repository ID of the server object type and  could
41              for example look like "IDL:StackModule/Stack:1.0".
42
43              Module is the name of the interface API module.
44
45              Env  is  the arguments passed which will be passed to the imple‐
46              mentations init call-back function.
47
48              A server started with create/2, create/3 or  create/4  does  not
49              care  about  the parent, which means that the parent is not han‐
50              dled explicitly in the generic process part.
51
52              A  server  started  with  create_link2,  create_link/3  or  cre‐
53              ate_link/4 is initially linked to the caller, the parent, and it
54              will terminate whenever the parent process terminates, and  with
55              the  same  reason  as the parent. If the server traps exits, the
56              terminate/2 call-back function is called in order  to  clean  up
57              before  the  termination.  These functions should be used if the
58              server is a worker in a supervision tree.
59
60              If you use  the  option  {sup_child,  true}  create_link/4  will
61              return {ok, Pid, #objref}, otherwise #objref, and make it possi‐
62              ble to start a server  as  a  supervisor  child  (stdlib-1.7  or
63              later).
64
65              If  you  use the option {persistent, true} you also must use the
66              option {regname, {global, Name}}. This combination makes it pos‐
67              sible to tell the difference between a server permanently termi‐
68              nated or in the process of restarting.
69
70              The option {pseudo, true}, allow us to create an object which is
71              not  a  server.  Using  {pseudo, true} overrides all other start
72              options. For more information see section Module_Interface.
73
74              If a server is started using the option {persistent,  true}  the
75              object  key will not be removed unless it terminates with reason
76              normal or shutdown. Hence, if  persistent  servers  is  used  as
77              supervisor  children  they  should  be  transient and the objec‐
78              tkeys_gc_time should be modified (default equals infinity).
79
80              The option {local_typecheck,  boolean()},  which  overrides  the
81              Local  Typechecking environment flag, turns on or off typecheck‐
82              ing. If activated, parameters,  replies  and  raised  exceptions
83              will  be checked to ensure that the data is correct, when invok‐
84              ing operations on CORBA Objects within the  same  Orber  domain.
85              Due  to  the extra overhead, this option MAY ONLY be used during
86              testing and development.
87
88              Example:
89
90                corba:create('StackModule_Stack', "IDL:StackModule/Stack:1.0", {10, test})
91
92
93       dispose(Object) -> ok
94
95              Types:
96
97                 Object = #objref
98
99              This function is used for terminating the execution of a  server
100              object. Invoking this operation on a NIL object reference, e.g.,
101              the return value of corba:create_nil_objref/0, always return ok.
102              For  valid  object references, invoking this operation more than
103              once, will result in a system exception.
104
105       create_nil_objref() -> Object
106
107              Types:
108
109                 Object = #objref representing NIL.
110
111              Creates an object  reference  that  represents  the  NIL  value.
112              Attempts  to  invoke operations using the returned object refer‐
113              ence will return a system exception.
114
115       create_subobject_key(Object, Key) -> Result
116
117              Types:
118
119                 Object = #objref
120                 Key = term()
121                 Result = #objref
122
123              This function is used to create a subobject in a server  object.
124              It  can  for  example  be useful when one wants unique access to
125              separate rows in a mnesia or an ETS  table.  The  Result  is  an
126              object  reference that will be seen as a unique reference to the
127              outside world but will access the same server object  where  one
128              can  use the get_subobject_key/1 function to get the private key
129              value.
130
131              Key is stored in the object reference Object. If it is a  binary
132              it  will  be  stored  as  is  and otherwise it is converted to a
133              binary before storage.
134
135       get_subobject_key(Object) -> Result
136
137              Types:
138
139                 Object = #objref
140                 Result = #binary
141
142              This function is used to fetch a subobject key from  the  object
143              reference  Object. The result is a always a binary, if it was an
144              Erlang term that was stored with create_subobject_key/2 one  can
145              to do binary_to_term/1 to get the real value.
146
147       get_pid(Object) -> Result
148
149              Types:
150
151                 Object = #objref
152                 Result = #pid | {error, Reason} | {'EXCEPTION',E}
153
154              This  function is to get the process id from an object, which is
155              a must when CORBA objects is  started/handled  in  a  supervisor
156              tree. The function will throw exceptions if the key is not found
157              or some other error occurs.
158
159       raise(Exception)
160
161              Types:
162
163                 Exception = record()
164
165              This function is used for raising corba exceptions as an  Erlang
166              user  generated  exit  signal.  It will throw the tuple {'EXCEP‐
167              TION', Exception}.
168
169       reply(To, Reply) -> true
170
171              Types:
172
173                 To = client reference
174                 Reply = IDL type
175
176              This function can be used by a CORBA object to explicitly send a
177              reply  to  a  client  that  invoked a two-way operation. If this
178              operation is used, it is not possible to return a reply  in  the
179              call-back module.
180              To  must be the From argument provided to the callback function,
181              which requires that the IC option from was used  when  compiling
182              the IDL-file.
183
184       resolve_initial_references(ObjectId) -> Object
185       resolve_initial_references(ObjectId, Contexts) -> Object
186
187              Types:
188
189                 ObjectId = string()
190                 Contexts = [Context]
191                 Context  =  #'IOP_ServiceContext'{context_id  =  CtxId,  con‐
192                 text_data = CtxData}
193                 CtxId = ?ORBER_GENERIC_CTX_ID
194                 CtxData = {interface, Interface} | {userspecific,  term()}  |
195                 {configuration, Options}
196                 Interface = string()
197                 Options = [{Key, Value}]
198                 Key = ssl_client_options
199                 Value = allowed value associated with the given key
200                 Object = #objref
201
202              This  function  returns the object reference associated with the
203              given object id. Initially, only "NameService" is available.  To
204              add  or remove services use add_initial_service/2 or remove_ini‐
205              tial_service/1.
206
207              The configuration context is used to  override  the  global  SSL
208              client side configuration.
209
210       add_initial_service(ObjectId, Object) -> boolean()
211
212              Types:
213
214                 ObjectId = string()
215                 Object = #objref
216
217              This  operation  allows us to add initial services, which can be
218              accessed by using resolve_initial_references/1 or  the  corbaloc
219              schema. If using an Id defined by the OMG, the given object must
220              be of the correct type; for more information see the Interopera‐
221              ble  Naming  Service.  Returns  false  if  the  given id already
222              exists.
223
224       remove_initial_service(ObjectId) -> boolean()
225
226              Types:
227
228                 ObjectId = string()
229
230              If we don not want a certain service to be accessible,  invoking
231              this  function will remove the association. Returns true if able
232              to terminate the binding. If no such binding  existed  false  is
233              returned.
234
235       list_initial_services() -> [ObjectId]
236
237              Types:
238
239                 ObjectId = string()
240
241              This function returns a list of allowed object id's.
242
243       resolve_initial_references_remote(ObjectId, Address) -> Object
244       resolve_initial_references_remote(ObjectId,   Address,   Contexts)   ->
245       Object
246
247              Types:
248
249                 ObjectId = string()
250                 Address = [RemoteModifier]
251                 RemoteModifier = string()
252                 Contexts = [Context]
253                 Context  =  #'IOP_ServiceContext'{context_id  =  CtxId,  con‐
254                 text_data = CtxData}
255                 CtxId = ?ORBER_GENERIC_CTX_ID
256                 CtxData  =  {interface, Interface} | {userspecific, term()} |
257                 {configuration, Options}
258                 Interface = string()
259                 Options = [{Key, Value}]
260                 Key = ssl_client_options
261                 Value = allowed value associated with the given key
262                 Object = #objref
263
264              This function returns the object reference  for  the  object  id
265              asked  for. The remote modifier string has the following format:
266              "iiop://"<host>":"<port> where <host> = <DNS hostname>  |  <IPv4
267              address> | "["<IPv6 address>"]".
268
269              The  configuration  context  is  used to override the global SSL
270              client side configuration.
271
272          Warning:
273              This operation is  not  supported  by  most  ORB's.  Hence,  use
274              corba:string_to_object/1 instead.
275
276
277       list_initial_services_remote(Address) -> [ObjectId]
278       list_initial_services_remote(Address, Contexts) -> [ObjectId]
279
280              Types:
281
282                 Address = [RemoteModifier]
283                 RemoteModifier = string()
284                 Contexts = [Context]
285                 Context  =  #'IOP_ServiceContext'{context_id  =  CtxId,  con‐
286                 text_data = CtxData}
287                 CtxId = ?ORBER_GENERIC_CTX_ID
288                 CtxData = {interface, Interface} | {userspecific,  term()}  |
289                 {configuration, Options}
290                 Interface = string()
291                 Options = [{Key, Value}]
292                 Key = ssl_client_options
293                 Value = allowed value associated with the given key
294                 ObjectId = string()
295
296              This  function returns a list of allowed object id's. The remote
297              modifier     string     has      the      following      format:
298              "iiop://"<host>":"<port>  where  <host> = <DNS hostname> | <IPv4
299              address> | "["<IPv6 address>"]".
300
301              The configuration context is used to  override  the  global  SSL
302              client side configuration.
303
304          Warning:
305              This  operation  is  not  supported  by most ORB's. Hence, avoid
306              using it.
307
308
309       object_to_string(Object) -> IOR_string
310
311              Types:
312
313                 Object = #objref
314                 IOR_string = string()
315
316              This function returns  the  object  reference  as  the  external
317              string representation of an IOR.
318
319       string_to_object(IOR_string) -> Object
320       string_to_object(IOR_string, Contexts) -> Object
321
322              Types:
323
324                 IOR_string = string()
325                 Contexts = [Context]
326                 Context  =  #'IOP_ServiceContext'{context_id  =  CtxId,  con‐
327                 text_data = CtxData}
328                 CtxId = ?ORBER_GENERIC_CTX_ID
329                 CtxData = {interface, Interface} | {userspecific,  term()}  |
330                 {configuration, Options}
331                 Interface = string()
332                 Options = [{Key, Value}]
333                 Key = ssl_client_options
334                 Value = allowed value associated with the given key
335                 Object = #objref
336
337              This  function  takes  a  corbaname,  corbaloc  or an IOR on the
338              external string representation and returns the object reference.
339
340              To lookup the NameService reference, simply use:
341
342              corbaloc:iiop:1.2@123.0.0.12:4001/NameService
343
344              We can also resolve an object from the NameService by using:
345
346              corbaname:iiop:1.2@123.0.0.12:4001/NameService#org/Erlang/MyObj
347
348              To lookup the NameService reference with an IPv6 address, simply
349              use:
350
351              corbaloc:iiop:1.2@[FEC1:0:3:0:0312:44AF:FAB1:3D01]:4001/NameService
352
353              For  more  information  about  corbaname  and  corbaloc, see the
354              User's Guide (Interoperable Naming Service).
355
356              The configuration context is used to  override  the  global  SSL
357              client side configuration.
358
359              How  to handle the interface context is further described in the
360              User's Guide.
361
362       print_object(Data [, Type]) -> ok | {'EXCEPTION', E} |  {'EXIT',  R}  |
363       string()
364
365              Types:
366
367                 Data  =  IOR_string  |  #objref  (local  or  external) | cor‐
368                 baloc/corbaname string
369                 Type = IoDevice | error_report  |  {error_report,  Reason}  |
370                 info_msg | {info_msg, Comment} | string
371                 IoDevice = see the io-module
372                 Reason = Comment = string()
373
374              The  object  represented  by  the supplied data is dissected and
375              presented in  a  more  readable  form.  The  Type  parameter  is
376              optional;   if   not  supplied  standard  output  is  used.  For
377              error_report and info_msg the error_logger module is used,  with
378              or  without  Reason  or  Comment. If the atom string is supplied
379              this function will return a flat list. The IoDevice is passed to
380              the operation io:format/2.
381
382              If  the  supplied  object  is  a  local reference, the output is
383              equivalent to an object exported from the node this function  is
384              invoked on.
385
386       add_alternate_iiop_address(Object,  Host, Port) -> NewObject | {'EXCEP‐
387       TION', E}
388
389              Types:
390
391                 Object = NewObject = local #objref
392                 Host = string()
393                 Port = integer()
394
395              This operation creates a new instance  of  the  supplied  object
396              containing  an  ALTERNATE_IIOP_ADDRESS  component.  Only the new
397              instance contains the new component. When this object is  passed
398              to  another  ORB,  which  supports  the  ALTERNATE_IIOP_ADDRESS,
399              requests will be routed to the alternate address if  it  is  not
400              possible to communicate with the main address.
401
402              The  ALTERNATE_IIOP_ADDRESS  component requires that IIOP-1.2 is
403              used. Hence, make sure both Orber and the other ORB is correctly
404              configured.
405
406          Note:
407              Make  sure that the given Object is accessible via the alternate
408              Host/port. For example, if the object is  correctly  started  as
409              local  or  pseudo,  the  object should be available on all nodes
410              within a multi-node Orber installation. Since only one  instance
411              exists for other object types, it will not be possible to access
412              it if the node it was started on terminates.
413
414
415       orb_init(KeyValueList) -> ok | {'EXIT', Reason}
416
417              Types:
418
419                 KeyValueList = [{Key, Value}]
420                 Key = any key listed in the configuration chapter
421                 Value = allowed value associated with the given key
422
423              This function allows the user to configure Orber in,  for  exam‐
424              ple, an Erlang shell. Orber may NOT be started prior to invoking
425              this operation. For more information, see configuration settings
426              in the User's Guide.
427
428
429
430Ericsson AB                       orber 3.8.4                         corba(3)
Impressum