#pragma once #include #if USE_AWS_S3 #include namespace DB { class Context; /* s3(source, [access_key_id, secret_access_key,] format, structure) - creates a temporary storage for a file in S3 */ class TableFunctionS3 : public ITableFunction { public: static constexpr auto name = "s3"; std::string getName() const override { return name; } bool hasStaticStructure() const override { return true; } protected: StoragePtr executeImpl( const ASTPtr & ast_function, const Context & context, const std::string & table_name, ColumnsDescription cached_columns) const override; const char * getStorageTypeName() const override { return "S3"; } ColumnsDescription getActualTableStructure(const Context & context) const override; void parseArguments(const ASTPtr & ast_function, const Context & context) override; String filename; String format; String structure; String access_key_id; String secret_access_key; String compression_method = "auto"; }; class TableFunctionCOS : public TableFunctionS3 { public: static constexpr auto name = "cosn"; std::string getName() const override { return name; } private: const char * getStorageTypeName() const override { return "COSN"; } }; } #endif