001 // Copyright 2007, 2008 The Apache Software Foundation 002 // 003 // Licensed under the Apache License, Version 2.0 (the "License"); 004 // you may not use this file except in compliance with the License. 005 // You may obtain a copy of the License at 006 // 007 // http://www.apache.org/licenses/LICENSE-2.0 008 // 009 // Unless required by applicable law or agreed to in writing, software 010 // distributed under the License is distributed on an "AS IS" BASIS, 011 // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 012 // See the License for the specific language governing permissions and 013 // limitations under the License. 014 015 package org.apache.tapestry5.internal.services; 016 017 import org.apache.tapestry5.Asset; 018 import org.apache.tapestry5.annotations.Path; 019 import org.apache.tapestry5.ioc.AnnotationProvider; 020 import org.apache.tapestry5.ioc.ObjectLocator; 021 import org.apache.tapestry5.ioc.ObjectProvider; 022 import org.apache.tapestry5.ioc.services.Builtin; 023 import org.apache.tapestry5.ioc.services.SymbolSource; 024 import org.apache.tapestry5.ioc.services.TypeCoercer; 025 import org.apache.tapestry5.services.AssetSource; 026 import org.apache.tapestry5.services.Core; 027 028 /** 029 * Exposes assets (in the current locale). The Inject annotation must be supplemented by a {@link Path} annotation, to 030 * identify what asset to be injected. 031 */ 032 public class AssetObjectProvider implements ObjectProvider 033 { 034 private final AssetSource source; 035 036 private final TypeCoercer typeCoercer; 037 038 private final SymbolSource symbolSource; 039 040 public AssetObjectProvider(@Core AssetSource source, 041 042 @Builtin TypeCoercer typeCoercer, 043 044 @Builtin SymbolSource symbolSource) 045 { 046 this.source = source; 047 this.typeCoercer = typeCoercer; 048 this.symbolSource = symbolSource; 049 } 050 051 /** 052 * Provides the asset. If the expression does not identify an asset domain, with a prefix, it is assumed to be a 053 * path on the classpath, relative to the root of the classpath. 054 * 055 * @param objectType the type of object (which must be Object or Asset) 056 * @param locator not used 057 */ 058 public <T> T provide(Class<T> objectType, AnnotationProvider annotationProvider, ObjectLocator locator) 059 { 060 Path path = annotationProvider.getAnnotation(Path.class); 061 062 if (path == null) return null; 063 064 String expanded = symbolSource.expandSymbols(path.value()); 065 066 Asset asset = source.getAsset(null, expanded, null); 067 068 return typeCoercer.coerce(asset, objectType); 069 } 070 }