All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.beetl.sql.saga.ms.client.SagaServerApi Maven / Gradle / Ivy

There is a newer version: 3.27.1-RELEASE
Show newest version
package org.beetl.sql.saga.ms.client;

import com.fasterxml.jackson.core.JsonProcessingException;
import org.beetl.sql.saga.ms.client.task.*;

/**
 * 与saga-server 交互的api
 */
public class SagaServerApi {
	SagaClientConfig level3Config;

	public SagaServerApi(SagaClientConfig level3Config) {
		this.level3Config = level3Config;
	}

	/**
	 * 标记开始
	 * @param gid
	 * @param time
	 */
	public void start(String gid, long time) {
		StartClientTask startTask = new StartClientTask(level3Config.getAppName(),gid, time);
		level3Config.getTemplate().send(level3Config.getServerTopic(), gid,toString(startTask));
	}


	/**
	 * 发送回滚任务到服务器
	 * @param tasks
	 */
	public void sendRollbackTask(String gid, long time, SagaClientTransaction tasks) {
		RollbackClientTask rollbackTask = new RollbackClientTask(level3Config.getAppName(),gid, time, tasks);
		level3Config.getTemplate().send(level3Config.getServerTopic(), gid,toString(rollbackTask));
	}

	/**
	 * 发送回滚任务到服务器
	 * @param tasks
	 */
	public void sendRollbackTaskInCommit(String gid, long time, SagaClientTransaction tasks) {
		RollbackInCommitClientTask rollbackInCommitTask =
				new RollbackInCommitClientTask(level3Config.getAppName(),gid, time, tasks);
		level3Config.getTemplate().send(level3Config.getServerTopic(), gid,toString(rollbackInCommitTask));
	}

	public void rollbackSuccess(String gid, long time) {
		RollbackSuccessClientTask rollbackSuccessTask = new RollbackSuccessClientTask(level3Config.getAppName(),gid, time);
		level3Config.getTemplate().send(level3Config.getServerTopic(), gid,toString(rollbackSuccessTask));

	}

	public void rollbackFailure(String gid, long time, SagaClientTransaction tasks) {
		RollbackFailureClientTask rollbackFailureTask =
				new RollbackFailureClientTask(level3Config.getAppName(),gid, time, tasks);
		level3Config.getTemplate().send(level3Config.getServerTopic(), gid,toString(rollbackFailureTask));

	}

	protected  String toString(ClientTask task)  {
		try {
			return level3Config.getObjectMapper().writeValueAsString(task);
		} catch (JsonProcessingException e) {
			throw new IllegalStateException("不能序列化 "+task.getClass());
		}
	}


}




© 2015 - 2024 Weber Informatics LLC | Privacy Policy