modeled.ModeledCuratorExamples Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of curator-examples Show documentation
Show all versions of curator-examples Show documentation
Example usages of various Curator features.
/**
* Licensed to the Apache Software Foundation (ASF) under one
* or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information
* regarding copyright ownership. The ASF licenses this file
* to you under the Apache License, Version 2.0 (the
* "License"); you may not use this file except in compliance
* with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing,
* software distributed under the License is distributed on an
* "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
* specific language governing permissions and limitations
* under the License.
*/
package modeled;
import org.apache.curator.x.async.AsyncCuratorFramework;
import org.apache.curator.x.async.modeled.JacksonModelSerializer;
import org.apache.curator.x.async.modeled.ModelSpec;
import org.apache.curator.x.async.modeled.ModeledFramework;
import org.apache.curator.x.async.modeled.ZPath;
import java.util.function.Consumer;
public class ModeledCuratorExamples
{
public static ModeledFramework wrap(AsyncCuratorFramework client)
{
JacksonModelSerializer serializer = JacksonModelSerializer.build(PersonModel.class);
// build a model specification - you can pre-build all the model specifications for your app at startup
ModelSpec modelSpec = ModelSpec.builder(ZPath.parse("/example/path"), serializer).build();
// wrap a CuratorFramework instance so that it can be used "modeled".
// do this once and re-use the returned ModeledFramework instance.
// ModeledFramework instances are tied to a given path
return ModeledFramework.wrap(client, modelSpec);
}
public static void createOrUpdate(ModeledFramework modeled, PersonModel model)
{
// change the affected path to be modeled's base path plus id: i.e. "/example/path/{id}"
ModeledFramework atId = modeled.child(model.getId().getId());
// by default ModeledFramework instances update the node if it already exists
// so this will either create or update the node
atId.set(model); // note - this is async
}
public static void readPerson(ModeledFramework modeled, String id, Consumer receiver)
{
// read the person with the given ID and asynchronously call the receiver after it is read
modeled.child(id).read().whenComplete((person, exception) -> {
if ( exception != null )
{
exception.printStackTrace(); // handle the error
}
else
{
receiver.accept(person);
}
});
}
}