Module Values.PostgreSQLSettingsSource

Provides information that defines a PostgreSQL endpoint.

Sourcetype nonrec t = {
  1. afterConnectScript : String_.t option;
    (*

    For use with change data capture (CDC) only, this attribute has DMS bypass foreign keys and user triggers to reduce the time it takes to bulk load data. Example: afterConnectScript=SET session_replication_role='replica'

    *)
  2. captureDdls : BooleanOptional.t option;
    (*

    To capture DDL events, DMS creates various artifacts in the PostgreSQL database when the task starts. You can later remove these artifacts. The default value is true. If this value is set to N, you don't have to create tables or triggers on the source database.

    *)
  3. maxFileSize : IntegerOptional.t option;
    (*

    Specifies the maximum size (in KB) of any .csv file used to transfer data to PostgreSQL. The default value is 32,768 KB (32 MB). Example: maxFileSize=512

    *)
  4. databaseName : String_.t option;
    (*

    Database name for the endpoint.

    *)
  5. ddlArtifactsSchema : String_.t option;
    (*

    The schema in which the operational DDL database artifacts are created. The default value is public. Example: ddlArtifactsSchema=xyzddlschema;

    *)
  6. executeTimeout : IntegerOptional.t option;
    (*

    Sets the client statement timeout for the PostgreSQL instance, in seconds. The default value is 60 seconds. Example: executeTimeout=100;

    *)
  7. failTasksOnLobTruncation : BooleanOptional.t option;
    (*

    When set to true, this value causes a task to fail if the actual size of a LOB column is greater than the specified LobMaxSize. The default value is false. If task is set to Limited LOB mode and this option is set to true, the task fails instead of truncating the LOB data.

    *)
  8. heartbeatEnable : BooleanOptional.t option;
    (*

    The write-ahead log (WAL) heartbeat feature mimics a dummy transaction. By doing this, it prevents idle logical replication slots from holding onto old WAL logs, which can result in storage full situations on the source. This heartbeat keeps restart_lsn moving and prevents storage full scenarios. The default value is false.

    *)
  9. heartbeatSchema : String_.t option;
    (*

    Sets the schema in which the heartbeat artifacts are created. The default value is public.

    *)
  10. heartbeatFrequency : IntegerOptional.t option;
    (*

    Sets the WAL heartbeat frequency (in minutes). The default value is 5 minutes.

    *)
  11. password : SecretString.t option;
    (*

    Endpoint connection password.

    *)
  12. port : IntegerOptional.t option;
    (*

    Endpoint TCP port. The default is 5432.

    *)
  13. serverName : String_.t option;
    (*

    The host name of the endpoint database. For an Amazon RDS PostgreSQL instance, this is the output of DescribeDBInstances, in the Endpoint.Address field. For an Aurora PostgreSQL instance, this is the output of DescribeDBClusters, in the Endpoint field.

    *)
  14. username : String_.t option;
    (*

    Endpoint connection user name.

    *)
  15. slotName : String_.t option;
    (*

    Sets the name of a previously created logical replication slot for a change data capture (CDC) load of the PostgreSQL source instance. When used with the CdcStartPosition request parameter for the DMS API , this attribute also makes it possible to use native CDC start points. DMS verifies that the specified logical replication slot exists before starting the CDC load task. It also verifies that the task was created with a valid setting of CdcStartPosition. If the specified slot doesn't exist or the task doesn't have a valid CdcStartPosition setting, DMS raises an error. For more information about setting the CdcStartPosition request parameter, see Determining a CDC native start point in the Database Migration Service User Guide. For more information about using CdcStartPosition, see CreateReplicationTask, StartReplicationTask, and ModifyReplicationTask.

    *)
  16. pluginName : PluginNameValue.t option;
    (*

    Specifies the plugin to use to create a replication slot. The default value is pglogical.

    *)
  17. secretsManagerAccessRoleArn : String_.t option;
    (*

    The full Amazon Resource Name (ARN) of the IAM role that specifies DMS as the trusted entity and grants the required permissions to access the value in SecretsManagerSecret. The role must allow the iam:PassRole action. SecretsManagerSecret has the value of the Amazon Web Services Secrets Manager secret that allows access to the PostgreSQL endpoint. You can specify one of two sets of values for these permissions. You can specify the values for this setting and SecretsManagerSecretId. Or you can specify clear-text values for UserName, Password, ServerName, and Port. You can't specify both. For more information on creating this SecretsManagerSecret and the SecretsManagerAccessRoleArn and SecretsManagerSecretId required to access it, see Using secrets to access Database Migration Service resources in the Database Migration Service User Guide.

    *)
  18. secretsManagerSecretId : String_.t option;
    (*

    The full ARN, partial ARN, or friendly name of the SecretsManagerSecret that contains the PostgreSQL endpoint connection details.

    *)
  19. trimSpaceInChar : BooleanOptional.t option;
    (*

    Use the TrimSpaceInChar source endpoint setting to trim data on CHAR and NCHAR data types during migration. The default value is true.

    *)
  20. mapBooleanAsBoolean : BooleanOptional.t option;
    (*

    When true, lets PostgreSQL migrate the boolean type as boolean. By default, PostgreSQL migrates booleans as varchar(5). You must set this setting on both the source and target endpoints for it to take effect. The default value is false.

    *)
  21. mapJsonbAsClob : BooleanOptional.t option;
    (*

    When true, DMS migrates JSONB values as CLOB. The default value is false.

    *)
  22. mapLongVarcharAs : LongVarcharMappingType.t option;
    (*

    Sets what datatype to map LONG values as. The default value is wstring.

    *)
  23. databaseMode : DatabaseMode.t option;
    (*

    Specifies the default behavior of the replication's handling of PostgreSQL- compatible endpoints that require some additional configuration, such as Babelfish endpoints.

    *)
  24. babelfishDatabaseName : String_.t option;
    (*

    The Babelfish for Aurora PostgreSQL database name for the endpoint.

    *)
  25. disableUnicodeSourceFilter : BooleanOptional.t option;
    (*

    Disables the Unicode source filter with PostgreSQL, for values passed into the Selection rule filter on Source Endpoint column values. By default DMS performs source filter comparisons using a Unicode string which can cause look ups to ignore the indexes in the text columns and slow down migrations. Unicode support should only be disabled when using a selection rule filter is on a text column in the Source database that is indexed.

    *)
  26. serviceAccessRoleArn : String_.t option;
    (*

    The IAM role arn you can use to authenticate the connection to your endpoint. Ensure to include iam:PassRole and rds-db:connect actions in permission policy.

    *)
  27. authenticationMethod : PostgreSQLAuthenticationMethod.t option;
    (*

    This attribute allows you to specify the authentication method as "iam auth".

    *)
}
Sourceval make : ?afterConnectScript:??? -> ?captureDdls:??? -> ?maxFileSize:??? -> ?databaseName:??? -> ?ddlArtifactsSchema:??? -> ?executeTimeout:??? -> ?failTasksOnLobTruncation:??? -> ?heartbeatEnable:??? -> ?heartbeatSchema:??? -> ?heartbeatFrequency:??? -> ?password:??? -> ?port:??? -> ?serverName:??? -> ?username:??? -> ?slotName:??? -> ?pluginName:??? -> ?secretsManagerAccessRoleArn:??? -> ?secretsManagerSecretId:??? -> ?trimSpaceInChar:??? -> ?mapBooleanAsBoolean:??? -> ?mapJsonbAsClob:??? -> ?mapLongVarcharAs:??? -> ?databaseMode:??? -> ?babelfishDatabaseName:??? -> ?disableUnicodeSourceFilter:??? -> ?serviceAccessRoleArn:??? -> ?authenticationMethod:??? -> unit -> t
Sourceval to_value : t -> [> `Structure of (string * [> `Boolean of BooleanOptional.t | `Enum of string | `Integer of IntegerOptional.t | `String of String_.t ]) list ]
Sourceval to_query : t -> Awso.Client.Query.t
Sourceval of_xml : Awso.Xml.t -> t
Sourceval of_string : string -> t
Sourceval of_json : Yojson.Safe.t -> t
Sourceval to_json : t -> Yojson.Safe.t