You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
272 lines
8.4 KiB
272 lines
8.4 KiB
/*
|
|
* Port for usage with qt-framework and development for tdesvn
|
|
* (C) 2005-2007 by Rajko Albrecht
|
|
* http://tdesvn.alwins-world.de
|
|
*/
|
|
/*
|
|
* ====================================================================
|
|
* Copyright (c) 2002-2005 The RapidSvn Group. All rights reserved.
|
|
*
|
|
* This library is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU Lesser 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 library 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 Lesser General Public
|
|
* License along with this library (in the file LGPL.txt); if not,
|
|
* write to the Free Software Foundation, Inc., 51 Franklin St,
|
|
* Fifth Floor, Boston, MA 02110-1301 USA
|
|
*
|
|
* This software consists of voluntary contributions made by many
|
|
* individuals. For exact contribution history, see the revision
|
|
* history and logs, available at http://rapidsvn.tigris.org/.
|
|
* ====================================================================
|
|
*/
|
|
|
|
#ifndef _SVNCPP_CONTEXT_LISTENER_HPP_
|
|
#define _SVNCPP_CONTEXT_LISTENER_HPP_
|
|
|
|
// svncpp
|
|
#include "pool.hpp"
|
|
#include "commititem.hpp"
|
|
#include "svnqt_defines.hpp"
|
|
// qt
|
|
#include <tqstring.h>
|
|
// Subversion api
|
|
#include <svn_client.h>
|
|
|
|
|
|
namespace svn
|
|
{
|
|
class ConflictResult;
|
|
class ConflictDescription;
|
|
/**
|
|
* This is the interface that is used by @a Context
|
|
* for callbacks.
|
|
* To use this you will have to inherit from this
|
|
* interface and overwrite the virtual methods.
|
|
*/
|
|
class SVNTQT_EXPORT ContextListener
|
|
{
|
|
public:
|
|
/**
|
|
* empty destructor avoids a lot of compiler warnings
|
|
*/
|
|
virtual ~ContextListener(){}
|
|
/**
|
|
* this method will be called to retrieve
|
|
* authentication information. This will called until valid information were
|
|
* inserted or it returns false.
|
|
*
|
|
* @param username username set as default by subversion
|
|
* @param realm in which username/password will be used
|
|
* @param password target storage for password
|
|
* @param maySave in/out set false to not save
|
|
* @return continue action?
|
|
* @retval true continue
|
|
*/
|
|
virtual bool
|
|
contextGetLogin (const TQString & realm,
|
|
TQString & username,
|
|
TQString & password,
|
|
bool & maySave) = 0;
|
|
/**
|
|
* this method will be called to retrieve
|
|
* authentication information stored not by subversion. This
|
|
* will only called once!
|
|
*
|
|
* @param username username set as default by subversion
|
|
* @param realm in which username/password will be used
|
|
* @param password target storage for password
|
|
* @return continue action? should only in case of emergency return false.
|
|
* @retval true continue
|
|
*/
|
|
virtual bool
|
|
contextGetSavedLogin(const TQString & realm,
|
|
TQString & username,
|
|
TQString & password) = 0;
|
|
/**
|
|
* this method will be called to retrieve
|
|
* authentication information stored not persistent. This
|
|
* will only called once!
|
|
*
|
|
* @param username username set as default by subversion
|
|
* @param realm in which username/password will be used
|
|
* @param password target storage for password
|
|
* @return continue action? should only in case of emergency return false.
|
|
* @retval true continue
|
|
*/
|
|
virtual bool
|
|
contextGetCachedLogin(const TQString & realm,
|
|
TQString & username,
|
|
TQString & password) = 0;
|
|
|
|
/**
|
|
* this method will be called to notify about
|
|
* the progress of an ongoing action
|
|
*
|
|
* @param path
|
|
* @param action
|
|
* @param kind
|
|
* @param mime_type
|
|
* @param content_state
|
|
* @param prop_state
|
|
* @param revision
|
|
*/
|
|
virtual void
|
|
contextNotify (const char *path,
|
|
svn_wc_notify_action_t action,
|
|
svn_node_kind_t kind,
|
|
const char *mime_type,
|
|
svn_wc_notify_state_t content_state,
|
|
svn_wc_notify_state_t prop_state,
|
|
svn_revnum_t revision) = 0;
|
|
/**
|
|
* this method will be called to notify about
|
|
* the progress of an ongoing action
|
|
*
|
|
* @param action the action got notified about
|
|
* @since subversion 1.2
|
|
*/
|
|
virtual void
|
|
contextNotify (const svn_wc_notify_t *action) = 0;
|
|
/**
|
|
* this method will be called periodically to allow
|
|
* the app to cancel long running operations
|
|
*
|
|
* @return cancel action?
|
|
* @retval true cancel
|
|
*/
|
|
virtual bool
|
|
contextCancel() = 0;
|
|
|
|
/**
|
|
* this method will be called to retrieve
|
|
* a log message
|
|
*
|
|
* WORKAROUND FOR apr_xlate PROBLEM:
|
|
* STRINGS ALREADY HAVE TO BE UTF8!!!
|
|
*
|
|
* @param msg log message
|
|
* @return continue action?
|
|
* @retval true continue
|
|
*/
|
|
virtual bool
|
|
contextGetLogMessage (TQString & msg,const CommitItemList&) = 0;
|
|
|
|
typedef enum
|
|
{
|
|
DONT_ACCEPT = 0,
|
|
ACCEPT_TEMPORARILY,
|
|
ACCEPT_PERMANENTLY
|
|
} SslServerTrustAnswer;
|
|
|
|
|
|
/**
|
|
* @see contextSslServerTrust
|
|
* @see svn_auth_cred_ssl_server_trust_t
|
|
*/
|
|
struct SslServerTrustData
|
|
{
|
|
public:
|
|
/** bit coded failures */
|
|
const apr_uint32_t failures;
|
|
|
|
/** certificate information */
|
|
TQString hostname;
|
|
TQString fingerprint;
|
|
TQString validFrom;
|
|
TQString validUntil;
|
|
TQString issuerDName;
|
|
TQString realm;
|
|
bool maySave;
|
|
|
|
SslServerTrustData (const apr_uint32_t failures_)
|
|
: failures (failures_), hostname (""), fingerprint (""),
|
|
validFrom (""), validUntil (""), issuerDName (""),
|
|
realm (""), maySave (true)
|
|
{
|
|
}
|
|
};
|
|
|
|
|
|
/**
|
|
* this method is called if there is ssl server
|
|
* information, that has to be confirmed by the user
|
|
*
|
|
* @param data
|
|
* @param acceptedFailures
|
|
* @return @a SslServerTrustAnswer
|
|
*/
|
|
virtual SslServerTrustAnswer
|
|
contextSslServerTrustPrompt (const SslServerTrustData & data,
|
|
apr_uint32_t & acceptedFailures) = 0;
|
|
|
|
/**
|
|
* this method is called to retrieve client side
|
|
* information
|
|
*/
|
|
virtual bool
|
|
contextSslClientCertPrompt (TQString & certFile) = 0;
|
|
|
|
/**
|
|
* this method is called to retrieve the password
|
|
* for the client certificate
|
|
*
|
|
* @param password
|
|
* @param realm
|
|
* @param maySave
|
|
*/
|
|
virtual bool
|
|
contextSslClientCertPwPrompt (TQString & password,
|
|
const TQString & realm,
|
|
bool & maySave) = 0;
|
|
/**
|
|
* this method is called to retrieve the password
|
|
* for the client certificate from a local storage or such. it will called only once.
|
|
*
|
|
* @param password
|
|
* @param realm
|
|
*/
|
|
virtual bool
|
|
contextLoadSslClientCertPw(TQString&password,const TQString&realm)=0;
|
|
|
|
virtual void
|
|
contextProgress(long long int current, long long int max) = 0;
|
|
|
|
/**
|
|
* try to translate a text. In current implementation does
|
|
* nothing than returning the origin but may used to get an
|
|
* application specific translation.
|
|
* @param what text to translate
|
|
* @return translated text or origin.
|
|
*/
|
|
virtual TQString translate(const TQString&what){return what;}
|
|
|
|
/** Callback for svn_wc_conflict_resolver_func_t in subversion 1.5
|
|
* This method is only useful when build with subverion 1.5 or above. The default implementation sets
|
|
* result to ConflictResult::ChoosePostpone. Then conflicts while merge, update and switch results in an
|
|
* item with "conflict" status set.
|
|
*
|
|
* @param result The result where to store
|
|
* @param description description of conflict.
|
|
* @return true if result may used and operaion should continue.
|
|
* @sa svn_wc_conflict_description_t, svn_wc_conflict_result_t
|
|
* @since subversion 1.5
|
|
*/
|
|
virtual bool contextConflictResolve(ConflictResult&result,const ConflictDescription&description);
|
|
};
|
|
}
|
|
|
|
#endif
|
|
/* -----------------------------------------------------------------
|
|
* local variables:
|
|
* eval: (load-file "../../rapidsvn-dev.el")
|
|
* end:
|
|
*/
|