certmanager/lib

dn.h
00001 /*
00002     dn.h
00003 
00004     This file is part of libkleopatra, the KDE keymanagement library
00005     Copyright (c) 2004 Klarälvdalens Datakonsult AB
00006 
00007     Libkleopatra is free software; you can redistribute it and/or
00008     modify it under the terms of the GNU General Public License as
00009     published by the Free Software Foundation; either version 2 of the
00010     License, or (at your option) any later version.
00011 
00012     Libkleopatra is distributed in the hope that it will be useful,
00013     but WITHOUT ANY WARRANTY; without even the implied warranty of
00014     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00015     General Public License for more details.
00016 
00017     You should have received a copy of the GNU General Public License
00018     along with this program; if not, write to the Free Software
00019     Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301  USA
00020 
00021     In addition, as a special exception, the copyright holders give
00022     permission to link the code of this program with any edition of
00023     the TQt library by Trolltech AS, Norway (or with modified versions
00024     of TQt that use the same license as TQt), and distribute linked
00025     combinations including the two.  You must obey the GNU General
00026     Public License in all respects for all of the code used other than
00027     TQt.  If you modify this file, you may extend this exception to
00028     your version of the file, but you are not obligated to do so.  If
00029     you do not wish to do so, delete this exception statement from
00030     your version.
00031 */
00032 
00033 #ifndef __KLEO_DN_H__
00034 #define __KLEO_DN_H__
00035 
00036 #include <tqstring.h>
00037 #include <tqvaluevector.h>
00038 #include <tdepimmacros.h>
00039 
00040 class TQStringList;
00041 class TQWidget;
00042 
00043 namespace Kleo {
00044   class DNAttributeOrderConfigWidget;
00045 }
00046 
00047 namespace Kleo {
00048 
00052   class KDE_EXPORT DNAttributeMapper {
00053     DNAttributeMapper();
00054     ~DNAttributeMapper();
00055   public:
00056     static const DNAttributeMapper * instance();
00057 
00058     TQString name2label( const TQString & s ) const;
00059     TQStringList names() const;
00060 
00061     const TQStringList & attributeOrder() const;
00062 
00063     void setAttributeOrder( const TQStringList & order );
00064 
00065     DNAttributeOrderConfigWidget * configWidget( TQWidget * parent=0, const char * name=0 ) const;
00066 
00067   private:
00068     class Private;
00069     Private * d;
00070     static DNAttributeMapper * mSelf;
00071   };
00072 
00076   class KDE_EXPORT DN  {
00077   public:
00078     class Attribute;
00079     typedef TQValueVector<Attribute> AttributeList;
00080     typedef AttributeList::const_iterator const_iterator;
00081 
00082     DN();
00083     DN( const TQString & dn );
00084     DN( const char * utf8DN );
00085     DN( const DN & other );
00086     ~DN();
00087 
00088     const DN & operator=( const DN & other );
00089 
00091     static TQString escape( const TQString & value );
00092 
00095     TQString prettyDN() const;
00097     TQString dn() const;
00098 
00099     TQString operator[]( const TQString & attr ) const;
00100 
00101     void append( const Attribute & attr );
00102 
00103     const_iterator begin() const;
00104     const_iterator end() const;
00105 
00106   private:
00107     void detach();
00108   private:
00109     class Private;
00110     Private * d;
00111   };
00112 
00113   class KDE_EXPORT DN::Attribute {
00114   public:
00115     typedef DN::AttributeList List;
00116 
00117     Attribute( const TQString & name=TQString(), const TQString & value=TQString() )
00118       : mName( name.upper() ), mValue( value ) {}
00119     Attribute( const Attribute & other )
00120       : mName( other.name() ), mValue( other.value() ) {}
00121 
00122     const Attribute & operator=( const Attribute & other ) {
00123       if ( this != &other ) {
00124     mName = other.name();
00125     mValue = other.value();
00126       }
00127       return *this;
00128     }
00129 
00130     const TQString & name() const { return mName; }
00131     const TQString & value() const { return mValue; }
00132 
00133     void setValue( const TQString & value ) { mValue = value; }
00134     
00135   private:
00136     TQString mName;
00137     TQString mValue;
00138   };
00139 
00140 }
00141 
00142 #endif // __KLEO_DN_H__