- private static final Logger log = LoggerFactory.getLogger(PeopleProvider.class);
-
- private DataBroker dataProvider;
-
- private BindingAwareBroker.RoutedRpcRegistration<CarPurchaseService> rpcRegistration;
-
- public void setDataProvider(final DataBroker salDataProvider) {
- this.dataProvider = salDataProvider;
- }
-
-
- public void setRpcRegistration(BindingAwareBroker.RoutedRpcRegistration<CarPurchaseService> rpcRegistration) {
- this.rpcRegistration = rpcRegistration;
- }
-
- @Override
- public Future<RpcResult<Void>> addPerson(AddPersonInput input) {
- log.info("RPC addPerson : adding person [{}]", input);
-
- PersonBuilder builder = new PersonBuilder(input);
- final Person person = builder.build();
- final SettableFuture<RpcResult<Void>> futureResult = SettableFuture.create();
-
- // Each entry will be identifiable by a unique key, we have to create that identifier
- final InstanceIdentifier.InstanceIdentifierBuilder<Person> personIdBuilder =
- InstanceIdentifier.<People>builder(People.class)
- .child(Person.class, person.getKey());
- final InstanceIdentifier personId = personIdBuilder.build();
- // Place entry in data store tree
- WriteTransaction tx = dataProvider.newWriteOnlyTransaction();
- tx.put(LogicalDatastoreType.CONFIGURATION, personId, person);
-
- Futures.addCallback(tx.submit(), new FutureCallback<Void>() {
- @Override
- public void onSuccess(final Void result) {
- log.info("RPC addPerson : person added successfully [{}]", person);
- rpcRegistration.registerPath(PersonContext.class, personId);
- log.info("RPC addPerson : routed rpc registered for instance ID [{}]", personId);
- futureResult.set(RpcResultBuilder.<Void>success().build());
- }
-
- @Override
- public void onFailure(final Throwable t) {
- log.error(String.format("RPC addPerson : person addition failed [%s]", person), t);
- futureResult.set(RpcResultBuilder.<Void>failed()
- .withError(RpcError.ErrorType.APPLICATION, t.getMessage()).build());
- }
- });
- return futureResult;
- }
-
- @Override
- public void close() throws Exception {
-
- }
+ private static final Logger LOG = LoggerFactory.getLogger(PeopleProvider.class);
+
+ private final Set<ObjectRegistration<?>> regs = new HashSet<>();
+ private DataBroker dataProvider;
+ private RpcProviderService rpcProviderService;
+ private CarPurchaseService rpcImplementation;
+
+ public void setDataProvider(final DataBroker salDataProvider) {
+ this.dataProvider = salDataProvider;
+ }
+
+ public void setRpcImplementation(final CarPurchaseService rpcImplementation) {
+ this.rpcImplementation = rpcImplementation;
+ }
+
+ @Override
+ public ListenableFuture<RpcResult<AddPersonOutput>> addPerson(final AddPersonInput input) {
+ LOG.info("RPC addPerson : adding person [{}]", input);
+
+ PersonBuilder builder = new PersonBuilder(input);
+ final Person person = builder.build();
+ final SettableFuture<RpcResult<AddPersonOutput>> futureResult = SettableFuture.create();
+
+ // Each entry will be identifiable by a unique key, we have to create that identifier
+ final InstanceIdentifier<Person> personId = InstanceIdentifier.builder(People.class)
+ .child(Person.class, person.key()).build();
+ // Place entry in data store tree
+ WriteTransaction tx = dataProvider.newWriteOnlyTransaction();
+ tx.put(LogicalDatastoreType.CONFIGURATION, personId, person);
+
+ tx.commit().addCallback(new FutureCallback<CommitInfo>() {
+ @Override
+ public void onSuccess(final CommitInfo result) {
+ LOG.info("RPC addPerson : person added successfully [{}]", person);
+ regs.add(rpcProviderService.registerRpcImplementation(CarPurchaseService.class, rpcImplementation,
+ ImmutableSet.of(personId)));
+ LOG.info("RPC addPerson : routed rpc registered for instance ID [{}]", personId);
+ futureResult.set(RpcResultBuilder.success(new AddPersonOutputBuilder().build()).build());
+ }
+
+ @Override
+ public void onFailure(final Throwable ex) {
+ LOG.error("RPC addPerson : person addition failed [{}]", person, ex);
+ futureResult.set(RpcResultBuilder.<AddPersonOutput>failed()
+ .withError(RpcError.ErrorType.APPLICATION, ex.getMessage()).build());
+ }
+ }, MoreExecutors.directExecutor());
+ return futureResult;
+ }
+
+ @Override
+ public void close() {
+ regs.forEach(ObjectRegistration::close);
+ regs.clear();
+ }