X-Git-Url: https://git.opendaylight.org/gerrit/gitweb?a=blobdiff_plain;f=netconf%2Fyanglib%2Fsrc%2Fmain%2Fjava%2Forg%2Fopendaylight%2Fyanglib%2Fimpl%2FYangLibServiceImpl.java;h=949d8f577393c35baaf747ae4a1b51266d3aa0fb;hb=5a32bcd2c7752cb3a90a721e17079af9c6d049ad;hp=bf8b04ceb08c3c138091ff935b725e576bf24226;hpb=ddfdd7b56162e9c45639388b10407d45f5f0ba13;p=netconf.git diff --git a/netconf/yanglib/src/main/java/org/opendaylight/yanglib/impl/YangLibServiceImpl.java b/netconf/yanglib/src/main/java/org/opendaylight/yanglib/impl/YangLibServiceImpl.java index bf8b04ceb0..949d8f5773 100644 --- a/netconf/yanglib/src/main/java/org/opendaylight/yanglib/impl/YangLibServiceImpl.java +++ b/netconf/yanglib/src/main/java/org/opendaylight/yanglib/impl/YangLibServiceImpl.java @@ -8,15 +8,16 @@ package org.opendaylight.yanglib.impl; -import com.google.common.base.Optional; import com.google.common.base.Preconditions; import com.google.common.io.ByteStreams; -import com.google.common.util.concurrent.CheckedFuture; +import com.google.common.util.concurrent.ListenableFuture; import java.io.IOException; +import java.nio.charset.Charset; +import java.util.concurrent.ExecutionException; import org.opendaylight.yanglib.api.YangLibService; +import org.opendaylight.yangtools.yang.common.Revision; import org.opendaylight.yangtools.yang.model.repo.api.RevisionSourceIdentifier; import org.opendaylight.yangtools.yang.model.repo.api.SchemaRepository; -import org.opendaylight.yangtools.yang.model.repo.api.SchemaSourceException; import org.opendaylight.yangtools.yang.model.repo.api.SourceIdentifier; import org.opendaylight.yangtools.yang.model.repo.api.YangTextSchemaSource; import org.slf4j.Logger; @@ -28,32 +29,32 @@ import org.slf4j.LoggerFactory; public class YangLibServiceImpl implements YangLibService { private static final Logger LOG = LoggerFactory.getLogger(YangLibServiceImpl.class); - private SchemaRepository schemaRepository; + private static volatile SchemaRepository schemaRepository; public YangLibServiceImpl() { } - public void setSchemaRepository(final SchemaRepository schemaRepository) { + public static void setSchemaRepository(final SchemaRepository schemaRepository) { LOG.debug("Setting schema repository {}", schemaRepository); - this.schemaRepository = schemaRepository; + YangLibServiceImpl.schemaRepository = schemaRepository; } @Override public String getSchema(final String name, final String revision) { Preconditions.checkNotNull(schemaRepository, "Schema repository is not initialized"); LOG.debug("Attempting load for schema source {}:{}", name, revision); - final SourceIdentifier sourceId = - RevisionSourceIdentifier.create(name, Optional.fromNullable(revision.equals("") ? null : revision)); + final SourceIdentifier sourceId = RevisionSourceIdentifier.create(name, + revision.isEmpty() ? null : Revision.of(revision)); - final CheckedFuture sourceFuture = - schemaRepository.getSchemaSource(sourceId, YangTextSchemaSource.class); + final ListenableFuture sourceFuture = schemaRepository.getSchemaSource(sourceId, + YangTextSchemaSource.class); try { - final YangTextSchemaSource source = sourceFuture.checkedGet(); - return new String(ByteStreams.toByteArray(source.openStream())); - } catch (SchemaSourceException | IOException e) { - throw new IllegalStateException("Unable to get schema" + sourceId, e); + final YangTextSchemaSource source = sourceFuture.get(); + return new String(ByteStreams.toByteArray(source.openStream()), Charset.defaultCharset()); + } catch (InterruptedException | ExecutionException | IOException e) { + throw new IllegalStateException("Unable to get schema " + sourceId, e); } } }