loopback-connector-ersoft-go

ersoft-go connector for loopback-datasource-juggler

Usage no npm install needed!

<script type="module">
  import loopbackConnectorErsoftGo from 'https://cdn.skypack.dev/loopback-connector-ersoft-go';
</script>

README

loopback-connector-ersoft-go

此connector解析器是专门为loopback3连接后台restful接口并将其自动挂载到loopback3自动生成的restful接口上,这只是一个基础框架,支持按照自己的业务改动

后台所需实现的接口

因为此解析包需要后台资源的配合,所以后台资源应实现以下方法,以达到对loopback3的所有自动生成的restful接口的完全支持:

find 此方法映射loopback3的restful中的find、findOne、findById以及它们的变种count,此方法是最基础方法,请务必支持! 入参: filter(包含:fields,limit,order,skip), filter是可选项,如果不填则默认为null filter中在前端包含include,但后台不需要支持,中台会自动支持include

let filter = {

where: {

    name: 'test',

    age: {

        gte: 17,

    },

},

fields: {

    id: false,

},

order: [

    'id DESC',

    'age DESC',

],

limit: 5,

skip: 1,

};

出参: 对象数组,未得到查询结果时返回空数组[]

[ { "title": "string", "content": "string", "id": "string" } ]

参考文档

create 创建对象,对应POST /modelName 方法,此方法只为创建某个表的对象,但却和find一样基础,同时也是findOrCreate组合方法的基础方法,请务必支持!

入参:

data 创建对象所需对象的必填字段,希望支持冗余字段(用户多填的的关键字,可以不用读取,希望后台支持冗余,这样业务上和数据上的操作更加灵活),如:

{ "title": "string", "content": "string" }

出参:创建的对象,但我在解析的时候只会取id(其他的参数以用户填的数据为标准),但还是希望能支持返回对象就返回对象

{ "title": "string", "content": "string", "id": 0 }

update

update有点复杂,这里希望后台能支持两种方法update,和replaceById

(1)update

此方法会根据where条件支持单一属性更新,不需要全量

入参:

1)where

查询语句的对象,如:{id:4}

2)data

需要更改的属性值,如:

{ where:{id:4}, data:{ title:"hh4" } } 更改所有id属性为4的对象的title值为”hh4“ (2)replaceById

此方法是全量更新,提供一个id,并替换其全部属性的值,此方法会在更新此id的对象之前由中台使用find自动验证其id是否存在,不存在则不会去调用后台方法,存在则会获取id,使用id调用此方法,所以后台只需实现全量更新即可, 入参: id 所要全量更新的条目的id

data 更新的数据

如:

{ id:4, data:{ "title": "string", "content": "string", "id": 4 //此处id为冗余字段,如果后台不希望看到则我在中台解析的时候会删除 } } destroyAll

根据条件删除所得的所有条目,destroyById和destroy则会自动转化条件{where:{id:4}}

入参: where 查询语句,参考find 如:

GET where={"id":4} POST {where:{id:4}} DELETE where={"id":4}

只要实现以上四类共五种方法,则可以基本完美支持loopback3的自动生成的所有的方法!

改造

改造参考文档:https://loopback.io/doc/en/lb3/Building-a-connector.html#notes-for-creating-non-database-connectors

测试

此代码使用的数据源是官方示例的notes项目,可以支持两个项目互联