Object APIs
ご覧のページは、お客様の利便性のために一部機械翻訳されています。また、ドキュメントは頻繁に更新が加えられており、翻訳は未完成の部分が含まれることをご了承ください。最新情報は都度公開されておりますため、必ず英語版をご参照ください。翻訳に問題がある場合は、 こちら までご連絡ください。

候補リストAPIの基本

Liferay は、ピックリスト定義 (ListTypeDefinition) とそのエントリ (ListTypeEntry) を作成および管理するための headless-admin-list-types REST API を提供しています。 RESTサービスメニューの[server]:[port]/o/api (例: localhost:8080/o/api)にあるLiferayのAPIエクスプローラーで利用できるAPIを表示し、テストすることができます。

headless-admin-list-typeで候補リストのAPIにアクセスします。

ピックリストを作成および管理するには、 headless-admin-list-types サービスを呼び出します。

候補リストを追加する

新しいLiferay DXPインスタンスを起動し、以下を実行します。

docker run -it -m 8g -p 8080:8080 liferay/dxp:2025.q1.6-lts

メールアドレス test@liferay.com とパスワード testを使用して、 http://localhost:8080 で Liferay にサインインします。 プロンプトが表示されたら、パスワードを learnに変更します。

次に、サンプル コードを準備します。

  1. Picklists API Basicsをダウンロードして解凍します。

    curl https://resources.learn.liferay.com/examples/liferay-v3n6.zip -O
    
    unzip liferay-v3n6.zip
    
  2. cURLスクリプトを使用して、新しい候補リストをインスタンスに追加します。 コマンドラインで、curlフォルダに移動します。 ListTypeDefinitions_POST_ToInstance.sh スクリプトを実行します。

    ./ListTypeDefinitions_POST_ToInstance.sh
    

    JSONのレスポンスには、新しい候補リストが追加されたことが示されています。

    "dateCreated" : "2022-11-17T18:42:13Z",
    "dateModified" : "2022-11-17T18:42:13Z",
    "id" : 47502,
    "listTypeEntries" : [ ],
    "name" : "Foo",
    "name_i18n" : {
       "en-US" : "Foo"
    }
    
  3. グローバル メニューコントロール パネルピックリストに移動します。 新しい候補リストが表示されます。

    新しい候補リストが追加されたことを確認します。

  4. または、Javaクライアントを使用してRESTサービスを呼び出すことができます。 java

    javac -classpath .:* *.java
    
  5. ListTypeDefinitions_POST_ToInstance.java クラスを実行します。

    java -classpath .:* ListTypeDefinitions_POST_ToInstance
    

cURLコマンドの検証

ListTypeDefinitions_POST_ToInstance.sh スクリプトは、cURL を使用して REST サービスを呼び出します。

curl \
	"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions" \
	--data-raw '
		{
			"name": "Foo",
			"name_i18n": {
				"en_US": "Foo"
			}
		}' \
	--header "Content-Type: application/json" \
	--request "POST" \
	--user "test@liferay.com:learn"

ここでは、コマンドの引数を紹介します。

引数説明
-H "Content-Type: application/json"リクエストボディのフォーマットがJSONであることを示します。
-X POST指定されたエンドポイントで起動するHTTPメソッド
"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions"RESTサービスのエンドポイント
-d "{\"name\": \"Foo\", \"name_i18n\": {\"en_US\": \"Foo\"}}"お客様が掲載を希望するデータ
-u "test@liferay.com:learn"基本的な認証情報

ここでは、デモのために基本的な認証を使用しています。 本番環境では、 OAuth2経由でユーザーを認証する必要があります。

他のcURLコマンドも同様のJSON引数を使用しています。

Javaクラスを調べる

ListTypeDefinitions_POST_ToInstance.java クラスは、 ListType関連サービスを呼び出してピックリストを追加します。

public static void main(String[] args) throws Exception {
	ListTypeDefinitionResource.Builder builder =
		ListTypeDefinitionResource.builder();

	ListTypeDefinitionResource listTypeDefinitionResource =
		builder.authentication(
			"test@liferay.com", "learn"
		).build();

	ListTypeDefinition listTypeDefinition =
		listTypeDefinitionResource.postListTypeDefinition(
			new ListTypeDefinition() {
				{
					name = "Foo";
					name_i18n = Collections.singletonMap("en_US", "Foo");
				}
			});

	System.out.println(listTypeDefinition);
}

このクラスは、3行のコードでRESTサービスを呼び出します。

行(省略形)説明
ListTypeDefinitionResource.Builder builder = ...ListTypeDefinitionResourceサービスインスタンスを生成するためのBuilderを取得します。
ListTypeDefinitionResource listTypeDefinitionResource = builder.authentication(...).build();基本認証を指定し、ListTypeDefinitionResourceサービスインスタンスを生成します。
ListTypeDefinition listTypeDefinitionResource = listTypeDefinitionResource.postListTypeDefinition(...);listTypeDefinitionResource.postListTypeDefinitionメソッドを呼び出し、投稿するデータを渡します。

プロジェクトには、依存関係としてcom.liferay.headless.admin.list.type.clientファイルが含まれていることに注意してください。 すべての REST アプリケーションのクライアント JAR 依存関係情報は、インストールの API エクスプローラーの /o/api (例: http://localhost:8080/o/api) で確認できます。

メイン メソッドのコメントは、クラスの実行を示しています。

他のJavaクラスも同様に、異なるListTypeDefinitionResourceメソッドを呼び出します。

重要

サービスの詳細については、 ListTypeDefinitionResource を参照してください。

以下は、cURLとJavaを使用して、他の ListTypeDefinition RESTサービスを呼び出す例です。

インスタンスから候補リストを取得する

以下のcURLまたはJavaコマンドを実行することで、候補リストの一覧を表示することができます。

ListTypeDefinitions_GET_FromInstance.sh

コマンド:

./ListTypeDefinitions_GET_FromInstance.sh

コード:

curl \
	"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions" \
	--user "test@liferay.com:learn"

ListTypeDefinitions_GET_FromInstance.java

コマンド:

java -classpath .:* ListTypeDefinitions_GET_FromInstance

コード:

public static void main(String[] args) throws Exception {
	ListTypeDefinitionResource.Builder builder =
		ListTypeDefinitionResource.builder();

	ListTypeDefinitionResource listTypeDefinitionResource =
		builder.authentication(
			"test@liferay.com", "learn"
		).build();

	Page<ListTypeDefinition> page =
		listTypeDefinitionResource.getListTypeDefinitionsPage(
			null, null, null, Pagination.of(1, 2), null);

	System.out.println(page);
}

インスタンスのPicklistオブジェクトがJSONで表示されます。

候補リストを取得する

以下のcURLまたはJavaコマンドで、特定の候補リストを取得します。

ヒント

ListTypeDefinitions_GET_FromInstance.[java|sh] を使用して、インスタンス Picklist ID を取得します。

リストタイプ定義_GET_ById.sh

コマンド:

./ListTypeDefinitions_GET_ById.sh 1234

コード:

curl \
	"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions/${1}" \
	--user "test@liferay.com:learn"

リストタイプ定義_GET_ById.java

コマンド:

java -classpath .:* -DlistTypeDefinitionId=1234 ListTypeDefinitions_GET_ById

コード:

public static void main(String[] args) throws Exception {
	ListTypeDefinitionResource.Builder builder =
		ListTypeDefinitionResource.builder();

	ListTypeDefinitionResource listTypeDefinitionResource =
		builder.authentication(
			"test@liferay.com", "learn"
		).build();

	System.out.println(
		listTypeDefinitionResource.getListTypeDefinition(
			Long.valueOf(System.getProperty("listTypeDefinitionId"))));
}

PicklistフィールドはJSONで表示されます。

候補リストへのパッチ

cURLとJavaパッチコマンドで、既存の候補リストを編集します。 1234を候補リストのIDに置き換えます。

リストタイプ定義_PATCH_ById.sh

コマンド:

./ListTypeDefinitions_PATCH_ById.sh 1234

コード:

curl \
	"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions/${1}" \
	--data-raw '
		{
			"name": "Bar",
			"name_i18n": {
				"en_US": "Bar"
			}
		}' \
	--header "Content-Type: application/json" \
	--request "PATCH" \
	--user "test@liferay.com:learn"

リストタイプ定義_PATCH_ById.java

コマンド:

java -classpath .:* -DlistTypeDefinitionId=1234 ListTypeDefinitions_PATCH_ById

コード:

public static void main(String[] args) throws Exception {
	ListTypeDefinitionResource.Builder builder =
		ListTypeDefinitionResource.builder();

	ListTypeDefinitionResource listTypeDefinitionResource =
		builder.authentication(
			"test@liferay.com", "learn"
		).build();

	ListTypeDefinition listTypeDefinition =
		listTypeDefinitionResource.patchListTypeDefinition(
			Long.valueOf(System.getProperty("listTypeDefinitionId")),
			new ListTypeDefinition() {
				{
					name = "Bar";
					name_i18n = Collections.singletonMap("en_US", "Bar");
				}
			});

	System.out.println(listTypeDefinition);
}

候補リストを配置する

cURLとJavaの put コマンドで、既存の候補リストを完全に上書きします。 1234を候補リストのIDに置き換えます。

リストタイプ定義_PUT_ById.sh

コマンド:

./ListTypeDefinitions_PUT_ById.sh 1234

コード:

curl \
	"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions/${1}" \
	--data-raw '
		{
			"name": "Goo",
			"name_i18n": {
				"en_US": "Goo"
			}
		}' \
	--header "Content-Type: application/json" \
	--request "PUT" \
	--user "test@liferay.com:learn"

リストタイプ定義_PUT_ById.java

コマンド:

java -classpath .:* -DlistTypeDefinitionId=1234 ListTypeDefinitions_PUT_ById

コード:

public static void main(String[] args) throws Exception {
	ListTypeDefinitionResource.Builder builder =
		ListTypeDefinitionResource.builder();

	ListTypeDefinitionResource listTypeDefinitionResource =
		builder.authentication(
			"test@liferay.com", "learn"
		).build();

	ListTypeDefinition listTypeDefinition =
		listTypeDefinitionResource.putListTypeDefinition(
			Long.valueOf(System.getProperty("listTypeDefinitionId")),
			new ListTypeDefinition() {
				{
					name = "Goo";
					name_i18n = Collections.singletonMap("en_US", "Goo");
				}
			});

	System.out.println(listTypeDefinition);
}

候補リストを削除する

cURLとJavaの delete コマンドで既存の候補リストを削除します。 1234を候補リストのIDに置き換えます。

リストタイプ定義_DELETE_ById.sh

コマンド:

./Picklist_DELETE_ById.sh 1234

コード:

curl \
	"http://localhost:8080/o/headless-admin-list-type/v1.0/list-type-definitions/${1}" \
	--request "DELETE" \
	--user "test@liferay.com:learn"

リストタイプ定義_DELETE_ById.java

コマンド

java -classpath .:* -DlistTypeDefinitionId=1234 ListTypeDefinitions_DELETE_ById

コード:

public static void main(String[] args) throws Exception {
	ListTypeDefinitionResource.Builder builder =
		ListTypeDefinitionResource.builder();

	ListTypeDefinitionResource listTypeDefinitionResource =
		builder.authentication(
			"test@liferay.com", "learn"
		).build();

	listTypeDefinitionResource.deleteListTypeDefinition(
		Long.valueOf(System.getProperty("listTypeDefinitionId")));
}

候補リストエントリサービス

候補リストを作成したら、以下のサービスを利用して、候補リストのエントリーを作成・管理します。 ListTypeEntryのcURLコマンドとJavaクラスはListTypeDefinitionのように機能します。 サービスによっては、候補リストIDを渡す必要があります。

ファイル説明
ListTypeEntries_GET_FromListTypeDefinition.[java\|sh]候補リストから候補リストエントリーの一覧を取得します。
ListTypeEntries_DELETE_ById.[java\|sh]候補リストエントリーを削除します。
ListTypeEntries_GET_ById[java\|sh]IDで特定の候補リストエントリーを取得します。
ListTypeEntries_POST_ToListTypeDefinition.[java\|sh]候補リストにエントリーを投稿します。
ListTypeEntries_PUT_ById.[java\|sh]候補リストエントリーを配置します。

API エクスプローラー には、すべての ListTypeDefinition および ListTypeEntry サービスとスキーマが表示され、各サービスをテストするためのインターフェースがあります。