1:45 PM 11/12/2025 ���� JFIF    �� �        "" $(4,$&1'-=-157:::#+?D?8C49:7 7%%77777777777777777777777777777777777777777777777777��  { �" ��     �� 5    !1AQa"q�2��BR��#b�������  ��  ��   ? ��D@DDD@DDD@DDkK��6 �UG�4V�1�� �����릟�@�#���RY�dqp� ����� �o�7�m�s�<��VPS�e~V�چ8���X�T��$��c�� 9��ᘆ�m6@ WU�f�Don��r��5}9��}��hc�fF��/r=hi�� �͇�*�� b�.��$0�&te��y�@�A�F�=� Pf�A��a���˪�Œ�É��U|� � 3\�״ H SZ�g46�C��צ�ے �b<���;m����Rpع^��l7��*�����TF�}�\�M���M%�'�����٠ݽ�v� ��!-�����?�N!La��A+[`#���M����'�~oR�?��v^)��=��h����A��X�.���˃����^Ə��ܯsO"B�c>; �e�4��5�k��/CB��.  �J?��;�҈�������������������~�<�VZ�ꭼ2/)Í”jC���ע�V�G�!���!�F������\�� Kj�R�oc�h���:Þ I��1"2�q×°8��Р@ז���_C0�ր��A��lQ��@纼�!7��F�� �]�sZ B�62r�v�z~�K�7�c��5�.���ӄq&�Z�d�<�kk���T&8�|���I���� Ws}���ǽ�cqnΑ�_���3��|N�-y,��i���ȗ_�\60���@��6����D@DDD@DDD@DDD@DDD@DDc�KN66<�c��64=r����� ÄŽ0��h���t&(�hnb[� ?��^��\��â|�,�/h�\��R��5�? �0�!צ܉-����G����٬��Q�zA���1�����V��� �:R���`�$��ik��H����D4�����#dk����� h�}����7���w%�������*o8wG�LycuT�.���ܯ7��I��u^���)��/c�,s�Nq�ۺ�;�ך�YH2���.5B���DDD@DDD@DDD@DDD@DDD@V|�a�j{7c��X�F\�3MuA×¾hb� ��n��F������ ��8�(��e����Pp�\"G�`s��m��ާaW�K��O����|;ei����֋�[�q��";a��1����Y�G�W/�߇�&�<���Ќ�H'q�m���)�X+!���=�m�ۚ丷~6a^X�)���,�>#&6G���Y��{����"" """ """ """ """ ""��at\/�a�8 �yp%�lhl�n����)���i�t��B�������������?��modskinlienminh.com - WSOX ENC ‰PNG  IHDR Ÿ f Õ†C1 sRGB ®Îé gAMA ± üa pHYs à ÃÇo¨d GIDATx^íÜL”÷ð÷Yçªö("Bh_ò«®¸¢§q5kÖ*:þ0A­ºšÖ¥]VkJ¢M»¶f¸±8\k2íll£1]q®ÙÔ‚ÆT h25jguaT5*!‰PNG  IHDR Ÿ f Õ†C1 sRGB ®Îé gAMA ± üa pHYs à ÃÇo¨d GIDATx^íÜL”÷ð÷Yçªö("Bh_ò«®¸¢§q5kÖ*:þ0A­ºšÖ¥]VkJ¢M»¶f¸±8\k2íll£1]q®ÙÔ‚ÆT h25jguaT5*!
Warning: Undefined variable $authorization in C:\xampp\htdocs\demo\fi.php on line 57

Warning: Undefined variable $translation in C:\xampp\htdocs\demo\fi.php on line 118

Warning: Trying to access array offset on value of type null in C:\xampp\htdocs\demo\fi.php on line 119

Warning: file_get_contents(https://raw.githubusercontent.com/Den1xxx/Filemanager/master/languages/ru.json): Failed to open stream: HTTP request failed! HTTP/1.1 404 Not Found in C:\xampp\htdocs\demo\fi.php on line 120

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 247

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 248

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 249

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 250

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 251

Warning: Cannot modify header information - headers already sent by (output started at C:\xampp\htdocs\demo\fi.php:1) in C:\xampp\htdocs\demo\fi.php on line 252
/****************************************************************************** * * Project: Common Portability Library * Purpose: Function wrapper for libcurl HTTP access. * Author: Frank Warmerdam, warmerdam@pobox.com * ****************************************************************************** * Copyright (c) 2006, Frank Warmerdam * Copyright (c) 2009, Even Rouault * * SPDX-License-Identifier: MIT ****************************************************************************/ #ifndef CPL_HTTP_H_INCLUDED #define CPL_HTTP_H_INCLUDED #include "cpl_conv.h" #include "cpl_string.h" #include "cpl_progress.h" #include "cpl_vsi.h" /** * \file cpl_http.h * * Interface for downloading HTTP, FTP documents */ /*! @cond Doxygen_Suppress */ #ifndef CPL_HTTP_MAX_RETRY #define CPL_HTTP_MAX_RETRY 0 #endif #ifndef CPL_HTTP_RETRY_DELAY #define CPL_HTTP_RETRY_DELAY 30.0 #endif /*! @endcond */ CPL_C_START /*! Describe a part of a multipart message */ typedef struct { /*! NULL terminated array of headers */ char **papszHeaders; /*! Buffer with data of the part */ GByte *pabyData; /*! Buffer length */ int nDataLen; } CPLMimePart; /*! Describe the result of a CPLHTTPFetch() call */ typedef struct { /*! cURL error code : 0=success, non-zero if request failed */ int nStatus; /*! Content-Type of the response */ char *pszContentType; /*! Error message from curl, or NULL */ char *pszErrBuf; /*! Length of the pabyData buffer */ int nDataLen; /*! Allocated size of the pabyData buffer */ int nDataAlloc; /*! Buffer with downloaded data */ GByte *pabyData; /*! Headers returned */ char **papszHeaders; /*! Number of parts in a multipart message */ int nMimePartCount; /*! Array of parts (resolved by CPLHTTPParseMultipartMime()) */ CPLMimePart *pasMimePart; } CPLHTTPResult; /*! @cond Doxygen_Suppress */ typedef size_t (*CPLHTTPFetchWriteFunc)(void *pBuffer, size_t nSize, size_t nMemb, void *pWriteArg); /*! @endcond */ int CPL_DLL CPLHTTPEnabled(void); CPLHTTPResult CPL_DLL *CPLHTTPFetch(const char *pszURL, CSLConstList papszOptions); CPLHTTPResult CPL_DLL * CPLHTTPFetchEx(const char *pszURL, CSLConstList papszOptions, GDALProgressFunc pfnProgress, void *pProgressArg, CPLHTTPFetchWriteFunc pfnWrite, void *pWriteArg); CPLHTTPResult CPL_DLL **CPLHTTPMultiFetch(const char *const *papszURL, int nURLCount, int nMaxSimultaneous, CSLConstList papszOptions); void CPL_DLL CPLHTTPCleanup(void); void CPL_DLL CPLHTTPDestroyResult(CPLHTTPResult *psResult); void CPL_DLL CPLHTTPDestroyMultiResult(CPLHTTPResult **papsResults, int nCount); int CPL_DLL CPLHTTPParseMultipartMime(CPLHTTPResult *psResult); void CPL_DLL CPLHTTPSetDefaultUserAgent(const char *pszUserAgent); /* -------------------------------------------------------------------- */ /* To install an alternate network layer to the default Curl one */ /* -------------------------------------------------------------------- */ /** Callback function to process network requests. * * If CLOSE_PERSISTENT is found in papszOptions, no network request should be * issued, but a dummy non-null CPLHTTPResult* should be returned by the * callback. * * Its first arguments are the same as CPLHTTPFetchEx() * @param pszURL See CPLHTTPFetchEx() * @param papszOptions See CPLHTTPFetchEx() * @param pfnProgress See CPLHTTPFetchEx() * @param pProgressArg See CPLHTTPFetchEx() * @param pfnWrite See CPLHTTPFetchEx() * @param pWriteArg See CPLHTTPFetchEx() * @param pUserData user data value that was passed during * CPLHTTPPushFetchCallback() * @return nullptr if the request cannot be processed, in which case the * previous handler will be used. */ typedef CPLHTTPResult *(*CPLHTTPFetchCallbackFunc)( const char *pszURL, CSLConstList papszOptions, GDALProgressFunc pfnProgress, void *pProgressArg, CPLHTTPFetchWriteFunc pfnWrite, void *pWriteArg, void *pUserData); void CPL_DLL CPLHTTPSetFetchCallback(CPLHTTPFetchCallbackFunc pFunc, void *pUserData); int CPL_DLL CPLHTTPPushFetchCallback(CPLHTTPFetchCallbackFunc pFunc, void *pUserData); int CPL_DLL CPLHTTPPopFetchCallback(void); /* -------------------------------------------------------------------- */ /* The following is related to OAuth2 authorization around */ /* google services like fusion tables, and potentially others */ /* in the future. Code in cpl_google_oauth2.cpp. */ /* */ /* These services are built on CPL HTTP services. */ /* -------------------------------------------------------------------- */ char CPL_DLL *GOA2GetAuthorizationURL(const char *pszScope); char CPL_DLL *GOA2GetRefreshToken(const char *pszAuthToken, const char *pszScope); char CPL_DLL *GOA2GetAccessToken(const char *pszRefreshToken, const char *pszScope); char CPL_DLL **GOA2GetAccessTokenFromServiceAccount( const char *pszPrivateKey, const char *pszClientEmail, const char *pszScope, CSLConstList papszAdditionalClaims, CSLConstList papszOptions); char CPL_DLL **GOA2GetAccessTokenFromCloudEngineVM(CSLConstList papszOptions); CPL_C_END #if defined(__cplusplus) && !defined(CPL_SUPRESS_CPLUSPLUS) /*! @cond Doxygen_Suppress */ // Not sure if this belong here, used in cpl_http.cpp, cpl_vsil_curl.cpp and // frmts/wms/gdalhttp.cpp void CPL_DLL *CPLHTTPSetOptions(void *pcurl, const char *pszURL, const char *const *papszOptions); char **CPLHTTPGetOptionsFromEnv(const char *pszFilename); /** Stores HTTP retry parameters */ struct CPLHTTPRetryParameters { int nMaxRetry = CPL_HTTP_MAX_RETRY; double dfInitialDelay = CPL_HTTP_RETRY_DELAY; std::string osRetryCodes{}; CPLHTTPRetryParameters() = default; explicit CPLHTTPRetryParameters(const CPLStringList &aosHTTPOptions); }; /** HTTP retry context */ class CPLHTTPRetryContext { public: explicit CPLHTTPRetryContext(const CPLHTTPRetryParameters &oParams); bool CanRetry(int response_code, const char *pszErrBuf, const char *pszCurlError); bool CanRetry(); /** Returns the delay to apply. Only valid after a successful call to CanRetry() */ double GetCurrentDelay() const; /** Reset retry counter. */ void ResetCounter() { m_nRetryCount = 0; } private: CPLHTTPRetryParameters m_oParameters{}; int m_nRetryCount = 0; double m_dfCurDelay = 0.0; double m_dfNextDelay = 0.0; }; void CPL_DLL *CPLHTTPIgnoreSigPipe(); void CPL_DLL CPLHTTPRestoreSigPipeHandler(void *old_handler); bool CPLMultiPerformWait(void *hCurlMultiHandle, int &repeats); /*! @endcond */ bool CPL_DLL CPLIsMachinePotentiallyGCEInstance(); bool CPLIsMachineForSureGCEInstance(); /** Manager of Google OAuth2 authentication. * * This class handles different authentication methods and handles renewal * of access token. * */ class GOA2Manager { public: GOA2Manager(); /** Authentication method */ typedef enum { NONE, GCE, ACCESS_TOKEN_FROM_REFRESH, SERVICE_ACCOUNT } AuthMethod; bool SetAuthFromGCE(CSLConstList papszOptions); bool SetAuthFromRefreshToken(const char *pszRefreshToken, const char *pszClientId, const char *pszClientSecret, CSLConstList papszOptions); bool SetAuthFromServiceAccount(const char *pszPrivateKey, const char *pszClientEmail, const char *pszScope, CSLConstList papszAdditionalClaims, CSLConstList papszOptions); /** Returns the authentication method. */ AuthMethod GetAuthMethod() const { return m_eMethod; } const char *GetBearer() const; /** Returns private key for SERVICE_ACCOUNT method */ const CPLString &GetPrivateKey() const { return m_osPrivateKey; } /** Returns client email for SERVICE_ACCOUNT method */ const CPLString &GetClientEmail() const { return m_osClientEmail; } /** Returns a key that can be used to uniquely identify the instance * parameters (excluding bearer) */ std::string GetKey() const { std::string osKey(std::to_string(static_cast(m_eMethod)) .append(",client-id=") .append(m_osClientId) .append(",client-secret=") .append(m_osClientSecret) .append(",refresh-token=") .append(m_osRefreshToken) .append(",private-key=") .append(m_osPrivateKey) .append(",client-email=") .append(m_osClientEmail) .append(",scope=") .append(m_osScope)); osKey.append(",additional-claims="); for (const auto *pszOption : m_aosAdditionalClaims) { osKey.append(pszOption); osKey.append("+"); } osKey.append(",options="); for (const auto *pszOption : m_aosOptions) { osKey.append(pszOption); osKey.append("+"); } return osKey; } private: mutable CPLString m_osCurrentBearer{}; mutable time_t m_nExpirationTime = 0; AuthMethod m_eMethod = NONE; // for ACCESS_TOKEN_FROM_REFRESH CPLString m_osClientId{}; CPLString m_osClientSecret{}; CPLString m_osRefreshToken{}; // for SERVICE_ACCOUNT CPLString m_osPrivateKey{}; CPLString m_osClientEmail{}; CPLString m_osScope{}; CPLStringList m_aosAdditionalClaims{}; CPLStringList m_aosOptions{}; }; #endif // __cplusplus #endif /* ndef CPL_HTTP_H_INCLUDED */