2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

SalesforceAdvent Calendar 2024

Day 5

LWCからRestAPI呼び出し方法の振り返る

Last updated at Posted at 2024-12-04

目的

ご閲覧ありがとうございます。オレンジ羽のlibra189です。
転職を機におおよそ2年ぶりにSalesforceの案件を担当する事になりました。色々と忘れていたので忘備録として記録していきたいと思います。
今回はLWC(Lightning Web Component)からREST APIを呼び出す設定、実装方法の手順です。

前提条件

  • SalesforceのDeveloper環境
  • APIバージョン:62.0
  • SFDX CLIのインストール
  • VS CodeとDeveloper環境との連携

Salesforceの設定

リモートサイト設定

Salesforceはセキュリティ上、事前にアクセス可能な外部ドメインを許可する必要があります。
今回は簡略化のために認証不要で利用できる PokeAPI(https://pokeapi.co) を利用します。
本来はJWT Web トークンなどで認証する必要があります。

PokeAPIについては下記記事で詳細に説明していただいているのでご参照ください。
PokeAPIで取得できるポケモンのデータを簡単にまとめてみた - Qiita

  1. 設定 > セキュリティ > リモートサイト設定 を開く。
  2. 「新規リモートサイト」ボタンからAPIの呼び出す外部のベースURL https://pokeapi.co を「リモートサイトの URL」に入力。他の項目は適宜入力してください。

REST API呼び出しのApexクラス作成

HttpRequestを使ったAPI呼び出し

APIを呼び出すApexクラスを作成します。
今回のAPIは認証不要のため、認証ヘッダーはコメントアウトしています。必要な場合は適宜設定してください。

サンプルコードは長いので、折りたたんでいます。
public class PokeApiService {
    @AuraEnabled(cacheable=true) // クライアントにメソッドの結果をキャッシュ
    public static String callExternalApi(Integer id) {
        try {
            // HTTPリクエストを作成
            HttpRequest req = new HttpRequest();
            req.setEndpoint('https://pokeapi.co/api/v2/pokemon/' + String.valueOf(id)); // 外部APIのエンドポイント
            req.setMethod('GET'); // HTTPメソッド
            // req.setHeader('Authorization', 'Bearer YOUR_ACCESS_TOKEN'); // 認証ヘッダー
            req.setHeader('Content-Type', 'application/json'); // 必要なヘッダー
            req.setTimeout(120000); // タイムアウト時間を設定

            // HTTPリクエストを送信
            Http http = new Http();
            HttpResponse res = http.send(req);

            // ステータスコードとレスポンス処理
            if (res.getStatusCode() == 200) {
                System.debug('Response: ' + res.getBody());
                return res.getBody();
            } else {
                System.debug('Error: ' + res.getStatusCode() + ' ' + res.getStatus());
                return null;
            }
        } catch (Exception e) {
            System.debug('Exception: ' + e.getMessage());
            return null;
        }
    }
}

API呼び出しのテスト

設定ボタンから開発者コンソールを開き、「Ctrl + E」を押して、「Execute Anonymous Window」に移ります。
下記のコードを入力し、ログにレスポンスが出ていれば動作テスト完了です。

Integer id = 1;
String response = PokeApiService.callExternalApi(id);
System.debug('API Response: ' + response);

LWCの作成

LWCの実装

サンプルコードは長いので、折りたたんでいます。
FetchPokemon
<template>
    <div class="external-api-container">
        <lightning-card title="External API Data" icon-name="standard:record">
            <div class="slds-p-around_medium">
                <template if:true={apiResponse}>
                    <pre class="response-display">{apiResponse}</pre>
                </template>

                <template if:true={errorMessage}>
                    <div class="slds-theme_error">
                        <p>{errorMessage}</p>
                    </div>
                </template>

                <template if:false={apiResponse}>
                    <lightning-spinner alternative-text="Loading" size="medium">
                    </lightning-spinner>
                </template>
            </div>
        </lightning-card>
    </div>
</template>
fetchPokemon.js
import { LightningElement, wire } from 'lwc';
import callExternalApi from "@salesforce/apexPokeApiService.callExternalApi";

export default class FetchPokemon extends LightningElement {
    apiResponse;
    errorMessage;

    @wire(callExternalApi, {
        id: 1, // 簡略化のため固定値
    })
    wiredAPIData({ error, data }) {
        if (data) {
            this.apiResponse = data;
        } else if (error) {
            this.errorMessage = error;
        }
    }
}
fetchPokemon.js-meta.xml
<?xml version="1.0" encoding="UTF-8"?>
<LightningComponentBundle xmlns="http://soap.sforce.com/2006/04/metadata">
    <apiVersion>62.0</apiVersion>
    <isExposed>true</isExposed>
    <targets>
        <target>lightning__RecordPage</target>
        <target>lightning__AppPage</target>
        <target>lightning__HomePage</target>
    </targets>
    <targetConfigs>
        <targetConfig targets="lightning__RecordPage">
            <objects>
                <object>Account</object>
                <object>Contact</object>
            </objects>
        </targetConfig>
    </targetConfigs>
</LightningComponentBundle>

コンポーネントの配置

今回はアプリケーションページ、ホームページまたは、取引先(Account)、取引先責任者(Contact)のレコード詳細ページに配置できるようにXMLの設定をしたので、いづれかにコンポーネントを配置し、動作を確認すれば完了です。

まとめ

以上で大まかな流れと実装は完了です。
今回は簡略化のために認証不要としましたが、本来であれば認証は必須です。呼び出す外部APIの認証方法に合わせてカスタマイズが必要です。
外部システムとの連携にはREST API以外に連携ツールとしてSalesforce社のMuleSoftがあります。
価格面で難ありと聞いているので、案件があるかは不明ですが、キャッチアップを続けて、資格取得を目指したいです。

参考

2
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
2
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?