Java Code Examples for com.sun.corba.se.spi.ior.iiop.GIOPVersion#supportsIORIIOPProfileComponents()
The following examples show how to use
com.sun.corba.se.spi.ior.iiop.GIOPVersion#supportsIORIIOPProfileComponents() .
You can vote up the ones you like or vote down the ones you don't like,
and go to the original project or source file by following the links above each example. You may check out the related API usage on the sidebar.
Example 1
Source Project: jdk1.8-source-analysis File: MessageBase.java License: Apache License 2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 2
Source Project: jdk1.8-source-analysis File: SocketOrChannelAcceptorImpl.java License: Apache License 2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 3
Source Project: TencentKona-8 File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 4
Source Project: TencentKona-8 File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 5
Source Project: jdk8u60 File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 6
Source Project: jdk8u60 File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 7
Source Project: JDKSourceCode1.8 File: MessageBase.java License: MIT License | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 8
Source Project: JDKSourceCode1.8 File: SocketOrChannelAcceptorImpl.java License: MIT License | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 9
Source Project: openjdk-jdk8u File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 10
Source Project: openjdk-jdk8u File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 11
Source Project: openjdk-jdk8u-backup File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 12
Source Project: openjdk-jdk8u-backup File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 13
Source Project: openjdk-jdk9 File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 14
Source Project: openjdk-jdk9 File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 15
Source Project: hottub File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 16
Source Project: hottub File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 17
Source Project: openjdk-8-source File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 18
Source Project: openjdk-8-source File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }
Example 19
Source Project: openjdk-8 File: MessageBase.java License: GNU General Public License v2.0 | 4 votes |
public static RequestMessage createRequest( ORB orb, GIOPVersion gv, byte encodingVersion, int request_id, boolean response_expected, IOR ior, short addrDisp, String operation, ServiceContexts service_contexts, Principal requesting_principal) { RequestMessage requestMessage = null; IIOPProfile profile = ior.getProfile(); if (addrDisp == KeyAddr.value) { // object key will be used for target addressing profile = ior.getProfile(); ObjectKey objKey = profile.getObjectKey(); byte[] object_key = objKey.getBytes(orb); requestMessage = createRequest(orb, gv, encodingVersion, request_id, response_expected, object_key, operation, service_contexts, requesting_principal); } else { if (!(gv.equals(GIOPVersion.V1_2))) { // only object_key based target addressing is allowed for // GIOP 1.0 & 1.1 throw wrapper.giopVersionError( CompletionStatus.COMPLETED_MAYBE); } // Note: Currently we use response_expected flag to decide if the // call is oneway or not. Ideally, it is possible to expect a // response on a oneway call too, but we do not support it now. byte response_flags = 0x03; if (response_expected) { response_flags = 0x03; } else { response_flags = 0x00; } TargetAddress target = new TargetAddress(); if (addrDisp == ProfileAddr.value) { // iop profile will be used profile = ior.getProfile(); target.profile(profile.getIOPProfile()); } else if (addrDisp == ReferenceAddr.value) { // ior will be used IORAddressingInfo iorInfo = new IORAddressingInfo( 0, // profile index ior.getIOPIOR()); target.ior(iorInfo); } else { // invalid target addressing disposition value throw wrapper.illegalTargetAddressDisposition( CompletionStatus.COMPLETED_NO); } requestMessage = new RequestMessage_1_2(orb, request_id, response_flags, new byte[] { 0x00, 0x00, 0x00 }, target, operation, service_contexts); requestMessage.setEncodingVersion(encodingVersion); } if (gv.supportsIORIIOPProfileComponents()) { // add request partitioning thread pool to use info int poolToUse = 0; // default pool IIOPProfileTemplate temp = (IIOPProfileTemplate)profile.getTaggedProfileTemplate(); Iterator iter = temp.iteratorById(ORBConstants.TAG_REQUEST_PARTITIONING_ID); if (iter.hasNext()) { poolToUse = ((RequestPartitioningComponent)iter.next()).getRequestPartitioningId(); } if (poolToUse < ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID || poolToUse > ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID) { throw wrapper.invalidRequestPartitioningId(new Integer(poolToUse), new Integer(ORBConstants.REQUEST_PARTITIONING_MIN_THREAD_POOL_ID), new Integer(ORBConstants.REQUEST_PARTITIONING_MAX_THREAD_POOL_ID)); } requestMessage.setThreadPoolToUse(poolToUse); } return requestMessage; }
Example 20
Source Project: openjdk-8 File: SocketOrChannelAcceptorImpl.java License: GNU General Public License v2.0 | 4 votes |
public void addToIORTemplate(IORTemplate iorTemplate, Policies policies, String codebase) { Iterator iterator = iorTemplate.iteratorById( org.omg.IOP.TAG_INTERNET_IOP.value); String hostname = orb.getORBData().getORBServerHost(); if (iterator.hasNext()) { // REVISIT - how does this play with legacy ORBD port exchange? IIOPAddress iiopAddress = IIOPFactories.makeIIOPAddress(orb, hostname, port); AlternateIIOPAddressComponent iiopAddressComponent = IIOPFactories.makeAlternateIIOPAddressComponent(iiopAddress); while (iterator.hasNext()) { TaggedProfileTemplate taggedProfileTemplate = (TaggedProfileTemplate) iterator.next(); taggedProfileTemplate.add(iiopAddressComponent); } } else { GIOPVersion version = orb.getORBData().getGIOPVersion(); int templatePort; if (policies.forceZeroPort()) { templatePort = 0; } else if (policies.isTransient()) { templatePort = port; } else { templatePort = orb.getLegacyServerSocketManager() .legacyGetPersistentServerPort(SocketInfo.IIOP_CLEAR_TEXT); } IIOPAddress addr = IIOPFactories.makeIIOPAddress(orb, hostname, templatePort); IIOPProfileTemplate iiopProfile = IIOPFactories.makeIIOPProfileTemplate(orb, version, addr); if (version.supportsIORIIOPProfileComponents()) { iiopProfile.add(IIOPFactories.makeCodeSetsComponent(orb)); iiopProfile.add(IIOPFactories.makeMaxStreamFormatVersionComponent()); RequestPartitioningPolicy rpPolicy = (RequestPartitioningPolicy) policies.get_effective_policy( ORBConstants.REQUEST_PARTITIONING_POLICY); if (rpPolicy != null) { iiopProfile.add( IIOPFactories.makeRequestPartitioningComponent( rpPolicy.getValue())); } if (codebase != null && codebase != "") { iiopProfile.add(IIOPFactories. makeJavaCodebaseComponent(codebase)); } if (orb.getORBData().isJavaSerializationEnabled()) { iiopProfile.add( IIOPFactories.makeJavaSerializationComponent()); } } iorTemplate.add(iiopProfile); } }