def parse_feed_entry(self, entry): """ Reusable method to parse a feedparser entry from a blip rss feed into a dictionary mapping :class:`.Video` fields to values. """ enclosure = get_first_accepted_enclosure(entry) data = { 'guid': entry['id'], 'link': entry['link'], 'title': entry['title'], 'description': clean_description_html( entry['blip_puredescription']), 'file_url': enclosure['url'], 'embed_code': entry['media_player']['content'], 'publish_datetime': datetime.strptime(entry['blip_datestamp'], "%Y-%m-%dT%H:%M:%SZ"), 'thumbnail_url': get_entry_thumbnail_url(entry), 'tags': [tag['term'] for tag in entry['tags'] if tag['scheme'] is None][1:], 'user': entry['blip_safeusername'], 'user_url': entry['blip_showpage'] } if 'license' in entry: data['license'] = entry['license'] return data
def parse_feed_entry(self, entry): enclosure = get_first_accepted_enclosure(entry) if "published_parsed" in entry: best_date = struct_time_to_datetime(entry["published_parsed"]) elif "updated_parsed" in entry: best_date = struct_time_to_datetime(entry["updated_parsed"]) else: best_date = None link = entry.get("link") if "links" in entry: for possible_link in entry.links: if possible_link.get("rel") == "via": # original URL link = possible_link["href"] break if "content" in entry and entry["content"] and entry["content"][0]["value"]: # Atom description = entry["content"][0]["value"] else: description = entry.get("summary", "") embed_code = None if "media_player" in entry: player = entry["media_player"] if player.get("content"): embed_code = convert_entities(player["content"]) elif "url" in player: embed_code = make_embed_code(player["url"], "") if "media_license" in entry: license = entry["media_license"]["href"] else: license = entry.get("license") return { "link": link, "title": convert_entities(entry["title"]), "description": description, "thumbnail_url": get_entry_thumbnail_url(entry), "file_url": enclosure.get("url") if enclosure else None, "file_url_mimetype": enclosure.get("type") if enclosure else None, "file_url_length": ((enclosure.get("filesize") or enclosure.get("length")) if enclosure else None), "publish_datetime": best_date, "guid": entry.get("id"), "embed_code": embed_code, "tags": [tag["term"] for tag in entry["tags"] if tag["scheme"] is None] if "tags" in entry else None, "license": license, }
def parse_feed_entry(self, entry): enclosure = get_first_accepted_enclosure(entry) if 'published_parsed' in entry: best_date = struct_time_to_datetime(entry['published_parsed']) elif 'updated_parsed' in entry: best_date = struct_time_to_datetime(entry['updated_parsed']) else: best_date = None link = entry.get('link') if 'links' in entry: for possible_link in entry.links: if possible_link.get('rel') == 'via': # original URL link = possible_link['href'] break if ('content' in entry and entry['content'] and entry['content'][0]['value']): # Atom description = entry['content'][0]['value'] else: description = entry['summary'] or '' embed_code = None if 'media_player' in entry: player = entry['media_player'] if player.get('content'): embed_code = convert_entities(player['content']) elif 'url' in player: embed_code = make_embed_code(player['url'], '') return { 'link': link, 'title': convert_entities(entry['title']), 'description': description, 'thumbnail_url': get_entry_thumbnail_url(entry), 'file_url': enclosure.get('url') if enclosure else None, 'file_url_mimetype': enclosure.get('type') if enclosure else None, 'file_url_length': ((enclosure.get('filesize') or enclosure.get('length')) if enclosure else None), 'publish_datetime': best_date, 'guid': entry.get('id'), 'embed_code': embed_code, 'tags': [tag['term'] for tag in entry['tags'] if tag['scheme'] is None] if 'tags' in entry else None }