【Graphql实践】使用 Apollo(iOS) 访问 Github 的 Graphql API

最近在协助调研 Apollo 生成的代码是否有可能跨 Query 共享模型的问题,虽然初步结论是不能,并非预期的结果,可是在调研过程当中积累的一些经验,有必要记录下。若是你也对 Graphql 感兴趣,不妨先从 Github 的 Graphql API 来切手实践。html

关于 Graphql 官网

尽管只是作客户端的一些实践,我仍是建议你先过一遍 Graphql 官网的学习指南。这样能更快速地理解概念。一些客户端库的文档,大部分都只是介绍基本用法。前端

中文版,能够直接看 http://graphql.cn/ios

制做访问 Github API 的 Token

Github 中有多个 Token 的概念,你须要的是在 https://github.com/settings/tokens 这个页面。初步接触 Github API 的童鞋,可能会走好多弯路,好比把 Github APP 的token生成规则当成了 API 的访问 Token,几经周折生成出来,却发现彻底很差使。git

curl -H "Authorization: bearer 7b7cc672235587292be65d11d8ae729b14a0d162" https://api.github.com/graphql

其中的 7b7cc672235587292be65d11d8ae729b14a0d162 是我本身生成的几乎没有私人权限的 Token,能够临时提供给你们快速上手。可是不保证其一直可用,因此仍是建议你们本身去新建一个本身的专属 Toekn。github

配置 graphiql -- graphql 调试工具

这个地方,也是各类坑。第一反应就是去看官方文档,可是文档过期太多,坑太深。若是你非要看的话,我友情提醒一句,须要在父目录执行的是npm

yarn && npm run build

或者你干脆本身新建一个本身的示例:json

yarn add graphiql
yarn add graphql

若是看不懂我上面在说什么,说明你极可能不是一个 Web 前端,那就直接用一个基于 graphiql 开发的 APP 吧:swift

https://github.com/skevy/graphiql-app。Github 甚至还有专门的使用该 App 访问 Github API 的教程:https://developer.github.com/v4/guides/using-the-explorer/api

注意: 这个 App 是基于 Electron 开发的,做者没有直接说起对 Windows 的支持,可是若是你确实有须要,本身看下 Electron 的编译教程,确定是能够搞定的。app

以可视化方式查看 Github API

想象下,Graphql 把数据当作一个具体的图来处理,那这个图真的画出来是什么样呢?原本想本身用 Web 画下效果的,可是居然发现网上已经有了相关的工具。

完整的工具库,见https://github.com/APIs-guru/graphql-voyager。若是能和上文的 graphiql 的 App 聚合在一块儿,就很是完美了。

若是直接向看下效果,能够直接访问在线Demo: https://apis.guru/graphql-voyager/。里面提供了几个实例。Github 的 API 看起来,彷佛也不是很复杂嘛~~

关于 Apollo iOS 库

文档确定是要要先看下的:https://www.apollographql.com/docs/ios/。可是其中的坑,仍是有几个,记录下,或许能帮助后来的童鞋:

  • iOS 兼容性是 iOS 9.0。若是你的项目指定最低版本为 8.0,会发现 pod 安装的老是旧版 Apollo 库。

  • 若是找不到最新的库,可能须要更新下 pod:

pod install --repo-update
  • 写到 Xcode 里那段脚本,是不正确的。官网文档没有及时更新,应该下面这样写:
APOLLO_FRAMEWORK_PATH="$(eval find $FRAMEWORK_SEARCH_PATHS -name "Apollo.framework" -maxdepth 1)"

if [ -z "$APOLLO_FRAMEWORK_PATH" ]; then
echo "error: Couldn't find Apollo.framework in FRAMEWORK_SEARCH_PATHS; make sure to add the framework to your project."
exit 1
fi

cd "${SRCROOT}/${TARGET_NAME}"
$APOLLO_FRAMEWORK_PATH/check-and-run-apollo-codegen.sh generate "$(find . -name '*.graphql')" --schema=schema.json --output API.swift
相关文章
相关标签/搜索