mirror of
				https://git.tt-rss.org/fox/tt-rss.git
				synced 2025-10-25 18:01:23 +02:00 
			
		
		
		
	drop BACKEND_RSS_TYPE from update_rss_feed, support detection of dc:subject as tags in Atom feeds
This commit is contained in:
		
							parent
							
								
									8fd2dc95ba
								
							
						
					
					
						commit
						be832a1a56
					
				
							
								
								
									
										139
									
								
								functions.php
									
									
									
									
									
								
							
							
						
						
									
										139
									
								
								functions.php
									
									
									
									
									
								
							| @ -488,91 +488,98 @@ | ||||
| 
 | ||||
| 			foreach ($iterator as $item) { | ||||
| 
 | ||||
| 				if (RSS_BACKEND_TYPE == "magpie") { | ||||
| 				$entry_guid = $item["id"]; | ||||
| 	 | ||||
| 					$entry_guid = $item["id"]; | ||||
| 				if (!$entry_guid) $entry_guid = $item["guid"]; | ||||
| 				if (!$entry_guid) $entry_guid = $item["link"]; | ||||
| 				if (!$entry_guid) $entry_guid = make_guid_from_title($item["title"]); | ||||
| 
 | ||||
| 					if (!$entry_guid) $entry_guid = $item["guid"]; | ||||
| 					if (!$entry_guid) $entry_guid = $item["link"]; | ||||
| 					if (!$entry_guid) $entry_guid = make_guid_from_title($item["title"]); | ||||
| 				if (!$entry_guid) continue; | ||||
| 
 | ||||
| 					if (!$entry_guid) continue; | ||||
| 				$entry_timestamp = ""; | ||||
| 
 | ||||
| 					$entry_timestamp = ""; | ||||
| 				$rss_2_date = $item['pubdate']; | ||||
| 				$rss_1_date = $item['dc']['date']; | ||||
| 				$atom_date = $item['issued']; | ||||
| 				if (!$atom_date) $atom_date = $item['updated']; | ||||
| 			 | ||||
| 					$rss_2_date = $item['pubdate']; | ||||
| 					$rss_1_date = $item['dc']['date']; | ||||
| 					$atom_date = $item['issued']; | ||||
| 					if (!$atom_date) $atom_date = $item['updated']; | ||||
| 				if ($atom_date != "") $entry_timestamp = parse_w3cdtf($atom_date); | ||||
| 				if ($rss_1_date != "") $entry_timestamp = parse_w3cdtf($rss_1_date); | ||||
| 				if ($rss_2_date != "") $entry_timestamp = strtotime($rss_2_date); | ||||
| 				 | ||||
| 					if ($atom_date != "") $entry_timestamp = parse_w3cdtf($atom_date); | ||||
| 					if ($rss_1_date != "") $entry_timestamp = parse_w3cdtf($rss_1_date); | ||||
| 					if ($rss_2_date != "") $entry_timestamp = strtotime($rss_2_date); | ||||
| 				if ($entry_timestamp == "") { | ||||
| 					$entry_timestamp = time(); | ||||
| 					$no_orig_date = 'true'; | ||||
| 				} else { | ||||
| 					$no_orig_date = 'false'; | ||||
| 				} | ||||
| 
 | ||||
| 					if ($entry_timestamp == "") { | ||||
| 						$entry_timestamp = time(); | ||||
| 						$no_orig_date = 'true'; | ||||
| 					} else { | ||||
| 						$no_orig_date = 'false'; | ||||
| 					} | ||||
| 				$entry_timestamp_fmt = strftime("%Y/%m/%d %H:%M:%S", $entry_timestamp); | ||||
| 
 | ||||
| 					$entry_timestamp_fmt = strftime("%Y/%m/%d %H:%M:%S", $entry_timestamp); | ||||
| 				$entry_title = trim(strip_tags($item["title"])); | ||||
| 
 | ||||
| 					$entry_title = trim(strip_tags($item["title"])); | ||||
| 				// strange Magpie workaround
 | ||||
| 				$entry_link = $item["link_"]; | ||||
| 				if (!$entry_link) $entry_link = $item["link"]; | ||||
| 
 | ||||
| 					// strange Magpie workaround
 | ||||
| 					$entry_link = $item["link_"]; | ||||
| 					if (!$entry_link) $entry_link = $item["link"]; | ||||
| 	 | ||||
| 					if (!$entry_title) continue; | ||||
| 				if (!$entry_title) continue; | ||||
| #					if (!$entry_link) continue;
 | ||||
| 
 | ||||
| 					$entry_link = strip_tags($entry_link); | ||||
| 				$entry_link = strip_tags($entry_link); | ||||
| 
 | ||||
| 					$entry_content = $item["content:escaped"]; | ||||
| 				$entry_content = $item["content:escaped"]; | ||||
| 
 | ||||
| 					if (!$entry_content) $entry_content = $item["content:encoded"]; | ||||
| 					if (!$entry_content) $entry_content = $item["content"]; | ||||
| 					if (!$entry_content) $entry_content = $item["atom_content"]; | ||||
| 					if (!$entry_content) $entry_content = $item["summary"]; | ||||
| 					if (!$entry_content) $entry_content = $item["description"]; | ||||
| 				if (!$entry_content) $entry_content = $item["content:encoded"]; | ||||
| 				if (!$entry_content) $entry_content = $item["content"]; | ||||
| 				if (!$entry_content) $entry_content = $item["atom_content"]; | ||||
| 				if (!$entry_content) $entry_content = $item["summary"]; | ||||
| 				if (!$entry_content) $entry_content = $item["description"]; | ||||
| 
 | ||||
| 	//				if (!$entry_content) continue;
 | ||||
| //				if (!$entry_content) continue;
 | ||||
| 
 | ||||
| 					// WTF
 | ||||
| 					if (is_array($entry_content)) { | ||||
| 						$entry_content = $entry_content["encoded"]; | ||||
| 						if (!$entry_content) $entry_content = $entry_content["escaped"]; | ||||
| 					} | ||||
| 				// WTF
 | ||||
| 				if (is_array($entry_content)) { | ||||
| 					$entry_content = $entry_content["encoded"]; | ||||
| 					if (!$entry_content) $entry_content = $entry_content["escaped"]; | ||||
| 				} | ||||
| 
 | ||||
| 	//				print_r($item);
 | ||||
| 	//				print_r(htmlspecialchars($entry_content));
 | ||||
| 	//				print "<br>";
 | ||||
| //				print_r($item);
 | ||||
| //				print_r(htmlspecialchars($entry_content));
 | ||||
| //				print "<br>";
 | ||||
| 
 | ||||
| 					$entry_content_unescaped = $entry_content; | ||||
| 					$content_hash = "SHA1:" . sha1(strip_tags($entry_content)); | ||||
| 				$entry_content_unescaped = $entry_content; | ||||
| 				$content_hash = "SHA1:" . sha1(strip_tags($entry_content)); | ||||
| 
 | ||||
| 					$entry_comments = strip_tags($item["comments"]); | ||||
| 				$entry_comments = strip_tags($item["comments"]); | ||||
| 
 | ||||
| 					$entry_author = db_escape_string(strip_tags($item['dc']['creator'])); | ||||
| 				$entry_author = db_escape_string(strip_tags($item['dc']['creator'])); | ||||
| 
 | ||||
| 					if (!$entry_author) { | ||||
| 						$entry_author = db_escape_string(strip_tags($item['author'])); | ||||
| 					} | ||||
| 				if (!$entry_author) { | ||||
| 					$entry_author = db_escape_string(strip_tags($item['author'])); | ||||
| 				} | ||||
| 
 | ||||
| 					$entry_guid = db_escape_string(strip_tags($entry_guid)); | ||||
| 				$entry_guid = db_escape_string(strip_tags($entry_guid)); | ||||
| 
 | ||||
| 					$result = db_query($link, "SELECT id FROM	ttrss_entries 
 | ||||
| 						WHERE guid = '$entry_guid'");
 | ||||
| 				$result = db_query($link, "SELECT id FROM	ttrss_entries 
 | ||||
| 					WHERE guid = '$entry_guid'");
 | ||||
| 
 | ||||
| 					$entry_content = db_escape_string($entry_content); | ||||
| 					$entry_title = db_escape_string($entry_title); | ||||
| 					$entry_link = db_escape_string($entry_link); | ||||
| 					$entry_comments = db_escape_string($entry_comments); | ||||
| 				$entry_content = db_escape_string($entry_content); | ||||
| 				$entry_title = db_escape_string($entry_title); | ||||
| 				$entry_link = db_escape_string($entry_link); | ||||
| 				$entry_comments = db_escape_string($entry_comments); | ||||
| 
 | ||||
| 					$num_comments = db_escape_string($item["slash"]["comments"]); | ||||
| 				$num_comments = db_escape_string($item["slash"]["comments"]); | ||||
| 
 | ||||
| 					if (!$num_comments) $num_comments = 0; | ||||
| 				if (!$num_comments) $num_comments = 0; | ||||
| 
 | ||||
| 				$dc_subject = $item['dc']['subject']; | ||||
| 
 | ||||
| 				$subject_tags = false; | ||||
| 
 | ||||
| 				if (is_array($dc_subject)) { | ||||
| 					$subject_tags = $dc_subject; | ||||
| 				} else if ($dc_subject) { | ||||
| 					$subject_tags = array($dc_subject); | ||||
| 				} | ||||
| 
 | ||||
| 				# sanitize content
 | ||||
| @ -762,7 +769,15 @@ | ||||
| 					$manual_tags = trim_array(split(",", $filter_param)); | ||||
| 
 | ||||
| 					foreach ($manual_tags as $tag) {					 | ||||
| 						if (!preg_match("/^[0-9]*$/", $tag) && $tag != '') { | ||||
| 						if (tag_is_valid($tag)) { | ||||
| 							array_push($entry_tags, $tag); | ||||
| 						} | ||||
| 					} | ||||
| 				} | ||||
| 
 | ||||
| 				if ($subject_tags) { | ||||
| 					foreach ($subject_tags as $tag) { | ||||
| 						if (tag_is_valid($tag)) { | ||||
| 							array_push($entry_tags, $tag); | ||||
| 						} | ||||
| 					} | ||||
| @ -3112,4 +3127,8 @@ | ||||
| 		return $tmp; | ||||
| 	} | ||||
| 
 | ||||
| 	function tag_is_valid($tag) { | ||||
| 		return ($tag !='' && !preg_match("/^[0-9]*$/", $tag)); | ||||
| 	} | ||||
| 
 | ||||
| ?>
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user