LoopBackとは?
-
rapid API generation
に特化したNodeフレームワーク - モデルを定義すると、CRUDの操作が可能なREST APIが自動的に生成される
- とにかく素早く作ることに焦点をおいている印象
- クライアントとのコード共通化(
Isomorphic JavaScript
)も推している - 内部でSwaggerが組み込まれているらしく、
http://localhost:3000/explorer
にアクセスすることでこちらのようなAPIドキュメントを確認することができる。 - 他フレームワークとの比較
- LoopBackとは - Documentation
- LoopBack core concepts - Documentation
実装の雰囲気
- ECMAScriptなどで書けば特に普通のJavaScriptと変わらない
- モダンなサンプルがあるにはあるが、あまり多くない/ガッツリ作っているものは少ない印象
- 全体として英語でも情報が少ないのが気になる
ディレクトリ構成
- Project layout reference | LoopBack Documentation
- Learn more | LoopBack Documentation
- REST以上のAPIや、処理のカスタマイズをしたい場合は
server/models
に付け足してゆく - なかなか記事が見つからなかったので、ベストプラクティスはやりながらみつけていくしかないかもしれない。このへんに学習コストがありそう
モデル/ORM
- Working with data | LoopBack Documentation
- 基本的なORMが使える
- JSONファイルにモデルの設定を記述してゆく
- プロパティ
- リレーション
- バリデーションルール
- スコープ
- メソッド
- など
トランザクション
- Using database transactions | LoopBack Documentation
- Implementing create, retrieve, update, and delete methods | LoopBack Documentation
- トランザクションをちゃんとやりたいなら、自動生成されるREST APIは使えないかも?
- ちょっと調べただけだとわからなかった(特に明記してあるリソースがなかった)ので、調査する必要はある。
DBマイグレーション
- Creating a database schema from models | LoopBack Documentation
- Implementing auto-migration | LoopBack Documentation
- MySQL connector | LoopBack Documentation
- マイグレーション用コードを書いておいて実行するような感じ
パッケージ管理
- 普段通りnpmかyarnでOK
バリデーション
- Validating model data | LoopBack Documentation
- 基本的なバリデーションメソッドが用意されている
テスト
- LoopBack(v3)では特に提供していない
- AVAなどを使ったいつものテストに加え、ExpressなどNodeのテストを参考にすればかけそう
- ユニットテスト
- DB分離
- テストダブル
- などを考慮
- Testing your application | LoopBack Documentation
- Testing the API | LoopBack Documentation
- Loopback testing with supertest, mocha and models - Stack Overflow
- Loopback testing upload file as a user with role - Stack Overflow
- Unit testing Loopback models - Stack Overflow
- サーバーサイドのテストとして、他に何か考慮することがあるか?
- LoopBackのドキュメント(v3)でテストについて書かれていないのが気になる…
デバッグ/エラーハンドリング
- Running and debugging apps | LoopBack Documentation
- いつものJSと同じ。+↑でいい感じにできそう
工数感
- 最初は設計部分など迷うことがありそう
- CRUD+αレベルであればすぐ作れそう
- LoopBackで自動生成できるところを上手く使えると工数削減できそう
- 情報量が少ないように感じる。LoopBack自体に依存する部分はそんなに多くはないかもしれないが、フレームワークがブラックボックスにしている部分はハマることはあるかもしれない。
その他
その他の参考
- Web API フレームワーク LoopBack で遊んでみる - Qiita
- LoopBack.jsで高速REST API開発 〜ゼロから開発、APIの使い方まで〜 - Qiita
- Loopbackフレームワーク入門 | Now or Never
- Why LoopBack Is Better Than ExpressJS? – Hacker Noon
- StrongLoop - Working with LoopBack’s Object-Relational Mapping (ORM) System
- Roll Your Own API vs. LoopBack
- LoopBack資料まとめ - Qiita
サンプルアプリケーション
- Tutorials and examples | LoopBack Documentation
- damassi/loopback-isomorphic-react-example: ES6 (server / client) + Hot Reload Enabled + Loopback for API + Isomorphic + Local CSS-Modules + React Router + Flux Demo
- cslinmiso/loopback-vue-boilerplate: A boilerplate for a Vue application using LoopBack, build with Webpack.