All Downloads are FREE. Search and download functionalities are using the official Maven repository.

org.eclipse.jetty.http.ResourceHttpContent Maven / Gradle / Ivy

There is a newer version: 2024.11.18751.20241128T090041Z-241100
Show newest version
// 
// ========================================================================
// Copyright (c) 1995-2022 Mort Bay Consulting Pty Ltd and others.
// ------------------------------------------------------------------------
// All rights reserved. This program and the accompanying materials
// are made available under the terms of the Eclipse Public License v1.0
// and Apache License v2.0 which accompanies this distribution.
// 
// The Eclipse Public License is available at
// http://www.eclipse.org/legal/epl-v10.html
// 
// The Apache License v2.0 is available at
// http://www.opensource.org/licenses/apache2.0.php
// 
// You may elect to redistribute this code under either of these licenses.
// ========================================================================
// 
package org.eclipse.jetty.http;

import java.io.IOException;
import java.io.InputStream;
import java.nio.ByteBuffer;
import java.nio.channels.ReadableByteChannel;
import java.util.HashMap;
import java.util.Map;
import org.eclipse.jetty.http.MimeTypes.Type;
import org.eclipse.jetty.util.BufferUtil;
import org.eclipse.jetty.util.resource.Resource;

/**
 *  HttpContent created from a {@link Resource}.
 *  

The HttpContent is used to server static content that is not * cached. So fields and values are only generated as need be an not * kept for reuse

* * @deprecated The Eclipse Jetty and Apache Felix Http Jetty packages are no longer supported. */ @Deprecated(since = "2021-05-27") public class ResourceHttpContent implements HttpContent { final Resource _resource; final String _contentType; final int _maxBuffer; Map _precompressedContents; String _etag; public ResourceHttpContent(final Resource resource, final String contentType) { this(resource, contentType, -1, null); } public ResourceHttpContent(final Resource resource, final String contentType, int maxBuffer) { this(resource, contentType, maxBuffer, null); } public ResourceHttpContent(final Resource resource, final String contentType, int maxBuffer, Map precompressedContents) { _resource = resource; _contentType = contentType; _maxBuffer = maxBuffer; if (precompressedContents == null) { _precompressedContents = null; } else { _precompressedContents = new HashMap<>(precompressedContents.size()); for (Map.Entry entry : precompressedContents.entrySet()) { _precompressedContents.put(entry.getKey(), new PrecompressedHttpContent(this, entry.getValue(), entry.getKey())); } } } @Override public String getContentTypeValue() { return _contentType; } @Override public HttpField getContentType() { return _contentType == null ? null : new HttpField(HttpHeader.CONTENT_TYPE, _contentType); } @Override public HttpField getContentEncoding() { return null; } @Override public String getContentEncodingValue() { return null; } @Override public String getCharacterEncoding() { return _contentType == null ? null : MimeTypes.getCharsetFromContentType(_contentType); } @Override public Type getMimeType() { return _contentType == null ? null : MimeTypes.CACHE.get(MimeTypes.getContentTypeWithoutCharset(_contentType)); } @Override public HttpField getLastModified() { long lm = _resource.lastModified(); return lm >= 0 ? new HttpField(HttpHeader.LAST_MODIFIED, DateGenerator.formatDate(lm)) : null; } @Override public String getLastModifiedValue() { long lm = _resource.lastModified(); return lm >= 0 ? DateGenerator.formatDate(lm) : null; } @Override public ByteBuffer getDirectBuffer() { if (_resource.length() <= 0 || _maxBuffer > 0 && _resource.length() > _maxBuffer) return null; try { return BufferUtil.toBuffer(_resource, true); } catch (IOException e) { throw new RuntimeException(e); } } @Override public HttpField getETag() { return new HttpField(HttpHeader.ETAG, getETagValue()); } @Override public String getETagValue() { return _resource.getWeakETag(); } @Override public ByteBuffer getIndirectBuffer() { if (_resource.length() <= 0 || _maxBuffer > 0 && _resource.length() > _maxBuffer) return null; try { return BufferUtil.toBuffer(_resource, false); } catch (IOException e) { throw new RuntimeException(e); } } @Override public HttpField getContentLength() { long l = _resource.length(); return l == -1 ? null : new HttpField.LongValueHttpField(HttpHeader.CONTENT_LENGTH, l); } @Override public long getContentLengthValue() { return _resource.length(); } @Override public InputStream getInputStream() throws IOException { return _resource.getInputStream(); } @Override public ReadableByteChannel getReadableByteChannel() throws IOException { return _resource.getReadableByteChannel(); } @Override public Resource getResource() { return _resource; } @Override public void release() { _resource.close(); } @Override public String toString() { return String.format("%s@%x{r=%s,ct=%s,c=%b}", this.getClass().getSimpleName(), hashCode(), _resource, _contentType, _precompressedContents != null); } @Override public Map getPrecompressedContents() { return _precompressedContents; } }




© 2015 - 2024 Weber Informatics LLC | Privacy Policy