// ftpd is a server implementation based on the following: // - RFC 959 (https://tools.ietf.org/html/rfc959) // - RFC 3659 (https://tools.ietf.org/html/rfc3659) // - suggested implementation details from https://cr.yp.to/ftp/filesystem.html // // Copyright (C) 2024 Michael Theall // // This program is free software: you can redistribute it and/or modify // it under the terms of the GNU General Public License as published by // the Free Software Foundation, either version 3 of the License, or // (at your option) any later version. // // This program is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the // GNU General Public License for more details. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . #pragma once #include "sockAddr.h" #if defined(__NDS__) #include #elif defined(__3DS__) #include <3ds.h> #elif defined(__SWITCH__) #include #elif defined(__WIIU__) #include #include #endif #include #include #include #include #include #if defined(CLASSIC) && !defined(__WIIU__) extern PrintConsole g_statusConsole; extern PrintConsole g_logConsole; extern PrintConsole g_sessionConsole; #endif namespace platform { /// \brief Initialize platform bool init (); #ifdef __SWITCH__ /// \brief Enable access point /// \param enable_ Whether to enable access point /// \param ssid_ SSID /// \param passphrase_ Passphrase bool enableAP (bool enable_, std::string const &ssid_, std::string const &passphrase_); /// \brief Check if SSID is valid /// \param ssid_ SSID to check /// \returns empty string on success, error message on failure char const *validateSSID (std::string const &ssid_); /// \brief Check if passphrase is valid /// \param passphrase_ Passphrase to check /// \returns empty string on success, error message on failure char const *validatePassphrase (std::string const &passphrase_); #endif /// \brief Whether network is visible bool networkVisible (); /// \brief Get network address /// \param[out] addr_ Network address bool networkAddress (SockAddr &addr_); /// \brief Get hostname std::string const &hostname (); /// \brief Platform loop bool loop (); /// \brief Platform render void render (); /// \brief Deinitialize platform void exit (); #ifdef __3DS__ /// \brief Steady clock struct steady_clock { /// \brief Type representing number of ticks using rep = std::uint64_t; /// \brief Type representing ratio of clock period in seconds using period = std::ratio<1, SYSCLOCK_ARM11>; /// \brief Duration type using duration = std::chrono::duration; /// \brief Timestamp type using time_point = std::chrono::time_point; /// \brief Whether clock is steady constexpr static bool is_steady = true; /// \brief Current timestamp static time_point now () noexcept; }; #else /// \brief Steady clock using steady_clock = std::chrono::steady_clock; #endif #ifndef __NDS__ /// \brief Platform thread class Thread { public: ~Thread (); Thread (); /// \brief Parameterized constructor /// \param func_ Thread entrypoint Thread (std::function &&func_); Thread (Thread const &that_) = delete; /// \brief Move constructor /// \param that_ Object to move from Thread (Thread &&that_); Thread &operator= (Thread const &that_) = delete; /// \brief Move assignment /// \param that_ Object to move from Thread &operator= (Thread &&that_); /// \brief Join thread void join (); /// \brief Suspend current thread /// \param timeout_ Minimum time to sleep static void sleep (std::chrono::milliseconds timeout_); private: class privateData_t; /// \brief pimpl std::unique_ptr m_d; }; /// \brief Platform mutex class Mutex { public: ~Mutex (); Mutex (); /// \brief Lock mutex void lock (); /// \brief Unlock mutex void unlock (); private: class privateData_t; /// \brief pimpl std::unique_ptr m_d; }; #endif }