/// <summary> /// Returns filled object from reader /// </summary> /// <param name="reader"></param> /// <param name="prefix"></param> /// <returns></returns> static public SearchThreadPost CreatePostFromReader(IDnaDataReader reader, int postId, string[] searchTerms) { SearchThreadPost searchPost = new SearchThreadPost() { PostId = postId }; ThreadPost.CreateThreadPostFromReader(reader, string.Empty, postId, (SearchThreadPost)searchPost, false); if (reader.DoesFieldExist("rank")) { searchPost.Rank = reader.GetInt32NullAsZero("rank"); } searchPost.Rank = (searchPost.Rank * 100) / 200;//normalise to out of 100 if (reader.DoesFieldExist("forumid")) { searchPost.ForumId = reader.GetInt32NullAsZero("forumid"); } searchPost.Text = HtmlUtils.RemoveAllHtmlTags(searchPost.Text); searchPost.Text = FormatSearchPost(searchPost.Text, searchTerms); return searchPost; }
public static ArticleSummary CreateArticleSummaryFromReader(IDnaDataReader reader) { ArticleSummary articleSummary = new ArticleSummary(); articleSummary.H2G2ID = reader.GetInt32NullAsZero("h2g2id"); articleSummary.Name = reader.GetStringNullAsEmpty("subject"); articleSummary.StrippedName = StringUtils.StrippedName(reader.GetStringNullAsEmpty("subject")); if (reader.DoesFieldExist("Type")) { articleSummary.Type = Article.GetArticleTypeFromInt(reader.GetInt32NullAsZero("Type")); } if (reader.DoesFieldExist("editor")) { articleSummary.Editor = new UserElement() { user = User.CreateUserFromReader(reader, "editor") }; } articleSummary.DateCreated = new DateElement(reader.GetDateTime("datecreated")); if (reader.DoesFieldExist("lastupdated")) { articleSummary.LastUpdated = new DateElement(reader.GetDateTime("lastupdated")); ; } articleSummary.Status = ArticleStatus.GetStatus(reader.GetInt32NullAsZero("status")); return articleSummary; }
private void AddCommentForumListXML(IDnaDataReader dataReader, XmlNode commentForumList) { // start creating the comment forum structure XmlNode commentForum = CreateElementNode("COMMENTFORUM"); AddAttribute(commentForum, "UID", dataReader.GetStringNullAsEmpty("uid")); AddAttribute(commentForum, "FORUMID", dataReader.GetInt32NullAsZero("forumID").ToString()); AddAttribute(commentForum, "FORUMPOSTCOUNT", dataReader.GetInt32NullAsZero("forumpostcount").ToString()); AddAttribute(commentForum, "FORUMPOSTLIMIT", InputContext.GetSiteOptionValueInt("Forum", "PostLimit")); AddAttribute(commentForum, "CANWRITE", dataReader.GetByteNullAsZero("CanWrite").ToString()); AddAttribute(commentForum, "NOTSIGNEDINUSERID", dataReader.GetInt32NullAsZero("NotSignedInUserID").ToString()); AddTextTag(commentForum, "HOSTPAGEURL", dataReader.GetStringNullAsEmpty("url")); AddTextTag(commentForum, "TITLE", dataReader.GetStringNullAsEmpty("title")); AddTextTag(commentForum, "MODSTATUS", dataReader.GetByteNullAsZero("ModerationStatus")); AddTextTag(commentForum, "SITEID", dataReader.GetInt32NullAsZero("siteid")); AddTextTag(commentForum, "FASTMOD", dataReader.GetInt32NullAsZero("fastmod")); AddTextTag(commentForum, "CONTACTEMAIL", dataReader.GetStringNullAsEmpty("encryptedcontactemail")); if (dataReader.DoesFieldExist("DateCreated") && !dataReader.IsDBNull("DateCreated")) { DateTime dateCreated = dataReader.GetDateTime("DateCreated"); AddElement(commentForum, "DATECREATED", DnaDateTime.GetDateTimeAsElement(RootElement.OwnerDocument, dateCreated)); } if (dataReader.DoesFieldExist("ForumCloseDate") && !dataReader.IsDBNull("ForumCloseDate")) { DateTime closeDate = dataReader.GetDateTime("ForumCloseDate"); AddElement(commentForum, "CLOSEDATE", DnaDateTime.GetDateTimeAsElement(RootElement.OwnerDocument, closeDate)); } if (dataReader.DoesFieldExist("LastUpdated") && !dataReader.IsDBNull("LastUpdated")) { DateTime dateLastUpdated = dataReader.GetDateTime("LastUpdated"); AddElement(commentForum, "LASTUPDATED", DnaDateTime.GetDateTimeAsElement(RootElement.OwnerDocument, dateLastUpdated)); } int forumId = dataReader.GetInt32NullAsZero("forumID"); AddXmlTextTag(commentForum, "TERMS", ""); commentForumList.AppendChild(commentForum); }
/// <summary> /// /// </summary> /// <param name="dataReader"></param> /// <param name="userSearchType"></param> /// <param name="searchText"></param> /// <param name="checkAllSites"></param> /// <param name="twitterAPIException"></param> public void GenerateMemberListXml( IDnaDataReader dataReader, int userSearchType, string searchText, bool checkAllSites, string twitterAPIException) { int count = 0; XmlNode memberList = AddElementTag(RootElement, "MEMBERLIST"); AddAttribute(memberList, "USERSEARCHTYPE", userSearchType.ToString()); AddAttribute(memberList, "SEARCHTEXT", searchText); AddAttribute(memberList, "CHECKALLSITES", checkAllSites.ToString()); if (dataReader.HasRows) { if (dataReader.Read()) { XmlNode userAccounts = AddElementTag(memberList, "USERACCOUNTS"); //int previousUserID = 0; XmlNode userAccount = null; do { int userID = dataReader.GetInt32NullAsZero("USERID"); /*if (userID != previousUserID) { if (userAccount != null) { userAccounts.AppendChild(userAccount); } userAccount = CreateElementNode("USERACCOUNT"); previousUserID = userID; }*/ userAccount = CreateElementNode("USERACCOUNT"); //Start filling new user xml AddAttribute(userAccount, "USERID", userID); AddTextTag(userAccount, "SITEID", dataReader.GetInt32NullAsZero("SITEID")); AddTextTag(userAccount, "USERNAME", dataReader.GetStringNullAsEmpty("USERNAME")); AddTextTag(userAccount, "LOGINNAME", dataReader.GetStringNullAsEmpty("LOGINNAME")); AddTextTag(userAccount, "EMAIL", dataReader.GetStringNullAsEmpty("EMAIL")); AddTextTag(userAccount, "PREFSTATUS", dataReader.GetInt32NullAsZero("PREFSTATUS")); AddTextTag(userAccount, "PREFSTATUSDURATION", dataReader.GetInt32NullAsZero("PREFSTATUSDURATION")); AddTextTag(userAccount, "USERSTATUSDESCRIPTION", ((ModerationStatus.UserStatus)dataReader.GetInt32NullAsZero("PREFSTATUS")).ToString()); if (!dataReader.IsDBNull("DATEJOINED")) { AddDateXml(dataReader.GetDateTime("DATEJOINED"), userAccount, "DATEJOINED"); } if (!dataReader.IsDBNull("PREFSTATUSCHANGEDDATE")) { DateTime prefStatusChangedDate = dataReader.GetDateTime("PREFSTATUSCHANGEDDATE"); AddDateXml(prefStatusChangedDate, userAccount, "PREFSTATUSCHANGEDDATE"); } else { AddTextTag(userAccount, "PREFSTATUSCHANGEDDATE", ""); } AddTextTag(userAccount, "SHORTNAME", dataReader.GetStringNullAsEmpty("SHORTNAME")); AddTextTag(userAccount, "URLNAME", dataReader.GetStringNullAsEmpty("URLNAME")); if (dataReader.DoesFieldExist("IPADDRESS") && dataReader.GetStringNullAsEmpty("IPADDRESS") != String.Empty) { AddTextTag(userAccount, "IPADDRESS", dataReader.GetStringNullAsEmpty("IPADDRESS")); } if (dataReader.DoesFieldExist("BBCUID") && dataReader.GetGuidAsStringOrEmpty("BBCUID") != String.Empty) { AddTextTag(userAccount, "BBCUID", dataReader.GetGuidAsStringOrEmpty("BBCUID")); } if (userSearchType == 6) { AddTextTag(userAccount, "TWITTERUSERID", dataReader.GetStringNullAsEmpty("TwitterUserID")); } else { AddIntElement(userAccount, "SSOUSERID", dataReader.GetInt32NullAsZero("SSOUserID")); } AddTextTag(userAccount, "IDENTITYUSERID", dataReader.GetStringNullAsEmpty("IdentityUserID")); AddIntElement(userAccount, "ACTIVE", dataReader.GetInt32NullAsZero("STATUS") != 0 ? 1:0); userAccounts.AppendChild(userAccount); count++; } while (dataReader.Read()); memberList.AppendChild(userAccounts); } } AddAttribute(memberList, "COUNT", count); AddAttribute(memberList, "TWITTEREXCEPTION", twitterAPIException); //FileCache.PutItem(AppContext.TheAppContext.Config.CachePath, "memberlist", _cacheName, memberList.OuterXml); //memberList.OwnerDocument.Save(@"c:\TEMP\memberlist.xml"); }
private void GenerateXml(IDnaDataReader reader, int h2g2Id, int postId, string exLinkUrl) { XmlElement modHistory = AddElementTag(RootElement, "MODERATION-HISTORY"); reader.Read(); if (h2g2Id > 0) AddAttribute(modHistory, "H2G2ID", h2g2Id); else if (postId > 0) { AddAttribute(modHistory, "POSTID", postId); if ( reader.HasRows ) { AddAttribute(modHistory, "FORUMID", reader.GetInt32NullAsZero("forumid") ); AddAttribute(modHistory, "THREADID", reader.GetInt32NullAsZero("threadid") ); } } else if (exLinkUrl != String.Empty) AddAttribute(modHistory, "EXLINKURL", exLinkUrl ); if (reader.HasRows) { int rowCount = 0; do { if (rowCount == 0) { AddXmlTextTag(modHistory, "SUBJECT", reader.GetStringNullAsEmpty("subject")); if (reader.DoesFieldExist("authoruserid") && !reader.IsDBNull("authoruserid")) { XmlElement editorNode = AddElementTag(modHistory, "EDITOR"); User editor = new User(InputContext); editor.AddPrefixedUserXMLBlock(reader, reader.GetInt32NullAsZero("authoruserid"), "Author", editorNode); } } XmlElement moderation = AddElementTag(modHistory, "MODERATION"); AddAttribute(moderation, "MODID", reader.GetInt32NullAsZero("modid")); AddIntElement(moderation, "STATUS", reader.GetInt32NullAsZero("status")); AddTextElement(moderation, "URLNAME", InputContext.TheSiteList.GetSite(reader.GetInt32NullAsZero("siteid")).SiteName); if (reader.DoesFieldExist("reasonid") && reader.GetInt32NullAsZero("reasonid") > 0) { AddIntElement(moderation, "REASONID", reader.GetInt32NullAsZero("reasonid")); } User user = new User(InputContext); if ( !reader.IsDBNull("lockedbyuserid") ) { XmlElement locked = AddElementTag(moderation, "LOCKED-BY"); user.AddPrefixedUserXMLBlock(reader, reader.GetInt32NullAsZero("LockedBy"), "lockedby", locked); } if (!reader.IsDBNull("referredbyuserid")) { XmlElement referred = AddElementTag(moderation, "REFERRED-BY"); user.AddPrefixedUserXMLBlock(reader, reader.GetInt32NullAsZero("referredbyuserid"), "referredby", referred); } XmlElement complaint = AddElementTag(moderation, "COMPLAINT"); AddTextElement(complaint, "COMPLAINT-TEXT", reader.GetStringNullAsEmpty("complainttext")); if (reader.DoesFieldExist("complainantuserid") && !reader.IsDBNull("complainantuserid")) { user.AddPrefixedUserXMLBlock(reader, reader.GetInt32NullAsZero("complainantuserid"), "complainant", complaint); } AddTextElement(complaint, "IPADDRESS", reader.GetStringNullAsEmpty("ipaddress")); AddTextElement(complaint, "BBCUID", reader.GetGuidAsStringOrEmpty("bbcuid").ToString()); AddTextElement(complaint, "EMAIL-ADDRESS", reader.GetStringNullAsEmpty("correspondenceemail")); AddTextElement(moderation, "NOTES", HtmlUtils.ReplaceCRsWithBRs(reader.GetStringNullAsEmpty("notes"))); AddDateXml(reader.GetDateTime("datequeued"), moderation, "DATE-QUEUED"); if (!reader.IsDBNull("datelocked")) { AddDateXml(reader.GetDateTime("datelocked"), moderation, "DATE-LOCKED"); } if (!reader.IsDBNull("datereferred")) { AddDateXml(reader.GetDateTime("datereferred"), moderation, "DATE-REFERRED"); } if (!reader.IsDBNull("datecompleted")) { AddDateXml(reader.GetDateTime("datecompleted"), moderation, "DATE-COMPLETED"); } ++rowCount; } while (reader.Read()); } }
private User DmUserFromReader(IDnaDataReader reader, ISite site) { var user = new User { UserId = reader.GetInt32NullAsZero("DmUserID"), DisplayName = reader.GetStringNullAsEmpty("DmUserName"), Editor = (reader.GetInt32NullAsZero("DmUserIsEditor") == 1), Status = reader.GetInt32NullAsZero("DmStatus"), }; if (reader.DoesFieldExist("DmIdentityUserId")) { user.BbcId = reader.GetStringNullAsEmpty("DmIdentityUserId"); } user.SiteSpecificDisplayName = string.Empty; if (SiteList.GetSiteOptionValueBool(site.SiteID, "User", "UseSiteSuffix")) { if (reader.DoesFieldExist("DmSiteSpecificDisplayName")) { user.SiteSpecificDisplayName = reader.GetStringNullAsEmpty("SiteSpecificDisplayName"); } } return user; }
/// <summary> /// AddPollXml - Delegates responsibility of producing standard Poll Xml to the Poll Class. /// Only produces Poll Xml where a valid Poll exists in the resultset. /// </summary> /// <param name="dataReader">Record set containing the data</param> /// <param name="parent">Parent node to add the xml to</param> private void AddPollXml(IDnaDataReader dataReader, XmlNode parent) { if (dataReader.DoesFieldExist("CRPollID")) { int pollId = dataReader.GetInt32NullAsZero("CRPollID"); if (pollId > 0) { PollContentRating poll = new PollContentRating(this.InputContext, this.InputContext.ViewingUser); poll.PollID = dataReader.GetInt32NullAsZero("CRPollID"); poll.Hidden = dataReader.GetInt32NullAsZero("Hidden") != 0; int voteCount = dataReader.GetInt32NullAsZero("CRVoteCount"); double avgRating = dataReader.GetDoubleNullAsZero("CRAverageRating"); poll.SetContentRatingStatistics(voteCount, avgRating); XmlNode node = poll.MakePollXML(false); if (node != null) { parent.AppendChild(ImportNode(node)); } } } }
/// <summary> /// Generates the individual Comment CommentBoxForum Xml within the Comment CommentBoxForum List xml page /// </summary> /// <param name="dataReader">SP containing the comment forums</param> /// <param name="commentForumList">Parent node to attach to</param> private void AddCommentForumListXML(IDnaDataReader dataReader, XmlNode commentForumList) { // start creating the comment forum structure XmlNode commentForum = CreateElementNode("COMMENTFORUM"); AddAttribute(commentForum, "UID", dataReader.GetStringNullAsEmpty("uid")); AddAttribute(commentForum, "FORUMID", dataReader.GetInt32NullAsZero("forumID").ToString()); AddAttribute(commentForum, "FORUMPOSTCOUNT", dataReader.GetInt32NullAsZero("forumpostcount").ToString()); AddAttribute(commentForum, "FORUMPOSTLIMIT", InputContext.GetSiteOptionValueInt("Forum", "PostLimit")); AddAttribute(commentForum, "CANWRITE", dataReader.GetByteNullAsZero("CanWrite").ToString()); AddAttribute(commentForum, "NOTSIGNEDINUSERID", dataReader.GetInt32NullAsZero("NotSignedInUserID").ToString()); AddTextTag(commentForum, "HOSTPAGEURL", dataReader.GetStringNullAsEmpty("url")); AddTextTag(commentForum, "TITLE", dataReader.GetStringNullAsEmpty("title")); AddTextTag(commentForum, "MODSTATUS", dataReader.GetByteNullAsZero("ModerationStatus")); AddTextTag(commentForum, "SITEID", dataReader.GetInt32NullAsZero("siteid")); AddTextTag(commentForum, "FASTMOD", dataReader.GetInt32NullAsZero("fastmod")); if (dataReader.DoesFieldExist("DateCreated") && !dataReader.IsDBNull("DateCreated")) { DateTime dateCreated = dataReader.GetDateTime("DateCreated"); AddElement(commentForum, "DATECREATED", DnaDateTime.GetDateTimeAsElement(RootElement.OwnerDocument, dateCreated)); } if (dataReader.DoesFieldExist("ForumCloseDate") && !dataReader.IsDBNull("ForumCloseDate")) { DateTime closeDate = dataReader.GetDateTime("ForumCloseDate"); AddElement(commentForum, "CLOSEDATE", DnaDateTime.GetDateTimeAsElement(RootElement.OwnerDocument, closeDate)); } if (dataReader.DoesFieldExist("LastUpdated") && !dataReader.IsDBNull("LastUpdated")) { DateTime dateLastUpdated = dataReader.GetDateTime("LastUpdated"); AddElement(commentForum, "LASTUPDATED", DnaDateTime.GetDateTimeAsElement(RootElement.OwnerDocument, dateLastUpdated)); } int forumId = dataReader.GetInt32NullAsZero("forumID"); //get terms admin object TermsFilterAdmin termsAdmin = TermsFilterAdmin.CreateForumTermAdmin(InputContext.CreateDnaDataReaderCreator(), _cache, forumId); XmlDocument termNodeDoc = SerialiseToXmlDoc(termsAdmin); string termNodeText = termNodeDoc.DocumentElement.InnerXml.ToString(); AddXmlTextTag(commentForum, "TERMS", termNodeText); commentForumList.AppendChild(commentForum); }
/// <summary> /// With the returned data set generate the XML for the Article Search page /// </summary> /// <param name="dataReader">The returned search resultset</param> /// <param name="asp">The Article Search Params</param> private void GenerateArticleSearchXml(IDnaDataReader dataReader, ArticleSearchParams asp) { RootElement.RemoveAll(); XmlNode articleSearch = AddElementTag(RootElement, "ARTICLESEARCH"); AddAttribute(articleSearch, "CONTENTTYPE", asp.ContentType); AddAttribute(articleSearch, "SORTBY", asp.SortBy); AddAttribute(articleSearch, "SKIPTO", asp.Skip); AddAttribute(articleSearch, "SHOW", asp.Show); AddAttribute(articleSearch, "DATESEARCHTYPE", asp.DateSearchType); AddAttribute(articleSearch, "TIMEINTERVAL", asp.TimeInterval); AddAttribute(articleSearch, "ARTICLESTATUS", asp.ArticleStatus); AddAttribute(articleSearch, "ARTICLETYPE", asp.ArticleType); AddAttribute(articleSearch, "LATITUDE", asp.Latitude); AddAttribute(articleSearch, "LONGITUDE", asp.Longitude); AddAttribute(articleSearch, "RANGE", asp.Range); AddAttribute(articleSearch, "POSTCODE", asp.PostCode); AddAttribute(articleSearch, "PLACENAME", asp.Placename); AddAttribute(articleSearch, "LOCATIONSEARCHTYPE", asp.LocationSearchType); //Add the new descending order attribute if (asp.DescendingOrder) { AddAttribute(articleSearch, "DESCENDINGORDER", 1); } else { AddAttribute(articleSearch, "DESCENDINGORDER", 0); } //Add the requested searchphraselist GeneratePhraseXml(asp.SearchPhraseList, (XmlElement)articleSearch); //Add Date Search Params if we are doing a date search if (asp.DateSearchType != 0) { AddDateXml(asp.StartDate, articleSearch, "DATERANGESTART"); // Take a day from the end date as used in the database for UI purposes. // E.g. User submits a date range of 01/09/1980 to 02/09/1980. They mean for this to represent 2 days i.e. 01/09/1980 00:00 - 03/09/1980 00:00. // This gets used in the database but for display purposes we subtract a day from the database end date to return the // original dates submitted by the user inorder to match their expectations. AddDateXml(asp.EndDate.AddDays(-1), articleSearch, "DATERANGEEND"); } AddTextTag(articleSearch, "FREETEXTSEARCH", asp.FreeTextSearchCondition); XmlNode articles = AddElementTag(articleSearch, "ARTICLES"); int total = 0; int count = 0; //Generate Hot-List from Search Results. PopularPhrases popularPhrases = null; if (InputContext.GetSiteOptionValueBool("articlesearch", "generatepopularphrases")) { popularPhrases = new PopularPhrases(); } if (dataReader.HasRows) { // process first results set: the Article Key phrase results set Dictionary<int, ArrayList> articleKeyPhrases = new Dictionary<int, ArrayList>(); ArrayList phraselist = new ArrayList(); int h2g2ID = 0; if (dataReader.Read()) { int previousH2G2ID = 0; do { h2g2ID = dataReader.GetInt32NullAsZero("H2G2ID"); if (h2g2ID != previousH2G2ID) { //New now have a new article so clean up the last one if (previousH2G2ID != 0) { articleKeyPhrases.Add(previousH2G2ID, phraselist); phraselist = new ArrayList(); } } //set the previous h2g2id to this one previousH2G2ID = h2g2ID; //Create fill an new Phrase object Phrase nameSpacedPhrase = new Phrase(); String nameSpace = String.Empty; String phraseName = dataReader.GetStringNullAsEmpty("phrase"); if (phraseName != String.Empty) { if (dataReader.Exists("namespace")) { nameSpace = dataReader.GetStringNullAsEmpty("namespace"); } nameSpacedPhrase.NameSpace = nameSpace; nameSpacedPhrase.PhraseName = phraseName; //add it to the list phraselist.Add(nameSpacedPhrase); //Record Popular Phrases. if (popularPhrases != null) { popularPhrases.AddPhrase(phraseName, nameSpace); } } } while (dataReader.Read()); } articleKeyPhrases.Add(h2g2ID, phraselist); dataReader.NextResult(); if (dataReader.Read()) { total = dataReader.GetInt32NullAsZero("TOTAL"); //The stored procedure returns one row for each article. The article's keyphrases have been stored in articleKeyPhrases. XmlNode article = CreateElementNode("ARTICLE"); do { count++; h2g2ID = dataReader.GetInt32NullAsZero("H2G2ID"); //Start filling new article xml AddAttribute(article, "H2G2ID", h2g2ID); int editorID = dataReader.GetInt32NullAsZero("editor"); XmlNode editor = CreateElementNode("EDITOR"); User user = new User(InputContext); user.AddUserXMLBlock(dataReader, editorID, editor); article.AppendChild(editor); AddTextTag(article, "STATUS", dataReader.GetInt32NullAsZero("status")); AddXmlTextTag(article, "SUBJECT", dataReader.GetStringNullAsEmpty("SUBJECT")); AddTextTag(article, "TYPE", dataReader.GetInt32NullAsZero("type")); AddDateXml(dataReader, article, "DateCreated", "DATECREATED"); AddDateXml(dataReader, article, "LastUpdated", "LASTUPDATED"); //Add Extra Info XML where it exists. string extraInfo = dataReader.GetAmpersandEscapedStringNullAsEmpty("EXTRAINFO"); if (extraInfo != string.Empty) { XmlDocument extraInfoXml = new XmlDocument(); extraInfoXml.LoadXml(extraInfo); article.AppendChild(ImportNode(extraInfoXml.FirstChild)); } AddTextTag(article, "NUMBEROFPOSTS", dataReader.GetInt32NullAsZero("ForumPostCount")); AddDateXml(dataReader, article, "LASTPOSTED", "FORUMLASTPOSTED"); if (!dataReader.IsDBNull("StartDate")) { AddDateXml(dataReader, article, "StartDate", "DATERANGESTART"); // Take a day from the end date as stored in the database for UI purposes. // E.g. User submits a date range of 01/09/1980 to 02/09/1980. They mean for this to represent 2 days i.e. 01/09/1980 00:00 - 03/09/1980 00:00. // This gets stored in the database but for display purposes we subtract a day from the database end date to return the // original dates submitted by the user inorder to match their expectations. AddDateXml(dataReader.GetDateTime("EndDate").AddDays(-1), article, "DATERANGEEND"); AddTextTag(article, "TIMEINTERVAL", dataReader.GetInt32NullAsZero("TimeInterval")); } if (dataReader.DoesFieldExist("BookmarkCount")) { AddTextTag(article, "BOOKMARKCOUNT", dataReader.GetInt32NullAsZero("BookmarkCount")); } if (dataReader.DoesFieldExist("ZeitgeistScore")) { AddElement(article, "ZEITGEIST", "<SCORE>" + dataReader.GetDoubleNullAsZero("ZeitgeistScore") + "</SCORE>"); } #region LocationXML //*********************************************************************** // Location Info //*********************************************************************** if (dataReader.DoesFieldExist("Latitude") && !dataReader.IsDBNull("Latitude")) { AddTextTag(article, "LATITUDE", dataReader.GetDoubleNullAsZero("Latitude").ToString()); AddTextTag(article, "LONGITUDE", dataReader.GetDoubleNullAsZero("Longitude").ToString()); if (dataReader.DoesFieldExist("Distance")) { if (dataReader.GetDoubleNullAsZero("Distance") < 0.0001) { AddTextTag(article, "DISTANCE", "0"); } else { AddTextTag(article, "DISTANCE", dataReader.GetDoubleNullAsZero("Distance").ToString()); } } AddTextTag(article, "LOCATIONTITLE", dataReader.GetString("LocationTitle")); AddTextTag(article, "LOCATIONDESCRIPTION", dataReader.GetString("LocationDescription")); AddTextTag(article, "LOCATIONZOOMLEVEL", dataReader.GetInt32NullAsZero("LocationZoomLevel").ToString()); AddTextTag(article, "LOCATIONUSERID", dataReader.GetInt32NullAsZero("LocationUserID").ToString()); AddDateXml(dataReader.GetDateTime("LocationDateCreated"), article, "LOCATIONDATECREATED"); } //*********************************************************************** #endregion //*********************************************************************** // Media Asset Info //*********************************************************************** int mediaAssetID = dataReader.GetInt32NullAsZero("MediaAssetID"); if (mediaAssetID != 0) { AddMediaAssetXml(dataReader, article, mediaAssetID); } //*********************************************************************** AddPollXml(dataReader, article); if (articleKeyPhrases.ContainsKey(h2g2ID)) { GeneratePhraseXml(articleKeyPhrases[h2g2ID], (XmlElement)article); } XmlNode previousarticle = article.CloneNode(true); articles.AppendChild(previousarticle); article.RemoveAll(); } while (dataReader.Read()); } } articleSearch.AppendChild(articles); AddAttribute(articleSearch, "COUNT", count); AddAttribute(articleSearch, "TOTAL", total); if (popularPhrases != null) { //Include popularPhrase statistics. XmlElement popularPhrasesXml = popularPhrases.GenerateXml(); articleSearch.AppendChild(ImportNode(popularPhrasesXml)); } FileCache.PutItem(AppContext.TheAppContext.Config.CachePath, "articlesearch", _cacheName, articleSearch.OuterXml); //articleSearch.OwnerDocument.Save(@"c:\TEMP\Articlesearch.xml"); }
private void GetGroupedLinks(IDnaDataReader dataReader, XmlElement parent, int show) { string currentGroup = String.Empty; string newGroup = String.Empty; int count = show; bool groupOpen = false; XmlElement group = null; do { newGroup = dataReader.GetStringNullAsEmpty("Type"); if (newGroup != currentGroup) { groupOpen = false; } if (!groupOpen) { groupOpen = true; currentGroup = dataReader.GetStringNullAsEmpty("Type"); group = AddElementTag(parent, "GROUP"); AddAttribute(group, "CURRENT", dataReader.GetInt32NullAsZero("selected")); AddTextTag(group, "NAME", currentGroup); } string type = dataReader.GetStringNullAsEmpty("DestinationType"); int objectID = dataReader.GetInt32NullAsZero("DestinationID"); XmlElement link = AddElementTag(group, "LINK"); AddAttribute(link, "TYPE", type); AddAttribute(link, "LINKID", dataReader.GetInt32NullAsZero("linkID")); AddAttribute(link, "TEAMID", dataReader.GetInt32NullAsZero("TeamID")); AddAttribute(link, "RELATIONSHIP", StringUtils.EscapeAllXmlForAttribute(dataReader.GetStringNullAsEmpty("Relationship"))); switch (type) { case "article" : { AddAttribute(link, "DNAID", "A" + objectID.ToString()); break; } case "userpage" : { AddAttribute(link, "BIO", "U" + objectID.ToString()); break; } case "category" : { AddAttribute(link, "DNAID", "C" + objectID.ToString()); break; } case "forum" : { AddAttribute(link, "DNAID", "F" + objectID.ToString()); break; } case "thread" : { AddAttribute(link, "DNAID", "T" + objectID.ToString()); break; } case "posting" : { AddAttribute(link, "DNAID", "TP" + objectID.ToString()); break; } case "club" : { AddAttribute(link, "DNAID", "G" + objectID.ToString()); break; } default : // "external" : { AddAttribute(link, "URL", StringUtils.EscapeAllXmlForAttribute(dataReader.GetStringNullAsEmpty("URL"))); break; } } AddAttribute(link, "PRIVATE", dataReader.GetTinyIntAsInt("Private")); AddTextTag(link, "TITLE", dataReader.GetStringNullAsEmpty("Title")); AddTextTag(link, "DESCRIPTION", dataReader.GetStringNullAsEmpty("LinkDescription")); // Submitter, if we have one if(dataReader.DoesFieldExist("SubmitterID")) { int submitterID = dataReader.GetInt32NullAsZero("SubmitterID"); XmlElement submitterTag = AddElementTag(link, "SUBMITTER"); AddIntElement(submitterTag, "USERID", submitterID); //TODO Add all Submitter User fields to SP //User submitter = new User(InputContext); //submitter.AddPrefixedUserXMLBlock(dataReader, submitterID, "Submitter", submitterTag); } /* //add information about a team which added the link: CTeam team(m_InputContext); if (team.GetAllTeamMembers(iTeamID)) { CTDVString sTeam; team.GetAsString(sTeam); sXML << sTeam; } */ // Add author block if we have one if (dataReader.DoesFieldExist("AuthorID")) { int authorID = dataReader.GetInt32NullAsZero("AuthorID"); XmlElement authorTag = AddElementTag(link, "AUTHOR"); AddIntElement(authorTag, "USERID", authorID); //TODO Add all Author User fields to SP //User author = new User(InputContext); //author.AddPrefixedUserXMLBlock(dataReader, authorID, "Author", authorTag); } // Add LastUpdated if (dataReader.DoesFieldExist("LastUpdated") && !dataReader.IsDBNull("LastUpdated")) { AddDateXml(dataReader, link, "LastUpdated", "LASTUPDATED"); } count--; } while (dataReader.Read() && count > 0); }
/// <summary> /// Helper method to create the list after a specific stored procedure /// has been called to return an appropriate results set. /// </summary> /// <param name="articleList"></param> /// <param name="dataReader"></param> /// <param name="skip">Number of Articles to skip</param> /// <param name="show">Number of Articles to show</param> /// <returns></returns> public int CreateList(XmlElement articleList, IDnaDataReader dataReader, int skip, int show) { int count = show; bool records = true; //Read/skip over the skip number of rows so that the row that the first row that in the do below is //the one required for (int i = 0; i < skip; i++) { records = dataReader.Read(); if (!records) { break; } } if (records) { do { // Setup the article XmlElement article = AddElementTag(articleList, "ARTICLE"); if (dataReader.DoesFieldExist("EntryID")) { AddIntElement(article, "ENTRY-ID", dataReader.GetInt32NullAsZero("EntryID")); } if (dataReader.DoesFieldExist("h2g2ID")) { AddAttribute(article, "H2G2ID", dataReader.GetInt32NullAsZero("h2g2ID")); //TODO: remove the H2G2-ID from all schemas and skins... AddIntElement(article, "H2G2-ID", dataReader.GetInt32NullAsZero("h2g2ID")); } if (dataReader.DoesFieldExist("SiteID")) { AddIntElement(article, "SITEID", dataReader.GetInt32NullAsZero("SiteID")); } if (dataReader.DoesFieldExist("RecommendationID")) { AddIntElement(article, "RECOMMENDATION-ID", dataReader.GetInt32NullAsZero("RecommendationID")); } if (dataReader.DoesFieldExist("NotificationSent")) { AddIntElement(article, "NOTIFIED", dataReader.GetBoolean("NotificationSent") ? 1 : 0); } User user = new User(InputContext); if (dataReader.DoesFieldExist("Editor")) { // place all user details within a USER tag and structure them appropriately // editor info int editorID = dataReader.GetInt32NullAsZero("Editor"); XmlElement editorTag = AddElementTag(article, "EDITOR"); user.AddPrefixedUserXMLBlock(dataReader, editorID, "Editor", editorTag); } if (dataReader.DoesFieldExist("AuthorID")) { // author info int authorID = dataReader.GetInt32NullAsZero("AuthorID"); XmlElement authorTag = AddElementTag(article, "AUTHOR"); user.AddPrefixedUserXMLBlock(dataReader, authorID, "Author", authorTag); } if (dataReader.DoesFieldExist("AcceptorID")) { // acceptor info (user that accepted a recommendation) int acceptorID = dataReader.GetInt32NullAsZero("AcceptorID"); XmlElement acceptorTag = AddElementTag(article, "ACCEPTOR"); user.AddPrefixedUserXMLBlock(dataReader, acceptorID, "Acceptor", acceptorTag); } if (dataReader.DoesFieldExist("AllocatorID")) { // allocator info (user that allocated a recommendation to a sub) int allocatorID = dataReader.GetInt32NullAsZero("AllocatorID"); XmlElement allocatorTag = AddElementTag(article, "ALLOCATOR"); user.AddPrefixedUserXMLBlock(dataReader, allocatorID, "Allocator", allocatorTag); } if (dataReader.DoesFieldExist("ScoutID")) { // scout info int scoutID = dataReader.GetInt32NullAsZero("ScoutID"); XmlElement scoutTag = AddElementTag(article, "SCOUT"); user.AddPrefixedUserXMLBlock(dataReader, scoutID, "Scout", scoutTag); } if (dataReader.DoesFieldExist("SubEditorID")) { // sub editor info int subEditorID = dataReader.GetInt32NullAsZero("SubEditorID"); XmlElement subEditorTag = AddElementTag(article, "SUBEDITOR"); user.AddPrefixedUserXMLBlock(dataReader, subEditorID, "SubEditor", subEditorTag); } if (dataReader.DoesFieldExist("Status")) { AddIntElement(article, "STATUS", dataReader.GetInt32NullAsZero("Status")); } if (dataReader.DoesFieldExist("RecommendationStatus")) { AddIntElement(article, "RECOMMENDATION-STATUS", dataReader.GetInt32NullAsZero("RecommendationStatus")); } if (dataReader.DoesFieldExist("SubbingStatus")) { AddIntElement(article, "SUBBING-STATUS", dataReader.GetInt32NullAsZero("SubbingStatus")); } if (dataReader.DoesFieldExist("Style")) { AddIntElement(article, "STYLE", dataReader.GetInt32NullAsZero("Style")); } if (dataReader.DoesFieldExist("Subject")) { AddTextTag(article, "SUBJECT", dataReader.GetStringNullAsEmpty("Subject")); } if (dataReader.DoesFieldExist("DateCreated")) { AddDateXml(dataReader, article, "DateCreated", "DATE-CREATED"); } if (dataReader.DoesFieldExist("LastUpdated")) { AddDateXml(dataReader, article, "LastUpdated", "LASTUPDATED"); } if (dataReader.DoesFieldExist("DateRecommended")) { AddDateXml(dataReader, article, "DateRecommended", "DATE-RECOMMENDED"); } if (dataReader.DoesFieldExist("DecisionDate")) { AddDateXml(dataReader, article, "DecisionDate", "RECOMMENDATION-DECISION-DATE"); } if (dataReader.DoesFieldExist("DateAllocated")) { AddDateXml(dataReader, article, "DateAllocated", "DATE-ALLOCATED"); } if (dataReader.DoesFieldExist("DateReturned")) { AddDateXml(dataReader, article, "DateReturned", "DATE-RETURNED"); } //TODO add Extra Info correctly if (dataReader.DoesFieldExist("ExtraInfo")) { //Add Extra Info XML where it exists. string extraInfo = dataReader.GetAmpersandEscapedStringNullAsEmpty("ExtraInfo"); if (extraInfo != string.Empty) { XmlDocument extraInfoXml = new XmlDocument(); extraInfoXml.LoadXml(extraInfo); article.AppendChild(ImportNode(extraInfoXml.FirstChild)); } //TODO Use Extra Info Class will need to change SP to get out the guide entry Type //ExtraInfo extraInfo = new ExtraInfo(); //extraInfo.TryCreate(dataReader.GetInt32NullAsZero("Type"), dataReader.GetStringNullAsEmpty("ExtraInfo")); //AddInside(article, extraInfo); } if (dataReader.DoesFieldExist("ForumPostCount")) { AddIntElement(article, "FORUMPOSTCOUNT", dataReader.GetInt32NullAsZero("ForumPostCount")); AddIntElement(article, "FORUMPOSTLIMIT", InputContext.GetSiteOptionValueInt("Forum", "PostLimit")); } if (dataReader.DoesFieldExist("StartDate") && !dataReader.IsDBNull("StartDate")) { AddDateXml(dataReader, article, "StartDate", "DATERANGESTART"); } // Take a day from the end date as stored in the database for UI purposes. // E.g. User submits a date range of 01/09/1980 to 02/09/1980. They mean for this to represent 2 days i.e. 01/09/1980 00:00 - 03/09/1980 00:00. // This gets stored in the database but for display purposes we subtract a day from the database end date to return the // original dates submitted by the user inorder to match their expectations. if (dataReader.DoesFieldExist("EndDate") && !dataReader.IsDBNull("EndDate")) { AddDateXml(dataReader.GetDateTime("EndDate").AddDays(-1), article, "DATERANGEEND"); } if (dataReader.DoesFieldExist("TimeInterval")) { AddIntElement(article, "TIMEINTERVAL", dataReader.GetInt32NullAsZero("TimeInterval")); } if (dataReader.DoesFieldExist("LASTPOSTED")) { AddDateXml(dataReader, article, "LASTPOSTED", "FORUMLASTPOSTED"); } ////////// if (dataReader.DoesFieldExist("BookmarkCount")) { AddTextTag(article, "BOOKMARKCOUNT", dataReader.GetInt32NullAsZero("BookmarkCount")); } if (dataReader.DoesFieldExist("ZeitgeistScore")) { AddElement(article, "ZEITGEIST", "<SCORE>" + dataReader.GetDoubleNullAsZero("ZeitgeistScore") + "</SCORE>"); } #region LocationXML //*********************************************************************** // Location Info //*********************************************************************** if (dataReader.DoesFieldExist("Latitude") && !dataReader.IsDBNull("Latitude")) { AddTextTag(article, "LATITUDE", dataReader.GetDoubleNullAsZero("Latitude").ToString()); AddTextTag(article, "LONGITUDE", dataReader.GetDoubleNullAsZero("Longitude").ToString()); if (dataReader.DoesFieldExist("Distance")) { if (dataReader.GetDoubleNullAsZero("Distance") < 0.0001) { AddTextTag(article, "DISTANCE", "0"); } else { AddTextTag(article, "DISTANCE", dataReader.GetDoubleNullAsZero("Distance").ToString()); } } AddTextTag(article, "LOCATIONTITLE", dataReader.GetString("LocationTitle")); AddTextTag(article, "LOCATIONDESCRIPTION", dataReader.GetString("LocationDescription")); AddTextTag(article, "LOCATIONZOOMLEVEL", dataReader.GetInt32NullAsZero("LocationZoomLevel").ToString()); AddTextTag(article, "LOCATIONUSERID", dataReader.GetInt32NullAsZero("LocationUserID").ToString()); AddDateXml(dataReader.GetDateTime("LocationDateCreated"), article, "LOCATIONDATECREATED"); } //*********************************************************************** #endregion if (dataReader.DoesFieldExist("MediaAssetID")) { AddMediaAssetXml(dataReader, article, dataReader.GetInt32NullAsZero("MediaAssetID")); } if (dataReader.DoesFieldExist("CRPollID")) { AddPollXml(dataReader, article); } count--; } while (count > 0 && dataReader.Read()); // dataReader.Read won't get called if count == 0 // See if there's an extra row waiting if (count == 0 && dataReader.Read()) { AddAttribute(articleList, "MORE", 1); } } return count; }
/// <summary> /// /// </summary> /// <param name="reader"></param> /// <param name="forumId"></param> /// <param name="index"></param> /// <param name="applySkin">whether we need to apply the transform to the post</param> /// <returns></returns> public static ThreadSummary CreateThreadSummaryFromReader(IDnaDataReader reader, int forumId, int index, bool applySkin) { var thread = new ThreadSummary(); thread.ForumId = forumId; thread.Index = index; thread.Type = string.Empty; //TODO: remove as this is a legacy ripley element if (reader.DoesFieldExist("ThisCanRead")) { thread.CanRead = (byte)(reader.GetBoolean("ThisCanRead") ? 1 : 0); } if (reader.DoesFieldExist("ThisCanWrite")) { thread.CanWrite = (byte)(reader.GetBoolean("ThisCanWrite") ? 1 : 0); } thread.ThreadId = reader.GetInt32NullAsZero("ThreadID"); thread.DateLastPosted = new DateElement(reader.GetDateTime("LastPosted")); if (reader.DoesFieldExist("cnt")) { thread.TotalPosts = reader.GetInt32NullAsZero("cnt"); } if (reader.DoesFieldExist("firstpostentryid")) { thread.FirstPost = ThreadPostSummary.CreateThreadPostFromReader(reader, "FirstPost", reader.GetInt32NullAsZero("firstpostentryid"), applySkin); } if (reader.DoesFieldExist("lastpostentryid")) { thread.LastPost = ThreadPostSummary.CreateThreadPostFromReader(reader, "LastPost", reader.GetInt32NullAsZero("lastpostentryid"), applySkin); } if (reader.DoesFieldExist("FirstSubject")) { if (thread.FirstPost != null) { thread.Subject = ThreadPost.FormatSubject(reader.GetString("FirstSubject"), (CommentStatus.Hidden)thread.FirstPost.Hidden); } else { thread.Subject = ThreadPost.FormatSubject(reader.GetString("FirstSubject"), CommentStatus.Hidden.NotHidden ); } } if(reader.DoesFieldExist("IsSticky")) {//conditionally check if field exists.. thread.IsSticky = (reader.GetInt32NullAsZero("IsSticky")==1); } return thread; }
public static PostThreadInfo CreatePostThreadInfoFromReader(IDnaDataReader reader) { PostThreadInfo postThreadInfo = new PostThreadInfo(); postThreadInfo.ForumId = reader.GetInt32NullAsZero("ForumId"); postThreadInfo.ThreadId = reader.GetInt32NullAsZero("ThreadId"); string type = reader.GetStringNullAsEmpty("Type"); if (type == "") { postThreadInfo.Type = 0; } else if (type == "Notice") { postThreadInfo.Type = 1; } else if (type == "Event") { postThreadInfo.Type = 2; } else { postThreadInfo.Type = 3; } if (reader.DoesFieldExist("FirstPostId")) { postThreadInfo.FirstPostId = reader.GetInt32NullAsZero("FirstPostId"); } if (reader["DateFirstPosted"] != DBNull.Value) { postThreadInfo.DateFirstPosted = new DateElement(reader.GetDateTime("DateFirstPosted")); } if (reader["LastReply"] != DBNull.Value) { postThreadInfo.ReplyDate = new DateElement(reader.GetDateTime("LastReply")); } postThreadInfo.Subject = reader.GetStringNullAsEmpty("FirstSubject"); postThreadInfo.ForumTitle = reader.GetStringNullAsEmpty("ForumTitle"); if (reader.DoesFieldExist("JournalUserID")) { postThreadInfo.Journal = new UserElement() { user = BBC.Dna.Objects.User.CreateUserFromReader(reader, "Journal") }; } return postThreadInfo; }
/// <summary> /// CreateRouteXML from a dataReader. /// Allows standard Route XML to be generated from different resultsets. /// </summary> /// <param name="dataReader"></param> /// <param name="includeLocations">Whether the locations need to be included or just route info</param> public void CreateRouteXML(IDnaDataReader dataReader, bool includeLocations) { int count = 0; XmlElement routeXML = (XmlElement) AddElementTag(RootElement, "ROUTE"); if (dataReader.HasRows && dataReader.DoesFieldExist("RouteID")) { AddAttribute(routeXML, "ROUTEID", dataReader.GetInt32NullAsZero("RouteID").ToString()); AddTextTag(routeXML, "ROUTETITLE", dataReader.GetStringNullAsEmpty("RouteTitle")); AddTextTag(routeXML, "ROUTEDESCRIPTION", dataReader.GetStringNullAsEmpty("RouteDescription")); AddTextTag(routeXML, "DESCRIBINGARTICLEID", dataReader.GetInt32NullAsZero("H2G2ID").ToString()); AddTextTag(routeXML, "SUBJECT", dataReader.GetStringNullAsEmpty("Subject")); //AddTextTag(routeXML, "GPSTRACKDATALOCATION", dataReader.GetStringNullAsEmpty("GPSTRACKDATALOCATION")); if (includeLocations) { XmlElement locations = AddElementTag(routeXML, "LOCATIONS"); if (dataReader.NextResult() && dataReader.Read()) { do { count++; XmlElement location = AddElementTag(locations, "LOCATION"); location.SetAttribute("LOCATIONID", dataReader.GetInt32NullAsZero("LocationID").ToString()); location.SetAttribute("ORDER", dataReader.GetInt32NullAsZero("Order").ToString()); AddTextTag(location, "LATITUDE", dataReader.GetDoubleNullAsZero("Latitude").ToString()); AddTextTag(location, "LONGITUDE", dataReader.GetDoubleNullAsZero("Longitude").ToString()); AddTextTag(location, "LOCATIONTITLE", dataReader.GetStringNullAsEmpty("LocationTitle")); AddTextTag(location, "LOCATIONDESCRIPTION", dataReader.GetStringNullAsEmpty("LocationDescription")); AddTextTag(location, "LOCATIONZOOMLEVEL", dataReader.GetInt32NullAsZero("LocationZoomLevel").ToString()); AddTextTag(location, "LOCATIONUSERID", dataReader.GetInt32NullAsZero("LocationUserID").ToString()); AddDateXml(dataReader.GetDateTime("LocationDateCreated"), location, "LOCATIONDATECREATED"); } while (dataReader.Read()); } AddAttribute(locations, "COUNT", count.ToString()); } } }
/// <summary> /// Creates a threadpost from a given reader /// </summary> /// <param name="reader"></param> /// <param name="prefix">The data base name prefix</param> /// <param name="postId">postId to get</param> /// <param name="post">The post in question to load with data</param> /// <param name="applySkin">Whether we need to process the text into html for output</param> /// <returns></returns> static public ThreadPost CreateThreadPostFromReader(IDnaDataReader reader, string prefix, int postId, ThreadPost post, bool applySkin) { if (post == null) { post = new ThreadPost() { PostId = postId }; } if (reader.DoesFieldExist(prefix +"threadid")) { post.ThreadId = reader.GetInt32NullAsZero(prefix +"threadid"); } if (reader.DoesFieldExist(prefix +"parent")) { post.InReplyTo = reader.GetInt32NullAsZero(prefix +"parent"); } if (reader.DoesFieldExist(prefix +"replypostindex")) { post.InReplyToIndex = reader.GetInt32NullAsZero(prefix + "replypostindex"); } if (reader.DoesFieldExist(prefix +"postindex")) { post.Index = reader.GetInt32NullAsZero(prefix + "postindex"); } if (reader.DoesFieldExist(prefix +"prevSibling")) { post.PrevSibling = reader.GetInt32NullAsZero(prefix +"prevSibling"); } if (reader.DoesFieldExist(prefix +"nextSibling")) { post.NextSibling = reader.GetInt32NullAsZero(prefix +"nextSibling"); } if (reader.DoesFieldExist(prefix +"firstChild")) { post.FirstChild = reader.GetInt32NullAsZero(prefix +"firstChild"); } if (reader.DoesFieldExist(prefix +"hidden")) { post.Hidden = (byte)reader.GetInt32NullAsZero(prefix +"hidden"); } if (reader.DoesFieldExist(prefix +"subject")) { post.Subject = FormatSubject(reader.GetStringNullAsEmpty("subject"), (CommentStatus.Hidden)post.Hidden); } if (reader.DoesFieldExist(prefix + "datePosted") && reader[prefix + "datePosted"] != DBNull.Value) { post.DatePosted = new DateElement(reader.GetDateTime(prefix + "datePosted".ToString())); } if (reader.DoesFieldExist(prefix +"postStyle")) { post.Style = (PostStyle.Style)reader.GetByteNullAsZero(prefix + "postStyle"); } if (reader.DoesFieldExist(prefix +"text")) { post.Text = ThreadPost.FormatPost(reader.GetStringNullAsEmpty(prefix + "text"), (CommentStatus.Hidden)post.Hidden, true, applySkin); } if (reader.DoesFieldExist(prefix +"hostpageurl")) { post.HostPageUrl = reader.GetStringNullAsEmpty(prefix + "hostpageurl"); } if (reader.DoesFieldExist(prefix +"commentforumtitle")) { post.CommentForumTitle = reader.GetStringNullAsEmpty(prefix + "commentforumtitle"); } post.User = BBC.Dna.Objects.User.CreateUserFromReader(reader); #region Depreciated code /* * This code has been depreciated from forum.cpp ln 1066 as the functionality is no longer in use. // Add the event date if it has one! bOk = bOk && AddDBXMLDateTag("eventdate",NULL,false,true); // Get the Type of post we're looking at bOk = bOk && AddDBXMLTag("type",NULL,false,true,&sPostType); // Now see if we are an event or notice, if so put the taginfo in for the post if (sPostType.CompareText("Notice") || sPostType.CompareText("Event")) { // We've got a notice or event! Get all the tag info CTagItem TagItem(m_InputContext); if (TagItem.InitialiseFromThreadId(ThreadID,m_SiteID,pViewer) && TagItem.GetAllNodesTaggedForItem()) { TagItem.GetAsString(sPosts); } } */ #endregion return post; }
void RiskMod_ProcessRiskAssessmentForThreadEntry(IDnaDataReader reader, int riskModId, string isRisky, out int? newThreadId, out int? newThreadEntryId) { string sql = string.Format(@" declare @ret int exec @ret=riskmod_processriskassessmentforthreadentry @riskmodthreadentryqueueid={0}, @risky={1} ", riskModId, RiskyOrNotRisky(isRisky)); reader.ExecuteWithinATransaction(sql); reader.Read(); if (reader.DoesFieldExist("ThreadId")) { newThreadId = reader.GetInt32("ThreadID"); newThreadEntryId = reader.GetInt32("PostID"); } else { newThreadId = newThreadEntryId = null; } }
private static Contribution CreateContributionInternal(IDnaDataReader reader) { Contribution contribution = new Contribution(); // Make sure we got something back if (reader.HasRows && reader.Read()) { contribution.Body = reader.GetStringNullAsEmpty("Body"); contribution.PostIndex = reader.GetLongNullAsZero("PostIndex"); contribution.SiteName = reader.GetStringNullAsEmpty("SiteName"); contribution.SiteType = (SiteType)Enum.Parse(typeof(SiteType), reader.GetStringNullAsEmpty("SiteType")); contribution.SiteDescription = reader.GetStringNullAsEmpty("SiteDescription"); contribution.SiteUrl = reader.GetStringNullAsEmpty("UrlName"); contribution.FirstSubject = reader.GetStringNullAsEmpty("FirstSubject"); contribution.Subject = reader.GetStringNullAsEmpty("Subject"); contribution.Timestamp = new DateTimeHelper(reader.GetDateTime("TimeStamp")); contribution.Title = reader.GetStringNullAsEmpty("ForumTitle"); contribution.ThreadEntryID = reader.GetInt32("ThreadEntryID"); contribution.CommentForumUrl = reader.GetStringNullAsEmpty("CommentForumUrl"); contribution.GuideEntrySubject = reader.GetStringNullAsEmpty("GuideEntrySubject"); contribution.TotalPostsOnForum = reader.GetInt32NullAsZero("TotalPostsOnForum"); contribution.AuthorUserId = reader.GetInt32NullAsZero("AuthorUserId"); contribution.AuthorUsername = reader.GetStringNullAsEmpty("AuthorUsername"); contribution.AuthorIdentityUsername = reader.GetStringNullAsEmpty("AuthorIdentityUsername"); bool forumCanWrite = reader.GetByteNullAsZero("ForumCanWrite") == 1; bool isEmergencyClosed = reader.GetInt32NullAsZero("SiteEmergencyClosed") == 1; //bool isSiteScheduledClosed = reader2.GetByteNullAsZero("SiteScheduledClosed") == 1; DateTime closingDate = DateTime.MaxValue; if (reader.DoesFieldExist("forumclosedate") && !reader.IsDBNull("forumclosedate")) { closingDate = reader.GetDateTime("forumclosedate"); contribution.ForumCloseDate = new DateTimeHelper(closingDate); } contribution.isClosed = (!forumCanWrite || isEmergencyClosed || (closingDate != null && DateTime.Now > closingDate)); } else { throw ApiException.GetError(ErrorType.ThreadPostNotFound); } return contribution; }
/// <summary> /// Method to generate POST XML and add to a parent node /// </summary> /// <param name="reader">DataReader result of stored procedure returning forum post data.</param> /// <param name="component">DnaComponent to add posts to.</param> /// <param name="parentNode">Parent Node to xml the generated xml to.</param> /// <param name="context">The Input Context</param> public static void AddPostXml(IDnaDataReader reader, DnaComponent component, XmlNode parentNode, IInputContext context) { int hidden = 0; int inReplyTo = 0; int prevSibling = 0; int nextSibling = 0; int firstChild = 0; int userID = 0; int entryId = 0; int threadId = 0; int postIndex = 0; string subject = String.Empty; string datePosted = String.Empty; string bodyText = String.Empty; string hostPageUrl = String.Empty; string commentForumTitle = String.Empty; //get from db if (reader.DoesFieldExist("parent")) { inReplyTo = reader.GetInt32NullAsZero("parent"); } if (reader.DoesFieldExist("prevSibling")) { prevSibling = reader.GetInt32NullAsZero("prevSibling"); } if (reader.DoesFieldExist("nextSibling")) { nextSibling = reader.GetInt32NullAsZero("nextSibling"); } if (reader.DoesFieldExist("firstChild")) { firstChild = reader.GetInt32NullAsZero("firstChild"); } if (reader.DoesFieldExist("userID")) { userID = reader.GetInt32NullAsZero("userID"); } if (reader.DoesFieldExist("hidden")) { hidden = reader.GetInt32NullAsZero("hidden"); } subject = String.Empty; if (hidden == 3) // 3 means premoderated! - hidden! { subject = "Hidden"; } else if (hidden > 0) { subject = "Removed"; } else { subject = reader["subject"] as string; subject = StringUtils.EscapeAllXml(subject); } datePosted = String.Empty; if (reader["datePosted"] != DBNull.Value) { datePosted = reader["datePosted"].ToString(); } bodyText = String.Empty; if (hidden == 3) // 3 means premoderated! - hidden! { bodyText = "This post has been hidden"; } else if (hidden > 0) { bodyText = "This post has been Removed"; } else { bodyText = reader.GetStringNullAsEmpty("text"); } byte postStyle = reader.GetByteNullAsZero("postStyle"); if (postStyle != 1) { bodyText = StringUtils.ConvertPlainText(bodyText); } else { //TODO Do we need Rich Post stuff for the post style?? string temp = "<RICHPOST>" + bodyText.Replace("\r\n", "<BR />").Replace("\n", "<BR />") + "</RICHPOST>"; //Regex regex = new Regex(@"(<[^<>]+)<BR \/>"); //while (regex.Match(temp).Success) //{ // temp = regex.Replace(temp,@"$1 "); //} //bodyText = temp; bodyText = HtmlUtils.TryParseToValidHtml(temp); } if (reader.DoesFieldExist("hostpageurl")) { hostPageUrl = reader.GetStringNullAsEmpty("hostpageurl"); } if (reader.DoesFieldExist("commentforumtitle")) { commentForumTitle = reader.GetStringNullAsEmpty("commentforumtitle"); } if (reader.DoesFieldExist("entryID")) { entryId = reader.GetInt32NullAsZero("entryID"); } if (reader.DoesFieldExist("threadID")) { threadId = reader.GetInt32NullAsZero("threadID"); } if (reader.DoesFieldExist("postindex")) { postIndex = reader.GetInt32NullAsZero("postindex"); } string canRead = String.Empty; if (reader.DoesFieldExist("canRead")) { canRead = reader.GetByteNullAsZero("canRead").ToString(); } string canWrite = String.Empty; if (reader.DoesFieldExist("canWrite")) { canWrite = reader.GetByteNullAsZero("canWrite").ToString(); } XmlNode post = component.CreateElementNode("POST"); User user = new User(context); user.AddUserXMLBlock(reader, userID, post); AddPostXmlInternal(component, parentNode, context, hidden, inReplyTo, prevSibling, nextSibling, firstChild, userID, subject, datePosted, bodyText, hostPageUrl, commentForumTitle, entryId, threadId, postIndex, canRead, canWrite, post.ChildNodes[0]); }
/// <summary> /// Builds ARTICLEMEMBER xml based on current row in dataReader /// </summary> /// <param name="dataReader">The data reader with the data</param> /// <param name="articleKeyPhraseMap">The map of article key phrases</param> /// <returns>XML Element contain the articlemember data</returns> XmlElement AddArticleMemberXML(IDnaDataReader dataReader, Dictionary<int, List<Phrase>> articleKeyPhraseMap) { ArticleMember articleMember = new ArticleMember(InputContext); int H2G2ID = dataReader.GetInt32NullAsZero("h2g2id"); string name = dataReader.GetStringNullAsEmpty("subject"); string extraInfo = dataReader.GetStringNullAsEmpty("extrainfo"); articleMember.H2G2ID = H2G2ID; articleMember.Name = name; articleMember.IncludeStrippedName = true; // Get and Set editor data articleMember.SetEditor(dataReader); articleMember.Status = dataReader.GetInt32NullAsZero("status"); if (dataReader.DoesFieldExist("type")) { articleMember.SetExtraInfo(extraInfo, dataReader.GetInt32NullAsZero("type")); } else { articleMember.SetExtraInfo(extraInfo); } articleMember.DateCreated = dataReader.GetDateTime("datecreated"); articleMember.LastUpdated = dataReader.GetDateTime("lastupdated"); if (InputContext.CurrentSite.IncludeCrumbtrail == 1) { if (dataReader.DoesFieldExist("type") && dataReader.GetInt32NullAsZero("type") > 0) { articleMember.Local = true; } } if (dataReader.DoesFieldExist("CRPollID")) { articleMember.SetContentRatingStatistics(dataReader.GetInt32NullAsZero("CRPollID"), dataReader.GetInt32NullAsZero("CRVoteCount"), dataReader.GetDoubleNullAsZero("CRAverageRating")); } if (dataReader.DoesFieldExist("MediaAssetID")) { string caption = dataReader.GetStringNullAsEmpty("Caption"); string extraElementXML = dataReader.GetStringNullAsEmpty("ExtraElementXML"); string externalLinkURL = dataReader.GetStringNullAsEmpty("ExternalLinkURL"); articleMember.SetMediaAssetInfo(dataReader.GetInt32NullAsZero("MediaAssetID"), dataReader.GetInt32NullAsZero("ContentType"), caption, dataReader.GetInt32NullAsZero("MimeType"), dataReader.GetInt32NullAsZero("OwnerID"), extraElementXML, dataReader.GetInt32NullAsZero("Hidden"), externalLinkURL); } bool includeKeyPhraseData = InputContext.GetSiteOptionValueBool("KeyPhrases", "ReturnInCategoryList"); if (includeKeyPhraseData) { int entryId = dataReader.GetInt32NullAsZero("entryid"); articleMember.SetPhraseList(articleKeyPhraseMap[entryId]); } articleMember.TryCreateXML(); return articleMember.RootElement; }
/// <summary> /// Builds Hierarchy xml from the given datareader /// </summary> /// <param name="reader">The datset to query</param> /// <returns>resulting xml element</returns> public XmlElement GetHierarchyDetails(IDnaDataReader reader) { XmlElement hierarchyDetails = CreateElement("HIERARCHYDETAILS"); string description = reader.GetStringNullAsEmpty("Description"); string synonyms = reader.GetStringNullAsEmpty("Synonyms"); int H2G2ID = reader.GetInt32NullAsZero("h2g2id"); int nodeID = reader.GetInt32NullAsZero("nodeid"); int userAdd = reader.GetInt32NullAsZero("UserAdd"); int parentID = reader.GetInt32NullAsZero("ParentID"); int typeID = reader.GetInt32NullAsZero("Type"); AddAttribute(hierarchyDetails, "NODEID", nodeID); if (parentID == 0) //is root? { AddAttribute(hierarchyDetails, "ISROOT", 1); } else { AddAttribute(hierarchyDetails, "ISROOT", 0); } AddAttribute(hierarchyDetails, "USERADD", userAdd); AddAttribute(hierarchyDetails, "TYPE", typeID); string displayName = reader.GetStringNullAsEmpty("DisplayName"); AddTextTag(hierarchyDetails, "DISPLAYNAME", displayName); if (nodeID > 0) { AddTextTag(hierarchyDetails, "DESCRIPTION", description); AddTextTag(hierarchyDetails, "SYNONYMS", synonyms); if (H2G2ID > 0) { AddIntElement(hierarchyDetails, "H2G2ID", H2G2ID); } // Check to see if the node has a redirected if (reader.DoesFieldExist("RedirectNodeID") && !reader.IsDBNull("RedirectNodeID")) { string RedirectNodeName = reader.GetStringNullAsEmpty("RedirectNodeName"); XmlElement redirectNode = AddTextTag(hierarchyDetails, "REDIRECTNODE", RedirectNodeName); AddAttribute(redirectNode, "ID", reader.GetInt32NullAsZero("RedirectNodeID")); } } return hierarchyDetails; }
/// <summary> /// Creates a commentinfo object /// </summary> /// <param name="reader">A reader with all information</param> /// <param name="site">site information</param> /// <returns>Comment info object</returns> private CommentInfo CommentCreateFromReader(IDnaDataReader reader, ISite site) { var commentInfo = new CommentInfo { Created = new DateTimeHelper(DateTime.Parse(reader.GetDateTime("Created").ToString())), User = UserReadById(reader, site), ID = reader.GetInt32NullAsZero("id") }; commentInfo.hidden = (CommentStatus.Hidden) reader.GetInt32NullAsZero("hidden"); if (reader.IsDBNull("poststyle")) { commentInfo.PostStyle = PostStyle.Style.richtext; } else { commentInfo.PostStyle = (PostStyle.Style) reader.GetTinyIntAsInt("poststyle"); } commentInfo.IsEditorPick = reader.GetBoolean("IsEditorPick"); commentInfo.Index = reader.GetInt32NullAsZero("PostIndex"); //get complainant var replacement = new Dictionary<string, string>(); replacement.Add("sitename", site.SiteName); replacement.Add("postid", commentInfo.ID.ToString()); commentInfo.ComplaintUri = UriDiscoverability.GetUriWithReplacments(BasePath, SiteList.GetSiteOptionValueString(site.SiteID, "General", "ComplaintUrl"), replacement); replacement = new Dictionary<string, string>(); replacement.Add("commentforumid", reader.GetString("forumuid")); replacement.Add("sitename", site.SiteName); commentInfo.ForumUri = UriDiscoverability.GetUriWithReplacments(BasePath, UriDiscoverability.UriType.CommentForumById, replacement); replacement = new Dictionary<string, string>(); replacement.Add("parentUri", reader.GetString("parentUri")); replacement.Add("postid", commentInfo.ID.ToString()); commentInfo.Uri = UriDiscoverability.GetUriWithReplacments(BasePath, UriDiscoverability.UriType.Comment, replacement); if(reader.DoesFieldExist("nerovalue")) { commentInfo.NeroRatingValue = reader.GetInt32NullAsZero("nerovalue"); } if (reader.DoesFieldExist("neropositivevalue")) { commentInfo.NeroPositiveRatingValue = reader.GetInt32NullAsZero("neropositivevalue"); } if (reader.DoesFieldExist("neronegativevalue")) { commentInfo.NeroNegativeRatingValue = reader.GetInt32NullAsZero("neronegativevalue"); } if (reader.DoesFieldExist("tweetid")) { commentInfo.TweetId = reader.GetLongNullAsZero("tweetid"); } commentInfo.text = CommentInfo.FormatComment(reader.GetStringNullAsEmpty("text"), commentInfo.PostStyle, commentInfo.hidden, commentInfo.User.Editor); if (reader.DoesFieldExist("twitterscreenname")) { commentInfo.TwitterScreenName = reader.GetStringNullAsEmpty("twitterscreenname"); } if (reader.DoesFieldExist("retweetid")) { commentInfo.RetweetId = reader.GetLongNullAsZero("retweetid"); } if (reader.DoesFieldExist("retweetedby")) { commentInfo.RetweetedBy = reader.GetStringNullAsEmpty("retweetedby"); } if (reader.DoesFieldExist("DmID")) { if (reader.IsDBNull("DmID") == false) { commentInfo.DistressMessage = IncludeDistressMessage(reader, site); } } return commentInfo; }
/// <summary> /// /// </summary> /// <param name="reader"></param> /// <returns></returns> public User UserReadById(IDnaDataReader reader, ISite site) { var user = new User { UserId = reader.GetInt32NullAsZero("UserID"), DisplayName = reader.GetStringNullAsEmpty("UserName"), Editor = (reader.GetInt32NullAsZero("userIsEditor") == 1), Journal = reader.GetInt32NullAsZero("userJournal"), Status = reader.GetInt32NullAsZero("userstatus"), }; if (reader.DoesFieldExist("userIsNotable")) { user.Notable = (reader.GetInt32NullAsZero("userIsNotable") == 1); } if (reader.DoesFieldExist("identityUserId")) { user.BbcId = reader.GetStringNullAsEmpty("identityUserId"); } if (reader.DoesFieldExist("TwitterScreenName")) { user.TwitterScreenName = reader.GetStringNullAsEmpty("TwitterScreenName"); } user.SiteSpecificDisplayName = string.Empty; if (SiteList.GetSiteOptionValueBool(site.SiteID, "User", "UseSiteSuffix")) { if (reader.DoesFieldExist("SiteSpecificDisplayName")) { user.SiteSpecificDisplayName = reader.GetStringNullAsEmpty("SiteSpecificDisplayName"); } } //if there is an anonymous user name use it if (reader.DoesFieldExist("AnonymousUserName") && !String.IsNullOrEmpty(reader.GetStringNullAsEmpty("AnonymousUserName"))) { user.DisplayName = reader.GetStringNullAsEmpty("AnonymousUserName"); } return user; }
/// <summary> /// Creates and adds the returned User Xml block to a given parent post node from the passed user parameters with a prefix /// ie the field name of OwnerUserName, OwnerFirstNames /// </summary> /// <param name="dataReader">Data reader object</param> /// <param name="userID">The users id</param> /// <param name="prefix">The prefix of the field names for a different user in the same result set</param> /// <param name="parent">The parent Node to add the user xml to</param> /// <returns>XmlNode Containing user XML from the stored procedure</returns> public void AddPrefixedUserXMLBlock(IDnaDataReader dataReader, int userID, string prefix, XmlNode parent) { string userName = ""; if (dataReader.Exists(prefix + "UserName")) { userName = dataReader.GetStringNullAsEmpty(prefix + "UserName"); } else if (dataReader.Exists(prefix + "Name")) { userName = dataReader.GetStringNullAsEmpty(prefix + "Name"); } if (userName == String.Empty) { userName = "******" + userID.ToString(); } string identityUserId = ""; if (dataReader.Exists(prefix + "identityUserId")) { identityUserId = dataReader.GetStringNullAsEmpty(prefix + "identityUserId"); } string emailAddress = ""; if (dataReader.Exists(prefix + "Email")) { emailAddress = dataReader.GetStringNullAsEmpty(prefix + "Email"); } double zeigeistScore = 0.0; if (dataReader.DoesFieldExist(prefix + "ZeitgeistScore")) { zeigeistScore = dataReader.GetDoubleNullAsZero(prefix + "ZeitgeistScore"); } string siteSuffix = ""; if (dataReader.Exists(prefix + "SiteSuffix")) { siteSuffix = dataReader.GetStringNullAsEmpty(prefix + "SiteSuffix"); } string area = ""; if (dataReader.Exists(prefix + "Area")) { area = dataReader.GetStringNullAsEmpty(prefix + "Area"); } string title = ""; if (dataReader.Exists(prefix + "Title")) { title = dataReader.GetStringNullAsEmpty(prefix + "Title"); } int subQuota = 0; if (dataReader.Exists(prefix + "SubQuota")) { subQuota = dataReader.GetInt32NullAsZero(prefix + "SubQuota"); } int allocations = 0; if (dataReader.Exists(prefix + "Allocations")) { allocations = dataReader.GetInt32NullAsZero(prefix + "Allocations"); } int journal = 0; if (dataReader.Exists(prefix + "Journal")) { journal = dataReader.GetInt32NullAsZero(prefix + "Journal"); } bool isActive = false; if (dataReader.Exists(prefix + "Active") && !dataReader.IsDBNull(prefix + "Active")) { isActive = dataReader.GetBoolean(prefix + "Active"); } DateTime dateLastNotified = DateTime.MinValue; if (dataReader.Exists(prefix + "DateLastNotified") && dataReader.GetValue(prefix + "DateLastNotified") != DBNull.Value) { dateLastNotified = dataReader.GetDateTime(prefix + "DateLastNotified"); } DateTime dateJoined = DateTime.MinValue; if (dataReader.Exists(prefix + "DateJoined") && dataReader.GetValue(prefix + "DateJoined") != DBNull.Value) { dateJoined = dataReader.GetDateTime(prefix + "DateJoined"); } int forumPostedTo = -1; if (dataReader.Exists(prefix + "ForumPostedTo")) { forumPostedTo = dataReader.GetInt32NullAsZero(prefix + "ForumPostedTo"); } int masthead = -1; if (dataReader.Exists(prefix + "Masthead")) { masthead = dataReader.GetInt32NullAsZero(prefix + "Masthead"); } int sinbin = -1; if (dataReader.Exists(prefix + "SinBin")) { sinbin = dataReader.GetInt32NullAsZero(prefix + "SinBin"); } int forumID = -1; if (dataReader.Exists(prefix + "ForumID")) { forumID = dataReader.GetInt32NullAsZero(prefix + "ForumID"); } XmlNode userXML = GenerateUserXml(userID, userName, emailAddress, dataReader.GetStringNullAsEmpty(prefix + "FirstNames"), dataReader.GetStringNullAsEmpty(prefix + "LastName"), dataReader.GetInt32NullAsZero(prefix + "Status"), dataReader.GetInt32NullAsZero(prefix + "TaxonomyNode"), isActive, zeigeistScore, siteSuffix, area, title, journal, dateLastNotified, subQuota, allocations, dateJoined, forumID, forumPostedTo, masthead, sinbin, identityUserId); if (userXML != null) { XmlNode importxml = parent.OwnerDocument.ImportNode(userXML, true); parent.AppendChild(importxml); } }
/// <summary> /// Creates a threadpost from a given reader /// </summary> /// <param name="reader"></param> /// <param name="prefix">The data base name prefix</param> /// <param name="postId">The post Id</param> /// <param name="applySkin">whether we need to format the post</param> /// <returns></returns> static public ThreadPostSummary CreateThreadPostFromReader(IDnaDataReader reader, string prefix, int postId, bool applySkin) { ThreadPostSummary post = new ThreadPostSummary() { PostId = postId }; if (reader.DoesFieldExist(prefix +"hidden")) { post.Hidden = (byte)reader.GetInt32NullAsZero(prefix +"hidden"); } if (reader.DoesFieldExist("firstposting") && reader["firstposting"] != DBNull.Value) { post.Date = new Date(reader.GetDateTime("firstposting")); } if (reader.DoesFieldExist(prefix +"text")) { post.Text = ThreadPost.FormatPost(reader.GetStringNullAsEmpty(prefix + "text"), (CommentStatus.Hidden)post.Hidden, true, applySkin); } post.User = BBC.Dna.Objects.User.CreateUserFromReader(reader, prefix); return post; }