IAdminForthDataSourceConnectorBase
Interface that exposes methods to interact with AdminForth in standard way
Extends
Properties
client
client:
any
Inherited from
IAdminForthDataSourceConnector.client
Methods
aggregate()
aggregate(
__namedParameters):Promise<object[]>
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { aggregations: {[alias: string]: IAggregationRule; }; filters: IAdminForthAndOrFilter; groupBy?: IGroupByRule; resource: AdminForthResource; } |
__namedParameters.aggregations | {[alias: string]: IAggregationRule; } |
__namedParameters.filters | IAdminForthAndOrFilter |
__namedParameters.groupBy? | IGroupByRule |
__namedParameters.resource | AdminForthResource |
Returns
Promise<object[]>
createRecord()
createRecord(
__namedParameters):Promise<{createdRecord?:any;error?:string;ok:boolean; }>
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { adminUser: AdminUser; record: any; resource: AdminForthResource; } |
__namedParameters.adminUser | AdminUser |
__namedParameters.record | any |
__namedParameters.resource | AdminForthResource |
Returns
Promise<{ createdRecord?: any; error?: string; ok: boolean; }>
createRecordOriginalValues()
createRecordOriginalValues(
__namedParameters):Promise<string>
Used to create record in database. Should return value of primary key column of created record.
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { record: any; resource: AdminForthResource; } |
__namedParameters.record | any |
__namedParameters.resource | AdminForthResource |
Returns
Promise<string>
Inherited from
IAdminForthDataSourceConnector.createRecordOriginalValues
deleteMany()?
optionaldeleteMany(__namedParameters):Promise<number>
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { recordIds: any[]; resource: AdminForthResource; } |
__namedParameters.recordIds | any[] |
__namedParameters.resource | AdminForthResource |
Returns
Promise<number>
deleteRecord()
deleteRecord(
__namedParameters):Promise<boolean>
Used to delete record in database.
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { recordId: any; resource: AdminForthResource; } |
__namedParameters.recordId | any |
__namedParameters.resource | AdminForthResource |
Returns
Promise<boolean>
Inherited from
IAdminForthDataSourceConnector.deleteRecord
discoverFields()
discoverFields(
resource,config):Promise<{[key:string]:AdminForthResourceColumn; }>
Function should go over all columns of table defined in resource.table and try to guess data and constraints for each columns. Type should be saved to:
- AdminForthResourceColumn.type Constraints:
- AdminForthResourceColumn.required
- AdminForthResourceColumn.primaryKey For string fields:
- AdminForthResourceColumn.maxLength For numbers: // min/max are used inside getMinMaxForColumns from base connector
- AdminForthResourceColumn.min
- AdminForthResourceColumn.max
- AdminForthResourceColumn.minValue,
- AdminForthResourceColumn.maxValue,
- AdminForthResourceColumn.enum,
- AdminForthResourceColumn.foreignResource,
- AdminForthResourceColumn.sortable,
- AdminForthResourceColumn.backendOnly,
- AdminForthResourceColumn.masked,
- AdminForthResourceColumn.virtual,
- AdminForthResourceColumn.components,
- AdminForthResourceColumn.allowMinMaxQuery,
- AdminForthResourceColumn.editingNote,
- AdminForthResourceColumn.showIn,
- AdminForthResourceColumn.isUnique,
- AdminForthResourceColumn.validation) Also you can additionally save original column type to AdminForthResourceColumn._underlineType. This might be later used in IAdminForthDataSourceConnector.getFieldValue and IAdminForthDataSourceConnector.setFieldValue methods.
Parameters
| Parameter | Type | Description |
|---|---|---|
resource | AdminForthResource | - |
config | AdminForthConfig | - |
Returns
Promise<{[key: string]: AdminForthResourceColumn; }>
Inherited from
IAdminForthDataSourceConnector.discoverFields
getAggregateWithOriginalTypes()?
optionalgetAggregateWithOriginalTypes(__namedParameters):Promise<object[]>
Optional. Used to perform aggregation queries on a resource table. Returns rows with aliased aggregate values and optional group key.
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { aggregations: {[alias: string]: IAggregationRule; }; filters: IAdminForthAndOrFilter; groupBy?: IGroupByRule; resource: AdminForthResource; } |
__namedParameters.aggregations | {[alias: string]: IAggregationRule; } |
__namedParameters.filters | IAdminForthAndOrFilter |
__namedParameters.groupBy? | IGroupByRule |
__namedParameters.resource | AdminForthResource |
Returns
Promise<object[]>
Inherited from
IAdminForthDataSourceConnector.getAggregateWithOriginalTypes
getAllColumnsInTable()
getAllColumnsInTable(
tableName):Promise<object[]>
Function to get all columns in table.
Parameters
| Parameter | Type |
|---|---|
tableName | string |
Returns
Promise<object[]>
Inherited from
IAdminForthDataSourceConnector.getAllColumnsInTable
getAllTables()
getAllTables():
Promise<string[]>
Function to get all tables from database.
Returns
Promise<string[]>
Inherited from
IAdminForthDataSourceConnector.getAllTables
getCount()
getCount(
__namedParameters):Promise<number>
Used to get count of records in database.
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { filters: IAdminForthAndOrFilter; resource: AdminForthResource; } |
__namedParameters.filters | IAdminForthAndOrFilter |
__namedParameters.resource | AdminForthResource |
Returns
Promise<number>
Inherited from
IAdminForthDataSourceConnector.getCount
getData()
getData(
__namedParameters):Promise<{data:any[];total:number; }>
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { columns?: AdminForthResourceColumn[]; filters: IAdminForthAndOrFilter; getTotals?: boolean; limit: number; offset: number; resource: AdminForthResource; sort: IAdminForthSort[]; } |
__namedParameters.columns? | AdminForthResourceColumn[] |
__namedParameters.filters | IAdminForthAndOrFilter |
__namedParameters.getTotals? | boolean |
__namedParameters.limit | number |
__namedParameters.offset | number |
__namedParameters.resource | AdminForthResource |
__namedParameters.sort | IAdminForthSort[] |
Returns
Promise<{ data: any[]; total: number; }>
getDataWithOriginalTypes()
getDataWithOriginalTypes(
__namedParameters):Promise<any[]>
Used to fetch data from database. This method is reused both to list records and show one record (by passing limit 1 and offset 0) .
Fields are returned from db "as is" then AdminForthBaseConnector.getData will transform each field using IAdminForthDataSourceConnector.getFieldValue
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { columns?: AdminForthResourceColumn[]; filters: IAdminForthAndOrFilter; limit: number; offset: number; resource: AdminForthResource; sort: IAdminForthSort[]; } |
__namedParameters.columns? | AdminForthResourceColumn[] |
__namedParameters.filters | IAdminForthAndOrFilter |
__namedParameters.limit | number |
__namedParameters.offset | number |
__namedParameters.resource | AdminForthResource |
__namedParameters.sort | IAdminForthSort[] |
Returns
Promise<any[]>
Inherited from
IAdminForthDataSourceConnector.getDataWithOriginalTypes
getFieldValue()
getFieldValue(
field,value):any
Used to transform record after fetching from database. According to AdminForth convention, if AdminForthResourceColumn.type is set to AdminForthDataTypes.DATETIME then it should be transformed to ISO string.
Parameters
| Parameter | Type | Description |
|---|---|---|
field | AdminForthResourceColumn | - |
value | any | - |
Returns
any
Inherited from
IAdminForthDataSourceConnector.getFieldValue
getMinMaxForColumns()
getMinMaxForColumns(
__namedParameters):Promise<ColumnMinMaxValue>
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { columns: AdminForthResourceColumn[]; resource: AdminForthResource; } |
__namedParameters.columns | AdminForthResourceColumn[] |
__namedParameters.resource | AdminForthResource |
Returns
Promise<ColumnMinMaxValue>
getMinMaxForColumnsWithOriginalTypes()
getMinMaxForColumnsWithOriginalTypes(
__namedParameters):Promise<ColumnMinMaxValue>
Optional method which used to get min and max values for columns in resource. Called only for columns which have AdminForthResourceColumn.allowMinMaxQuery set to true.
Internally should call IAdminForthDataSourceConnector.getFieldValue for both min and max values.
Parameters
| Parameter | Type |
|---|---|
__namedParameters | { columns: AdminForthResourceColumn[]; resource: AdminForthResource; } |
__namedParameters.columns | AdminForthResourceColumn[] |
__namedParameters.resource | AdminForthResource |
Returns
Promise<ColumnMinMaxValue>