DCMTK Version 3.6.8
OFFIS DICOM Toolkit
|
This class maintains a list of association negotiation configuration profiles. More...
Public Member Functions | |
DcmAssociationConfiguration () | |
default constructor | |
~DcmAssociationConfiguration () | |
destructor | |
DcmAssociationConfiguration (const DcmAssociationConfiguration &arg) | |
Copy constructor, performs deep copy. More... | |
DcmAssociationConfiguration & | operator= (const DcmAssociationConfiguration &arg) |
Copy assignment operator, performs deep copy. More... | |
void | clear () |
Reset configuration. | |
OFCondition | setAssociationParameters (const char *profile, T_ASC_Parameters ¶ms) const |
this method prepares a T_ASC_Parameters structure according to the settings of a profile maintained by this object. More... | |
OFCondition | evaluateAssociationParameters (const char *profile, T_ASC_Association &assoc) const |
this method evaluates an incoming association request according to the settings of a profile maintained by this object. More... | |
OFCondition | addTransferSyntax (const char *key, const char *transferSyntaxUID) |
adds the given transfer syntax UID to the list of transfer syntaxes maintained under the given key. More... | |
OFCondition | addPresentationContext (const char *key, const char *abstractSyntaxUID, const char *transferSyntaxKey, OFBool scuMode) |
adds the given abstract syntax UID and transfer syntax list key to the list of presentation contexts maintained under the given key. More... | |
OFCondition | addRole (const char *key, const char *abstractSyntaxUID, T_ASC_SC_ROLE role) |
adds the given abstract syntax UID and role to the list of SCP/SCU role selection items maintained under the given key. More... | |
OFCondition | createEmptyRoleList (const char *key) |
adds empty role list, also returns ok if list is already existing. More... | |
OFCondition | addExtendedNegotiation (const char *key, const char *abstractSyntaxUID, const unsigned char *rawData, Uint32 length) |
adds the given abstract syntax UID and extended negotiation data to the list of extended negotiation items maintained under the given key. More... | |
OFCondition | addProfile (const char *key, const char *presentationContextKey, const char *roleSelectionKey=NULL, const char *extendedNegotiationKey=NULL) |
creates a new association negotiation profile under the given key. More... | |
OFBool | isKnownProfile (const char *key) const |
checks if the profile is known More... | |
const DcmProfileEntry * | getProfileEntry (const OFString &profileName) |
returns profile identified by given name More... | |
OFBool | isValidSCPProfile (const char *key) const |
checks if the profile is suitable for use by an SCP. More... | |
OFBool | isValidSCUProfile (const char *key) const |
checks if the profile is suitable for use by an SCU. More... | |
OFString | findTSKey (const OFList< OFString > &tslist) |
find a list of transfer syntaxes that matches the given list and return its name. More... | |
void | setAlwaysAcceptDefaultRole (const OFBool enabled) |
Option to always accept a default role as association acceptor. More... | |
void | dumpProfiles (STD_NAMESPACE ostream &out, const OFString &profileName="") |
dumps all profiles or a selected profile to the given output stream. More... | |
Protected Member Functions | |
void | dumpProfile (STD_NAMESPACE ostream &out, const DcmProfileEntry *profile, const OFString &profileName) |
dump a single association profile, mainly interesting for debugging purposes. More... | |
Private Attributes | |
DcmTransferSyntaxMap | xferSyntaxes_ |
map of transfer syntax lists | |
DcmPresentationContextMap | contexts_ |
map of presentation context lists | |
DcmRoleSelectionMap | roleselection_ |
map of role selection lists | |
DcmExtendedNegotiationMap | extneg_ |
map of extended negotiation lists | |
DcmProfileMap | profiles_ |
map of profiles | |
OFBool | alwaysAcceptDefaultRole_ |
Option to always accept a default role as association acceptor. More... | |
This class maintains a list of association negotiation configuration profiles.
A profile is a combination of the following components: A list of presentation contexts, an optional list of SCP/SCU role selection items and an optional list of extended negotiation items. A presentation context itself consist of an abstract syntax and a list of transfer syntaxes, the latter each being separate components. Role selection and extended negotiation items are atomic (i.e. they do not reference other components). All components are identified by a unique symbolic name. All components are re-usable since they are only referenced from a profile by their respective symbolic names. E.g. a list of transfer syntaxes can be referenced from various presentation contexts. This approach has been taken in order to save memory since, for instance, in many presentation contexts, the list of supported transfer syntaxes will be the same.
DcmAssociationConfiguration::DcmAssociationConfiguration | ( | const DcmAssociationConfiguration & | arg | ) |
Copy constructor, performs deep copy.
arg | the DcmAC to copy |
OFCondition DcmAssociationConfiguration::addExtendedNegotiation | ( | const char * | key, |
const char * | abstractSyntaxUID, | ||
const unsigned char * | rawData, | ||
Uint32 | length | ||
) |
adds the given abstract syntax UID and extended negotiation data to the list of extended negotiation items maintained under the given key.
If key is not yet known, a new list is created under this key. One abstract syntax UID must not appear twice within one list.
key | role list key, must not be NULL |
abstractSyntaxUID | abstract syntax UID in symbolic or numeric format |
rawData | pointer to raw data, must not be NULL |
length | length of data block pointed to by data, in bytes |
OFCondition DcmAssociationConfiguration::addPresentationContext | ( | const char * | key, |
const char * | abstractSyntaxUID, | ||
const char * | transferSyntaxKey, | ||
OFBool | scuMode | ||
) |
adds the given abstract syntax UID and transfer syntax list key to the list of presentation contexts maintained under the given key.
If key is not yet known, a new list is created under this key. One list of presentation contexts may not have more than 128 entries because of the limitations of the DICOM ACSE protocol.
key | presentation context list key, must not be NULL |
abstractSyntaxUID | abstract syntax UID in symbolic or numeric format |
transferSyntaxKey | symbolic key that has been used in a call to addTransferSyntax() prior to this call. |
scuMode | true if the configuration is intended for an SCU (i.e. the limit of 128 presentation contexts must be preserved), false otherwise |
OFCondition DcmAssociationConfiguration::addProfile | ( | const char * | key, |
const char * | presentationContextKey, | ||
const char * | roleSelectionKey = NULL , |
||
const char * | extendedNegotiationKey = NULL |
||
) |
creates a new association negotiation profile under the given key.
A profile consists of a list of presentation contexts and may optionally also include a list of SCP/SCU role selection items and a list of extended negotiation items. This method checks the consistency of the three lists, i.e. makes sure that all abstract syntaxes mentioned either in the list of role selection items or the list of extended negotiation items are also contained in at least one presentation context.
key | profile key, must not be NULL |
presentationContextKey | presentation context list key, must not be NULL |
roleSelectionKey | role selection list key, may be NULL |
extendedNegotiationKey | extended negotiation list key, may be NULL |
OFCondition DcmAssociationConfiguration::addRole | ( | const char * | key, |
const char * | abstractSyntaxUID, | ||
T_ASC_SC_ROLE | role | ||
) |
adds the given abstract syntax UID and role to the list of SCP/SCU role selection items maintained under the given key.
If key is not yet known, a new list is created under this key. One abstract syntax UID must not appear twice within one list.
key | role list key, must not be NULL |
abstractSyntaxUID | abstract syntax UID in symbolic or numeric format |
role | role enum |
OFCondition DcmAssociationConfiguration::addTransferSyntax | ( | const char * | key, |
const char * | transferSyntaxUID | ||
) |
adds the given transfer syntax UID to the list of transfer syntaxes maintained under the given key.
If key is not yet known, a new list is created under this key.
key | transfer syntax list key, must not be NULL |
transferSyntaxUID | transfer syntax UID in symbolic or numeric format |
OFCondition DcmAssociationConfiguration::createEmptyRoleList | ( | const char * | key | ) |
adds empty role list, also returns ok if list is already existing.
If key is not yet known, a new list is created under this key.
key | role list key, must not be NULL |
|
protected |
dump a single association profile, mainly interesting for debugging purposes.
out | output stream to be used |
profile | profile to dump |
profileName | name of the profile to dump (used for debug output) |
void DcmAssociationConfiguration::dumpProfiles | ( | STD_NAMESPACE ostream & | out, |
const OFString & | profileName = "" |
||
) |
dumps all profiles or a selected profile to the given output stream.
Mainly useful for debugging.
out | output stream to be used |
profileName | if not empty, only the profile defined by the given is dumped. Otherwise, all profiles are dumped. |
OFCondition DcmAssociationConfiguration::evaluateAssociationParameters | ( | const char * | profile, |
T_ASC_Association & | assoc | ||
) | const |
this method evaluates an incoming association request according to the settings of a profile maintained by this object.
It is used by an association acceptor.
profile | symbolic profile name, must not be NULL |
assoc | T_ASC_Association structure to be evaluated |
find a list of transfer syntaxes that matches the given list and return its name.
A match is only found if the number of transfer syntaxes is the same, each transfer syntax exists in the other list and the order is preserved.
tslist | the list of transfer syntaxes to look for |
const DcmProfileEntry * DcmAssociationConfiguration::getProfileEntry | ( | const OFString & | profileName | ) |
returns profile identified by given name
profileName | the name of the profile to look for |
OFBool DcmAssociationConfiguration::isKnownProfile | ( | const char * | key | ) | const |
checks if the profile is known
key | profile name, must not be NULL |
OFBool DcmAssociationConfiguration::isValidSCPProfile | ( | const char * | key | ) | const |
checks if the profile is suitable for use by an SCP.
A profile is suitable for use by an SCP if each SOP class in the list of presentation contexts appears at most once.
key | profile name, must not be NULL |
OFBool DcmAssociationConfiguration::isValidSCUProfile | ( | const char * | key | ) | const |
checks if the profile is suitable for use by an SCU.
A profile is suitable for use by an SCU if the list of presentation contexts appears has not more than 128 entries.
key | profile name, must not be NULL |
DcmAssociationConfiguration & DcmAssociationConfiguration::operator= | ( | const DcmAssociationConfiguration & | arg | ) |
Copy assignment operator, performs deep copy.
arg | the DcmAC to copy |
void DcmAssociationConfiguration::setAlwaysAcceptDefaultRole | ( | const OFBool | enabled | ) |
Option to always accept a default role as association acceptor.
If OFFalse (default) the acceptor will reject a presentation context proposed with Default role (no role selection at all) when it is configured for role SCP only. If this option is set to OFTrue then such presentation contexts will be accepted in Default role (i.e. acceptor does not return role selection for this presentation context at all). Overall, if set to OFTrue, there are no requestor proposals possible that lead to a complete rejection of a presentation context. See also role documentation in dul.h.
enabled | If OFTrue, do not reject Default role proposals when configured for SCP role. OFFalse (default behaviour): Reject such proposals. |
OFCondition DcmAssociationConfiguration::setAssociationParameters | ( | const char * | profile, |
T_ASC_Parameters & | params | ||
) | const |
this method prepares a T_ASC_Parameters structure according to the settings of a profile maintained by this object.
It is used by an association initiator.
profile | symbolic profile name, must not be NULL |
params | T_ASC_Parameters structure to be filled |
|
private |
Option to always accept a default role as association acceptor.
If OFFalse (default) the acceptor will reject a presentation context proposed with Default role (no role selection at all) when it is configured for role SCP only. If this option is set to OFTrue then such presentation contexts will be accepted in Default role (i.e. acceptor does not return role selection for this presentation context at all). Overall, if set to OFTrue, there are no requestor proposals possible that lead to a complete rejection of a presentation context. See also role documentation in dul.h.