@aws-amplify/graphql-api-construct
Version:
AppSync GraphQL Api Construct using Amplify GraphQL Transformer.
95 lines • 14.1 kB
JavaScript
;
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.SQLLambdaModelDataSourceStrategyFactory = exports.isSqlModelDataSourceSsmDbConnectionStringConfig = exports.isSqlModelDataSourceSecretsManagerDbConnectionConfig = exports.isSqlModelDataSourceSsmDbConnectionConfig = exports.isSqlModelDataSourceDbConnectionConfig = exports.isSQLLambdaModelDataSourceStrategy = void 0;
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const fs = require("fs");
const path = require("path");
const graphql_transformer_core_1 = require("@aws-amplify/graphql-transformer-core");
/**
* Type predicate that returns true if the object is a SQLLambdaModelDataSourceStrategy.
* @param obj the object to inspect
* @returns true if the object is shaped like a SQLLambdaModelDataSourceStrategy
*/
const isSQLLambdaModelDataSourceStrategy = (obj) => {
return ((typeof obj === 'object' || typeof obj === 'function') &&
typeof obj.name === 'string' &&
typeof obj.dbType === 'string' &&
(0, graphql_transformer_core_1.isSqlDbType)(obj.dbType) &&
(0, exports.isSqlModelDataSourceDbConnectionConfig)(obj.dbConnectionConfig));
};
exports.isSQLLambdaModelDataSourceStrategy = isSQLLambdaModelDataSourceStrategy;
/**
* Type predicate that returns true if the object is a SqlModelDataSourceDbConnectionConfig.
* @param obj the object to inspect
* @returns true if the object is shaped like a SqlModelDataSourceDbConnectionConfig
*/
const isSqlModelDataSourceDbConnectionConfig = (obj) => {
return ((0, exports.isSqlModelDataSourceSsmDbConnectionConfig)(obj) ||
(0, exports.isSqlModelDataSourceSecretsManagerDbConnectionConfig)(obj) ||
(0, exports.isSqlModelDataSourceSsmDbConnectionStringConfig)(obj));
};
exports.isSqlModelDataSourceDbConnectionConfig = isSqlModelDataSourceDbConnectionConfig;
/**
* Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionConfig.
* @param obj the object to inspect
* @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionConfig
*/
const isSqlModelDataSourceSsmDbConnectionConfig = (obj) => {
return ((typeof obj === 'object' || typeof obj === 'function') &&
typeof obj.hostnameSsmPath === 'string' &&
typeof obj.portSsmPath === 'string' &&
typeof obj.usernameSsmPath === 'string' &&
typeof obj.passwordSsmPath === 'string' &&
typeof obj.databaseNameSsmPath === 'string');
};
exports.isSqlModelDataSourceSsmDbConnectionConfig = isSqlModelDataSourceSsmDbConnectionConfig;
/**
* Type predicate that returns true if the object is a SqlModelDataSourceSecretsManagerDbConnectionConfig.
* @param obj the object to inspect
* @returns true if the object is shaped like a SqlModelDataSourceSecretsManagerDbConnectionConfig
*/
const isSqlModelDataSourceSecretsManagerDbConnectionConfig = (obj) => {
return ((typeof obj === 'object' || typeof obj === 'function') &&
typeof obj.secretArn === 'string' &&
typeof obj.port === 'number' &&
typeof obj.databaseName === 'string' &&
typeof obj.hostname == 'string');
};
exports.isSqlModelDataSourceSecretsManagerDbConnectionConfig = isSqlModelDataSourceSecretsManagerDbConnectionConfig;
/**
* Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionStringConfig.
* @param obj the object to inspect
* @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionStringConfig
*/
const isSqlModelDataSourceSsmDbConnectionStringConfig = (obj) => {
return ((typeof obj === 'object' || typeof obj === 'function') &&
(typeof obj.connectionUriSsmPath === 'string' || Array.isArray(obj.connectionUriSsmPath)));
};
exports.isSqlModelDataSourceSsmDbConnectionStringConfig = isSqlModelDataSourceSsmDbConnectionStringConfig;
/**
* Class exposing utilities to produce SQLLambdaModelDataSourceStrategy objects given various inputs.
*/
class SQLLambdaModelDataSourceStrategyFactory {
/**
* Creates a SQLLambdaModelDataSourceStrategy where the binding's `customSqlStatements` are populated from `sqlFiles`. The key
* of the `customSqlStatements` record is the file's base name (that is, the name of the file minus the directory and extension).
* @param sqlFiles the list of files to load SQL statements from.
* @param options the remaining SQLLambdaModelDataSourceStrategy options.
*/
static fromCustomSqlFiles(sqlFiles, options) {
const customSqlStatements = sqlFiles.reduce((acc, filePath) => {
const basename = path.parse(filePath).name;
acc[basename] = fs.readFileSync(filePath, 'utf8');
return acc;
}, {});
return {
customSqlStatements,
...options,
};
}
}
exports.SQLLambdaModelDataSourceStrategyFactory = SQLLambdaModelDataSourceStrategyFactory;
_a = JSII_RTTI_SYMBOL_1;
SQLLambdaModelDataSourceStrategyFactory[_a] = { fqn: "@aws-amplify/graphql-api-construct.SQLLambdaModelDataSourceStrategyFactory", version: "1.20.3" };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"sql-model-datasource-strategy.js","sourceRoot":"","sources":["../src/sql-model-datasource-strategy.ts"],"names":[],"mappings":";;;;;AAAA,yBAAyB;AACzB,6BAA6B;AAC7B,oFAAoE;AASpE;;;;GAIG;AACI,MAAM,kCAAkC,GAAG,CAAC,GAAQ,EAA2C,EAAE;IACtG,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,OAAO,GAAG,CAAC,MAAM,KAAK,QAAQ;QAC9B,IAAA,sCAAW,EAAC,GAAG,CAAC,MAAM,CAAC;QACvB,IAAA,8CAAsC,EAAC,GAAG,CAAC,kBAAkB,CAAC,CAC/D,CAAC;AACJ,CAAC,CAAC;AARW,QAAA,kCAAkC,sCAQ7C;AAEF;;;;GAIG;AACI,MAAM,sCAAsC,GAAG,CAAC,GAAQ,EAA+C,EAAE;IAC9G,OAAO,CACL,IAAA,iDAAyC,EAAC,GAAG,CAAC;QAC9C,IAAA,4DAAoD,EAAC,GAAG,CAAC;QACzD,IAAA,uDAA+C,EAAC,GAAG,CAAC,CACrD,CAAC;AACJ,CAAC,CAAC;AANW,QAAA,sCAAsC,0CAMjD;AAEF;;;;GAIG;AACI,MAAM,yCAAyC,GAAG,CAAC,GAAQ,EAAkD,EAAE;IACpH,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,WAAW,KAAK,QAAQ;QACnC,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,eAAe,KAAK,QAAQ;QACvC,OAAO,GAAG,CAAC,mBAAmB,KAAK,QAAQ,CAC5C,CAAC;AACJ,CAAC,CAAC;AATW,QAAA,yCAAyC,6CASpD;AAEF;;;;GAIG;AACI,MAAM,oDAAoD,GAAG,CAClE,GAAQ,EACmD,EAAE;IAC7D,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,OAAO,GAAG,CAAC,SAAS,KAAK,QAAQ;QACjC,OAAO,GAAG,CAAC,IAAI,KAAK,QAAQ;QAC5B,OAAO,GAAG,CAAC,YAAY,KAAK,QAAQ;QACpC,OAAO,GAAG,CAAC,QAAQ,IAAI,QAAQ,CAChC,CAAC;AACJ,CAAC,CAAC;AAVW,QAAA,oDAAoD,wDAU/D;AAEF;;;;GAIG;AACI,MAAM,+CAA+C,GAAG,CAAC,GAAQ,EAAwD,EAAE;IAChI,OAAO,CACL,CAAC,OAAO,GAAG,KAAK,QAAQ,IAAI,OAAO,GAAG,KAAK,UAAU,CAAC;QACtD,CAAC,OAAO,GAAG,CAAC,oBAAoB,KAAK,QAAQ,IAAI,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,oBAAoB,CAAC,CAAC,CAC1F,CAAC;AACJ,CAAC,CAAC;AALW,QAAA,+CAA+C,mDAK1D;AAEF;;GAEG;AACH,MAAa,uCAAuC;IAClD;;;;;OAKG;IACH,MAAM,CAAC,kBAAkB,CACvB,QAAkB,EAClB,OAAyE;QAEzE,MAAM,mBAAmB,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,QAAQ,EAA0B,EAAE;YACpF,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC;YAC3C,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC,YAAY,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;YAClD,OAAO,GAAG,CAAC;QACb,CAAC,EAAE,EAA4B,CAAC,CAAC;QAEjC,OAAO;YACL,mBAAmB;YACnB,GAAG,OAAO;SACX,CAAC;IACJ,CAAC;;AArBH,0FAsBC","sourcesContent":["import * as fs from 'fs';\nimport * as path from 'path';\nimport { isSqlDbType } from '@aws-amplify/graphql-transformer-core';\nimport {\n  SQLLambdaModelDataSourceStrategy,\n  SqlModelDataSourceDbConnectionConfig,\n  SqlModelDataSourceSsmDbConnectionConfig,\n  SqlModelDataSourceSecretsManagerDbConnectionConfig,\n  SqlModelDataSourceSsmDbConnectionStringConfig,\n} from './model-datasource-strategy-types';\n\n/**\n * Type predicate that returns true if the object is a SQLLambdaModelDataSourceStrategy.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SQLLambdaModelDataSourceStrategy\n */\nexport const isSQLLambdaModelDataSourceStrategy = (obj: any): obj is SQLLambdaModelDataSourceStrategy => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.name === 'string' &&\n    typeof obj.dbType === 'string' &&\n    isSqlDbType(obj.dbType) &&\n    isSqlModelDataSourceDbConnectionConfig(obj.dbConnectionConfig)\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceDbConnectionConfig\n */\nexport const isSqlModelDataSourceDbConnectionConfig = (obj: any): obj is SqlModelDataSourceDbConnectionConfig => {\n  return (\n    isSqlModelDataSourceSsmDbConnectionConfig(obj) ||\n    isSqlModelDataSourceSecretsManagerDbConnectionConfig(obj) ||\n    isSqlModelDataSourceSsmDbConnectionStringConfig(obj)\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionConfig\n */\nexport const isSqlModelDataSourceSsmDbConnectionConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.hostnameSsmPath === 'string' &&\n    typeof obj.portSsmPath === 'string' &&\n    typeof obj.usernameSsmPath === 'string' &&\n    typeof obj.passwordSsmPath === 'string' &&\n    typeof obj.databaseNameSsmPath === 'string'\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSecretsManagerDbConnectionConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSecretsManagerDbConnectionConfig\n */\nexport const isSqlModelDataSourceSecretsManagerDbConnectionConfig = (\n  obj: any,\n): obj is SqlModelDataSourceSecretsManagerDbConnectionConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    typeof obj.secretArn === 'string' &&\n    typeof obj.port === 'number' &&\n    typeof obj.databaseName === 'string' &&\n    typeof obj.hostname == 'string'\n  );\n};\n\n/**\n * Type predicate that returns true if the object is a SqlModelDataSourceSsmDbConnectionStringConfig.\n * @param obj the object to inspect\n * @returns true if the object is shaped like a SqlModelDataSourceSsmDbConnectionStringConfig\n */\nexport const isSqlModelDataSourceSsmDbConnectionStringConfig = (obj: any): obj is SqlModelDataSourceSsmDbConnectionStringConfig => {\n  return (\n    (typeof obj === 'object' || typeof obj === 'function') &&\n    (typeof obj.connectionUriSsmPath === 'string' || Array.isArray(obj.connectionUriSsmPath))\n  );\n};\n\n/**\n * Class exposing utilities to produce SQLLambdaModelDataSourceStrategy objects given various inputs.\n */\nexport class SQLLambdaModelDataSourceStrategyFactory {\n  /**\n   * Creates a SQLLambdaModelDataSourceStrategy where the binding's `customSqlStatements` are populated from `sqlFiles`. The key\n   * of the `customSqlStatements` record is the file's base name (that is, the name of the file minus the directory and extension).\n   * @param sqlFiles the list of files to load SQL statements from.\n   * @param options the remaining SQLLambdaModelDataSourceStrategy options.\n   */\n  static fromCustomSqlFiles(\n    sqlFiles: string[],\n    options: Exclude<SQLLambdaModelDataSourceStrategy, 'customSqlStatements'>,\n  ): SQLLambdaModelDataSourceStrategy {\n    const customSqlStatements = sqlFiles.reduce((acc, filePath): Record<string, string> => {\n      const basename = path.parse(filePath).name;\n      acc[basename] = fs.readFileSync(filePath, 'utf8');\n      return acc;\n    }, {} as Record<string, string>);\n\n    return {\n      customSqlStatements,\n      ...options,\n    };\n  }\n}\n"]}