freee プロジェクト管理 の API をドライバー化:各種ツールから接続してみた

f:id:sugimomoto:20210916095648p:plain

こんにちは。CData Software Japanリードエンジニアの杉本です。

本記事では、各種 Web API を ODBC / JDBC / ADO.NET といった標準のDB接続規格でアクセスできるようにするCData API Driverを用いて、freee プロジェクト管理 の API を各種ツールから接続する方法を紹介します。

ExcelやAccess・Power BIなどのエンドユーザーが利用するUIベースのツールはもちろん、Visual StduioやEclipseといった開発ツールからも接続することが可能です。

対象 API

freee プロジェクト管理 とは プロジェクト型ビジネスを行っている事業者向けのリアルタイムでプロジェクト毎の収支管理を可能とするクラウドサービスです。

www.freee.co.jp

f:id:sugimomoto:20210916095654p:plain

freee プロジェクト管理では、会計 freeeと同様にAPIが提供されており、取引先やプロジェクト工数等のデータが取得できるようになっています。

developer.freee.co.jp

f:id:sugimomoto:20210916095659p:plain

今回はこのAPIを用いて様々なツールとの連携を実現します。

実現イメージ

この記事では freee プロジェクト管理 APIに対してBIやETL/EAIなど、様々なツールから接続します。しかしながら、各APIは単純にツールと接続・連携することはできません。

各ツールがどのようにWeb API側へリクエストを投げるべきかの判断材料や各種認証方法の処理、メタデータの情報等が無いためです。そのためには基本的にカスタムコネクタを作るか、プログラムを組まなければいけません。

f:id:sugimomoto:20210916095705p:plain

そこで、CData API Driver を用いて、このボトルネックを解決します。

まず、各ツールからはODBCやJDBCインタフェースでSQL(Select文)をCData API Driverに向けて発行してもらいます。そのリクエストを受け取った CData API Driverは、freee プロジェクト管理 の API のエンドポイントに対して、SQL文を解釈し、HTTPリクエスト発行します。

リクエスト後、JSONフォーマットで返ってきたデータをCData API Driverが各種インタフェースフォーマットにデータを変換してツールに返します。

f:id:sugimomoto:20210916095709p:plain

これにより、各種ツールからアドホックにSQLによるリクエストがあったタイミングで最新のデータをfreee プロジェクト管理 API から取得することが可能となります。

各種接続シナリオと必要なツール

CData API Driver は様々なツールとの接続に利用できますが、今回は以下のツールを用いて接続する方法を解説していきます。

  • Excel(Excel-addin で利用)
  • Access(ODBC 接続で利用)
  • PowerBI (Power BI Connector 接続で利用)
  • ASTERIA Warp(JDBC Driver 接続で利用)
  • CDataSync

なお、CData API Driverは上記以外にも様々なツールと連携することが可能です。

www.cdata.com

f:id:sugimomoto:20201120133303p:plain

テーブル(ビュー)一覧

CData API Drvier で freee プロジェクト管理 APIに接続するためには専用の設定ファイル(Profile)が必要になります。

freee プロジェクト管理 API Profile では、以下のテーブル(ビュー)を提供しています。用途に合わせて、接続してみてください。

Name Resource API Reference
PartnerProjectAsContractors 取引先の一覧取得(発注元として登録されているプロジェクト一覧) Link
PartnerProjectAsOrderers 取引先の一覧取得(発注先として登録されているプロジェクト一覧) Link
Partners 取引先の一覧取得 Link
People 従業員一覧の取得 Link
ProjectBalance プロジェクト詳細の取得(収支管理詳細) Link
ProjectConstractors プロジェクト一覧の取得(発注先) Link
ProjectMembers プロジェクト一覧の取得(プロジェクトメンバー) Link
ProjectOrderers プロジェクト一覧の取得(発注元) Link
Projects プロジェクト一覧の取得 Link
ProjectTags プロジェクト一覧の取得(プロジェクトタグ) Link
ProjectWorkloadTagGroups プロジェクト一覧の取得(プロジェクトで使える工数タグのグループ) Link
TeamMembers チームの一覧取得(チームに登録されているメンバー) Link
Teams チームの一覧取得 Link
UnitCostRules 単価マスタの取得(期間ごとの適用金額の配列) Link
UnitCosts 単価マスタの取得 Link
UsersMe ログインユーザー情報の取得 Link
Workloads 工数詳細の取得 Link
WorkloadSummaries 工数実績の取得 Link

freee プロジェクト管理 API 利用準備

最初にfreee プロジェクト管理のAPIを利用するために、freee プロジェクト管理側でアプリケーション登録を行います。

詳しくは以下の記事を参照してみてください。

developer.freee.co.jp

アプリを作成したら、コールバックURLを設定しましょう。

コールバックURLはドライバーの場合だと「http://localhost:33333」、CData Sync の場合は「http://localhost:8019/src/oauthCallback.rst」を指定します。

f:id:sugimomoto:20210813162341p:plain

権限は上記テーブルの一覧から、利用する機能に併せて設定してください。

f:id:sugimomoto:20210813162406p:plain

設定後、ClientId・Client Secretを控えておきます。

API データ処理用 設定ファイルを作成

続いて、freee プロジェクト管理 の API を CData API Deiver が解釈できるように設定ファイル(API Profile)を作成します。

すでに私が作成したものがあるので、以下のURLからダウンロードしてください。

https://cdatajbuilds.s3.ap-northeast-1.amazonaws.com/APIProfiles/FreeePM.apip

保存先フォルダは後ほど使用するので「C:\APIProfiles\FreeePM.apip」といったツールからアクセスが可能な任意のフォルダに配置してください。

CData API Driver のインストール

各種ツールとfreee プロジェクト管理 API を繋ぐために必要となるCData API Driverをインストールします。

基本的なインストール・設定方法は各種Driver共通ですので、ここではODBC Driverを例に説明します。

まず、CData API ODBC Driverの30日間の評価版をダウンロードします。ダウンロードの際には、Emailの登録が必要となります。

www.cdata.com

f:id:sugimomoto:20201027111336p:plain

ダウンロードしたsetup.exeファイルをBIツールがインストールされているマシンにインストールします。インストールウィザードに従い、EULAを確認した上でインストールを完了します。

f:id:sugimomoto:20201027111341p:plain

※途中、ライセンスサーバーへのオンラインアクティベーションが行われるためネットワーク環境に接続されている必要があります。

インストールが完了すると、ODBCのDSN設定のウィンドウが立ち上がります。

以下の項目をセットし、「接続のテスト」をクリックします。

プロパティ名 備考
Profile C:\APIProfiles\FreeePM.apip 予めダウンロードしたfreee プロジェクト管理 .apipのパスを指定します。
ProfileSettings CompanyId=XXXXX; 接続先となるCompanyIdを指定します。
Auth Scheme OAuth
Initiate OAuth GETANDREFRESH
OAuth Client Id 例)3cdebb30b42c77a56970f6e58740 登録したアプリのClient IDを指定します。
OAuth Client Secret 例)a931e9558edb8020c003074523512 登録したアプリのClient Secret を指定します。
Callback URL http://localhost:33333 Redirect URL を指定します。

f:id:sugimomoto:20210916095728p:plain

入力後「接続のテスト」をクリックすると、ブラウザが立ち上がり、freee へのログインおよび認可が求められます。

設定されている情報を確認し「許可する」をクリックしましょう。

f:id:sugimomoto:20210813162419p:plain

これで CData API Driver から freee API への接続が完了します。

f:id:sugimomoto:20210813162426p:plain

それでは実際に各種ツールからの接続方法を解説していきましょう。

Excel から freee プロジェクト管理 API に接続(Excel Add-in for API)

CData Excel Add-in for API をインストール後、Excelを立ち上げるとCDataタブが追加されていることがわかります。このタブから各種操作を実施します。

接続を開始するには、CDataタブから[取得元 API]をクリックします。

f:id:sugimomoto:20201116171024p:plain

最初に接続するためのウィザードが表示されるので、「CData API Driverのインストール」の内容と同様に各種パラメータを入力します。

f:id:sugimomoto:20210916095734p:plain

接続後、対象テーブルを選択し、クエリを編集の上、「OK」をクリックします。

f:id:sugimomoto:20210916095738p:plain

f:id:sugimomoto:20210916095741p:plain

クリック後、対象のデータが一括で取得できます。

f:id:sugimomoto:20210916095746p:plain

Access リンクテーブル から freee プロジェクト管理 API に接続(CData API ODBC Driver)

次はCData ODBC Driverを利用して、Access リンクテーブルから接続してみたいと思います。

あらかじめ新規にAccessを立ち上げて、空のデータベースを作成しておきましょう。

続いて「外部データ」タブから「新しいデータ ソース」→「他のソースから」→「ODBC データベース」を選択します。

f:id:sugimomoto:20210813162454p:plain

ウィザードが表示されるので「リンクテーブルを作成」を選択し、「OK」をクリックします。

f:id:sugimomoto:20210813162459p:plain

データソースの選択では「コンピューターデータソース」から事前に作成したCData API Driver用DSNを選択し「OK」をクリック

f:id:sugimomoto:20210916095752p:plain

テーブルの一覧が表示されるので、任意のテーブルを選択し「OK」をクリックします。

f:id:sugimomoto:20210916095756p:plain

設定後、リンクテーブルが追加され、以下のようにfreee プロジェクト管理のデータを閲覧することができるようになります。もちろん、通常通りクエリデザイナーでも使用可能です。

f:id:sugimomoto:20210916095801p:plain

PowerBI から freee プロジェクト管理 API に接続(CData API Driver for Power BI)

最後にCData Power BI API Connector を用いて、Power BIからfreee プロジェクト管理のデータを取得します。

PowerBI Desktopを起動して、「データを取得」をクリックします。

f:id:sugimomoto:20201027111449p:plain

データ接続先一覧の中から「CData API」を選択し、「接続」をクリックします。

f:id:sugimomoto:20201027111519p:plain

データソース名は先程登録したfreee プロジェクト管理のDSNを入力し「OK」をクリックします。

f:id:sugimomoto:20210916095809p:plain

テーブルの一覧から対象となるテーブルを選択し「読み込み」をクリックします。

f:id:sugimomoto:20210916095830p:plain

以下のようにfreee プロジェクト管理のデータを読み込みことができます。

f:id:sugimomoto:20210916095835p:plain

あとはPoewr BIの機能を用いて、ビジュアライズに利用することができます。

f:id:sugimomoto:20210916095840p:plain

ASTERIA Warp から freee プロジェクト管理 API に接続(CData JDBC API Driver)

ASTERIA Warpでは、フローデザイナーを使って、データ処理のプロセスを作成します。

フローデザイナーの基本的な利用方法についてはWarpのフローデザイナー操作ガイドをご覧ください。

CData JDBC API Driver はインストール後、「cdata.jdbc.api.jar」と「cdata.jdbc.api.lic」のファイルをAsteriaのドライバーフォルダ(asteriahome5\system\lib\drivers)に登録します。

f:id:sugimomoto:20210218152238p:plain

その後、ASTERIA Warpを立ち上げて、フローデザイナーにアクセスし、CData JDBC Driverを使用するために接続を追加します。

画面左のコネクションペイン上にある電源ボタンをクリックをクリックすると、「コネクションの作成」ダイアログが表示されます。

f:id:sugimomoto:20210216154030p:plain

「接続種別」として「RDB」を選択、「名前」に分かりやすい名前を設定し「OK」をクリックします。

f:id:sugimomoto:20210916095847p:plain

作成したコネクションをダブルクリックすると、画面右のインスペクタに接続プロパティが表示されます。 「基本」タブでドライバーのパスとURLをそれぞれ設定します。

プロパティ名 備考
ドライバーのパス 例)C:\asteriahome5\system\lib\drivers\cdata.jdbc.api.jar 前節でインストールした API JDBC Driverファイルへの参照を指定します。
URL jdbc:api:Profile=C:\Publish\lib\v21\APIProfiles\FreeePM.apip;
ProfileSettings="CompanyId=XXX";
AuthScheme=OAuth;
InitiateOAuth=GETANDREFRESH;
OAuthClientId=XXXX;OAuthClientSecret=XXXXX;
callbackurl=http://localhost:33333;

f:id:sugimomoto:20210916095852p:plain

構成後、「接続のテスト」を実行して、成功すればOKです。

f:id:sugimomoto:20210813162555p:plain

これでコネクションの作成は完了です。あとは、フロー上でデータベースタブにある「RDBGet」のコンポーネントを使って、データの取得が行なえます。

「RDBGet」フローに配置し、ダブルクリックします。

f:id:sugimomoto:20210216180653p:plain

コネクションの選択ウインドウが表示されるので、先程作成したfreee プロジェクト管理のコネクションを選択しましょう。

f:id:sugimomoto:20210916095857p:plain

その後、SQLビルダーが表示されるので、取得したいデータが格納されている、任意のテーブルとカラムを選択します。

f:id:sugimomoto:20210916095901p:plain

あとは、「モデルにSQLを適用する」をクリックし「SELECTテスト」でデータが正常に取得できているかを確認します。

以下のようにデータが参照できれいればOKです。設定を保存してSQLビルダーを閉じます。

f:id:sugimomoto:20210916095906p:plain

あとは Asteria Warp の機能で様々なサービスと freee のデータの連携を実現できます。

CData Sync から freee プロジェクト管理 に接続

www.cdata.com

CData Sync ではデータソースとして、freee プロジェクト管理に接続することができます。

なお、CData Sync Windows版の場合は「freeeHR.apip」のプロファイルをSyncの本体が存在するフォルダの「www\app_data\profiles」に配置してください。profilesフォルダが存在しない場合は手動で作成してください。

C:\ProgramData\CData\sync\profiles

Cross-Platform版の組み込みJettyで構成している場合は、以下のフォルダにapipファイルを配置します。

/opt/sync/profiles

配置後、CDataSyncを起動すると以下のようにデータソースとして freee プロジェクト管理が利用できるようになります。

f:id:sugimomoto:20210916095910p:plain

また、接続する前にコールバックURLに「http://localhost:8019/src/oauthCallback.rst」を指定しておきましょう。

f:id:sugimomoto:20210813162659p:plain

接続プロパティは以下の通り設定します。

プロパティ名 備考
Other ComapnyIdy=XXXXX;
OAuth Client Id 例)3cdebb30b42c77a56970f6e58740 登録したアプリのClient IDを指定します。
OAuth Client Secret 例)a931e9558edb8020c003074523512 登録したアプリのClient Secret を指定し
Auth Scheme OAuth Advancedタブの項目です。

入力後、「接続」ボタンをクリックし、接続テストが完了すればOKです。

f:id:sugimomoto:20210916095917p:plain

併せて、任意の同期先の接続情報も構成しておきましょう。

f:id:sugimomoto:20210311162106p:plain

接続完了後、新しくジョブを作成します。

f:id:sugimomoto:20210311162114p:plain

先程作成した freee プロジェクト管理 のコネクションを選択します。

f:id:sugimomoto:20210916095922p:plain

ジョブを作成した後は、freee プロジェクト管理 の同期対象となる任意のテーブルを選択しましょう。

f:id:sugimomoto:20210916095926p:plain

データのプレビュー画面で、実際に取得が成功しているかどうかを確認できました。

f:id:sugimomoto:20210916095930p:plain

あとは、任意のスケジュールを指定してデータのレプリケーションを実行できます。

f:id:sugimomoto:20210311162149p:plain

試しに手動で実行してみると、それぞれのレプリケーション件数が結果として表示されます。

f:id:sugimomoto:20210916095934p:plain

RDBの中でもレプリケーションされたデータが確認できました。

f:id:sugimomoto:20210916095939p:plain

終わりに

これら以外にもCData API Driverは各種ETLツールや帳票ツールなどからも接続することが可能です。

以下のCData オンラインナレッジベースには、各種ツールからの接続方法を紹介した記事が多数掲載されているので、是非見てみてください。

https://www.cdata.com/jp/kb/

不明な点があれば、テクニカルサポートまでお気軽にどうぞ!

https://www.cdata.com/jp/support/submit.aspx

トライアル・お問い合わせ

関連コンテンツ