blob: d04736298c4e1ae4f6c34b8bdc0c03e7e5d7fe57 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
|
/////////////////////////////////////////////////////////////////////////////
//
// Project: SMB tdeioslave for KDE2
//
// File: tdeio_smb_internal.h
//
// Abstract: Utility classes used by SMBSlave
//
// Author(s): Matthew Peterson <mpeterson@caldera.com>
// Frank Schwanz <schwanz@fh-brandenburg.de>
//---------------------------------------------------------------------------
//
// 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 TDEIO_SMB_INTERNAL_H_INCLUDED
#define TDEIO_SMB_INTERNAL_H_INCLUDED
#include <tdeio/authinfo.h>
/**
* Types of a SMBURL :
* SMBURLTYPE_UNKNOWN - Type could not be determined. Bad SMB Url.
* SMBURLTYPE_ENTIRE_NETWORK - "smb:/" is entire network
* SMBURLTYPE_WORKGROUP_OR_SERVER - "smb:/mygroup" or "smb:/myserver"
* URLTYPE_SHARE_OR_PATH - "smb:/mygroupe/mymachine/myshare/mydir"
*/
enum SMBUrlType {
SMBURLTYPE_UNKNOWN = 0, SMBURLTYPE_ENTIRE_NETWORK = 1,
SMBURLTYPE_WORKGROUP_OR_SERVER = 2, SMBURLTYPE_SHARE_OR_PATH = 3
};
//===========================================================================
/**
* Class to handle URL's
* it can convert KURL to smbUrl
* and Handle UserInfo
* it also check the correctness of the URL
*/
class SMBUrl : public KURL
{
public:
SMBUrl();
SMBUrl(const KURL & kurl);
/**
* Appends the specified file and dir to this SMBUrl
* "smb://server/share" --> "smb://server/share/filedir"
*/
void addPath(const TQString &filedir);
bool cd(const TQString &dir);
/**
* Returns the type of this SMBUrl:
* SMBURLTYPE_UNKNOWN - Type could not be determined. Bad SMB Url.
* SMBURLTYPE_ENTIRE_NETWORK - "smb:/" is entire network
* SMBURLTYPE_WORKGROUP_OR_SERVER - "smb:/mygroup" or "smb:/myserver"
* URLTYPE_SHARE_OR_PATH - "smb:/mygroupe/mymachine/myshare/mydir"
*/
SMBUrlType getType() const;
void setPass( const TQString& _txt ) { KURL::setPass(_txt); updateCache(); }
void setUser( const TQString& _txt ) { KURL::setUser(_txt); updateCache(); }
void setHost( const TQString& _txt ) { KURL::setHost(_txt); updateCache(); }
/**
* Returns the workgroup if it given in url
*/
// TQString getWorkgroup() const;
/**
* Returns path after workgroup
*/
// TQString getServerShareDir() const;
/**
* Return a URL that is suitable for libsmbclient
*/
TQCString toSmbcUrl() const { return m_surl; }
private:
/**
* Change from TQString to TQCString (MS Windows's character encoding)
*/
TQCString fromUnicode( const TQString &_str ) const;
void updateCache();
TQCString m_surl;
/**
* Type of URL
* @see _SMBUrlType
*/
mutable SMBUrlType m_type;
};
#endif
|