MutationLog l = convSlobFacilities.getMutationLogFactory().create(tx, convId);
StateAndVersion stateAndVersion = l.reconstruct(null);
Assert.check(stateAndVersion.getVersion() > 0, "%s at version 0: %s",
convId, stateAndVersion);
// TODO(ohler): use generics to avoid the cast
ReadableWaveletObject state = (ReadableWaveletObject) stateAndVersion.getState();
if (state.getParticipants().contains(importingUser)) {
log.info(importingUser + " is a participant at version "
+ stateAndVersion.getVersion());
return;
}
WaveletOperation op =
HistorySynthesizer.newAddParticipant(importingUser.getAddress(),
// We preserve last modified time to avoid re-ordering people's inboxes
// just because another participant imported.
state.getLastModifiedMillis(),
importingUser.getAddress());
log.info(importingUser + " is not a participant at version "
+ stateAndVersion.getVersion() + ", adding " + op);
MutationLog.Appender appender = l.prepareAppender().getAppender();
try {