Detect the type of subscription import format based on the content type of the file uploaded
This commit is contained in:
		| @@ -746,6 +746,8 @@ post "/data_control" do |env| | ||||
|  | ||||
|     HTTP::FormData.parse(env.request) do |part| | ||||
|       body = part.body.gets_to_end | ||||
|       type = part.headers["Content-Type"] | ||||
|  | ||||
|       next if body.empty? | ||||
|  | ||||
|       # TODO: Unify into single import based on content-type | ||||
| @@ -816,12 +818,12 @@ post "/data_control" do |env| | ||||
|           end | ||||
|         end | ||||
|       when "import_youtube" | ||||
|         if body[0..4] == "<opml" | ||||
|         if type == "application/xml" | ||||
|           subscriptions = XML.parse(body) | ||||
|           user.subscriptions += subscriptions.xpath_nodes(%q(//outline[@type="rss"])).map do |channel| | ||||
|             channel["xmlUrl"].match(/UC[a-zA-Z0-9_-]{22}/).not_nil![0] | ||||
|           end | ||||
|         elsif body[0] == '[' | ||||
|         elsif type == "application/json" | ||||
|           subscriptions = JSON.parse(body) | ||||
|           user.subscriptions += subscriptions.as_a.compact_map do |entry| | ||||
|             entry["snippet"]["resourceId"]["channelId"].as_s | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 bbielsa
					bbielsa