!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/agent/Core/SpawningKit/Handshake/   drwxr-xr-x
Free 223.21 GB of 981.82 GB (22.73%)
Home    Back    Forward    UPDIR    Refresh    Search    Buffer    Encoder    Tools    Proc.    FTP brute    Sec.    SQL    PHP-code    Update    Feedback    Self remove    Logout    


Viewing file:     BackgroundIOCapturer.h (5.43 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*
 *  Phusion Passenger - https://www.phusionpassenger.com/
 *  Copyright (c) 2011-2018 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_SPAWNING_KIT_BACKGROUND_IO_CAPTURER_H_
#define _PASSENGER_SPAWNING_KIT_BACKGROUND_IO_CAPTURER_H_

#include <boost/thread.hpp>
#include <boost/bind.hpp>
#include <boost/function.hpp>
#include <boost/foreach.hpp>
#include <oxt/backtrace.hpp>
#include <oxt/system_calls.hpp>
#include <string>
#include <vector>
#include <cstring>

#include <sys/types.h>

#include <LoggingKit/LoggingKit.h>
#include <FileDescriptor.h>
#include <StaticString.h>
#include <Utils.h>
#include <StrIntTools/StrIntUtils.h>

namespace Passenger {
namespace SpawningKit {

using namespace std;


/**
 * Given a file descriptor, captures its output in a background thread
 * and also forwards it immediately to a target file descriptor.
 * Call stop() to stop the background thread and to obtain the captured
 * output so far.
 */
class BackgroundIOCapturer {
private:
    const FileDescriptor fd;
    const pid_t pid;
    const string appGroupName;
    const string appLogFile;
    uid_t uid;
    gid_t gid;
    const StaticString channelName;
    mutable boost::mutex dataSyncher;
    string data;
    oxt::thread *thr;
    boost::function<void ()> endReachedCallback;
    bool stopped;

    void capture() {
        TRACE_POINT();
        while (!boost::this_thread::interruption_requested()) {
            char buf[1024 * 8];
            ssize_t ret;

            UPDATE_TRACE_POINT();
            ret = syscalls::read(fd, buf, sizeof(buf));
            int e = errno;
            boost::this_thread::disable_syscall_interruption dsi;
            if (ret == 0) {
                break;
            } else if (ret == -1) {
                if (e != EAGAIN && e != EWOULDBLOCK) {
                    P_WARN("Background I/O capturer error: " <<
                        strerror(e) << " (errno=" << e << ")");
                    break;
                }
            } else {
                {
                    boost::lock_guard<boost::mutex> l(dataSyncher);
                    data.append(buf, ret);
                }
                UPDATE_TRACE_POINT();
                if (ret == 1 && buf[0] == '\n') {
                    LoggingKit::logAppOutput(appGroupName, pid, channelName, "", 0, appLogFile, uid, gid);
                } else {
                    vector<StaticString> lines;
                    if (ret > 0 && buf[ret - 1] == '\n') {
                        ret--;
                    }
                    split(StaticString(buf, ret), '\n', lines);
                    foreach (const StaticString line, lines) {
                        LoggingKit::logAppOutput(appGroupName, pid, channelName, line.data(), line.size(), appLogFile, uid, gid);
                    }
                }
            }
        }

        {
            boost::lock_guard<boost::mutex> l(dataSyncher);
            stopped = true;
        }
        if (endReachedCallback) {
            endReachedCallback();
        }
    }

public:
    BackgroundIOCapturer(const FileDescriptor &_fd, pid_t _pid,
        const string &_appGroupName,
        const string &_appLogFile,
        uid_t _uid = 500,
        gid_t _gid = 500,
        const StaticString &_channelName = P_STATIC_STRING("output"),
        const StaticString &_data = StaticString())
        : fd(_fd),
          pid(_pid),
          appGroupName(_appGroupName),
          appLogFile(_appLogFile),
          uid(_uid),
          gid(_gid),
          channelName(_channelName),
          data(_data.data(), _data.size()),
          thr(NULL),
          stopped(false)
        { }

    ~BackgroundIOCapturer() {
        TRACE_POINT();
        if (thr != NULL) {
            boost::this_thread::disable_interruption di;
            boost::this_thread::disable_syscall_interruption dsi;
            thr->interrupt_and_join();
            delete thr;
            thr = NULL;
        }
    }

    const FileDescriptor &getFd() const {
        return fd;
    }

    void start() {
        assert(thr == NULL);
        thr = new oxt::thread(boost::bind(&BackgroundIOCapturer::capture, this),
            "Background I/O capturer", 64 * 1024);
    }

    void stop() {
        TRACE_POINT();
        if (thr != NULL) {
            boost::this_thread::disable_interruption di;
            boost::this_thread::disable_syscall_interruption dsi;
            thr->interrupt_and_join();
            delete thr;
            thr = NULL;
        }
    }

    void setEndReachedCallback(const boost::function<void ()> &callback) {
        endReachedCallback = callback;
    }

    void appendToBuffer(const StaticString &dataToAdd) {
        TRACE_POINT();
        boost::lock_guard<boost::mutex> l(dataSyncher);
        data.append(dataToAdd.data(), dataToAdd.size());
    }

    string getData() const {
        boost::lock_guard<boost::mutex> l(dataSyncher);
        return data;
    }

    bool isStopped() const {
        boost::lock_guard<boost::mutex> l(dataSyncher);
        return stopped;
    }
};

typedef boost::shared_ptr<BackgroundIOCapturer> BackgroundIOCapturerPtr;


} // namespace SpawningKit
} // namespace Passenger

#endif /* _PASSENGER_SPAWNING_KIT_BACKGROUND_IO_CAPTURER_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.0738 ]--