summaryrefslogtreecommitdiffstats
path: root/kioslave/smb/kio_smb.h
diff options
context:
space:
mode:
authortoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
committertoma <toma@283d02a7-25f6-0310-bc7c-ecb5cbfe19da>2009-11-25 17:56:58 +0000
commit4aed2c8219774f5d797760606b8489a92ddc5163 (patch)
tree3f8c130f7d269626bf6a9447407ef6c35954426a /kioslave/smb/kio_smb.h
downloadtdebase-4aed2c8219774f5d797760606b8489a92ddc5163.tar.gz
tdebase-4aed2c8219774f5d797760606b8489a92ddc5163.zip
Copy the KDE 3.5 branch to branches/trinity for new KDE 3.5 features.
BUG:215923 git-svn-id: svn://anonsvn.kde.org/home/kde/branches/trinity/kdebase@1054174 283d02a7-25f6-0310-bc7c-ecb5cbfe19da
Diffstat (limited to 'kioslave/smb/kio_smb.h')
-rw-r--r--kioslave/smb/kio_smb.h301
1 files changed, 301 insertions, 0 deletions
diff --git a/kioslave/smb/kio_smb.h b/kioslave/smb/kio_smb.h
new file mode 100644
index 000000000..a04d7b3fa
--- /dev/null
+++ b/kioslave/smb/kio_smb.h
@@ -0,0 +1,301 @@
+/////////////////////////////////////////////////////////////////////////////
+//
+// Project: SMB kioslave for KDE2
+//
+// File: kio_smb.h
+//
+// Abstract: The main kio slave class declaration. For convenience,
+// in concurrent devlopment, the implementation for this class
+// is separated into several .cpp files -- the file containing
+// the implementation should be noted in the comments for each
+// member function.
+//
+// Author(s): Matthew Peterson <mpeterson@caldera.com>
+//
+//---------------------------------------------------------------------------
+//
+// Copyright (c) 2000 Caldera Systems, Inc.
+//
+// This program 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.1 of the License, or
+// (at your option) any later version.
+//
+// This program 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 Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU General Public License
+// along with this program; see the file COPYING. If not, please obtain
+// a copy from http://www.gnu.org/copyleft/gpl.html
+//
+/////////////////////////////////////////////////////////////////////////////
+
+
+#ifndef KIO_SMB_H_INCLUDED
+#define KIO_SMB_H_INCLUDED
+
+//-------------
+// QT includes
+//-------------
+#include <qstring.h>
+#include <qptrlist.h>
+#include <qstringlist.h>
+#include <qtextstream.h>
+#include <qstrlist.h>
+
+//--------------
+// KDE includes
+//--------------
+#include <kdebug.h>
+#include <kinstance.h>
+#include <kio/global.h>
+#include <kio/slavebase.h>
+#include <kurl.h>
+#include <klocale.h>
+
+//-----------------------------
+// Standard C library includes
+//-----------------------------
+#include <stdlib.h>
+#include <sys/stat.h>
+#include <sys/ioctl.h>
+#include <sys/socket.h>
+#include <netinet/in.h>
+#include <net/if.h>
+#include <arpa/inet.h>
+#include <stdio.h>
+#include <errno.h>
+#include <time.h>
+#include <qobject.h>
+
+//-------------------------------
+// Samba client library includes
+//-------------------------------
+extern "C"
+{
+#include <libsmbclient.h>
+}
+
+//---------------------------
+// kio_smb internal includes
+//---------------------------
+#include "kio_smb_internal.h"
+
+#define MAX_XFER_BUF_SIZE 16348
+#define KIO_SMB 7106
+
+using namespace KIO;
+class KProcess;
+
+//===========================================================================
+
+
+class SMBSlave : public QObject, public KIO::SlaveBase
+{
+ Q_OBJECT
+
+private:
+ //---------------------------------------------------------------------
+ // please make sure your private data does not duplicate existing data
+ //---------------------------------------------------------------------
+ bool m_initialized_smbc;
+
+ /**
+ * From Controlcenter
+ */
+ QString m_default_user;
+// QString m_default_workgroup; //currently unused, Alex <neundorf@kde.org>
+ QString m_default_password;
+ QString m_default_encoding;
+
+ /**
+ * we store the current url, it's needed for
+ * callback authorisation method
+ */
+ SMBUrl m_current_url;
+
+ /**
+ * From Controlcenter, show SHARE$ or not
+ */
+// bool m_showHiddenShares; //currently unused, Alex <neundorf@kde.org>
+
+ /**
+ * libsmbclient need global variables to store in,
+ * else it crashes on exit next method after use cache_stat,
+ * looks like gcc (C/C++) failure
+ */
+ struct stat st;
+protected:
+ //---------------------------------------------
+ // Authentication functions (kio_smb_auth.cpp)
+ //---------------------------------------------
+ // (please prefix functions with auth)
+
+
+ /**
+ * Description : Initilizes the libsmbclient
+ * Return : true on success false with errno set on error
+ */
+ bool auth_initialize_smbc();
+
+ bool checkPassword(SMBUrl &url);
+
+
+ //---------------------------------------------
+ // Cache functions (kio_smb_auth.cpp)
+ //---------------------------------------------
+
+ //Stat methods
+
+ //-----------------------------------------
+ // Browsing functions (kio_smb_browse.cpp)
+ //-----------------------------------------
+ // (please prefix functions with browse)
+
+ /**
+ * Description : Return a stat of given SMBUrl. Calls cache_stat and
+ * pack it in UDSEntry. UDSEntry will not be cleared
+ * Parameter : SMBUrl the url to stat
+ * ignore_errors do not call error(), but warning()
+ * Return : false if any error occoured (errno), else true
+ */
+ bool browse_stat_path(const SMBUrl& url, UDSEntry& udsentry, bool ignore_errors);
+
+ /**
+ * Description : call smbc_stat and return stats of the url
+ * Parameter : SMBUrl the url to stat
+ * Return : stat* of the url
+ * Note : it has some problems with stat in method, looks like
+ * something leave(or removed) on the stack. If your
+ * method segfault on returning try to change the stat*
+ * variable
+ */
+ int cache_stat( const SMBUrl& url, struct stat* st );
+
+ //---------------------------------------------
+ // Configuration functions (kio_smb_config.cpp)
+ //---------------------------------------------
+ // (please prefix functions with config)
+
+
+ //---------------------------------------
+ // Directory functions (kio_smb_dir.cpp)
+ //---------------------------------------
+ // (please prefix functions with dir)
+
+
+ //--------------------------------------
+ // File IO functions (kio_smb_file.cpp)
+ //--------------------------------------
+ // (please prefix functions with file)
+
+ //----------------------------
+ // Misc functions (this file)
+ //----------------------------
+
+
+ /**
+ * Description : correct a given URL
+ * valid URL's are
+ *
+ * smb://[[domain;]user[:password]@]server[:port][/share[/path[/file]]]
+ * smb:/[[domain;]user[:password]@][group/[server[/share[/path[/file]]]]]
+ * domain = workgroup(domain) of the user
+ * user = username
+ * password = password of useraccount
+ * group = workgroup(domain) of server
+ * server = host to connect
+ * share = a share of the server (host)
+ * path = a path of the share
+ * Parameter : KURL the url to check
+ * Return : new KURL if its corrected. else the same KURL
+ */
+ KURL checkURL(const KURL& kurl) const;
+
+ void reportError(const SMBUrl &kurl);
+
+public:
+
+ //-----------------------------------------------------------------------
+ // smbclient authentication callback (note that this is called by the
+ // global ::auth_smbc_get_data() call.
+ void auth_smbc_get_data(const char *server,const char *share,
+ char *workgroup, int wgmaxlen,
+ char *username, int unmaxlen,
+ char *password, int pwmaxlen);
+
+
+ //-----------------------------------------------------------------------
+ // Overwritten functions from the base class that define the operation of
+ // this slave. (See the base class headerfile slavebase.h for more
+ // details)
+ //-----------------------------------------------------------------------
+
+ // Functions overwritten in kio_smb.cpp
+ SMBSlave(const QCString& pool, const QCString& app);
+ virtual ~SMBSlave();
+
+ // Functions overwritten in kio_smb_browse.cpp
+ virtual void listDir( const KURL& url );
+ virtual void stat( const KURL& url );
+
+ // Functions overwritten in kio_smb_config.cpp
+ virtual void reparseConfiguration();
+
+ // Functions overwritten in kio_smb_dir.cpp
+ virtual void copy( const KURL& src, const KURL &dest, int permissions, bool overwrite );
+ virtual void del( const KURL& kurl, bool isfile);
+ virtual void mkdir( const KURL& kurl, int permissions );
+ virtual void rename( const KURL& src, const KURL& dest, bool overwrite );
+
+ // Functions overwritten in kio_smb_file.cpp
+ virtual void get( const KURL& kurl );
+ virtual void put( const KURL& kurl, int permissions, bool overwrite, bool resume );
+
+ // Functions not implemented (yet)
+ //virtual void setHost(const QString& host, int port, const QString& user, const QString& pass);
+ //virtual void openConnection();
+ //virtual void closeConnection();
+ //virtual void slave_status();
+ virtual void special( const QByteArray & );
+
+private slots:
+ void readOutput(KProcess *proc, char *buffer, int buflen);
+ void readStdErr(KProcess *proc, char *buffer, int buflen);
+
+private:
+ QString mybuf, mystderr;
+
+};
+
+//===========================================================================
+// pointer to the slave created in kdemain
+extern SMBSlave* G_TheSlave;
+
+
+//==========================================================================
+// the global libsmbclient authentication callback function
+extern "C"
+{
+
+void auth_smbc_get_data(const char *server,const char *share,
+ char *workgroup, int wgmaxlen,
+ char *username, int unmaxlen,
+ char *password, int pwmaxlen);
+
+}
+
+
+//===========================================================================
+// Main slave entrypoint (see kio_smb.cpp)
+extern "C"
+{
+
+int kdemain( int argc, char **argv );
+
+}
+
+
+#endif //#endif KIO_SMB_H_INCLUDED