Merge branch 'master' of https://github.com/lbryio/lbry-android
This commit is contained in:
commit
52e3938597
3 changed files with 131 additions and 40 deletions
|
@ -7,29 +7,18 @@ import org.json.JSONException;
|
||||||
import org.json.JSONObject;
|
import org.json.JSONObject;
|
||||||
|
|
||||||
import java.io.IOException;
|
import java.io.IOException;
|
||||||
import java.math.BigDecimal;
|
import java.util.Objects;
|
||||||
import java.text.DecimalFormat;
|
|
||||||
import java.text.DecimalFormatSymbols;
|
|
||||||
import java.util.HashMap;
|
|
||||||
import java.util.Locale;
|
|
||||||
import java.util.Map;
|
|
||||||
import java.util.concurrent.TimeUnit;
|
|
||||||
|
|
||||||
import io.lbry.browser.exceptions.ApiCallException;
|
import io.lbry.browser.exceptions.ApiCallException;
|
||||||
import io.lbry.browser.model.Comment;
|
import io.lbry.browser.model.Comment;
|
||||||
|
import io.lbry.browser.utils.Comments;
|
||||||
import io.lbry.browser.utils.Helper;
|
import io.lbry.browser.utils.Helper;
|
||||||
import io.lbry.browser.utils.Lbry;
|
|
||||||
import io.lbry.browser.utils.Lbryio;
|
|
||||||
import okhttp3.OkHttpClient;
|
|
||||||
import okhttp3.Request;
|
|
||||||
import okhttp3.Response;
|
import okhttp3.Response;
|
||||||
|
|
||||||
public class CommentCreateTask extends AsyncTask<Void, Void, Comment> {
|
public class CommentCreateTask extends AsyncTask<Void, Void, Comment> {
|
||||||
private static final String STATUS_ENDPOINT = "https://comments.lbry.com";
|
private final Comment comment;
|
||||||
|
private final View progressView;
|
||||||
private Comment comment;
|
private final CommentCreateWithTipHandler handler;
|
||||||
private View progressView;
|
|
||||||
private CommentCreateWithTipHandler handler;
|
|
||||||
private Exception error;
|
private Exception error;
|
||||||
|
|
||||||
public CommentCreateTask(Comment comment, View progressView, CommentCreateWithTipHandler handler) {
|
public CommentCreateTask(Comment comment, View progressView, CommentCreateWithTipHandler handler) {
|
||||||
|
@ -46,29 +35,31 @@ public class CommentCreateTask extends AsyncTask<Void, Void, Comment> {
|
||||||
Comment createdComment = null;
|
Comment createdComment = null;
|
||||||
try {
|
try {
|
||||||
// check comments status endpoint
|
// check comments status endpoint
|
||||||
Request request = new Request.Builder().url(STATUS_ENDPOINT).build();
|
Comments.checkCommentsEndpointStatus();
|
||||||
OkHttpClient client = new OkHttpClient.Builder().
|
|
||||||
writeTimeout(30, TimeUnit.SECONDS).
|
JSONObject comment_body = new JSONObject();
|
||||||
readTimeout(30, TimeUnit.SECONDS).
|
comment_body.put("comment", comment.getText());
|
||||||
build();
|
comment_body.put("claim_id", comment.getClaimId());
|
||||||
Response response = client.newCall(request).execute();
|
if (!Helper.isNullOrEmpty(comment.getParentId())) {
|
||||||
JSONObject status = new JSONObject(response.body().string());
|
comment_body.put("parent_id", comment.getParentId());
|
||||||
String statusText = Helper.getJSONString("text", null, status);
|
}
|
||||||
boolean isRunning = Helper.getJSONBoolean("is_running", false, status);
|
comment_body.put("channel_id", comment.getChannelId());
|
||||||
if (!"ok".equalsIgnoreCase(statusText) || !isRunning) {
|
comment_body.put("channel_name", comment.getChannelName());
|
||||||
throw new ApiCallException("The comment server is not available at this time. Please try again later.");
|
|
||||||
|
JSONObject jsonChannelSign = Comments.channelSign(comment_body, comment.getChannelId(), comment.getChannelName());
|
||||||
|
|
||||||
|
if (jsonChannelSign.has("signature") && jsonChannelSign.has("signing_ts")) {
|
||||||
|
comment_body.put("signature", jsonChannelSign.getString("signature"));
|
||||||
|
comment_body.put("signing_ts", jsonChannelSign.getString("signing_ts"));
|
||||||
}
|
}
|
||||||
|
|
||||||
Map<String, Object> options = new HashMap<>();
|
Response resp = Comments.performRequest(comment_body, "comment.Create");
|
||||||
options.put("comment", comment.getText());
|
String responseString = Objects.requireNonNull(resp.body()).string();
|
||||||
options.put("claim_id", comment.getClaimId());
|
resp.close();
|
||||||
options.put("channel_id", comment.getChannelId());
|
JSONObject jsonResponse = new JSONObject(responseString);
|
||||||
options.put("channel_name", comment.getChannelName());
|
|
||||||
if (!Helper.isNullOrEmpty(comment.getParentId())) {
|
if (jsonResponse.has("result"))
|
||||||
options.put("parent_id", comment.getParentId());
|
createdComment = Comment.fromJSONObject(jsonResponse.getJSONObject("result"));
|
||||||
}
|
|
||||||
JSONObject jsonObject = (JSONObject) Lbry.genericApiCall(Lbry.METHOD_COMMENT_CREATE, options);
|
|
||||||
createdComment = Comment.fromJSONObject(jsonObject);
|
|
||||||
} catch (ApiCallException | ClassCastException | IOException | JSONException ex) {
|
} catch (ApiCallException | ClassCastException | IOException | JSONException ex) {
|
||||||
error = ex;
|
error = ex;
|
||||||
}
|
}
|
||||||
|
|
|
@ -14,6 +14,7 @@ import java.util.List;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
import io.lbry.browser.model.Comment;
|
import io.lbry.browser.model.Comment;
|
||||||
|
import io.lbry.browser.utils.Comments;
|
||||||
import io.lbry.browser.utils.Helper;
|
import io.lbry.browser.utils.Helper;
|
||||||
import io.lbry.browser.utils.Lbry;
|
import io.lbry.browser.utils.Lbry;
|
||||||
|
|
||||||
|
@ -21,8 +22,8 @@ public class CommentListTask extends AsyncTask<Void, Void, List<Comment>> {
|
||||||
private final int page;
|
private final int page;
|
||||||
private final int pageSize;
|
private final int pageSize;
|
||||||
private final String claim;
|
private final String claim;
|
||||||
private ProgressBar progressBar;
|
private final ProgressBar progressBar;
|
||||||
private CommentListHandler handler;
|
private final CommentListHandler handler;
|
||||||
private Exception error;
|
private Exception error;
|
||||||
|
|
||||||
public CommentListTask(int page, int pageSize, String claim, ProgressBar progressBar, CommentListHandler handler) {
|
public CommentListTask(int page, int pageSize, String claim, ProgressBar progressBar, CommentListHandler handler) {
|
||||||
|
@ -52,7 +53,7 @@ public class CommentListTask extends AsyncTask<Void, Void, List<Comment>> {
|
||||||
options.put("skip_validation", true);
|
options.put("skip_validation", true);
|
||||||
options.put("visible", true);
|
options.put("visible", true);
|
||||||
|
|
||||||
JSONObject result = (JSONObject) Lbry.genericApiCall(Lbry.METHOD_COMMENT_LIST, options);
|
JSONObject result = (JSONObject) Lbry.parseResponse(Comments.performRequest(Lbry.buildJsonParams(options), "comment.List"));
|
||||||
JSONArray items = result.getJSONArray("items");
|
JSONArray items = result.getJSONArray("items");
|
||||||
|
|
||||||
List<Comment> children = new ArrayList<>();
|
List<Comment> children = new ArrayList<>();
|
||||||
|
|
99
app/src/main/java/io/lbry/browser/utils/Comments.java
Normal file
99
app/src/main/java/io/lbry/browser/utils/Comments.java
Normal file
|
@ -0,0 +1,99 @@
|
||||||
|
package io.lbry.browser.utils;
|
||||||
|
|
||||||
|
import android.os.Build;
|
||||||
|
|
||||||
|
import org.apache.commons.codec.binary.Hex;
|
||||||
|
import org.json.JSONException;
|
||||||
|
import org.json.JSONObject;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Objects;
|
||||||
|
import java.util.concurrent.TimeUnit;
|
||||||
|
|
||||||
|
import io.lbry.browser.exceptions.ApiCallException;
|
||||||
|
import okhttp3.MediaType;
|
||||||
|
import okhttp3.OkHttpClient;
|
||||||
|
import okhttp3.Request;
|
||||||
|
import okhttp3.RequestBody;
|
||||||
|
import okhttp3.Response;
|
||||||
|
|
||||||
|
public class Comments {
|
||||||
|
private static final String STATUS_ENDPOINT = "https://comments.lbry.com";
|
||||||
|
public static final String COMMENT_SERVER_ENDPOINT = "https://comments.lbry.com/api/v2";
|
||||||
|
|
||||||
|
public static JSONObject channelSign(JSONObject commentBody, String channelId, String channelName) throws ApiCallException, JSONException {
|
||||||
|
byte[] commentBodyBytes = commentBody.getString("comment").getBytes(StandardCharsets.UTF_8);
|
||||||
|
String encodedCommentBody;
|
||||||
|
|
||||||
|
if (Build.VERSION.SDK_INT > Build.VERSION_CODES.O_MR1)
|
||||||
|
encodedCommentBody = Hex.encodeHexString(commentBodyBytes, false);
|
||||||
|
else
|
||||||
|
encodedCommentBody = new String(Hex.encodeHex(commentBodyBytes));
|
||||||
|
|
||||||
|
Map<String, Object> signingParams = new HashMap<>(3);
|
||||||
|
signingParams.put("hexdata", encodedCommentBody);
|
||||||
|
signingParams.put("channel_id", channelId);
|
||||||
|
signingParams.put("channel_name", channelName);
|
||||||
|
|
||||||
|
return (JSONObject) Lbry.genericApiCall("channel_sign", signingParams);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs request to default Comment Server
|
||||||
|
* @param params JSON containing parameters to send to the server
|
||||||
|
* @param method One of the available methods for comments
|
||||||
|
* @return Response from the server
|
||||||
|
* @throws IOException throwable from OkHttpClient execute()
|
||||||
|
*/
|
||||||
|
public static Response performRequest(JSONObject params, String method) throws IOException {
|
||||||
|
return performRequest(COMMENT_SERVER_ENDPOINT, params, method);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Performs the request to Comment Server
|
||||||
|
* @param commentServer Url where to direct the request
|
||||||
|
* @param params JSON containing parameters to send to the server
|
||||||
|
* @param method One of the available methods for comments
|
||||||
|
* @return Response from the server
|
||||||
|
* @throws IOException throwable from OkHttpClient execute()
|
||||||
|
*/
|
||||||
|
public static Response performRequest(String commentServer, JSONObject params, String method) throws IOException {
|
||||||
|
final MediaType JSON = MediaType.get("application/json; charset=utf-8");
|
||||||
|
|
||||||
|
Map<String, Object> requestParams = new HashMap<>(4);
|
||||||
|
requestParams.put("jsonrpc", "2.0");
|
||||||
|
requestParams.put("id", TimeUnit.MILLISECONDS.toSeconds(System.currentTimeMillis()));
|
||||||
|
requestParams.put("method", method);
|
||||||
|
requestParams.put("params", params);
|
||||||
|
|
||||||
|
RequestBody requestBody = RequestBody.create(Lbry.buildJsonParams(requestParams).toString(), JSON);
|
||||||
|
|
||||||
|
Request commentCreateRequest = new Request.Builder()
|
||||||
|
.url(commentServer.concat("?m=").concat(method))
|
||||||
|
.post(requestBody)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
OkHttpClient client = new OkHttpClient.Builder().writeTimeout(30, TimeUnit.SECONDS)
|
||||||
|
.readTimeout(30, TimeUnit.SECONDS)
|
||||||
|
.build();
|
||||||
|
|
||||||
|
return client.newCall(commentCreateRequest).execute();
|
||||||
|
}
|
||||||
|
|
||||||
|
public static void checkCommentsEndpointStatus() throws IOException, JSONException, ApiCallException {
|
||||||
|
Request request = new Request.Builder().url(STATUS_ENDPOINT).build();
|
||||||
|
OkHttpClient client = new OkHttpClient.Builder().writeTimeout(30, TimeUnit.SECONDS)
|
||||||
|
.readTimeout(30, TimeUnit.SECONDS)
|
||||||
|
.build();
|
||||||
|
Response response = client.newCall(request).execute();
|
||||||
|
JSONObject status = new JSONObject(Objects.requireNonNull(response.body()).string());
|
||||||
|
String statusText = Helper.getJSONString("text", null, status);
|
||||||
|
boolean isRunning = Helper.getJSONBoolean("is_running", false, status);
|
||||||
|
if (!"ok".equalsIgnoreCase(statusText) || !isRunning) {
|
||||||
|
throw new ApiCallException("The comment server is not available at this time. Please try again later.");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
Loading…
Add table
Reference in a new issue