You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

AFPResourceAccessor.java 2.7KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. /*
  2. * Licensed to the Apache Software Foundation (ASF) under one or more
  3. * contributor license agreements. See the NOTICE file distributed with
  4. * this work for additional information regarding copyright ownership.
  5. * The ASF licenses this file to You under the Apache License, Version 2.0
  6. * (the "License"); you may not use this file except in compliance with
  7. * the License. You may obtain a copy of the License at
  8. *
  9. * http://www.apache.org/licenses/LICENSE-2.0
  10. *
  11. * Unless required by applicable law or agreed to in writing, software
  12. * distributed under the License is distributed on an "AS IS" BASIS,
  13. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  14. * See the License for the specific language governing permissions and
  15. * limitations under the License.
  16. */
  17. /* $Id$ */
  18. package org.apache.fop.afp.util;
  19. import java.io.IOException;
  20. import java.io.InputStream;
  21. import java.net.URI;
  22. import java.net.URISyntaxException;
  23. import org.apache.fop.apps.io.InternalResourceResolver;
  24. /**
  25. * Defines an interface through which external resource objects can be accessed.
  26. */
  27. public final class AFPResourceAccessor {
  28. private final InternalResourceResolver resourceResolver;
  29. private final String baseURI;
  30. /**
  31. * Constructor for resource to be accessed via the {@link org.apache.fop.apps.FOUserAgent}. This
  32. * contructor takes a base URI for resolving font resource URIs. So, if fonts need to be
  33. * accessed, you can set the {@link FontManager}'s base URI instead of the one on the
  34. * {@link org.apache.fop.apps.FopFactory}.
  35. *
  36. * @param InternalResourceResolver resource resolver
  37. * @param baseURI the custom base URI to resolve relative URIs against (may be null)
  38. */
  39. public AFPResourceAccessor(InternalResourceResolver resourceResolver, String baseURI) {
  40. this.resourceResolver = resourceResolver;
  41. this.baseURI = baseURI;
  42. }
  43. /**
  44. * Constructor for resource to be accessed via the {@link org.apache.fop.apps.FOUserAgent}.
  45. *
  46. * @param InternalResourceResolver resource resolver
  47. */
  48. public AFPResourceAccessor(InternalResourceResolver resourceResolver) {
  49. this(resourceResolver, null);
  50. }
  51. private URI getResourceURI(URI uri) {
  52. if (baseURI == null) {
  53. return uri;
  54. }
  55. try {
  56. URI baseURI = InternalResourceResolver.getBaseURI(this.baseURI);
  57. return baseURI.resolve(uri);
  58. } catch (URISyntaxException use) {
  59. return uri;
  60. }
  61. }
  62. /** {@inheritDoc} */
  63. public InputStream createInputStream(URI uri) throws IOException {
  64. return resourceResolver.getResource(getResourceURI(uri));
  65. }
  66. }