summaryrefslogtreecommitdiffstats
path: root/filesharing/advanced/kcm_sambaconf/sambashare.h
diff options
context:
space:
mode:
Diffstat (limited to 'filesharing/advanced/kcm_sambaconf/sambashare.h')
-rw-r--r--filesharing/advanced/kcm_sambaconf/sambashare.h231
1 files changed, 231 insertions, 0 deletions
diff --git a/filesharing/advanced/kcm_sambaconf/sambashare.h b/filesharing/advanced/kcm_sambaconf/sambashare.h
new file mode 100644
index 00000000..d6c0e3b7
--- /dev/null
+++ b/filesharing/advanced/kcm_sambaconf/sambashare.h
@@ -0,0 +1,231 @@
+/***************************************************************************
+ sambashare.h - description
+ -------------------
+ begin : Mon 12 2002
+ copyright : (C) 2002 by Jan Schäfer
+ email : janschaefer@users.sourceforge.net
+ ***************************************************************************/
+
+/******************************************************************************
+ * *
+ * This file is part of KSambaPlugin. *
+ * *
+ * KSambaPlugin is free software; you can redistribute it and/or modify *
+ * it under the terms of the GNU General Public License as published by *
+ * the Free Software Foundation; either version 2 of the License, or *
+ * (at your option) any later version. *
+ * *
+ * KSambaPlugin is distributed in the hope that it will be useful, *
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of *
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
+ * GNU General Public License for more details. *
+ * *
+ * You should have received a copy of the GNU General Public License *
+ * along with KSambaPlugin; if not, write to the Free Software *
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA *
+ * *
+ ******************************************************************************/
+
+#ifndef SAMBASHARE_H
+#define SAMBASHARE_H
+
+#include <qdict.h>
+#include <qstring.h>
+#include <qstringlist.h>
+#include <qptrlist.h>
+
+class SambaConfigFile;
+class QStringList;
+
+/**
+ * A class which represents a Samba share
+ * @author Jan Sch&auml;fer
+ **/
+class SambaShare :public QDict<QString>
+{
+public:
+
+ /**
+ * Creates a new SambaShare with an empty name
+ **/
+ SambaShare(SambaConfigFile* sambaFile);
+
+ /**
+ * Creates a new SambaShare with the given name
+ * @param name the name of the share
+ **/
+ SambaShare(const QString & name, SambaConfigFile* sambaFile);
+
+ /**
+ * Returns the name of the share
+ **/
+ const QString& getName() const;
+
+
+ /**
+ * Sets the name of the share
+ * returns false if the name already exists and the testWetherExists
+ * parameter is set to true
+ **/
+ bool setName(const QString & name, bool testWetherExists=true);
+
+ /**
+ * Tests wether or not the given option is supported by Samba.
+ * It does this by testing the output of testparm for this option
+ **/
+ bool optionSupported(const QString & name);
+
+ /**
+ * Returns the value of the given parameter
+ * if the parameter doesn't exists, the
+ * global and then the default value is returned.
+ * @param name the name of the parameter
+ * @param gobalValue if the gobal value should be returend
+ * @param defaultValue if the default value should be returned or a null string
+ **/
+ QString getValue(const QString & name, bool globalValue=true, bool defaultValue=true);
+
+ /**
+ * Same as above but for boolean parameters
+ * Don't use defaultValue = false with this function
+ * because you can't distinguish an unset parameter
+ * from a false parameter
+ **/
+ bool getBoolValue(const QString & name, bool globalValue=true, bool defaultValue=true);
+
+ /**
+ * Returns the value from the [globals] section
+ **/
+ QString getGlobalValue(const QString & name, bool defaultValue=true);
+
+ /**
+ * Sets the parameter name to the given value
+ * @param value the value of the parameter
+ * @param name the name of the parameter
+ * @param globalValue if true then the value is only set if it is different to the global value
+ * @param defaultValue if true then the value is only set if it is different to the default value
+ * if globalValue and defaultValue is true then the value is set when a global value
+ * exists and it it is different to it. If no global value exists then it is only
+ * set if different to the default value.
+ **/
+ void setValue(const QString & name,const QString & value, bool globalValue=true, bool defaultValue=true);
+
+ /**
+ * Same as above but for boolean parameters
+ **/
+ void setValue(const QString & name, bool value, bool globalValue=true, bool defaultValue=true);
+
+ /**
+ * Same as above but for integer parameters
+ **/
+ void setValue(const QString & name, int value, bool globalValue=true, bool defaultValue=true);
+
+ /**
+ * Returns the default value of the parameter
+ * @param name the name of the parameter
+ **/
+ QString getDefaultValue(const QString & name);
+
+ /**
+ * Same as above but for booleans
+ **/
+ bool getDefaultBoolValue(const QString & name);
+
+ /**
+ * Returns the default synonym for the given parameter
+ * if no synonym exists the original parameter in lower
+ * case is returned
+ **/
+ QString getSynonym(const QString & name) const;
+
+ /**
+ * Returns the comments of the share
+ * e.g. the text above the [...] section
+ **/
+ QStringList getComments();
+
+ /**
+ * Sets the comments for the share
+ * e.g. the text above the [...] section
+ **/
+ void setComments(const QStringList & commentList);
+
+ /**
+ * Sets the comments for the passed option
+ **/
+ void setComments(const QString & name, const QStringList & commentList);
+
+ /**
+ * Returns the comments of the passed option
+ **/
+ QStringList getComments(const QString & name);
+
+ /**
+ * Returns true if the passed option has comments
+ * otherwise returns false
+ **/
+ bool hasComments(const QString & name);
+
+ /**
+ * Returns the list of all options
+ * the order of the options is exactly the
+ * order of the insertion of the options
+ **/
+ QStringList getOptionList();
+
+ /**
+ * Returns true if this share is a printer
+ * that's if printable = true
+ **/
+ bool isPrinter();
+
+ /**
+ * Returns true if the share name is
+ * global, printers or homes
+ **/
+ bool isSpecialSection();
+
+protected:
+ /**
+ * The name of the share
+ * could be also printers, global and homes
+ **/
+ QString _name;
+ SambaConfigFile* _sambaFile;
+
+ /**
+ * This attribute stores all option comments.
+ * the comments which stood above the option name
+ * are stored in this QStringList
+ **/
+ QDict<QStringList> _commentList;
+
+ /**
+ * The comments for this share
+ **/
+ QStringList _comments;
+
+ /**
+ * An extra list which holds
+ * all stored options
+ * You might say, hey for what is this ?
+ * We have them already stored in the QDict.
+ * That's right, but there is a problem :
+ * QDict doesn't preserve the order of
+ * the inserted items, but when saving
+ * the options back to the smb.conf
+ * we want to have exactly the same order
+ * so this QStringList is only for saving
+ * the order of the options.
+ * On the other side we need a very fast lookup
+ * of the options, because we lookup very frequently
+ * so this is the best way to do both.
+ **/
+ QStringList _optionList;
+
+};
+
+typedef QPtrList<SambaShare> SambaShareList;
+
+
+#endif