@selfage/generator_cli
Version:
Code generation for message, service, and database.
3 lines • 15.2 kB
JavaScript
;
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"definition.js","sourceRoot":"","sources":["definition.ts"],"names":[],"mappings":"","sourcesContent":["export interface EnumValue {\n  // Recommended to be SNAKE_CASE.\n  name: string;\n  value: number;\n}\n\n// Generated code requires package `@selfage/message`.\nexport interface EnumDefinition {\n  kind: \"Enum\";\n  // Must be of CamelCase.\n  name: string;\n  values: Array<EnumValue>;\n}\n\nexport interface MessageFieldDefinition {\n  // Recommended to be camelCase.\n  name: string;\n  // Can be 'number', 'string', 'boolean' or the name of a message or enum.\n  type: string;\n  index: number;\n  isArray?: true;\n  // Import relative to CWD. Do not include '.yaml'.\n  import?: string;\n  deprecated?: true;\n}\n\nexport interface DatastoreFilterTemplate {\n  // The name of a `MessageFieldDefinition`.\n  fieldName: string;\n  // One of \"=\", \">\", \"<\", \">=\" and \"<=\".\n  operator: string;\n}\n\nexport interface DatastoreOrdering {\n  // The name of a `MessageFieldDefinition`.\n  fieldName: string;\n  descending: boolean;\n}\n\nexport interface DatastoreQueryTemplate {\n  // Recommended to be CamelCase, which will be part of the name of a class.\n  name: string;\n  filters?: Array<DatastoreFilterTemplate>;\n  orderings?: Array<DatastoreOrdering>;\n}\n\nexport interface DatastoreDefinition {\n  // The path to output the generated Datastore definition, relative to the\n  // current definition JSON file. It should be separated from its message\n  // definition. Do not include '.ts'.\n  output: string;\n  key: string;\n  queries?: Array<DatastoreQueryTemplate>;\n}\n\n// Generated code requires package `@selfage/message`.\nexport interface MessageDefinition {\n  kind: \"Message\";\n  // Must be of CamelCase.\n  name: string;\n  fields: Array<MessageFieldDefinition>;\n  // Deprecated for now.\n  // Requires package `@selfage/datastore_client`.\n  // datastore?: DatastoreDefinition;\n}\n\n// Generated code requires package `@selfage/service_descriptor`.\nexport interface ServiceDefinition {\n  kind: \"Service\";\n  // Must be of CamelCase.\n  name: string;\n  // Includes \"/\" at the beginning. Must be unique.\n  path: string;\n}\n\nexport interface KeyValueParamDefinition {\n  // The key of the search param.\n  key: string;\n  // Can only refer to a message.\n  type: string;\n  // Import relative to CWD. Do not include '.yaml'.\n  import?: string;\n}\n\nexport interface RemoteCallDefinition {\n  // Must be of CamelCase.\n  name: string;\n  // The pathname of a url. Must start with \"/\".\n  path: string;\n  // The body in a HTTP request. Support either 'bytes' or the name of a message.\n  body: string;\n  // Import relative to CWD. Do not include '.yaml'.\n  importBody?: string;\n  // The key in the HTTP header to pass an authorization string to the backend.\n  authKey?: string;\n  // Prefer `body` when possible. Often used when body is a stream.\n  metadata?: KeyValueParamDefinition;\n  // Support only referring to a message.\n  response: string;\n  // Import relative to CWD. Do not include '.yaml'.\n  importResponse?: string;\n}\n\nexport interface RemoteCallsGroupDefinition {\n  kind: \"RemoteCallsGroup\";\n  // Must be of CamelCase.\n  name: string;\n  // Refers to a service definition.\n  service: string;\n  // Import relative to CWD. Do not include '.yaml'.\n  importService?: string;\n  path?: string;\n  calls: Array<RemoteCallDefinition>;\n  // The path to output the generated web client interfaces, relative to CWD.\n  // It should be separated from its metadata definition. Do not include '.ts'.\n  outputClient: string;\n  // The path to output the generated handler interfaces, relative to CWD.\n  // It should be separated from its metadata definition. Do not include '.ts'.\n  outputHandler: string;\n}\n\nexport interface SpannerTableColumnType {\n  // Supports the following primitive types: bool, int53, float64, timestamp, and string.\n  // `bool` is the same in Spanner and JS/TS.\n  // `int53` maps to int64 in Spanner and number in JS/TS. Note that it's inefficiently handled by Spanner client in JS/TS.\n  // `float64` maps to float64 in Spanner and number in JS/TS.\n  // `timestamp` maps to timestamp in Spanner and number in milliseconds in JS/TS.\n  // `string` maps to string with MAX length in Spanner and string in JS/TS.\n  // `bytes` is NOT supported because it's error-prone due to encoding/decoding.\n  // `date` is NOT supported because it's error-prone due to timezone ambiguit.\n  // `struct` and `json` types are NOT supported in favor of the message type below.\n  // Supports the name of a message which must be defined first and can be imported, which maps to bytes in Spanner.\n  // Supports the name of an enum which must be defined first and can be imported, which maps to float64 in Spanner.\n  type: string;\n  // Import relative to CWD. Do not include '.yaml'.\n  import?: string;\n  isArray?: true;\n  nullable?: true;\n}\n\nexport interface SpannerTableColumnDefinition extends SpannerTableColumnType {\n  // Must be of camelCase.\n  name: string;\n}\n\nexport interface SpannerTableColumnGroupDefinition {\n  // Must be of camelCase.\n  name: string;\n  // Columns to be grouped.\n  columns: Array<string>;\n}\n\nexport interface SpannerTableSearchColumnDefinition {\n  // Must be of camelCase.\n  name: string;\n  // Columns to be tokenized. Can only be string type. Multiple columns will be concatenated with a space in between.\n  columnRefs: Array<string>;\n}\n\nexport interface SpannerIndexColumnDefinition {\n  name: string;\n  desc: boolean;\n}\n\nexport interface SpannerTablePrimaryKeyDefinition {\n  name: string;\n  desc: boolean;\n}\n\nexport interface SpannerTableInterleaveDefinition {\n  parentTable: string;\n  cascadeOnDelete?: true;\n}\n\nexport interface SpannerIndexDefinition {\n  // Must be of CamelCase.\n  name: string;\n  // Columns on the table that includes this definition.\n  columns: Array<string | SpannerIndexColumnDefinition>;\n  unique?: true;\n  nullFiltered?: true;\n}\n\nexport interface SpannerSearchIndexOrderByDefinition {\n  name: string;\n  desc: boolean;\n}\n\nexport interface SpannerSearchIndexDefinition {\n  // Must be of CamelCase.\n  name: string;\n  // Tokenized columns only.\n  columns: Array<string>;\n  partitionByColumns?: Array<string>;\n  orderByColumns?: Array<string | SpannerSearchIndexOrderByDefinition>;\n}\n\nexport interface SpannerTableDefinition {\n  kind: \"Table\";\n  // Must be of CamelCase.\n  name: string;\n  columns: Array<SpannerTableColumnDefinition>;\n  // Group columns to be easily selected.\n  columnGroups?: Array<SpannerTableColumnGroupDefinition>;\n  searchColumns?: Array<SpannerTableSearchColumnDefinition>;\n  primaryKeys: Array<string | SpannerTablePrimaryKeyDefinition>;\n  interleave?: SpannerTableInterleaveDefinition;\n  indexes?: Array<SpannerIndexDefinition>;\n  searchIndexes?: Array<SpannerSearchIndexDefinition>;\n  // Specify name of the queries.\n  insert?: string;\n  delete?: string;\n  get?: string;\n  update?: string;\n}\n\nexport interface SpannerTaskTableDefinition {\n  kind: \"TaskTable\";\n  // Must be of CamelCase.\n  name: string;\n  columns: Array<SpannerTableColumnDefinition>;\n  // The type is always float64.\n  retryCountColumn: string;\n  // The type is always timestamp.\n  executionTimeColumn: string;\n  // The type is always timestamp.\n  createdTimeColumn: string;\n  primaryKeys: Array<string | SpannerTablePrimaryKeyDefinition>;\n  indexes?: Array<SpannerIndexDefinition>;\n  // Always indexed by `executionTimeColumn`.\n  executionTimeIndex: string;\n  // Specify name of the queries.\n  insert: string;\n  delete: string;\n  get: string;\n  listPendingTasks: string;\n  getMetadata: string;\n  updateMetadata: string;\n}\n\nexport interface SpannerJoinOnLeaf {\n  // If not present, it matches an external variable.\n  lColumn?: string;\n  lTable?: string;\n  // For matching an external variable and you want a variable to be used in code.\n  lVar?: string;\n  op: \">\" | \"<\" | \">=\" | \"<=\" | \"!=\" | \"=\";\n  // Must be present, and refer to the table being joined.\n  rColumn: string;\n}\n\nexport interface SpannerJoinOnConcat {\n  op: \"AND\" | \"OR\";\n  exprs: Array<SpannerJoinOnConcat | SpannerJoinOnLeaf>;\n}\n\nexport interface SpannerJoin {\n  type: \"INNER\" | \"CROSS\" | \"FULL\" | \"LEFT\" | \"RIGHT\";\n  with: string;\n  as?: string;\n  on?: SpannerJoinOnConcat | SpannerJoinOnLeaf;\n}\n\nexport interface SpannerWhereLeaf {\n  lColumn: string;\n  lTable?: string;\n  // Functions might introduce input values.\n  func?: \"SCORE\";\n  // Binary operations introduces an input value.\n  op:\n    | \">\"\n    | \"<\"\n    | \">=\"\n    | \"<=\"\n    | \"!=\"\n    | \"=\"\n    | \"IS NULL\"\n    | \"IS NOT NULL\"\n    | \"SEARCH\"\n    | \"IN\";\n  // For binary operations, and you want a variable to be used in code.\n  rVar?: string;\n}\n\nexport interface SpannerWhereConcat {\n  op: \"AND\" | \"OR\";\n  exprs: Array<SpannerWhereConcat | SpannerWhereLeaf>;\n}\n\nexport interface SpannerOrderByExpr {\n  column: string;\n  table?: string;\n  // Function might introduce input values.\n  func?: \"SCORE\";\n  desc?: true;\n}\n\nexport interface SpannerGetColumnExpr {\n  column?: string;\n  func?: \"SCORE\"; // Function only works with `column`.\n  all?: true; // Get all columns from the table.\n  columnGroup?: string; // Get columns from the column group.\n  table?: string;\n}\n\nexport interface SpannerSelectDefinition {\n  // Must be of CamelCase.\n  name: string;\n  from: string;\n  as?: string;\n  join?: Array<SpannerJoin>;\n  where?: SpannerWhereConcat | SpannerWhereLeaf;\n  orderBy?: Array<string | SpannerOrderByExpr>;\n  withLimit?: boolean;\n  withOffset?: boolean;\n  get: Array<string | SpannerGetColumnExpr>;\n}\n\nexport interface SpannerInsertDefinition {\n  // Must be of CamelCase.\n  name: string;\n  table: string;\n  set: Array<string>;\n  onConflict?: \"IGNORE\" | \"UPDATE\"; // Absence means fail on conflict.\n}\n\nexport interface SpannerUpdateDefinition {\n  // Must be of CamelCase.\n  name: string;\n  table: string;\n  set: Array<string>;\n  where: SpannerWhereConcat | SpannerWhereLeaf;\n}\n\nexport interface SpannerDeleteDefinition {\n  // Must be of CamelCase.\n  name: string;\n  table: string;\n  where: SpannerWhereConcat | SpannerWhereLeaf;\n}\n\n// Generated code requires package `@google-cloud/spanner`, `@selfage/spanner_schema_update_cli` and `@selfage/message`.\nexport interface SpannerDatabaseDefinition {\n  kind: \"SpannerDatabase\";\n  // Must be of CamelCase.\n  name: string;\n  tables?: Array<SpannerTableDefinition | SpannerTaskTableDefinition>;\n  selects?: Array<SpannerSelectDefinition>;\n  inserts?: Array<SpannerInsertDefinition>;\n  updates?: Array<SpannerUpdateDefinition>;\n  deletes?: Array<SpannerDeleteDefinition>;\n  // The path to output the generated DDL JSON file, relative to CWD. Do not\n  // include '.yaml'.\n  outputDdl: string;\n  // The path to output the generated SQL functions, relative to CWD. Do not\n  // include '.ts'.\n  outputSql: string;\n}\n\nexport type Definition =\n  | EnumDefinition\n  | MessageDefinition\n  | ServiceDefinition\n  | RemoteCallsGroupDefinition\n  | SpannerDatabaseDefinition;\n"]}