use of net.jforum.entities.Poll in project jforum2 by rafaelsteil.
the class GenericPollDAO method makePoll.
protected Poll makePoll(ResultSet rs) throws SQLException {
Poll poll = new Poll();
poll.setId(rs.getInt("vote_id"));
poll.setTopicId(rs.getInt("topic_id"));
poll.setLabel(rs.getString("vote_text"));
poll.setStartTime(new Date(rs.getTimestamp("vote_start").getTime()));
poll.setLength(rs.getInt("vote_length"));
return poll;
}
use of net.jforum.entities.Poll in project jforum2 by rafaelsteil.
the class GenericPollDAO method selectById.
/**
* @see net.jforum.dao.PollDAO#selectById(int)
*/
public Poll selectById(int pollId) {
PreparedStatement p = null;
PreparedStatement o = null;
ResultSet ors = null;
ResultSet prs = null;
try {
p = JForumExecutionContext.getConnection().prepareStatement(SystemGlobals.getSql("PollModel.selectById"));
p.setInt(1, pollId);
prs = p.executeQuery();
Poll poll = null;
if (prs.next()) {
poll = this.makePoll(prs);
o = JForumExecutionContext.getConnection().prepareStatement(SystemGlobals.getSql("PollModel.selectOptionsByPollId"));
o.setInt(1, pollId);
ors = o.executeQuery();
while (ors.next()) {
poll.addOption(this.makePollOption(ors));
}
}
return poll;
} catch (SQLException e) {
throw new DatabaseException(e);
} finally {
DbUtils.close(prs, p);
DbUtils.close(ors, o);
}
}
use of net.jforum.entities.Poll in project jforum2 by rafaelsteil.
the class PostAction method editSave.
public void editSave() {
PostDAO postDao = DataAccessDriver.getInstance().newPostDAO();
PollDAO pollDao = DataAccessDriver.getInstance().newPollDAO();
TopicDAO topicDao = DataAccessDriver.getInstance().newTopicDAO();
Post post = postDao.selectById(this.request.getIntParameter("post_id"));
if (!PostCommon.canEditPost(post)) {
this.cannotEdit();
return;
}
boolean isModerator = SecurityRepository.canAccess(SecurityConstants.PERM_MODERATION_POST_EDIT);
String originalMessage = post.getText();
post = PostCommon.fillPostFromRequest(post, true);
// The user wants to preview the message before posting it?
if ("1".equals(this.request.getParameter("preview"))) {
this.context.put("preview", true);
Post postPreview = new Post(post);
this.context.put("postPreview", PostCommon.preparePostForDisplay(postPreview));
this.edit(true, post);
} else {
AttachmentCommon attachments = new AttachmentCommon(this.request, post.getForumId());
try {
attachments.preProcess();
} catch (AttachmentException e) {
JForumExecutionContext.enableRollback();
post.setText(this.request.getParameter("message"));
this.context.put("errorMessage", e.getMessage());
this.context.put("post", post);
this.edit(false, post);
return;
}
Topic t = TopicRepository.getTopic(new Topic(post.getTopicId()));
if (t == null) {
t = topicDao.selectById(post.getTopicId());
}
if (!TopicsCommon.isTopicAccessible(t.getForumId())) {
return;
}
if (t.getStatus() == Topic.STATUS_LOCKED && !SecurityRepository.canAccess(SecurityConstants.PERM_MODERATION_POST_EDIT)) {
this.topicLocked();
return;
}
postDao.update(post);
// Attachments
attachments.editAttachments(post.getId(), post.getForumId());
attachments.insertAttachments(post);
// The first message (the one which originated the topic) was changed
if (t.getFirstPostId() == post.getId()) {
t.setTitle(post.getSubject());
int newType = this.request.getIntParameter("topic_type");
boolean changeType = SecurityRepository.canAccess(SecurityConstants.PERM_CREATE_STICKY_ANNOUNCEMENT_TOPICS) && newType != t.getType();
if (changeType) {
t.setType(newType);
}
// Poll
Poll poll = PollCommon.fillPollFromRequest();
if (poll != null && !t.isVote()) {
// They added a poll
poll.setTopicId(t.getId());
if (!this.ensurePollMinimumOptions(post, poll)) {
return;
}
pollDao.addNew(poll);
t.setVoteId(poll.getId());
} else if (poll != null) {
if (!this.ensurePollMinimumOptions(post, poll)) {
return;
}
// They edited the poll in the topic
Poll existing = pollDao.selectById(t.getVoteId());
PollChanges changes = new PollChanges(existing, poll);
if (changes.hasChanges()) {
poll.setId(existing.getId());
poll.setChanges(changes);
pollDao.update(poll);
}
} else if (t.isVote()) {
// They deleted the poll from the topic
pollDao.delete(t.getVoteId());
t.setVoteId(0);
}
topicDao.update(t);
if (changeType) {
TopicRepository.addTopic(t);
} else {
TopicRepository.updateTopic(t);
}
}
if (SystemGlobals.getBoolValue(ConfigKeys.MODERATION_LOGGING_ENABLED) && isModerator && post.getUserId() != SessionFacade.getUserSession().getUserId()) {
ModerationHelper helper = new ModerationHelper();
this.request.addParameter("log_original_message", originalMessage);
ModerationLog log = helper.buildModerationLogFromRequest();
log.getPosterUser().setId(post.getUserId());
helper.saveModerationLog(log);
}
if (this.request.getParameter("notify") == null) {
topicDao.removeSubscription(post.getTopicId(), SessionFacade.getUserSession().getUserId());
}
String path = this.request.getContextPath() + "/posts/list/";
int start = ViewCommon.getStartPage();
if (start > 0) {
path += start + "/";
}
path += post.getTopicId() + SystemGlobals.getValue(ConfigKeys.SERVLET_EXTENSION) + "#" + post.getId();
JForumExecutionContext.setRedirect(path);
if (SystemGlobals.getBoolValue(ConfigKeys.POSTS_CACHE_ENABLED)) {
PostRepository.update(post.getTopicId(), PostCommon.preparePostForDisplay(post));
}
}
}
use of net.jforum.entities.Poll in project jforum2 by rafaelsteil.
the class PostAction method edit.
private void edit(boolean preview, Post p) {
int userId = SessionFacade.getUserSession().getUserId();
if (!preview) {
PostDAO pm = DataAccessDriver.getInstance().newPostDAO();
p = pm.selectById(this.request.getIntParameter("post_id"));
// The post exist?
if (p.getId() == 0) {
this.postNotFound();
return;
}
}
boolean isModerator = SecurityRepository.canAccess(SecurityConstants.PERM_MODERATION_POST_EDIT);
boolean canEdit = SessionFacade.isLogged() && (isModerator || p.getUserId() == userId);
if (!canEdit) {
this.setTemplateName(TemplateKeys.POSTS_EDIT_CANNOTEDIT);
this.context.put("message", I18n.getMessage("CannotEditPost"));
} else {
Topic topic = TopicRepository.getTopic(new Topic(p.getTopicId()));
if (topic == null) {
topic = DataAccessDriver.getInstance().newTopicDAO().selectRaw(p.getTopicId());
}
if (!TopicsCommon.isTopicAccessible(topic.getForumId())) {
return;
}
if (topic.getStatus() == Topic.STATUS_LOCKED && !isModerator) {
this.topicLocked();
return;
}
if (preview && this.request.getParameter("topic_type") != null) {
topic.setType(this.request.getIntParameter("topic_type"));
}
if (p.hasAttachments()) {
this.context.put("attachments", DataAccessDriver.getInstance().newAttachmentDAO().selectAttachments(p.getId()));
}
Poll poll = null;
if (topic.isVote() && topic.getFirstPostId() == p.getId()) {
// It has a poll associated with the topic
PollDAO poolDao = DataAccessDriver.getInstance().newPollDAO();
poll = poolDao.selectById(topic.getVoteId());
}
this.setTemplateName(TemplateKeys.POSTS_EDIT);
this.context.put("attachmentsEnabled", SecurityRepository.canAccess(SecurityConstants.PERM_ATTACHMENTS_ENABLED, Integer.toString(p.getForumId())));
this.context.put("moderationLoggingEnabled", SystemGlobals.getBoolValue(ConfigKeys.MODERATION_LOGGING_ENABLED));
QuotaLimit ql = new AttachmentCommon(this.request, p.getForumId()).getQuotaLimit(userId);
this.context.put("maxAttachmentsSize", new Long(ql != null ? ql.getSizeInBytes() : 1));
this.context.put("isEdit", true);
this.context.put("maxAttachments", SystemGlobals.getValue(ConfigKeys.ATTACHMENTS_MAX_POST));
this.context.put("smilies", SmiliesRepository.getSmilies());
this.context.put("forum", ForumRepository.getForum(p.getForumId()));
this.context.put("action", "editSave");
this.context.put("post", p);
this.context.put("setType", p.getId() == topic.getFirstPostId());
this.context.put("topic", topic);
this.context.put("poll", poll);
this.context.put("pageTitle", I18n.getMessage("PostShow.messageTitle") + " " + p.getSubject());
this.context.put("isModerator", isModerator);
this.context.put("start", this.request.getParameter("start"));
this.context.put("htmlAllowed", SecurityRepository.canAccess(SecurityConstants.PERM_HTML_DISABLED, Integer.toString(topic.getForumId())));
this.context.put("canCreateStickyOrAnnouncementTopics", SecurityRepository.canAccess(SecurityConstants.PERM_CREATE_STICKY_ANNOUNCEMENT_TOPICS));
this.context.put("canCreatePolls", SecurityRepository.canAccess(SecurityConstants.PERM_CREATE_POLL));
}
UserDAO udao = DataAccessDriver.getInstance().newUserDAO();
User u = udao.selectById(userId);
ViewCommon.prepareUserSignature(u);
if (preview) {
u.setNotifyOnMessagesEnabled(this.request.getParameter("notify") != null);
if (u.getId() != p.getUserId()) {
// Probably a moderator is editing the message
User previewUser = udao.selectById(p.getUserId());
ViewCommon.prepareUserSignature(previewUser);
this.context.put("previewUser", previewUser);
}
}
this.context.put("user", u);
}
use of net.jforum.entities.Poll in project jforum2 by rafaelsteil.
the class PostAction method list.
public void list() {
PostDAO postDao = DataAccessDriver.getInstance().newPostDAO();
PollDAO pollDao = DataAccessDriver.getInstance().newPollDAO();
TopicDAO topicDao = DataAccessDriver.getInstance().newTopicDAO();
UserSession us = SessionFacade.getUserSession();
int anonymousUser = SystemGlobals.getIntValue(ConfigKeys.ANONYMOUS_USER_ID);
boolean logged = SessionFacade.isLogged();
int topicId = this.request.getIntParameter("topic_id");
Topic topic = TopicRepository.getTopic(new Topic(topicId));
if (topic == null) {
topic = topicDao.selectById(topicId);
}
// The topic exists?
if (topic.getId() == 0) {
this.topicNotFound();
return;
}
// Shall we proceed?
Forum forum = ForumRepository.getForum(topic.getForumId());
if (!logged) {
if (forum == null || !ForumRepository.isCategoryAccessible(forum.getCategoryId())) {
this.setTemplateName(ViewCommon.contextToLogin());
return;
}
} else if (!TopicsCommon.isTopicAccessible(topic.getForumId())) {
return;
}
int count = SystemGlobals.getIntValue(ConfigKeys.POSTS_PER_PAGE);
int start = ViewCommon.getStartPage();
PermissionControl pc = SecurityRepository.get(us.getUserId());
boolean moderatorCanEdit = false;
if (pc.canAccess(SecurityConstants.PERM_MODERATION_POST_EDIT)) {
moderatorCanEdit = true;
}
List helperList = PostCommon.topicPosts(postDao, moderatorCanEdit, us.getUserId(), topic.getId(), start, count);
// Is moderation pending for the topic?
if (topic.isModerated() && helperList.size() == 0) {
this.notModeratedYet();
return;
}
// Set the topic status as read
if (logged) {
topicDao.updateReadStatus(topic.getId(), us.getUserId(), true);
}
boolean canVoteOnPoll = logged && SecurityRepository.canAccess(SecurityConstants.PERM_VOTE);
Poll poll = null;
if (topic.isVote()) {
// It has a poll associated with the topic
poll = pollDao.selectById(topic.getVoteId());
if (canVoteOnPoll) {
canVoteOnPoll = !pollDao.hasUserVotedOnPoll(topic.getVoteId(), us.getUserId());
}
}
topicDao.incrementTotalViews(topic.getId());
topic.setTotalViews(topic.getTotalViews() + 1);
if (us.getUserId() != anonymousUser) {
SessionFacade.getTopicsReadTime().put(new Integer(topic.getId()), new Long(System.currentTimeMillis()));
}
boolean karmaEnabled = SecurityRepository.canAccess(SecurityConstants.PERM_KARMA_ENABLED);
Map userVotes = new HashMap();
if (logged && karmaEnabled) {
userVotes = DataAccessDriver.getInstance().newKarmaDAO().getUserVotes(topic.getId(), us.getUserId());
}
this.setTemplateName(TemplateKeys.POSTS_LIST);
this.context.put("attachmentsEnabled", pc.canAccess(SecurityConstants.PERM_ATTACHMENTS_ENABLED, Integer.toString(topic.getForumId())));
this.context.put("canDownloadAttachments", pc.canAccess(SecurityConstants.PERM_ATTACHMENTS_DOWNLOAD));
this.context.put("thumbShowBox", SystemGlobals.getBoolValue(ConfigKeys.ATTACHMENTS_IMAGES_THUMB_BOX_SHOW));
this.context.put("am", new AttachmentCommon(this.request, topic.getForumId()));
this.context.put("karmaVotes", userVotes);
this.context.put("rssEnabled", SystemGlobals.getBoolValue(ConfigKeys.RSS_ENABLED));
this.context.put("canRemove", pc.canAccess(SecurityConstants.PERM_MODERATION_POST_REMOVE));
this.context.put("moderatorCanEdit", moderatorCanEdit);
this.context.put("allCategories", ForumCommon.getAllCategoriesAndForums(false));
this.context.put("topic", topic);
this.context.put("poll", poll);
this.context.put("canVoteOnPoll", canVoteOnPoll);
this.context.put("rank", new RankingRepository());
this.context.put("posts", helperList);
this.context.put("forum", forum);
this.context.put("karmaMin", new Integer(SystemGlobals.getValue(ConfigKeys.KARMA_MIN_POINTS)));
this.context.put("karmaMax", new Integer(SystemGlobals.getValue(ConfigKeys.KARMA_MAX_POINTS)));
this.context.put("avatarAllowExternalUrl", SystemGlobals.getBoolValue(ConfigKeys.AVATAR_ALLOW_EXTERNAL_URL));
this.context.put("moderationLoggingEnabled", SystemGlobals.getBoolValue(ConfigKeys.MODERATION_LOGGING_ENABLED));
this.context.put("needCaptcha", SystemGlobals.getBoolValue(ConfigKeys.CAPTCHA_POSTS));
Map topicPosters = topicDao.topicPosters(topic.getId());
for (Iterator iter = topicPosters.values().iterator(); iter.hasNext(); ) {
ViewCommon.prepareUserSignature((User) iter.next());
}
this.context.put("users", topicPosters);
this.context.put("anonymousPosts", pc.canAccess(SecurityConstants.PERM_ANONYMOUS_POST, Integer.toString(topic.getForumId())));
this.context.put("watching", topicDao.isUserSubscribed(topicId, SessionFacade.getUserSession().getUserId()));
this.context.put("pageTitle", topic.getTitle());
this.context.put("isAdmin", pc.canAccess(SecurityConstants.PERM_ADMINISTRATION));
this.context.put("readonly", !pc.canAccess(SecurityConstants.PERM_READ_ONLY_FORUMS, Integer.toString(topic.getForumId())));
this.context.put("replyOnly", !pc.canAccess(SecurityConstants.PERM_REPLY_ONLY, Integer.toString(topic.getForumId())));
this.context.put("isModerator", us.isModerator(topic.getForumId()));
ViewCommon.contextToPagination(start, topic.getTotalReplies() + 1, count);
TopicsCommon.topicListingBase();
TopicRepository.updateTopic(topic);
}
Aggregations