服务配置:YAML结构

本文属使用Prisma构建GraphQL服务系列。

概述

服务定义文件prisma.yml具有以下根属性:

  • datamodel(必须):数据库模型,关系,枚举和其他类型的类型定义。
  • endpoint:Prisma API的HTTP端点。可以省略以提示CLI部署向导。
  • secret:保护API端点。
  • schema:Prism API的GraphQL schema的路径。
  • subscriptions:订阅webhooks的配置。
  • seed:指向包含突变的种子数据文件。
  • custom:用于提供可在prisma.yml其他地方引用的变量。

prisma.yml的精确结构是使用JSON Schema定义的。可以在这里找到相应的Schema定义。

datamodel(必须)

datamodel指向包含用GraphQL SDL编写的类型定义的一个或多个.graphql文件。如果提供多个​​文件,CLI将在部署时简单地拼接它们的内容。

类型

datamodel属性为一个字符串或一个字符串列表

示例

数据模型在一个名为types.graphql的文件中定义。

datamodel: types.graphql

数据模型在两个名为types.graphqlenums.graphl的文件中定义。部署时,两个文件的内容将通过CLI连接。

datamodel:
  - types.graphql
  - enums.graphql

endpoint(可选)

Prisma API的HTTP端点由以下组件组成:

  • Prisma server:承载您的Prisma API的服务器。
  • Workspace(仅Prisma Cloud):您通过Prisma Cloud配置的Workspace的名称。
  • Service name:Prism API的描述性名称。
  • Stage: cluster的开发阶段(例如,dev,staging,prod)。

请注意,endpoint实际上需要部署您的Prisma API。但是,如果您在运行prisma deploy之前没有在prisma.yml中指定它,CLI将使用向导来提示您几个问题,并将端点添加到prisma.yml中。

类型

endpoint属性为一个字符串

示例

1.以下示例端点对此信息进行编码:

  • Prisma serverlocalhost:4466意味着您使用Docker在本地计算机上部署API(在端口4466上)。
  • Service namedefault
  • Stagedefault

注意:当Service nameStage都设置为default时,它们可以省略,并由Prisma推断。这意味着如下示例端点相当于:http:// localhost:4466/

endpoint: http://localhost:4466/default/default

2.以下示例端点对此信息进行编码:

  • Prisma servereu1.prisma.sh意味着您使用Prisma Sandbox 部署Prisma API。
  • ** Workspace**:public-helixgoose-752是一个随机生成的字符串,用于标识Sandbox的Prisma Cloud工作区。
  • Service namemyservice
  • Stagedev
endpoint: https://eu1.prisma.sh/public-helixgoose-752/myservice/dev

3.以下示例端点对此信息进行编码:

  • Prisma serverhttp://my-pr-Publi-1GXX8QUZU3T89-413349553.us-east-1.elb.amazonaws.com意味着您正在使用自定义服务器来部署您的Prism API。
  • ** Workspace**:public-helixgoose-752是一个随机生成的字符串,用于标识Sandbox的Prisma Cloud工作区。
  • Service namecat-pictures
  • Stageprod
endpoint: http://my-pr-Publi-1GXX8QUZU3T89-413349553.us-east-1.elb.amazonaws.com/cat-pictures/prod

secret(可选)

secret用于生成(或签名)认证令牌(JWT)。其中一个身份验证令牌需要附加到HTTP请求(位于Authorization头字段中)。secret必须遵守这些要求:

  • 必须是utf8编码的
  • 不得包含空格
  • 最长不得超过256个字符

请注意,可以在此字符串中编码多个secret,从而实现平滑的secret旋转。

在这里阅读更多关于数据库认证

警告:如果Prisma API没有secret部署,它不需要验证。这意味着每个访问端点的人都可以发送任意查询和突变,因此可以读取和写入数据库!

类型

secret属性为一个字符串(不是字符串列表)。如果你想指定多个secret,用逗号分隔(空格被忽略),但仍然是一个字符串值。

示例

  1. 定义一个secret,其值为moo4ahn3ahb4phein1eingaep
secret: moo4ahn3ahb4phein1eingaep
  1. 定义3个secret,其值分别为myFirstSecret, SECRET_NUMBER_23rd-secret,注意,第二个前的空格会被忽略
secret: myFirstSecret,    SECRET_NUMBER_2,3rd-secret
  1. 使用环境变量,其名称为MY_SECRET
secret: ${env:MY_SECRET}

subscriptions (订阅,可选)

subscriptions属性用于为您的Prisma服务定义所有订阅webhook,其需要(至少)两条信息:

  • subscriptions query定义应在哪个事件中调用函数以及payload的样子
  • 一旦事件发生,通过HTTP调用的webhook的URL
  • (可选)附加到发送到URL的请求的HTTP头

类型

subscriptions属性是具有以下属性的对象

  • query(必须):subscription query的文件路径。
  • webhook(必须):关于要调用的webhook的信息(URL和可选的HTTP headers)。如果没有HTTP headers,则可以直接向该属性提供URL(请参阅下面的第一个示例)。否则,webhook会接收另一个具有urlheaders属性的对象(请参阅下面的第二个示例)。

示例

  1. 事件订阅没有HTTP headers。
subscriptions:
  sendWelcomeEmail:
      query: database/subscriptions/sendWelcomeEmail.graphql
      webhook: https://bcdeaxokbj.execute-api.eu-west-1.amazonaws.com/dev/sendWelcomeEmail
  1. 事件订阅指定两个HTTP headers。
subscriptions:
  sendWelcomeEmail:
      query: database/subscriptions/sendWelcomeEmail.graphql
      webhook:
        url: https://bcdeaxokbj.execute-api.eu-west-1.amazonaws.com/dev/sendWelcomeEmail
        headers:
          Authorization: ${env:MY_ENDPOINT_SECRET}
          Content-Type: application/json

seed (种子数据,可选)

数据库种子是用测试数据(或初始化数据)填充服务的标准方式。

类型

seed属性为一个对象,具有以下两个属性之一:

  • import:在播种服务时导入数据的说明。参考两种文件:
  • run:在种子服务时执行时的shell命令。这意味着不在导入范围内的更复杂的种子设置。

注意:目前不支持run。请关注此提议

首次部署服务时,会隐式执行种子(除非使用--no-seed标志显式禁用)。请关注请求以获取其他播种工作的workflows

示例

  1. 提供包含种子突变的.graphql文件:
seed:
  import: database/seed.graphql
  1. 使用NDF中的数据集引用.zip文件:
seed:
  import: database/backup.zip
  1. 播种时运行node脚本:
seed:
  run: node script.js

custom (自定义,可选)

custom属性可以让你指定任何你想在你的prisma.yml其他地方重用的值。因此它没有预定义的结构。您可以使用带有self variable source的变量来引用值,例如:$ {self:custom.myVariable}。

类型

custom属性为一个对象。没有对此对象的具体要求。

示例

定义两个custom值并在subscriptions的定义中重新使用它们。

custom:
  serverlessEndpoint: https://bcdeaxokbj.execute-api.eu-west-1.amazonaws.com/dev
  subscriptionQueries: database/subscriptions/

subscriptions:
  sendWelcomeEmail:
    query: ${self:custom.subscriptionQueries}/sendWelcomeEmail.graphql
    webhook: https://${self:custom.serverlessEndpoint}/sendWelcomeEmail

hooks (钩子,可选)

hooks属性用于定义在特定命令之前或之后由Prisma CLI执行的终端命令。

当前可用的钩子如下:

  • post-deploy:将在prisma deploy命令后调用,即部署后调用。

类型

hooks属性为一个对象。这些属性与当前可用的钩子的名称相匹配。

示例

以下是在执行prisma deploy后执行三项任务的示例:

  1. 输出Deployment finished
  2. 下载.graphqlconfig.yml中指定的db项目的GraphQL schema
  3. 调用.graphqlconfig.yml中指定的代码生成
hooks:
  post-deploy:
    - echo "Deployment finished"
    - graphql get-schema --project db
    - graphql prepare

请注意,此设置假定.graphqlconfig.yml的有如下代码:

projects:
  prisma:
    schemaPath: generated/prisma.graphql
    extensions:
      prisma: prisma.yml
      prepare-binding:
        output: generated/prisma.ts
        generator: prisma-ts
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,951评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,606评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,601评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,478评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,565评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,587评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,590评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,337评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,785评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,096评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,273评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,935评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,578评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,199评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,440评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,163评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,133评论 2 352

推荐阅读更多精彩内容

  • 本文属使用Prisma构建GraphQL服务系列。 应用层和数据库层分离 两个GraphQL API层 在使用Pr...
    guog阅读 1,151评论 3 0
  • 本文属使用Prisma构建GraphQL服务系列。 本文介绍如何使用typescript开发prisma服务。将使...
    guog阅读 2,917评论 0 2
  • 本文属使用Prisma构建GraphQL服务系列。 每个GraphQL API的核心:GraphQL schema...
    guog阅读 4,935评论 4 1
  • 本文属使用Prisma构建GraphQL服务系列。 当搞定了GraphQL服务端开发,且经过充分测试,那么接着需要...
    guog阅读 2,644评论 0 1
  • 本文属使用Prisma构建GraphQL服务系列。 本教程学习如何使用Prisma对数据库生成GraphQL AP...
    guog阅读 7,250评论 2 3