HEX
Server: LiteSpeed
System: Linux php-prod-3.spaceapp.ru 5.15.0-151-generic #161-Ubuntu SMP Tue Jul 22 14:25:40 UTC 2025 x86_64
User: sarli3128 (1010)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /home/marketing.cfbon.ru/public_html/vendor/google/auth/src/Logging/RpcLogEvent.php
<?php
/**
 * Copyright 2024 Google Inc. All Rights Reserved.
 *
 * Licensed under the Apache License, Version 2.0 (the "License");
 * you may not use this file except in compliance with the License.
 * You may obtain a copy of the License at
 *
 *      http://www.apache.org/licenses/LICENSE-2.0
 *
 * Unless required by applicable law or agreed to in writing, software
 * distributed under the License is distributed on an "AS IS" BASIS,
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 * See the License for the specific language governing permissions and
 * limitations under the License.
 */

namespace Google\Auth\Logging;

/**
 * A class that contains all the required information for logging.
 *
 * @internal
 */
class RpcLogEvent
{
    /**
     * Timestamp in format RFC3339 representing when this event ocurred
     *
     * @var string
     */
    public string $timestamp;

    /**
     * The time in milliseconds at time on creation for calculating latency
     *
     * @var float
     */
    public float $milliseconds;

    /**
     * Rest method type
     *
     * @var null|string
     */
    public null|string $method = null;

    /**
     * URL representing the rest URL endpoint
     *
     * @var null|string
     */
    public null|string $url = null;

    /**
     * An array that contains the headers for the response or request
     *
     * @var null|array<mixed>
     */
    public null|array $headers = null;

    /**
     * An array representation of JSON for the response or request
     *
     * @var null|string
     */
    public null|string $payload = null;

    /**
     * Status code for REST or gRPC methods
     *
     * @var null|int|string
     */
    public null|int|string $status = null;

    /**
     * The latency in milliseconds
     *
     * @var null|int
     */
    public null|int $latency = null;

    /**
     * The retry attempt number
     *
     * @var null|int
     */
    public null|int $retryAttempt = null;

    /**
     * The name of the gRPC method being called
     *
     * @var null|string
     */
    public null|string $rpcName = null;

    /**
     * The Service Name of the gRPC
     *
     * @var null|string $serviceName
     */
    public null|string $serviceName = null;

    /**
     * The Process ID for tracing logs
     *
     * @var null|int $processId
     */
    public null|int $processId = null;

    /**
     * The Request id for tracing logs
     *
     * @var null|int $requestId;
     */
    public null|int $requestId = null;

    /**
     * Creates an object with all the fields required for logging
     * Passing a string representation of a timestamp calculates the difference between
     * these two times and sets the latency field with the result.
     *
     * @param null|float $startTime (Optional) Parameter to calculate the latency
     */
    public function __construct(null|float $startTime = null)
    {
        $this->timestamp = date(DATE_RFC3339);

        // Takes the micro time and convets it to millis
        $this->milliseconds = round(microtime(true) * 1000);

        if ($startTime) {
            $this->latency = (int) round($this->milliseconds - $startTime);
        }
    }
}