每天进步一点点:condenser_api 与其它API(database_api)等的异同

想必用过API的都会有一点了解,那就是condenser_api,其实就是对其它各个API的封装,这样用户可以通过这个接口按一定的风格进行调用,可以忽略很多细节。


(图源 :pixabay)

以我们最常用的API get_dynamic_global_properties为例,condenser_api其实是对其进行了如下封装:

Reveal spoiler

image.png

看起来就是简单的映射,如果都是这样的,那么直接调用别的API也未尝不可。

但是等等,略复杂一点的情况来了,比如这个API:get_chain_properties,并没有同名的直接映射,而是其它API的部分返回结果:

Reveal spoiler

image.png

这种情况,如果你的程序依赖于condenser_api,那么就要找出具体是哪个API的哪个返回部分,复杂度略增。

以上两种还算简单,请看官继续看,更加复杂的马上就来了,让我们来看看我们最熟悉的get_accounts,我们使用condenser_api调用get_accounts会返回很多信息,比如我的声望分啊,我的见证人投票啊,那么我们来看看代码如何实现的:

Reveal spoiler

image.png

从上述代码中,我们不难看出condenser_apiget_accounts除了获取账户本身信息外,还追加了见证人票以及从其它插件获取了reputation信息,相当于多个API组合实现,这样我们如果用底层API直接实现,就复杂了好多。

尽管database_apifind_accounts提供了类似方法,但是并没有额外返回投的见证人票数据以及repution数据。

除此之外,在传递数据(输入)以及返回数据(输出)的格式方面,使用condenser_api以及直接使用其它APIdatabase_api等,也有很大的差异

condenser_api参数一般是作为数组传入[],而其它API的参数一般作为字典传入{},还是就是涉及资产类型比较头大,我为了这事卡住了三两天,总算理清一点眉目了。


(图源 :pixabay)

所以,真是试了其它API,才知道才知道condenser_api是多么便利啊。

Sort:  

I have picked your post for my daily hive voting initiative, Keep it up and Hive On!!