diff options
Diffstat (limited to 'ucb/source/ucp/ftp')
-rw-r--r-- | ucb/source/ucp/ftp/ftpcontent.cxx | 82 | ||||
-rw-r--r-- | ucb/source/ucp/ftp/ftpcontent.hxx | 8 | ||||
-rw-r--r-- | ucb/source/ucp/ftp/ftpurl.cxx | 71 | ||||
-rw-r--r-- | ucb/source/ucp/ftp/ftpurl.hxx | 16 | ||||
-rw-r--r-- | ucb/source/ucp/ftp/test.py | 18 |
5 files changed, 151 insertions, 44 deletions
diff --git a/ucb/source/ucp/ftp/ftpcontent.cxx b/ucb/source/ucp/ftp/ftpcontent.cxx index 37be547d4c56..d652e0a32d10 100644 --- a/ucb/source/ucp/ftp/ftpcontent.cxx +++ b/ucb/source/ucp/ftp/ftpcontent.cxx @@ -2,9 +2,9 @@ * * $RCSfile: ftpcontent.cxx,v $ * - * $Revision: 1.11 $ + * $Revision: 1.12 $ * - * last change: $Author: abi $ $Date: 2002-10-17 16:28:20 $ + * last change: $Author: abi $ $Date: 2002-10-21 13:12:59 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -102,6 +102,9 @@ #include <com/sun/star/ucb/UnsupportedOpenModeException.hpp> #include <com/sun/star/ucb/InteractiveNetworkConnectException.hpp> #include <com/sun/star/ucb/InteractiveNetworkResolveNameException.hpp> +#include <com/sun/star/ucb/MissingPropertiesException.hpp> +#include <com/sun/star/ucb/MissingInputStreamException.hpp> +#include <com/sun/star/ucb/NameClashException.hpp> #include <com/sun/star/ucb/OpenMode.hpp> #include <com/sun/star/ucb/IOErrorCode.hpp> @@ -296,7 +299,9 @@ enum ACTION { NOACTION, THROWAUTHENTICATIONREQUEST, THROWACCESSDENIED, THROWINTERACTIVECONNECT, - THROWRESOLVENAME }; + THROWRESOLVENAME, + THROWQUOTE, + THROWGENERAL }; // virtual @@ -407,8 +412,16 @@ Any SAL_CALL FTPContent::execute( ucbhelper::cancelCommandExecution( aRet, Environment); + } else if(action == THROWQUOTE) { + + } else if(action == THROWGENERAL) { + ucbhelper::cancelCommandExecution( + IOErrorCode_GENERAL, + Sequence<Any>(0), + Environment); } + if(aCommand.Name.compareToAscii("getPropertyValues") == 0) { Sequence<Property> Properties; if(!(aCommand.Argument >>= Properties)) @@ -445,7 +458,7 @@ Any SAL_CALL FTPContent::execute( aRet <<= IllegalArgumentException(); ucbhelper::cancelCommandExecution(aRet,Environment); } - insert(aInsertArgument); + insert(aInsertArgument,Environment); } else if(aCommand.Name.compareToAscii( "open" ) == 0) { OpenCommandArgument2 aOpenCommand; @@ -522,8 +535,11 @@ Any SAL_CALL FTPContent::execute( action = THROWAUTHENTICATIONREQUEST; else if(e.code() == CURLE_FTP_ACCESS_DENIED) action = THROWACCESSDENIED; + else if(e.code() == CURLE_FTP_QUOTE_ERROR) + action = THROWQUOTE; else - break; + // nothing known about the course of the error + action = THROWGENERAL; } return aRet; @@ -641,21 +657,53 @@ sal_Int32 InsertData::read(sal_Int8 *dest,sal_Int32 nBytesRequested) } -void FTPContent::insert(const InsertCommandArgument& aInsertCommand) +void FTPContent::insert(const InsertCommandArgument& aInsertCommand, + const Reference<XCommandEnvironment>& Env) { - if(!m_bInserted || (m_aInfo.Type == FTP_FILE && m_bTitleSet)) { - InsertData data(aInsertCommand.Data); - m_aFTPURL.insert(bool(aInsertCommand.ReplaceExisting),&data); - osl::MutexGuard aGuard(m_aMutex); - m_bInserted = false; - } else if(m_bInserted && m_aInfo.Type == FTP_FOLDER && m_bTitleSet ) { - // todo - // create a folder - osl::MutexGuard aGuard(m_aMutex); - m_bInserted = false; - } else { + osl::MutexGuard aGuard(m_aMutex); + + if(m_bInserted && !m_bTitleSet) { + MissingPropertiesException excep; + excep.Properties.realloc(1); + excep.Properties[0] = rtl::OUString::createFromAscii("Title"); + Any aAny; aAny <<= excep; + ucbhelper::cancelCommandExecution(aAny,Env); + } + + if(m_bInserted && + m_aInfo.Type == FTP_FILE && + !aInsertCommand.Data.is()) + { + MissingInputStreamException excep; + Any aAny; aAny <<= excep; + ucbhelper::cancelCommandExecution(aAny,Env); + } + try { + if(m_aInfo.Type == FTP_FILE) { + InsertData data(aInsertCommand.Data); + m_aFTPURL.insert(bool(aInsertCommand.ReplaceExisting), + &data); + } else if(m_aInfo.Type == FTP_FOLDER) + m_aFTPURL.mkdir(bool(aInsertCommand.ReplaceExisting)); + } catch(const curl_exception& e) { + if(e.code() == FILE_EXIST_DURING_INSERT) { + Any aAny; + NameClashException excep; + excep.Name = m_aFTPURL.child(); + ucbhelper::cancelCommandExecution(aAny,Env); + } else if(e.code() == FOLDER_EXIST_DURING_INSERT) { + Any aAny; + NameClashException excep; + excep.Name = m_aFTPURL.child(); + ucbhelper::cancelCommandExecution(aAny,Env); + } else + throw; } + + // May not be reached, because both mkdir and insert can throw curl- + // exceptions + m_bInserted = false; } diff --git a/ucb/source/ucp/ftp/ftpcontent.hxx b/ucb/source/ucp/ftp/ftpcontent.hxx index 0170635ab5d9..d32952d9a895 100644 --- a/ucb/source/ucp/ftp/ftpcontent.hxx +++ b/ucb/source/ucp/ftp/ftpcontent.hxx @@ -2,9 +2,9 @@ * * $RCSfile: ftpcontent.hxx,v $ * - * $Revision: 1.8 $ + * $Revision: 1.9 $ * - * last change: $Author: abi $ $Date: 2002-10-17 16:28:20 $ + * last change: $Author: abi $ $Date: 2002-10-21 13:13:00 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -215,7 +215,9 @@ namespace ftp const ::com::sun::star::uno::Sequence< ::com::sun::star::beans::PropertyValue>& seqPropVal); - void insert(const com::sun::star::ucb::InsertCommandArgument&); + void insert(const com::sun::star::ucb::InsertCommandArgument&, + const com::sun::star::uno::Reference< + com::sun::star::ucb::XCommandEnvironment>&); }; } diff --git a/ucb/source/ucp/ftp/ftpurl.cxx b/ucb/source/ucp/ftp/ftpurl.cxx index c0109a520aa7..3aa97b1fe317 100644 --- a/ucb/source/ucp/ftp/ftpurl.cxx +++ b/ucb/source/ucp/ftp/ftpurl.cxx @@ -2,9 +2,9 @@ * * $RCSfile: ftpurl.cxx,v $ * - * $Revision: 1.7 $ + * $Revision: 1.8 $ * - * last change: $Author: abi $ $Date: 2002-10-17 16:28:22 $ + * last change: $Author: abi $ $Date: 2002-10-21 13:13:00 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -312,7 +312,7 @@ rtl::OUString FTPURL::ident(bool withslash,bool internal) const } -rtl::OUString FTPURL::parent() const +rtl::OUString FTPURL::parent(bool internal) const { rtl::OUStringBuffer bff; @@ -328,7 +328,7 @@ rtl::OUString FTPURL::parent() const aPassword, aAccount); - if(m_bShowPassword && aPassword.getLength()) + if((internal || m_bShowPassword) && aPassword.getLength()) bff.append(sal_Unicode(':')) .append(aPassword); @@ -369,6 +369,15 @@ void FTPURL::child(const rtl::OUString& title) } +rtl::OUString FTPURL::child() const +{ + return + m_aPathSegmentVec.size() ? + m_aPathSegmentVec.back() : rtl::OUString(); +} + + + /** Listing of a directory. */ @@ -544,9 +553,6 @@ std::vector<FTPDirentry> FTPURL::list( p1 = p2 + 1; } - if(osKind == int(FTP_UNKNOWN)) - throw curl_exception(FTPCouldNotDetermineSystem); - return resvec; } @@ -677,6 +683,13 @@ extern "C" { void FTPURL::insert(bool replaceExisting,void* stream) const throw(curl_exception) { + if(!replaceExisting) { + FTPDirentry aDirentry(direntry()); + if(aDirentry.m_nMode == INETCOREFTP_FILEMODE_UNKNOWN) + throw curl_exception(FILE_EXIST_DURING_INSERT); + } // else + // overwrite is default in libcurl + CURL *curl = m_pFCP->handle(); SET_CONTROL_CONTAINER; @@ -696,3 +709,47 @@ void FTPURL::insert(bool replaceExisting,void* stream) const if(err != CURLE_OK) throw curl_exception(err); } + + + +void FTPURL::mkdir(bool ReplaceExisting) const + throw(curl_exception) +{ + rtl::OString title; + if(m_aPathSegmentVec.size()) + title = rtl::OString(m_aPathSegmentVec.back().getStr(), + m_aPathSegmentVec.back().getLength(), + RTL_TEXTENCODING_UTF8); + else + // will give an error + title = rtl::OString("/"); + + rtl::OString del("del "); del += title; + rtl::OString mkd("mkd "); mkd += title; + + struct curl_slist *slist = 0; + + FTPDirentry aDirentry(direntry()); + if(!ReplaceExisting) { + if(aDirentry.m_nMode != INETCOREFTP_FILEMODE_UNKNOWN) + throw curl_exception(FOLDER_EXIST_DURING_INSERT); + } else if(aDirentry.m_nMode != INETCOREFTP_FILEMODE_UNKNOWN) + slist = curl_slist_append(slist,del.getStr()); + + slist = curl_slist_append(slist,mkd.getStr()); + + CURL *curl = m_pFCP->handle(); + SET_CONTROL_CONTAINER; + curl_easy_setopt(curl,CURLOPT_NOBODY,TRUE); // no data => no transfer + + // post request + curl_easy_setopt(curl,CURLOPT_POSTQUOTE,slist); + + rtl::OUString url(parent(true)); + SET_URL(url); + + CURLcode err = curl_easy_perform(curl); + curl_slist_free_all(slist); + if(err != CURLE_OK) + throw curl_exception(err); +} diff --git a/ucb/source/ucp/ftp/ftpurl.hxx b/ucb/source/ucp/ftp/ftpurl.hxx index d526fa215c5b..9327d454fd60 100644 --- a/ucb/source/ucp/ftp/ftpurl.hxx +++ b/ucb/source/ucp/ftp/ftpurl.hxx @@ -2,9 +2,9 @@ * * $RCSfile: ftpurl.hxx,v $ * - * $Revision: 1.5 $ + * $Revision: 1.6 $ * - * last change: $Author: abi $ $Date: 2002-10-17 16:28:23 $ + * last change: $Author: abi $ $Date: 2002-10-21 13:13:00 $ * * The Contents of this file are made available subject to the terms of * either of the following licenses @@ -88,10 +88,8 @@ namespace ftp { class FTPHandleProvider; - - enum FTPErrorCode { - FTPCouldNotDetermineSystem = CURL_LAST + 1 - }; + enum FTPErrors { FILE_EXIST_DURING_INSERT = CURL_LAST +1, + FOLDER_EXIST_DURING_INSERT }; class malformed_exception { }; @@ -151,10 +149,12 @@ namespace ftp { /** returns the parent url. */ - rtl::OUString parent() const; + rtl::OUString parent(bool internal = false) const; void child(const rtl::OUString& title); + rtl::OUString child(void) const; + std::vector<FTPDirentry> list(sal_Int16 nMode) const throw(curl_exception); @@ -167,6 +167,8 @@ namespace ftp { void insert(bool ReplaceExisting,void* stream) const throw(curl_exception); + void mkdir(bool ReplaceExisting) const + throw(curl_exception); private: diff --git a/ucb/source/ucp/ftp/test.py b/ucb/source/ucp/ftp/test.py index 531ca605e498..931d9a3ec8a5 100644 --- a/ucb/source/ucp/ftp/test.py +++ b/ucb/source/ucp/ftp/test.py @@ -12,16 +12,14 @@ def grep(pattern,dirname,names): print filename break -def find(regexp,dirName = "."): - os.path.walk(dirName,grep,re.compile(regexp)) - +def find(pattern,directory = "."): + os.path.walk(directory,grep,re.compile(pattern)) + + if __name__ == "__main__": import sys - if len(sys.argv) == 3: - directory = sys.argv[2] - else: - directory = "." - - dir(sys) - os.path.walk(directory,grep,re.compile(sys.argv[1])) + if len(sys.argv) == 2: + find(sys.argv[1]) + elif len(sys.argv) == 2: + find(sys.argv[2],sys.argv[1]) |