* @throws Exception
*/
protected ActionForward doPublishLog(ActionMapping mapping, ActionForm form,
HttpServletRequest request, HttpServletResponse response, String identity)
throws Exception {
ActionMessages msgs = new ActionMessages();
DiaryForm log = (DiaryForm) form;
//super.validateClientId(request, log);
while (true) {
// ����ռDZ����ֵ
if (StringUtils.isEmpty(log.getTitle())) {
msgs.add("title", new ActionMessage("error.empty_not_allowed"));
break;
}
if (StringUtils.isEmpty(log.getContent())) {
msgs.add("content",
new ActionMessage("error.empty_not_allowed"));
break;
}
UserBean loginUser = super.getLoginUser(request, response);
if (loginUser == null) {
msgs.add("log", new ActionMessage("error.user_not_login"));
break;
}
if (loginUser.getStatus() != UserBean.STATUS_NORMAL) {
msgs.add("log", new ActionMessage("error.user_not_available"));
break;
}
SiteBean site = super.getSiteByID(log.getSid());
if (site == null) {
msgs.add("log", new ActionMessage("error.site_not_available"));
break;
}
boolean catalog_can_access = false;
CatalogBean catalog = null;
// վ�����Է���վ�ڵ��κη���
if (site.isOwner(loginUser)) {
catalog = CatalogDAO.getCatalogByID(log.getCatalogId());
if (catalog!=null && catalog.getSite().getId() == site.getId())
catalog_can_access = true;
} else {
// �г��û��ڸ�վ��ɷ��ʵ��ռǷ���
List catalogs = CatalogDAO.listCatalogs(site, loginUser, true);
for (int i = 0; catalogs != null && i < catalogs.size(); i++) {
CatalogBean t_catalog = (CatalogBean) catalogs.get(i);
if (t_catalog.getId() == log.getCatalogId()) {
catalog = t_catalog;
catalog_can_access = true;
break;
}
}
}
if (!catalog_can_access) {
msgs.add("log", new ActionMessage("error.catalog_deny",
new Integer(log.getCatalogId())));
break;
}
// �û����������ռǷ��౻����
if (StringUtils.isEmpty(log.getWeather()))
log.setWeather(DEFAULT_WEATHER);
if (StringUtils.isEmpty(log.getAuthor()))
log.setAuthor(loginUser.getNickname());
if (StringUtils.isEmpty(log.getTags()))
log.setTags(null);
if (StringUtils.isEmpty(log.getAuthorUrl()))
log.setAuthorUrl(null);
if (StringUtils.isEmpty(log.getRefUrl()))
log.setRefUrl(null);
// ����JournalBean
DiaryBean journal = new DiaryBean();
journal.setOwner(loginUser);
journal.setSite(site);
journal.setAuthor(super.autoFiltrate(site, log.getAuthor()));
journal.setAuthorUrl(log.getAuthorUrl());
journal.setCatalog(catalog);
journal.setClient(new ClientInfo(request, log.getClientType()));
// ������վ�İ�ȫ��־�����Ƿ�����ݽ��������ִʹ���
String ssn_id = RequestUtils.getDlogSessionId(request);
boolean wml = WML_IDENTITY.equalsIgnoreCase(identity);
String content = autoCompileContent(request, site, log.getContent(), loginUser.getId(), ssn_id, wml);
journal.setContent(content);
journal.setSize(content.getBytes().length);
journal.setTitle(super.autoFiltrate(site, log.getTitle()));
journal.setKeyword(super.autoFiltrate(site, log.getTags()));
journal.setMoodLevel(log.getMoodLevel());
journal.setRefUrl(log.getRefUrl());
journal.setReplyNotify(log.getNotify());
journal.setStatus(DiaryBean.STATUS_NORMAL);
journal.setWeather(log.getWeather());
journal.setWriteTime(DateUtils.mergeDateTime(log.getWriteDate(), log.getWriteTime()).getTime());
Date curTime = new Date();
if(journal.getWriteTime().after(curTime))
journal.setWriteTime(curTime);
// ��鱳�������Ƿ���Ч
MusicBean song = MusicDAO.getMusicByID(log.getBgSound());
if (song != null && song.getSite().getId() == site.getId()) {
journal.setBgSound(song);
}
DiaryDAO.create(journal, log.getBookmark() == 1);
// �����ϴ�����Ϣ
pickupUploadFileItems(request, response, loginUser.getId(), site, journal
.getId(), DiaryBean.TYPE_DIARY);
if (log.getRefUrl() != null) {
trackBack(journal, log.getRefUrl());
}
break;
}
if (!msgs.isEmpty()) {
saveMessages(request, msgs);
return mapping.findForward("addlog");
}
return makeForward(mapping.findForward("diary"), log.getSid());
}