Increase version of jsoup and import Link headers

Closes #1.
master
Peter Stuifzand 6 years ago
parent 1c67c20bc9
commit 3cea3f2e7b

@ -43,7 +43,7 @@ dependencies {
annotationProcessor "android.arch.lifecycle:compiler:1.1.0"
// Java8 support for Lifecycles
implementation 'android.arch.lifecycle:common-java8:1.1.0'
implementation 'org.jsoup:jsoup:1.10.1'
implementation 'org.jsoup:jsoup:1.11.2'
implementation 'com.google.code.gson:gson:2.8.2'
testImplementation 'junit:junit:4.12'
androidTestImplementation 'com.android.support.test:runner:1.0.1'

@ -8,12 +8,19 @@ import android.os.AsyncTask;
import android.os.Bundle;
import android.util.Log;
import org.jsoup.Connection;
import org.jsoup.Jsoup;
import org.jsoup.nodes.Document;
import org.jsoup.nodes.Element;
import org.jsoup.select.Elements;
import java.io.IOException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.regex.MatchResult;
import java.util.regex.Matcher;
import java.util.regex.Pattern;
public class WebsigninTask extends AsyncTask<String, Void, Bundle> {
@ -33,27 +40,53 @@ public class WebsigninTask extends AsyncTask<String, Void, Bundle> {
@Override
protected Bundle doInBackground(String... strings) {
Log.i("micropub", "Starting WebsigninTask.doInBackground");
Bundle bundle = new Bundle();
HashMap<String,String> linkHeaders = new HashMap<>();
try {
bundle.putString(ME, strings[0]);
Document doc = Jsoup.connect(strings[0]).get();
Connection conn = Jsoup.connect(strings[0]);
Document doc = conn.get();
Connection.Response resp = conn.response();
List<String> headers = resp.headers("Link");
Pattern linkParser = Pattern.compile("<([^>]+)>;\\s+rel=\"([^\"]+)\"");
for (String header : headers) {
Log.d("micropub", header);
Matcher matcher = linkParser.matcher(header);
while (matcher.find()) {
MatchResult results = matcher.toMatchResult();
String url = results.group(1);
String rel = results.group(2);
Log.d("micropub", "Found url=" + url + " and rel=" + rel);
if (!rel.isEmpty() && !linkHeaders.containsKey(rel)) {
linkHeaders.put(rel, url);
}
}
}
Elements links = doc.select("link");
for (Element link : links) {
String rel = link.attr("rel");
if (rel.equals("authorization_endpoint")) {
bundle.putString(rel, link.attr("href"));
}
else if (rel .equals("token_endpoint")) {
bundle.putString(rel, link.attr("href"));
}
else if (rel.equals("micropub")) {
bundle.putString(rel, link.attr("href"));
if (!rel.isEmpty() && !linkHeaders.containsKey(rel)) {
linkHeaders.put(rel, link.attr("href"));
}
}
} catch (IOException e) {
return bundle;
}
String[] rels = new String[]{"authorization_endpoint","token_endpoint","micropub"};
for (String rel : rels) {
if (linkHeaders.containsKey(rel)) {
bundle.putString(rel, linkHeaders.get(rel));
}
}
Log.i("micropub", bundle.toString());
return bundle;
}

@ -71,7 +71,7 @@
app:counterEnabled="true"
app:layout_constraintEnd_toEndOf="parent"
app:layout_constraintStart_toStartOf="parent"
app:layout_constraintTop_toBottomOf="@id/editInReplyToLayout">
app:layout_constraintTop_toBottomOf="@+id/editInReplyToLayout">
<android.support.design.widget.TextInputEditText
android:id="@+id/content"

Loading…
Cancel
Save