REST API reference

This page details the TDK REST API endpoints available.

openapi: 3.0.1
info:
  title: "Testing suite common API"
  description: |
    Test
  version: "0.1"

x-package: io.synthesized.api

paths: {}

components:
  schemas:
    TableConfig:
      description: "[TableConfig] is equivalent to [UserTableConfig] but with all parameters must set,
       it doesn't accept null values."
      type: object
      nullable: false
      x-extends:
        - java.io.Serializable
      properties:
        table:
          $ref: "#/components/schemas/Table"
        mode:
          $ref: "userconfig.yaml#/components/schemas/TransformationMode"
        transformations:
          type: array
          items:
            $ref: "userconfig.yaml#/components/schemas/ColumnTransformationParams"
          nullable: false
        target_ratio:
          type: number
          format: double
          nullable: true
        target_row_number:
          type: integer
          format: int64
          nullable: true
        cycle_breaker_references:
          type: array
          nullable: false
          items:
            type: string
            nullable: false
          default: [ ]
        target_count:
          type: integer
          format: int64
          nullable: false
          default: 0
        insert_batch_size:
          type: integer
          nullable: false
        use_working_directory:
          type: boolean
          nullable: false
        filter:
          type: string
        in_memory_filter_threshold:
          type: integer
          nullable: false

    DataType:
      type: object
      title: DataTypeDTO
      nullable: false
      x-extends:
        - java.io.Serializable
      properties:
        type_name:
          type: string
          nullable: false
        sql_type_name:
          type: string
          default: 'null'
        length:
          type: integer
          default: 'null'
        precision:
          type: integer
          default: 'null'
        scale:
          type: integer
          default: 'null'
        nullable:
          type: boolean
          default: true
          nullable: false
        is_user_defined:
          type: boolean
          nullable: false
          default: false
        is_computed:
          type: boolean
          nullable: false
          default: false
        is_enum:
          type: boolean
          nullable: false
          default: false
        has_explicit_size:
          description: "If the value is false, a datatype doesn't have explicit scale, precision or length in a
            SQL definition"
          type: boolean
          nullable: false
          default: true

    Field:
      type: object
      title: Field
      x-extends:
        - java.io.Serializable
      properties:
        name:
          type: string
          nullable: false
        database_id:
          type: string
          nullable: false
        database_name:
          type: string
          nullable: true
          default: null
        schema:
          type: string
        table:
          type: string
          nullable: false
        data_type:
          $ref: "#/components/schemas/DataType"
        external_meta:
          $ref: "#/components/schemas/ExternalFieldMeta"

    ForeignKey:
      type: object
      title: ForeignKey
      x-extends:
        - java.io.Serializable
      properties:
        database_id:
          type: string
          nullable: false
        database_name:
          type: string
          nullable: true
          default: null
        schema:
          type: string
        table:
          type: string
          nullable: false
        name:
          type: string
          nullable: false
        fields:
          type: array
          items:
            type: string
          nullable: false
        referred_name:
          type: string
          nullable: true
        referred_database_id:
          type: string
          nullable: false
        referred_database_name:
          type: string
          nullable: true
          default: null
        referred_schema:
          type: string
        referred_table:
          type: string
        referred_fields:
          type: array
          items:
            type: string
          nullable: false
        meta_source:
          $ref: "#/components/schemas/MetaSource"
        delete_referential_action:
          $ref: "#/components/schemas/ReferentialAction"
        update_referential_action:
          $ref: "#/components/schemas/ReferentialAction"

    # TODO: In case if we need to add more options, we need to add sealed marks
    # TODO: to the class implementing [Option] in order to perform fine-graded pattern matching
    Option:
      type: object
      title: Option
      x-extends:
        - java.io.Serializable
      properties:
        type:
          type: string
      discriminator:
        propertyName: type
        mapping:
          'history_table': "#/components/schemas/MSSQLHistoryTableOption"

    MSSQLHistoryTableOption:
      type: object
      title: MSSQLHistoryTableOption
      description: >
        Indicates that the table is a history table in MSSQL. This means that the table is associated
        with a versioned table and the versioned table is given by the `schema` and `table` fields.
      properties:
        versioned_table_schema:
          type: string
          nullable: false
        versioned_table_name:
          type: string
          nullable: false
        from_column:
          type: string
          nullable: false
        to_column:
          type: string
          nullable: false
      allOf:
        - $ref: "#/components/schemas/Option"

    PrimaryKey:
      type: object
      title: PrimaryKey
      x-extends:
        - java.io.Serializable
      properties:
        database_id:
          type: string
          nullable: false
        database_name:
          type: string
          nullable: true
          default: null
        schema:
          type: string
        table:
          type: string
          nullable: false
        name:
          type: string
          nullable: false
        fields:
          type: array
          items:
            type: string
          nullable: false

    UniqueKey:
      type: object
      title: UniqueKey
      x-extends:
        - java.io.Serializable
      properties:
        database_id:
          type: string
          nullable: false
        database_name:
          type: string
          nullable: true
          default: null
        schema:
          type: string
        table:
          type: string
          nullable: false
        name:
          type: string
          nullable: false
        fields:
          type: array
          items:
            type: string
          nullable: false

    Procedure:
      type: object
      title: Procedure
      nullable: false
      x-extends:
        - java.io.Serializable
      properties:
        name:
          type: string
          nullable: false
        schema:
          type: string

    Function:
      type: object
      title: Procedure
      nullable: false
      x-extends:
        - java.io.Serializable
      properties:
        name:
          type: string
          nullable: false
        schema:
          type: string
    UserType:
      type: object
      title: User type
      nullable: false
      x-extends:
        - java.io.Serializable
      properties:
        name:
          type: string
          nullable: false
        schema:
          type: string

    Trigger:
      type: object
      title: Trigger
      x-extends:
        - java.io.Serializable
      properties:
        name:
          type: string
          nullable: false
        is_enabled:
          type: boolean
          nullable: false

    Table:
      type: object
      title: Table
      nullable: false
      x-extends:
        - java.io.Serializable
      properties:
        name:
          type: string
          nullable: false
        fields:
          type: array
          items:
            $ref: '#/components/schemas/Field'
          nullable: false
        database_id:
          type: string
          nullable: false
        database_name:
          type: string
          nullable: true
          default: null
        schema:
          type: string
        indexes:
          type: array
          items:
            type:
              string
          nullable: false
          default: []
        triggers:
          type: array
          items:
            $ref: '#/components/schemas/Trigger'
          nullable: false
          default: [ ]
        primary_key:
          $ref: "#/components/schemas/PrimaryKey"
        foreign_keys:
          type: array
          items:
            $ref: '#/components/schemas/ForeignKey'
          nullable: false
          default: []
        unique_keys:
          type: array
          items:
            $ref: '#/components/schemas/UniqueKey'
          nullable: false
          default: []
        identity_column:
          description: >
            The name of IDENTITY column, if this table has one, null otherwise.
          type: string
          nullable: true
          default: null
        options:
          type: array
          items:
            $ref: '#/components/schemas/Option'
          nullable: false
          default: [ ]
        external_meta:
          $ref: "#/components/schemas/ExternalTableMeta"

    SQLDialect:
      enum:
        - POSTGRES
        - MYSQL
        - MARIADB
        - SQLITE
        - ORACLE
        - MSSQL
        - H2
        - DB2
        - SNOWFLAKE
        - CSV

    ReferentialAction:
      enum:
        - NO_ACTION
        - CASCADE
        - SET_NULL
        - SET_DEFAULT

    Database:
      type: object
      title: Database
      properties:
        id:
          description: "Database Id"
          type: string
          nullable: false
        name:
          description: "Database name (if exists)"
          type: string
          nullable: true
          default: null
        dialect:
          $ref: "#/components/schemas/SQLDialect"
        schemas:
          type: array
          nullable: false
          items:
            type: string
        tables:
          description: "Tables in the database"
          type: array
          nullable: false
          items:
            $ref: "#/components/schemas/Table"
          default: []
        views:
          type: array
          nullable: false
          items:
            type: string
          default: []
        procedures:
          description: "Procedures in the database"
          type: array
          nullable: false
          items:
            $ref: "#/components/schemas/Procedure"
          default: [ ]
        functions:
          description: "Functions in the database"
          type: array
          nullable: false
          items:
            $ref: "#/components/schemas/Function"
          default: [ ]
        user_types:
          description: "User types in the database"
          type: array
          nullable: false
          items:
            $ref: "#/components/schemas/UserType"
          default: [ ]
        users:
          type: array
          nullable: false
          items:
            type: string
          default: []

    DatabaseConnection:
      type: object
      title: DatabaseConnection
      nullable: false
      properties:
        jdbc_url:
          type: string
          nullable: false
        user:
          $ref: 'inventory.yaml#/components/schemas/Credentials'
        password:
          $ref: 'inventory.yaml#/components/schemas/Credentials'
        sql_dialect:
          $ref: '#/components/schemas/SQLDialect'
        spawned_id:
          description: Spawned database UUID (if this database is temporary)
          type: string

    ExternalFieldMeta:
      nullable: true
      default: null
      type: object
      properties:
        classifiers:
          type: array
          nullable: false
          items:
            type: string
          default: []

    ExternalTableMeta:
      nullable: true
      default: null
      type: object
      properties:
        sensitivity_tags:
          type: array
          nullable: false
          items:
            $ref: "#/components/schemas/SensitivityTag"
          default: []

    SensitivityTag:
      nullable: true
      type: object
      properties:
        group:
          type: string
          nullable: false
        level:
          type: string
          nullable: false

    MetaSource:
      nullable: false
      enum:
        - DATABASE
        - CONFIG

    ValidationResult:
      type: object
      title: ValidationResultDTO
      nullable: false
      properties:
        failed:
          type: boolean
          nullable: false
        messages:
          type: array
          nullable: false
          items:
            type: string
          default: [ ]