|
37 | 37 | @Data |
38 | 38 | public class BaseFileSinkConfig implements DelimiterConfig, Serializable { |
39 | 39 | private static final long serialVersionUID = 1L; |
40 | | - protected CompressFormat compressFormat = BaseSinkConfig.COMPRESS_CODEC.defaultValue(); |
41 | | - protected String fieldDelimiter = BaseSinkConfig.FIELD_DELIMITER.defaultValue(); |
42 | | - protected String rowDelimiter = BaseSinkConfig.ROW_DELIMITER.defaultValue(); |
43 | | - protected int batchSize = BaseSinkConfig.BATCH_SIZE.defaultValue(); |
| 40 | + protected CompressFormat compressFormat = FileBaseSinkOptions.COMPRESS_CODEC.defaultValue(); |
| 41 | + protected String fieldDelimiter = FileBaseSinkOptions.FIELD_DELIMITER.defaultValue(); |
| 42 | + protected String rowDelimiter = FileBaseSinkOptions.ROW_DELIMITER.defaultValue(); |
| 43 | + protected int batchSize = FileBaseSinkOptions.BATCH_SIZE.defaultValue(); |
44 | 44 | protected String path; |
45 | | - protected String fileNameExpression = BaseSinkConfig.FILE_NAME_EXPRESSION.defaultValue(); |
46 | | - protected boolean singleFileMode = BaseSinkConfig.SINGLE_FILE_MODE.defaultValue(); |
| 45 | + protected String fileNameExpression = FileBaseSinkOptions.FILE_NAME_EXPRESSION.defaultValue(); |
| 46 | + protected boolean singleFileMode = FileBaseSinkOptions.SINGLE_FILE_MODE.defaultValue(); |
47 | 47 | protected boolean createEmptyFileWhenNoData = |
48 | | - BaseSinkConfig.CREATE_EMPTY_FILE_WHEN_NO_DATA.defaultValue(); |
| 48 | + FileBaseSinkOptions.CREATE_EMPTY_FILE_WHEN_NO_DATA.defaultValue(); |
49 | 49 | protected FileFormat fileFormat; |
50 | | - protected String filenameExtension = BaseSinkConfig.FILENAME_EXTENSION.defaultValue(); |
| 50 | + protected String filenameExtension = FileBaseSinkOptions.FILENAME_EXTENSION.defaultValue(); |
51 | 51 | protected DateUtils.Formatter dateFormat = DateUtils.Formatter.YYYY_MM_DD; |
52 | 52 | protected DateTimeUtils.Formatter datetimeFormat = DateTimeUtils.Formatter.YYYY_MM_DD_HH_MM_SS; |
53 | 53 | protected TimeUtils.Formatter timeFormat = TimeUtils.Formatter.HH_MM_SS; |
54 | 54 | protected Boolean enableHeaderWriter = false; |
55 | 55 |
|
56 | 56 | public BaseFileSinkConfig(@NonNull Config config) { |
57 | | - if (config.hasPath(BaseSinkConfig.COMPRESS_CODEC.key())) { |
58 | | - String compressCodec = config.getString(BaseSinkConfig.COMPRESS_CODEC.key()); |
| 57 | + if (config.hasPath(FileBaseSinkOptions.COMPRESS_CODEC.key())) { |
| 58 | + String compressCodec = config.getString(FileBaseSinkOptions.COMPRESS_CODEC.key()); |
59 | 59 | this.compressFormat = CompressFormat.valueOf(compressCodec.toUpperCase()); |
60 | 60 | } |
61 | | - if (config.hasPath(BaseSinkConfig.BATCH_SIZE.key())) { |
62 | | - this.batchSize = config.getInt(BaseSinkConfig.BATCH_SIZE.key()); |
| 61 | + if (config.hasPath(FileBaseSinkOptions.BATCH_SIZE.key())) { |
| 62 | + this.batchSize = config.getInt(FileBaseSinkOptions.BATCH_SIZE.key()); |
63 | 63 | } |
64 | | - if (config.hasPath(BaseSinkConfig.FIELD_DELIMITER.key()) |
65 | | - && StringUtils.isNotEmpty(config.getString(BaseSinkConfig.FIELD_DELIMITER.key()))) { |
66 | | - this.fieldDelimiter = config.getString(BaseSinkConfig.FIELD_DELIMITER.key()); |
| 64 | + if (config.hasPath(FileBaseSinkOptions.FIELD_DELIMITER.key()) |
| 65 | + && StringUtils.isNotEmpty( |
| 66 | + config.getString(FileBaseSinkOptions.FIELD_DELIMITER.key()))) { |
| 67 | + this.fieldDelimiter = config.getString(FileBaseSinkOptions.FIELD_DELIMITER.key()); |
67 | 68 | } |
68 | 69 |
|
69 | | - if (config.hasPath(BaseSinkConfig.ROW_DELIMITER.key())) { |
70 | | - this.rowDelimiter = config.getString(BaseSinkConfig.ROW_DELIMITER.key()); |
| 70 | + if (config.hasPath(FileBaseSinkOptions.ROW_DELIMITER.key())) { |
| 71 | + this.rowDelimiter = config.getString(FileBaseSinkOptions.ROW_DELIMITER.key()); |
71 | 72 | } |
72 | 73 |
|
73 | | - if (config.hasPath(BaseSinkConfig.FILE_PATH.key()) |
74 | | - && !StringUtils.isBlank(config.getString(BaseSinkConfig.FILE_PATH.key()))) { |
75 | | - this.path = config.getString(BaseSinkConfig.FILE_PATH.key()); |
| 74 | + if (config.hasPath(FileBaseSinkOptions.FILE_PATH.key()) |
| 75 | + && !StringUtils.isBlank(config.getString(FileBaseSinkOptions.FILE_PATH.key()))) { |
| 76 | + this.path = config.getString(FileBaseSinkOptions.FILE_PATH.key()); |
76 | 77 | } |
77 | 78 | checkNotNull(path); |
78 | 79 |
|
79 | 80 | if (path.equals(File.separator)) { |
80 | 81 | this.path = ""; |
81 | 82 | } |
82 | 83 |
|
83 | | - if (config.hasPath(BaseSinkConfig.FILE_NAME_EXPRESSION.key()) |
| 84 | + if (config.hasPath(FileBaseSinkOptions.FILE_NAME_EXPRESSION.key()) |
84 | 85 | && !StringUtils.isBlank( |
85 | | - config.getString(BaseSinkConfig.FILE_NAME_EXPRESSION.key()))) { |
86 | | - this.fileNameExpression = config.getString(BaseSinkConfig.FILE_NAME_EXPRESSION.key()); |
| 86 | + config.getString(FileBaseSinkOptions.FILE_NAME_EXPRESSION.key()))) { |
| 87 | + this.fileNameExpression = |
| 88 | + config.getString(FileBaseSinkOptions.FILE_NAME_EXPRESSION.key()); |
87 | 89 | } |
88 | 90 |
|
89 | | - if (config.hasPath(BaseSinkConfig.SINGLE_FILE_MODE.key())) { |
90 | | - this.singleFileMode = config.getBoolean(BaseSinkConfig.SINGLE_FILE_MODE.key()); |
| 91 | + if (config.hasPath(FileBaseSinkOptions.SINGLE_FILE_MODE.key())) { |
| 92 | + this.singleFileMode = config.getBoolean(FileBaseSinkOptions.SINGLE_FILE_MODE.key()); |
91 | 93 | } |
92 | 94 |
|
93 | | - if (config.hasPath(BaseSinkConfig.CREATE_EMPTY_FILE_WHEN_NO_DATA.key())) { |
| 95 | + if (config.hasPath(FileBaseSinkOptions.CREATE_EMPTY_FILE_WHEN_NO_DATA.key())) { |
94 | 96 | this.createEmptyFileWhenNoData = |
95 | | - config.getBoolean(BaseSinkConfig.CREATE_EMPTY_FILE_WHEN_NO_DATA.key()); |
| 97 | + config.getBoolean(FileBaseSinkOptions.CREATE_EMPTY_FILE_WHEN_NO_DATA.key()); |
96 | 98 | } |
97 | 99 |
|
98 | | - if (config.hasPath(BaseSinkConfig.FILE_FORMAT_TYPE.key()) |
99 | | - && !StringUtils.isBlank(config.getString(BaseSinkConfig.FILE_FORMAT_TYPE.key()))) { |
| 100 | + if (config.hasPath(FileBaseSinkOptions.FILE_FORMAT_TYPE.key()) |
| 101 | + && !StringUtils.isBlank( |
| 102 | + config.getString(FileBaseSinkOptions.FILE_FORMAT_TYPE.key()))) { |
100 | 103 | this.fileFormat = |
101 | 104 | FileFormat.valueOf( |
102 | | - config.getString(BaseSinkConfig.FILE_FORMAT_TYPE.key()) |
| 105 | + config.getString(FileBaseSinkOptions.FILE_FORMAT_TYPE.key()) |
103 | 106 | .toUpperCase(Locale.ROOT)); |
104 | 107 | } else { |
105 | 108 | // fall back to the default |
106 | | - this.fileFormat = BaseSinkConfig.FILE_FORMAT_TYPE.defaultValue(); |
| 109 | + this.fileFormat = FileBaseSinkOptions.FILE_FORMAT_TYPE.defaultValue(); |
107 | 110 | } |
108 | 111 |
|
109 | | - if (config.hasPath(BaseSinkConfig.FILENAME_EXTENSION.key()) |
| 112 | + if (config.hasPath(FileBaseSinkOptions.FILENAME_EXTENSION.key()) |
110 | 113 | && !StringUtils.isBlank( |
111 | | - config.getString(BaseSinkConfig.FILENAME_EXTENSION.key()))) { |
112 | | - this.filenameExtension = config.getString(BaseSinkConfig.FILENAME_EXTENSION.key()); |
| 114 | + config.getString(FileBaseSinkOptions.FILENAME_EXTENSION.key()))) { |
| 115 | + this.filenameExtension = config.getString(FileBaseSinkOptions.FILENAME_EXTENSION.key()); |
113 | 116 | } |
114 | 117 |
|
115 | | - if (config.hasPath(BaseSinkConfig.DATE_FORMAT.key())) { |
| 118 | + if (config.hasPath(FileBaseSinkOptions.DATE_FORMAT.key())) { |
116 | 119 | dateFormat = |
117 | | - DateUtils.Formatter.parse(config.getString(BaseSinkConfig.DATE_FORMAT.key())); |
| 120 | + DateUtils.Formatter.parse( |
| 121 | + config.getString(FileBaseSinkOptions.DATE_FORMAT.key())); |
118 | 122 | } |
119 | 123 |
|
120 | | - if (config.hasPath(BaseSinkConfig.DATETIME_FORMAT.key())) { |
| 124 | + if (config.hasPath(FileBaseSinkOptions.DATETIME_FORMAT.key())) { |
121 | 125 | datetimeFormat = |
122 | 126 | DateTimeUtils.Formatter.parse( |
123 | | - config.getString(BaseSinkConfig.DATETIME_FORMAT.key())); |
| 127 | + config.getString(FileBaseSinkOptions.DATETIME_FORMAT.key())); |
124 | 128 | } |
125 | 129 |
|
126 | | - if (config.hasPath(BaseSinkConfig.TIME_FORMAT.key())) { |
| 130 | + if (config.hasPath(FileBaseSinkOptions.TIME_FORMAT.key())) { |
127 | 131 | timeFormat = |
128 | | - TimeUtils.Formatter.parse(config.getString(BaseSinkConfig.TIME_FORMAT.key())); |
| 132 | + TimeUtils.Formatter.parse( |
| 133 | + config.getString(FileBaseSinkOptions.TIME_FORMAT.key())); |
129 | 134 | } |
130 | 135 |
|
131 | | - if (config.hasPath(BaseSinkConfig.ENABLE_HEADER_WRITE.key())) { |
132 | | - enableHeaderWriter = config.getBoolean(BaseSinkConfig.ENABLE_HEADER_WRITE.key()); |
| 136 | + if (config.hasPath(FileBaseSinkOptions.ENABLE_HEADER_WRITE.key())) { |
| 137 | + enableHeaderWriter = config.getBoolean(FileBaseSinkOptions.ENABLE_HEADER_WRITE.key()); |
133 | 138 | } |
134 | 139 | } |
135 | 140 |
|
|
0 commit comments