Admins.java

/*
 * This file is generated by jOOQ.
 */
package com.io7m.idstore.database.postgres.internal.tables;


import com.io7m.idstore.database.postgres.internal.DefaultSchema;
import com.io7m.idstore.database.postgres.internal.Keys;
import com.io7m.idstore.database.postgres.internal.tables.records.AdminsRecord;

import java.time.OffsetDateTime;
import java.util.Arrays;
import java.util.List;
import java.util.UUID;
import java.util.function.Function;

import org.jooq.Field;
import org.jooq.ForeignKey;
import org.jooq.Function12;
import org.jooq.Name;
import org.jooq.Record;
import org.jooq.Records;
import org.jooq.Row12;
import org.jooq.Schema;
import org.jooq.SelectField;
import org.jooq.Table;
import org.jooq.TableField;
import org.jooq.TableOptions;
import org.jooq.UniqueKey;
import org.jooq.impl.DSL;
import org.jooq.impl.SQLDataType;
import org.jooq.impl.TableImpl;


/**
 * This class is generated by jOOQ.
 */
@SuppressWarnings({ "all", "unchecked", "rawtypes" })
public class Admins extends TableImpl<AdminsRecord> {

    private static final long serialVersionUID = 1L;

    /**
     * The reference instance of <code>ADMINS</code>
     */
    public static final Admins ADMINS = new Admins();

    /**
     * The class holding records for this type
     */
    @Override
    public Class<AdminsRecord> getRecordType() {
        return AdminsRecord.class;
    }

    /**
     * The column <code>ADMINS.ID</code>.
     */
    public final TableField<AdminsRecord, UUID> ID = createField(DSL.name("ID"), SQLDataType.UUID.nullable(false), this, "");

    /**
     * The column <code>ADMINS.ID_NAME</code>.
     */
    public final TableField<AdminsRecord, String> ID_NAME = createField(DSL.name("ID_NAME"), SQLDataType.VARCHAR(1000000).nullable(false), this, "");

    /**
     * The column <code>ADMINS.REAL_NAME</code>.
     */
    public final TableField<AdminsRecord, String> REAL_NAME = createField(DSL.name("REAL_NAME"), SQLDataType.VARCHAR(1000000).nullable(false), this, "");

    /**
     * The column <code>ADMINS.TIME_CREATED</code>.
     */
    public final TableField<AdminsRecord, OffsetDateTime> TIME_CREATED = createField(DSL.name("TIME_CREATED"), SQLDataType.TIMESTAMPWITHTIMEZONE(6).nullable(false), this, "");

    /**
     * The column <code>ADMINS.TIME_UPDATED</code>.
     */
    public final TableField<AdminsRecord, OffsetDateTime> TIME_UPDATED = createField(DSL.name("TIME_UPDATED"), SQLDataType.TIMESTAMPWITHTIMEZONE(6).nullable(false), this, "");

    /**
     * The column <code>ADMINS.PASSWORD_ALGO</code>.
     */
    public final TableField<AdminsRecord, String> PASSWORD_ALGO = createField(DSL.name("PASSWORD_ALGO"), SQLDataType.VARCHAR(1000000).nullable(false), this, "");

    /**
     * The column <code>ADMINS.PASSWORD_HASH</code>.
     */
    public final TableField<AdminsRecord, String> PASSWORD_HASH = createField(DSL.name("PASSWORD_HASH"), SQLDataType.VARCHAR(1000000).nullable(false), this, "");

    /**
     * The column <code>ADMINS.PASSWORD_SALT</code>.
     */
    public final TableField<AdminsRecord, String> PASSWORD_SALT = createField(DSL.name("PASSWORD_SALT"), SQLDataType.VARCHAR(1000000).nullable(false), this, "");

    /**
     * The column <code>ADMINS.PASSWORD_EXPIRES</code>.
     */
    public final TableField<AdminsRecord, OffsetDateTime> PASSWORD_EXPIRES = createField(DSL.name("PASSWORD_EXPIRES"), SQLDataType.TIMESTAMPWITHTIMEZONE(6), this, "");

    /**
     * The column <code>ADMINS.PERMISSIONS</code>.
     */
    public final TableField<AdminsRecord, String> PERMISSIONS = createField(DSL.name("PERMISSIONS"), SQLDataType.VARCHAR(1000000).nullable(false), this, "");

    /**
     * The column <code>ADMINS.DELETING</code>.
     */
    public final TableField<AdminsRecord, Boolean> DELETING = createField(DSL.name("DELETING"), SQLDataType.BOOLEAN.nullable(false), this, "");

    /**
     * The column <code>ADMINS.INITIAL</code>.
     */
    public final TableField<AdminsRecord, Boolean> INITIAL = createField(DSL.name("INITIAL"), SQLDataType.BOOLEAN.nullable(false), this, "");

    private Admins(Name alias, Table<AdminsRecord> aliased) {
        this(alias, aliased, null);
    }

    private Admins(Name alias, Table<AdminsRecord> aliased, Field<?>[] parameters) {
        super(alias, null, aliased, parameters, DSL.comment(""), TableOptions.table());
    }

    /**
     * Create an aliased <code>ADMINS</code> table reference
     */
    public Admins(String alias) {
        this(DSL.name(alias), ADMINS);
    }

    /**
     * Create an aliased <code>ADMINS</code> table reference
     */
    public Admins(Name alias) {
        this(alias, ADMINS);
    }

    /**
     * Create a <code>ADMINS</code> table reference
     */
    public Admins() {
        this(DSL.name("ADMINS"), null);
    }

    public <O extends Record> Admins(Table<O> child, ForeignKey<O, AdminsRecord> key) {
        super(child, key, ADMINS);
    }

    @Override
    public Schema getSchema() {
        return aliased() ? null : DefaultSchema.DEFAULT_SCHEMA;
    }

    @Override
    public UniqueKey<AdminsRecord> getPrimaryKey() {
        return Keys.CONSTRAINT_7;
    }

    @Override
    public List<UniqueKey<AdminsRecord>> getUniqueKeys() {
        return Arrays.asList(Keys.CONSTRAINT_72);
    }

    @Override
    public List<ForeignKey<AdminsRecord, ?>> getReferences() {
        return Arrays.asList(Keys.CONSTRAINT_72C);
    }

    private transient UserIds _userIds;

    /**
     * Get the implicit join path to the <code>PUBLIC.USER_IDS</code> table.
     */
    public UserIds userIds() {
        if (_userIds == null)
            _userIds = new UserIds(this, Keys.CONSTRAINT_72C);

        return _userIds;
    }

    @Override
    public Admins as(String alias) {
        return new Admins(DSL.name(alias), this);
    }

    @Override
    public Admins as(Name alias) {
        return new Admins(alias, this);
    }

    @Override
    public Admins as(Table<?> alias) {
        return new Admins(alias.getQualifiedName(), this);
    }

    /**
     * Rename this table
     */
    @Override
    public Admins rename(String name) {
        return new Admins(DSL.name(name), null);
    }

    /**
     * Rename this table
     */
    @Override
    public Admins rename(Name name) {
        return new Admins(name, null);
    }

    /**
     * Rename this table
     */
    @Override
    public Admins rename(Table<?> name) {
        return new Admins(name.getQualifiedName(), null);
    }

    // -------------------------------------------------------------------------
    // Row12 type methods
    // -------------------------------------------------------------------------

    @Override
    public Row12<UUID, String, String, OffsetDateTime, OffsetDateTime, String, String, String, OffsetDateTime, String, Boolean, Boolean> fieldsRow() {
        return (Row12) super.fieldsRow();
    }

    /**
     * Convenience mapping calling {@link SelectField#convertFrom(Function)}.
     */
    public <U> SelectField<U> mapping(Function12<? super UUID, ? super String, ? super String, ? super OffsetDateTime, ? super OffsetDateTime, ? super String, ? super String, ? super String, ? super OffsetDateTime, ? super String, ? super Boolean, ? super Boolean, ? extends U> from) {
        return convertFrom(Records.mapping(from));
    }

    /**
     * Convenience mapping calling {@link SelectField#convertFrom(Class,
     * Function)}.
     */
    public <U> SelectField<U> mapping(Class<U> toType, Function12<? super UUID, ? super String, ? super String, ? super OffsetDateTime, ? super OffsetDateTime, ? super String, ? super String, ? super String, ? super OffsetDateTime, ? super String, ? super Boolean, ? super Boolean, ? extends U> from) {
        return convertFrom(toType, Records.mapping(from));
    }
}