| /* |
| * Licensed to the Apache Software Foundation (ASF) under one or more |
| * contributor license agreements. The ASF licenses this file to You |
| * under the Apache License, Version 2.0 (the "License"); you may not |
| * use this file except in compliance with the License. |
| * You may obtain a copy of the License at |
| * |
| * http://www.apache.org/licenses/LICENSE-2.0 |
| * |
| * Unless required by applicable law or agreed to in writing, software |
| * distributed under the License is distributed on an "AS IS" BASIS, |
| * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| * See the License for the specific language governing permissions and |
| * limitations under the License. For additional information regarding |
| * copyright in this work, please see the NOTICE file in the top level |
| * directory of this distribution. |
| */ |
| |
| package org.apache.roller.weblogger.pojos.wrapper; |
| |
| import java.sql.Timestamp; |
| import org.apache.commons.lang3.StringEscapeUtils; |
| import org.apache.roller.weblogger.business.URLStrategy; |
| import org.apache.roller.weblogger.business.WebloggerFactory; |
| import org.apache.roller.weblogger.business.plugins.PluginManager; |
| import org.apache.roller.weblogger.pojos.WeblogEntryComment; |
| import org.apache.roller.weblogger.pojos.WeblogEntryComment.ApprovalStatus; |
| import org.apache.roller.weblogger.util.Utilities; |
| |
| |
| /** |
| * Pojo safety wrapper for WeblogEntryComment object. |
| */ |
| public final class WeblogEntryCommentWrapper { |
| |
| // keep a reference to the wrapped pojo |
| private final WeblogEntryComment pojo; |
| |
| // url strategy to use for any url building |
| private final URLStrategy urlStrategy; |
| |
| |
| // this is private so that we can force the use of the .wrap(pojo) method |
| private WeblogEntryCommentWrapper(WeblogEntryComment toWrap, URLStrategy strat) { |
| this.pojo = toWrap; |
| this.urlStrategy = strat; |
| } |
| |
| |
| // wrap the given pojo if it is not null |
| public static WeblogEntryCommentWrapper wrap(WeblogEntryComment toWrap, URLStrategy strat) { |
| if(toWrap != null) { |
| return new WeblogEntryCommentWrapper(toWrap, strat); |
| } |
| |
| return null; |
| } |
| |
| |
| public String getId() { |
| return this.pojo.getId(); |
| } |
| |
| |
| public WeblogEntryWrapper getWeblogEntry() { |
| return WeblogEntryWrapper.wrap(this.pojo.getWeblogEntry(), urlStrategy); |
| } |
| |
| |
| /** |
| * Get the name of the comment writer. |
| * |
| * Value is always html escaped. |
| */ |
| public String getName() { |
| return StringEscapeUtils.escapeHtml4(this.pojo.getName()); |
| } |
| |
| |
| /** |
| * Get the email address of the comment writer, if specified. |
| * |
| * Value is always html escaped. |
| */ |
| public String getEmail() { |
| return StringEscapeUtils.escapeHtml4(this.pojo.getEmail()); |
| } |
| |
| |
| /** |
| * Get the url of the comment writer, if specified. |
| * |
| * Value is always html escaped. |
| */ |
| public String getUrl() { |
| return StringEscapeUtils.escapeHtml4(this.pojo.getUrl()); |
| } |
| |
| |
| /** |
| * Get the comment contents. |
| * |
| * Any configured comment plugins are applied first, then the value is |
| * always html escaped. |
| */ |
| public String getContent() { |
| |
| String content = this.pojo.getContent(); |
| |
| // escape content if content-type is text/plain |
| if("text/plain".equals(this.pojo.getContentType())) { |
| content = StringEscapeUtils.escapeHtml4(content); |
| } |
| |
| // apply plugins |
| PluginManager pmgr = WebloggerFactory.getWeblogger().getPluginManager(); |
| content = pmgr.applyCommentPlugins(this.pojo, content); |
| |
| // always add rel=nofollow for links |
| content = Utilities.addNofollow(content); |
| |
| return content; |
| } |
| |
| |
| /** |
| * Get the time the comment was posted. |
| */ |
| public Timestamp getPostTime() { |
| return this.pojo.getPostTime(); |
| } |
| |
| |
| public ApprovalStatus getStatus() { |
| return this.pojo.getStatus(); |
| } |
| |
| |
| public Boolean getNotify() { |
| return this.pojo.getNotify(); |
| } |
| |
| |
| public String getRemoteHost() { |
| return this.pojo.getRemoteHost(); |
| } |
| |
| |
| /** |
| * Get the http referrer of the comment poster, used for trackbacks. |
| * |
| * Value is always html escaped. |
| */ |
| public String getReferrer() { |
| return StringEscapeUtils.escapeHtml4(this.pojo.getReferrer()); |
| } |
| |
| |
| public String getUserAgent() { |
| return this.pojo.getUserAgent(); |
| } |
| |
| |
| public Boolean getSpam() { |
| return this.pojo.getSpam(); |
| } |
| |
| |
| public Boolean getPending() { |
| return this.pojo.getPending(); |
| } |
| |
| |
| public Boolean getApproved() { |
| return this.pojo.getApproved(); |
| } |
| |
| |
| public String getTimestamp() { |
| return this.pojo.getTimestamp(); |
| } |
| |
| } |