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


Viewing file:     BufferBody.cpp (5.24 KB)      -rw-r--r--
Select action/file-type:
(+) | (+) | (+) | Code (+) | Session (+) | (+) | SDB (+) | (+) | (+) | (+) | (+) | (+) |
/*
 *  Phusion Passenger - https://www.phusionpassenger.com/
 *  Copyright (c) 2011-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.
 */
#include <Core/Controller.h>

/*************************************************************************
 *
 * Implements Core::Controller methods pertaining buffering the request
 * body.
 *
 *************************************************************************/

namespace Passenger {
namespace Core {

using namespace std;
using namespace boost;


/****************************
 *
 * Private methods
 *
 ****************************/


void
Controller::beginBufferingBody(Client *client, Request *req) {
    TRACE_POINT();
    req->state = Request::BUFFERING_REQUEST_BODY;
    req->bodyChannel.start();
    req->bodyBuffer.reinitialize();
    req->bodyBuffer.stop();
}

/**
 * Relevant when our body data source (bodyChannel) was throttled (by whenBufferingBody_onRequestBody).
 * Called when our data sink (bodyBuffer) in-memory part is drained and ready for more data.
 */
void
Controller::_bodyBufferFlushed(FileBufferedChannel *channel) {
    Request *req = static_cast<Request *>(static_cast<
        ServerKit::BaseHttpRequest *>(channel->getHooks()->userData));

    req->bodyBuffer.clearBuffersFlushedCallback();
    req->bodyChannel.start();
}

/**
 * Receives data (buffer) originating from the bodyChannel, to be passed on to the bodyBuffer.
 * Backpressure is applied when the bodyBuffer in-memory part exceeds a threshold.
 */
ServerKit::Channel::Result
Controller::whenBufferingBody_onRequestBody(Client *client, Request *req,
    const MemoryKit::mbuf &buffer, int errcode)
{
    TRACE_POINT();

    if (buffer.size() > 0) {
        // Data
        req->bodyBytesBuffered += buffer.size();
        SKC_TRACE(client, 3, "Buffering " << buffer.size() <<
            " bytes of client request body: \"" <<
            cEscapeString(StaticString(buffer.start, buffer.size())) <<
            "\"; " << req->bodyBytesBuffered << " bytes buffered so far");
        req->bodyBuffer.feed(buffer);

        if (req->bodyBuffer.passedThreshold()) {
            // Apply backpressure..
            req->bodyChannel.stop();
            // ..until the in-memory part of our bodyBuffer is drained.
            assert(req->bodyBuffer.getBuffersFlushedCallback() == NULL);
            req->bodyBuffer.setBuffersFlushedCallback(_bodyBufferFlushed);
        }

        return Channel::Result(buffer.size(), false);
    } else if (errcode == 0 || errcode == ECONNRESET) {
        // EOF
        SKC_TRACE(client, 2, "End of request body encountered");
        req->bodyBuffer.feed(MemoryKit::mbuf());
        if (req->bodyType == Request::RBT_CHUNKED) {
            // The data that we've stored in the body buffer is dechunked, so when forwarding
            // the buffered body to the app we must advertise it as being a fixed-length,
            // non-chunked body.
            const unsigned int UINT64_STRSIZE = sizeof("18446744073709551615");
            SKC_TRACE(client, 2, "Adjusting forwarding headers as fixed-length, non-chunked");
            ServerKit::Header *header = (ServerKit::Header *)
                psg_palloc(req->pool, sizeof(ServerKit::Header));
            char *contentLength = (char *) psg_pnalloc(req->pool, UINT64_STRSIZE);
            unsigned int size = integerToOtherBase<boost::uint64_t, 10>(
                req->bodyBytesBuffered, contentLength, UINT64_STRSIZE);

            psg_lstr_init(&header->key);
            psg_lstr_append(&header->key, req->pool, "content-length",
                sizeof("content-length") - 1);
            psg_lstr_init(&header->origKey);
            psg_lstr_append(&header->origKey, req->pool, "Content-Length",
                sizeof("Content-Length") - 1);
            psg_lstr_init(&header->val);
            psg_lstr_append(&header->val, req->pool, contentLength, size);

            header->hash = HashedStaticString("content-length",
                sizeof("content-length") - 1).hash();

            req->headers.erase(HTTP_TRANSFER_ENCODING);
            req->headers.insert(&header, req->pool);
        }
        checkoutSession(client, req);
        return Channel::Result(0, true);
    } else {
        const unsigned int BUFSIZE = 1024;
        char *message = (char *) psg_pnalloc(req->pool, BUFSIZE);
        int size = snprintf(message, BUFSIZE,
            "error reading request body: %s (errno=%d)",
            ServerKit::getErrorDesc(errcode), errcode);
        disconnectWithError(&client, StaticString(message, size));
        return Channel::Result(0, true);
    }
}


} // namespace Core
} // namespace Passenger

:: 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.0111 ]--