Objectifyで簡単DataStore操作(GWT-RPCでモデルの受け渡しを実装する)

Objectifyを使ってクライアント<—>サーバ間でオブジェクトの受け渡しをしてみたいと思います。そのためにはGWT-RPCでいくつか実装をする必要があります。Googleプラグインでプロジェクトを新規作成したときに自動で生成される
GreetingService.greetServer(String name)がそのサンプルです。

private void sendNameToServer()

で呼んでいますね。
GWT-RPCに独自メソッドを実装する場合3つのファイルにタッチする必要があります。

  • GreetingService.java RPCメソッドの定義です。
  • GreetingServiceImpl.java上記RPCメソッドの実装です。
  • GreetingServiceAsync.java クライアントからはここで定義した形で呼び出します。Ajaxで値が返ってきたとき受け取るコールバックも定義しています。

GWT-RPCメソッドの実装


2つのメソッドを実装します。
registerCar(Car car); // 生成したCarオブジェクトをDataStoreに登録します。
getCar(String name); // “name”が一致したCarオブジェクトをDataStoreから探して返す。

これらのメソッドの実装は以下になります。

// GreetingService.java
/**
 * The client side stub for the RPC service.
 */
@RemoteServiceRelativePath("greet")
public interface GreetingService extends RemoteService {
	void registerCar(Car car) throws IllegalArgumentException;
	Car getCar(String name) throws IllegalArgumentException;
}
// GreetingServiceImpl.java
	@Override
	public void registerCar(Car car) throws IllegalArgumentException {
		CarDAO dao = new CarDAO();
		dao.put(car);
	}

	@Override
	public Car getCar(String name) throws IllegalArgumentException {
		CarDAO dao = new CarDAO();
		return dao.get(name);
	}
// GreetingServiceAsync.java
/**
 * The async counterpart of GreetingService.
 */
public interface GreetingServiceAsync {
	void registerCar(Car car, AsyncCallback callback) throws IllegalArgumentException;
	void getCar(String name, AsyncCallback callback) throws IllegalArgumentException;
}

これで準備ができました。次回は早速呼び出してみましょう。

Objectifyで簡単DataStore操作(モデルオブジェクトを作ってみる)

では、さっそくモデルを作ってみます。作るモデルは”Car”モデルです。ありがちです。Carはサーバー側でもクライアント側でも使うのでどちらからもアクセスできるところに置きましょう。

shareの下にパッケージを作ります。こんな感じです。

package com.storadia.GAETest.shared.model

モデルの定義


モデルのクラス定義は以下です。

package com.storadia.GAETest.shared.model;

import javax.persistence.Id;
import com.google.gwt.user.client.rpc.IsSerializable;
import com.googlecode.objectify.annotation.Entity;

@Entity
public class Car implements IsSerializable {
	@Id
	public Long id;
	private String name;

	public String getName() {
		return name;
	}

	public void setName(String name) {
		this.name = name;
	}
}

IsSerializable インターフェイスを使用していますが、これはクライアント、サーバ、両方で使用するためのおまじないです。
@Idアノテーションに注目してください。このLong値を使ってオブジェクトを管理することをDataStoreに宣言しています。
あとはnameプロパティのGetter/Setterを持ったいたってシンプルなクラスです。

DAOの定義


DAOはサーバー側で使用します。パッケージは以下にしました。

package com.storadia.GAETest.server.dao;

Objectifyは扱うクラスの登録を最初の一回だけにしなければいけないという条件を持っています。ですのでstatic節で括って何度も登録しないようにしています。
いろいろ書き方はあるでしょうが、基本はこんな感じになると思います。DAOにはCarの登録用メソッド”put”、名前でCarをDataStoreから取り出す”get”を用意しました。

package com.storadia.GAETest.server.dao;

import com.googlecode.objectify.Objectify;
import com.googlecode.objectify.ObjectifyService;
import com.googlecode.objectify.util.DAOBase;
import com.storadia.GAETest.shared.model.Car;

public class CarDAO extends DAOBase {
	private Objectify ofy = ObjectifyService.begin();
	static {
		ObjectifyService.register(Car.class);
	}
	public void put(Car car) {
		ofy.put(car);
	}
	public Car get(String name) {
		return ofy.query(Car.class).filter("name", name).get();
	}

}

次回GWT-RPCを使ってクライアントからCarを登録・取得してみたいと思います。