!C99Shell v. 2.0 [PHP 7 Update] [25.02.2019]!

Software: Apache. PHP/5.6.40 

uname -a: Linux cpanel06wh.bkk1.cloud.z.com 2.6.32-954.3.5.lve1.4.80.el6.x86_64 #1 SMP Thu Sep 24
01:42:00 EDT 2020 x86_64
 

uid=851(cp949260) gid=853(cp949260) groups=853(cp949260) 

Safe-mode: OFF (not secure)

/opt/passenger-5.3.7-4.el6.cloudlinux/src/cxx_supportlib/   drwxr-xr-x
Free 235.15 GB of 981.82 GB (23.95%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     Exceptions.h (10.18 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*
 *  Phusion Passenger - https://www.phusionpassenger.com/
 *  Copyright (c) 2010-2017 Phusion Holding B.V.
 *
 *  "Passenger", "Phusion Passenger" and "Union Station" are registered
 *  trademarks of Phusion Holding B.V.
 *
 *  Permission is hereby granted, free of charge, to any person obtaining a copy
 *  of this software and associated documentation files (the "Software"), to deal
 *  in the Software without restriction, including without limitation the rights
 *  to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
 *  copies of the Software, and to permit persons to whom the Software is
 *  furnished to do so, subject to the following conditions:
 *
 *  The above copyright notice and this permission notice shall be included in
 *  all copies or substantial portions of the Software.
 *
 *  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 *  IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 *  FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 *  AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 *  LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
 *  OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
 *  THE SOFTWARE.
 */
#ifndef _PASSENGER_EXCEPTIONS_H_
#define _PASSENGER_EXCEPTIONS_H_

#ifdef __cplusplus
extern "C" {
#endif

/* Provides helper structs and functions for translating C++ exceptions
 * into C error objects.
 */

#define PP_NO_ERRNO -1

struct PP_Error {
    /** The exception message. */
    const char *message;
    /** If the original exception was a SystemException, then this
     * field is set to the corresponding errno value. Otherwise, it
     * is set to PP_NO_ERRNO.
     */
    int errnoCode;
    int messageIsStatic: 1;
};

typedef struct PP_Error PP_Error;

void pp_error_init(PP_Error *error);
void pp_error_destroy(PP_Error *error);

#ifdef __cplusplus
}
#endif


#ifdef __cplusplus

#include <oxt/tracable_exception.hpp>
#include <string>
#include <exception>
#include <sstream>
#include <cstring>
#include <cassert>


/**
 * Use as follows:
 *
 *     try {
 *         ...
 *     } catch (const std::exception &e) {
 *         pp_error_set(e, error);
 *     }
 */
void pp_error_set(const std::exception &ex, PP_Error *error);


/**
 * @defgroup Exceptions Exceptions
 */

namespace Passenger {

using namespace std;

/**
 * Represents an error returned by a system call or a standard library call.
 *
 * Use the code() method to find out the value of <tt>errno</tt> at the time
 * the error occured.
 *
 * @ingroup Exceptions
 */
class SystemException: public oxt::tracable_exception {
private:
    string briefMessage;
    string systemMessage;
    string fullMessage;
    int m_code;
public:
    /**
     * Create a new SystemException.
     *
     * @param briefMessage A brief message describing the error.
     * @param errorCode The error code, i.e. the value of errno right after the error occured.
     * @note A system description of the error will be appended to the given message.
     *    For example, if <tt>errorCode</tt> is <tt>EBADF</tt>, and <tt>briefMessage</tt>
     *    is <em>"Something happened"</em>, then what() will return <em>"Something happened: Bad
     *    file descriptor (10)"</em> (if 10 is the number for EBADF).
     * @post code() == errorCode
     * @post brief() == briefMessage
     */
    SystemException(const string &briefMessage, int errorCode) {
        stringstream str;

        str << strerror(errorCode) << " (errno=" << errorCode << ")";
        systemMessage = str.str();

        setBriefMessage(briefMessage);
        m_code = errorCode;
    }

    virtual ~SystemException() throw() {}

    virtual const char *what() const throw() {
        return fullMessage.c_str();
    }

    void setBriefMessage(const string &message) {
        briefMessage = message;
        fullMessage = briefMessage + ": " + systemMessage;
    }

    /**
     * The value of <tt>errno</tt> at the time the error occured.
     */
    int code() const throw() {
        return m_code;
    }

    /**
     * Returns a brief version of the exception message. This message does
     * not include the system error description, and is equivalent to the
     * value of the <tt>message</tt> parameter as passed to the constructor.
     */
    string brief() const throw() {
        return briefMessage;
    }

    /**
     * Returns the system's error message. This message contains both the
     * content of <tt>strerror(errno)</tt> and the errno number itself.
     */
    string sys() const throw() {
        return systemMessage;
    }
};

/**
 * A filesystem error, as returned by the operating system. This may include,
 * for example, permission errors.
 *
 * @ingroup Exceptions
 */
class FileSystemException: public SystemException {
private:
    string m_filename;
public:
    FileSystemException(const string &message, int errorCode,
        const string &filename)
        : SystemException(message, errorCode),
          m_filename(filename) {}

    virtual ~FileSystemException() throw() {}

    /**
     * The filename that's associated to the error.
     */
    string filename() const throw() {
        return m_filename;
    }
};

/**
 * Unable to retrieve the system time using <tt>time()</tt>.
 *
 * @ingroup Exceptions
 */
class TimeRetrievalException: public SystemException {
public:
    TimeRetrievalException(const string &message, int errorCode)
        : SystemException(message, errorCode)
        {}
    virtual ~TimeRetrievalException() throw() {}
};

/**
 * Represents an error that occured during an I/O operation.
 *
 * @ingroup Exceptions
 */
class IOException: public oxt::tracable_exception {
private:
    string msg;
public:
    IOException(const string &message): msg(message) {}
    virtual ~IOException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/**
 * Thrown when a certain file cannot be found.
 */
class FileNotFoundException: public IOException {
public:
    FileNotFoundException(const string &message): IOException(message) {}
    virtual ~FileNotFoundException() throw() {}
};

/**
 * An unexpected end-of-file I/O error.
 *
 * @ingroup Exceptions
 */
class EOFException: public IOException {
public:
    EOFException(const string &message): IOException(message) {}
    virtual ~EOFException() throw() {}
};

/**
 * Thrown when an invalid configuration is given.
 */
class ConfigurationException: public oxt::tracable_exception {
private:
    string msg;
public:
    ConfigurationException(const string &message): msg(message) {}
    virtual ~ConfigurationException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/**
 * Indicates that a Pool::get() or Pool::asyncGet() request was denied.
 * The request never reached a process. This could be because, before the
 * request could reach a process, the administrator detached the containing
 * group. Or maybe the request sat in the queue for too long.
 */
class GetAbortedException: public oxt::tracable_exception {
private:
    string msg;

public:
    GetAbortedException(const string &message)
        : msg(message)
        { }

    GetAbortedException(const oxt::tracable_exception::no_backtrace &tag)
        : oxt::tracable_exception(tag)
        { }

    virtual ~GetAbortedException() throw() {}

    virtual const char *what() const throw() {
        return msg.c_str();
    }
};

/**
 * Indicates that a Pool::get() or Pool::asyncGet() request was denied because
 * the getWaitlist queue was full.
 */
class RequestQueueFullException: public GetAbortedException {
private:
    string msg;

public:
    RequestQueueFullException(unsigned int maxQueueSize)
        : GetAbortedException(oxt::tracable_exception::no_backtrace())
        {
            stringstream str;
            str << "Request queue full (configured max. size: " << maxQueueSize << ")";
            msg = str.str();
        }

    virtual ~RequestQueueFullException() throw() {}

    virtual const char *what() const throw() {
        return msg.c_str();
    }
};

/**
 * Indicates that a specified argument is incorrect or violates a requirement.
 *
 * @ingroup Exceptions
 */
class ArgumentException: public oxt::tracable_exception {
private:
    string msg;
public:
    ArgumentException(const string &message): msg(message) {}
    virtual ~ArgumentException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/*
 * @ingroup Exceptions
 */
class InvalidModeStringException: public ArgumentException {
public:
    InvalidModeStringException(const string &message): ArgumentException(message) {}
};

/**
 * A generic runtime exception.
 *
 * @ingroup Exceptions
 */
class RuntimeException: public oxt::tracable_exception {
private:
    string msg;
public:
    RuntimeException(const string &message): msg(message) {}
    virtual ~RuntimeException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/**
 * An exception indicating that some timeout expired.
 *
 * @ingroup Exceptions
 */
class TimeoutException: public oxt::tracable_exception {
private:
    string msg;
public:
    TimeoutException(const string &message): msg(message) {}
    virtual ~TimeoutException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/**
 * Represents some kind of security error.
 *
 * @ingroup Exceptions
 */
class SecurityException: public oxt::tracable_exception {
private:
    string msg;
public:
    SecurityException(const string &message): msg(message) {}
    virtual ~SecurityException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/**
 * @ingroup Exceptions
 */
class NonExistentUserException: public SecurityException {
public:
    NonExistentUserException(const string &message): SecurityException(message) {}
};

/**
 * @ingroup Exceptions
 */
class NonExistentGroupException: public SecurityException {
public:
    NonExistentGroupException(const string &message): SecurityException(message) {}
};

/**
 * The application pool is too busy and cannot fulfill a get() request.
 *
 * @ingroup Exceptions
 */
class BusyException: public oxt::tracable_exception {
private:
    string msg;
public:
    BusyException(const string &message): msg(message) {}
    virtual ~BusyException() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

/**
 * A parser detected a syntax error.
 *
 * @ingroup Exceptions
 */
class SyntaxError: public oxt::tracable_exception {
private:
    string msg;
public:
    SyntaxError(const string &message): msg(message) {}
    virtual ~SyntaxError() throw() {}
    virtual const char *what() const throw() { return msg.c_str(); }
};

} // namespace Passenger

#endif /* __cplusplus */

#endif /* _PASSENGER_EXCEPTIONS_H_ */

:: Command execute ::

Enter:
 
Select:
 

:: Search ::
  - regexp 

:: Upload ::
 
[ Read-Only ]

:: Make Dir ::
 
[ Read-Only ]
:: Make File ::
 
[ Read-Only ]

:: Go Dir ::
 
:: Go File ::
 

--[ c99shell v. 2.0 [PHP 7 Update] [25.02.2019] maintained by KaizenLouie | C99Shell Github | Generation time: 0.0136 ]--