-
Notifications
You must be signed in to change notification settings - Fork 30
/
Copy pathparquet_s3_fdw.h
87 lines (78 loc) · 3.5 KB
/
parquet_s3_fdw.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/*-------------------------------------------------------------------------
*
* parquet_s3_fdw.h
* Header file to modify for S3 access for parquet_s3_fdw
*
* Portions Copyright (c) 2020, TOSHIBA CORPORATION
* Portions Copyright (c) 2018-2019, adjust GmbH
*
* IDENTIFICATION
* contrib/parquet_s3_fdw/parquet_s3_fdw.h
*
*-------------------------------------------------------------------------
*/
#ifndef __PARQUET_S3_FDW_H__
#define __PARQUET_S3_FDW_H__
#include "commands/defrem.h"
#define parquetGetForeignRelSize parquetS3GetForeignRelSize
#define parquetGetForeignPaths parquetS3GetForeignPaths
#define parquetGetForeignPlan parquetS3GetForeignPlan
#define parquetIterateForeignScan parquetS3IterateForeignScan
#define parquetBeginForeignScan parquetS3BeginForeignScan
#define parquetEndForeignScan parquetS3EndForeignScan
#define parquetReScanForeignScan parquetS3ReScanForeignScan
#define parquetAcquireSampleRowsFunc parquetS3AcquireSampleRowsFunc
#define parquetAnalyzeForeignTable parquetS3AnalyzeForeignTable
#define parquetExplainForeignScan parquetS3ExplainForeignScan
#define parquetIsForeignScanParallelSafe parquetS3IsForeignScanParallelSafe
#define parquetEstimateDSMForeignScan parquetS3EstimateDSMForeignScan
#define parquetInitializeDSMForeignScan parquetS3InitializeDSMForeignScan
#define parquetReInitializeDSMForeignScan parquetS3ReInitializeDSMForeignScan
#define parquetInitializeWorkerForeignScan parquetS3InitializeWorkerForeignScan
#define parquetShutdownForeignScan parquetS3ShutdownForeignScan
#define parquetImportForeignSchema parquetS3ImportForeignSchema
#define parquetAddForeignUpdateTargets parquetS3AddForeignUpdateTargets
#define parquetPlanForeignModify parquetS3PlanForeignModify
#define parquetBeginForeignModify parquetS3BeginForeignModify
#define parquetExecForeignUpdate parquetS3ExecForeignUpdate
#define parquetExecForeignInsert parquetS3ExecForeignInsert
#define parquetExecForeignDelete parquetS3ExecForeignDelete
#define parquetEndForeignModify parquetS3EndForeignModify
#define parquet_fdw_validator_impl parquet_s3_fdw_validator_impl
#define parquet_fdw_use_threads parquet_s3_fdw_use_threads
#define SingleFileExecutionState SingleFileExecutionStateS3
#define CODE_VERSION 10101
/* Structure to store option information. */
typedef struct parquet_s3_server_opt
{
bool use_minio; /* Connect to MinIO instead of Amazon S3. */
bool keep_connections; /* setting value of keep_connections
* server option */
char *region; /* AWS region to connect to */
char *endpoint; /* Address and port to connect to */
} parquet_s3_server_opt;
bool parquet_s3_is_valid_server_option(DefElem *def);
parquet_s3_server_opt *parquet_s3_get_options(Oid foreignoid, Oid userid);
parquet_s3_server_opt *parquet_s3_get_server_options(Oid serverid);
extern
#if (PG_VERSION_NUM >=160000)
PGDLLEXPORT
#endif
int ExecForeignDDL(Oid serverOid,
Relation rel,
int operation,
bool if_not_exists);
/* Option name for CREATE FOREIGN SERVER. */
#define SERVER_OPTION_USE_MINIO "use_minio"
#define SERVER_OPTION_KEEP_CONNECTIONS "keep_connections"
#define SERVER_OPTION_REGION "region"
#define SERVER_OPTION_ENDPOINT "endpoint"
/* Option name for key */
#define ATTRIBUTE_OPTION_KEY "key"
/* Option name for column mapping */
#define ATTRIBUTE_OPTION_COLUMN_NAME "column_name"
/* Parquet compression types */
#define PARQUET_NO_COMPRESSION "UNCOMPRESSED"
#define PARQUET_COMPRESSION_SNAPPY "SNAPPY"
#define PARQUET_COMPRESSION_ZSTD "ZSTD"
#endif /* __PARQUET_S3_FDW_H__ */