ナレッジベースAPIの基本
ナレッジベース記事の作成とナレッジベースの管理はLiferayのナレッジベースアプリでできますが、Liferay のREST APIを使うことも可能です。 ナレッジベースのコンテンツを作成・管理するために、これらのサービスを呼び出します。
ナレッジベースの記事を追加する
新しいLiferay DXPインスタンスを起動し、以下を実行します。
メールアドレス test@liferay.com とパスワード test を使用して、http://localhost:8080でLiferayにサインインしてください。 プロンプトが表示されたら、パスワードを learn に変更します。
次に、以下の手順を実行します。
-
Knowledge Base API Basics をダウンロードして解凍します。
-
ログインすると、 サイトのIDを取得します 。 このIDは、いくつかのサービス呼び出しで使用します。
-
cURLスクリプトを使用して、サイトに新しいナレッジベースの記事を追加します。 コマンドラインで、
curl
フォルダに移動します。 サイトIDをパラメーターとして使用して、KnowledgeBaseArticle_POST_ToSite.sh
スクリプトを実行します。 例えば、JSON応答では、新しいナレッジベースの記事が追加されたことを示しています。
-
メニュー アイコン(
)をクリックし、 [コンテンツとデータ] → [ナレッジベース] に移動します。 新しいナレッジベースの記事が追加されたことを確認します。
-
RESTサービスは、Javaクライアントを使って呼び出すこともできます。
curl
フォルダから、java
フォルダに移動します。 ソースファイルをコンパイルします。 -
KnowledgeBaseArticle_POST_ToSite.java
クラスを実行します。siteId
システムプロパティ値をサイトのIDに置き換えます。Javaクラスにより、新しいナレッジベース記事が作成されました。
cURLコマンドの検証
KnowledgeBaseArticle_POST_ToSite.sh
スクリプトは、cURLコマンドを使用してRESTサービスを呼び出します。
コマンドの引数は次のとおりです。
引数 | 説明 |
---|---|
-H "Content-Type: application/json" | リクエストボディのフォーマットがJSONであることを示します。 |
-X POST | 指定されたエンドポイントで起動するHTTPメソッド |
"http://localhost:8080/o/headless-delivery/v1.0/sites/${1}/knowledge-base-articles" | RESTサービスのエンドポイント |
-d "{\"articleBody\": \"Foo\", \"title\": \"Able\"}" | お客様が掲載を希望するデータ |
-u "test@liferay.com:learn" | 基本的な認証情報 |
デモのために基本認証を使用しています。 本番環境の場合は、OAuth2経由でユーザーを認証する必要があります。 OAuth2を使用したReactアプリケーションのサンプルは、OAuth2によるユーザーの認証をご覧ください。
他のcURLコマンドも同様のJSON引数を使用します。
Javaクラスを調べる
KnowledgeBaseArticle_POST_ToSite.java
クラスは、ナレッジベース関連サービスを呼び出してナレッジベースの記事を追加します。
このクラスは、次の3行のコードのみを使用してRESTサービスを呼び出します。
行(省略形) | 説明 |
---|---|
KnowledgeBaseArticleResource.Builder builder = ... | Builder を取得し、KnowledgeBaseArticleResource サービスインスタンスを生成します。 |
KnowledgeBaseArticleGroupResource knowledgeBaseArticleGroupResource = builder.authentication(...).build(); | 基本認証を指定し、KnowledgeBaseArticleResource </0>サービスインスタンスを生成します。 |
KnowledgeBaseArticle knowledgeBaseArticle = knowledgeBaseArticleResource.postSiteKnowledgeBaseArticle(...); | knowledgeBaseArticleResource.postSiteKnowledgeBaseArticle メソッドを呼び出し、データを投稿に渡します。 |
プロジェクトには、依存関係としてcom.liferay.headless.delivery.client.jar
ファイルが含まれていることに注意してください。 すべてのRESTアプリケーションのクライアントJAR依存関係情報は、/o/api
でインストール先のAPIエクスプローラーで確認できます。
main
メソッドのコメントでは、クラスの実行を実演しています。
他の例のJavaクラスはこれと類似していますが、異なるKnowledgeBaseArticle
メソッドを呼び出します。
サービスの詳細は、 KnowledgeBaseArticleResource を参照してください。
以下は、cURLとJavaを使って、他のKnowledgeBaseArticle
RESTサービスを呼び出す例です。
サイトからナレッジベース記事を取得する
次のcURLまたはJavaコマンドを実行すると、全てのサイトからナレッジベースの記事を取得できます。 1234
をサイトのIDに置き換えてください。
KnowledgeBaseArticles_GET_FromSite.sh
コマンド:
コード:
KnowledgeBaseArticles_GET_FromSite.java
コマンド:
コード:
インスタンスのKnowledgeBaseArticles
オブジェクトがJSONで表示されます。
ナレッジベースの記事を取得する
以下のcURLまたはJavaコマンドを使用し、特定のナレッジベースの記事をIDで取得します。
KnowledgeBaseArticles_GET_FromSite.[java|sh]
を使用して、インスタンスKnowledge Base Article
IDを取得します。
KnowledgeBaseArticle_GET_ById.sh
コマンド:
コード:
KnowledgeBaseArticle_GET_ById.java
コマンド:
コード:
KnowledgeBaseArticle
フィールドは、JSONで表示されます。
ナレッジベースの記事にパッチを適用する
次のcURLおよびJavaコマンドを使用して、既存のナレッジベースの記事を部分的に編集します。 1234
をナレッジベース記事のIDに置き換えてください。 修正したいフィールドとその新規値を指定します。
KnowledgeBaseArticle_PATCH_ById.sh
コマンド:
コード:
KnowledgeBaseArticle_PATCH_ById.java
コマンド:
コード:
ナレッジベース記事を上書きする
次のcURLおよびJavaコマンドを使用して、既存のナレッジベースの記事を完全に上書きします。 1234
をナレッジベース記事のIDに置き換えてください。
KnowledgeBaseArticle_PUT_ById.sh
コマンド:
コード:
KnowledgeBaseArticle_PUT_ById.java
コマンド:
コード:
ナレッジベース記事を削除する
次のcURLおよびJavaコマンドを使用して、既存のナレッジベースの記事を削除します。 1234
をナレッジベース記事のIDに置き換えてください。
KnowledgeBaseArticle_DELETE_ById.sh
コマンド:
コード:
KnowledgeBaseArticle_DELETE_ById.java
コマンド
コード:
ナレッジベースフォルダサービス
ナレッジベースフォルダ用のcURLコマンドとJavaクラスは、ナレッジベースの記事と同じように機能します。
ファイル | 説明 |
---|---|
KnowledgeBaseFolder_DELETE_ById.[java\|sh] | ナレッジベースフォルダをIDで削除する。 |
KnowledgeBaseFolder_GET_ById.[java\|sh] | 特定のナレッジベースフォルダをIDで取得する |
KnowledgeBaseFolder_PATCH_ById.[java\|sh] | IDでナレッジベースフォルダにパッチを適用する。 |
KnowledgeBaseFolder_POST_ToSite.[java\|sh] | ナレッジベースフォルダをサイトに投稿する。 |
KnowledgeBaseFolder_PUT_ToSite.[java\|sh] | ナレッジベースフォルダをIDで上書きする。 |
KnowledgeBaseFolders_GET_FromSite.[java\|sh] | サイトからナレッジベースフォルダの一覧を取得する。 |
APIエクスプローラーには、KnowledgeBaseArticle
およびKnowledgeBaseFolder
のすべてのサービスとスキーマが表示され、各サービスを試すためのインターフェースがあります。