From 9d4fd9ce7c5bee423054025ba89fc710135f6f4a Mon Sep 17 00:00:00 2001 From: kt programs Date: Sat, 29 Oct 2022 16:51:16 +0800 Subject: [PATCH] livestream chat: use commentron, respect default channel --- .../app/ui/findcontent/FileViewFragment.java | 33 ++++++++++++++++--- 1 file changed, 28 insertions(+), 5 deletions(-) diff --git a/app/src/main/java/com/odysee/app/ui/findcontent/FileViewFragment.java b/app/src/main/java/com/odysee/app/ui/findcontent/FileViewFragment.java index 061e1a8a..2130538d 100644 --- a/app/src/main/java/com/odysee/app/ui/findcontent/FileViewFragment.java +++ b/app/src/main/java/com/odysee/app/ui/findcontent/FileViewFragment.java @@ -1707,8 +1707,18 @@ public void onClick(View view) { } if (!Helper.isNullOrEmpty(chatMessage) && Lbry.ownChannels.size() > 0) { - // send chat messages as the first created channel - Claim channel = Lbry.ownChannels.get(0); + // get channel to send chat messages as from set default channel + String defaultChannelName = Helper.getDefaultChannelName(context); + List defaultChannel = Lbry.ownChannels + .stream() + .filter(c -> c != null && c.getName().equalsIgnoreCase(defaultChannelName)) + .collect(Collectors.toList()); + Claim channel; + if (defaultChannel.size() > 0) { + channel = defaultChannel.get(0); + } else { + channel = Lbry.ownChannels.get(0); + } // if the tip UI is open, then require a valid tip amount to be entered final boolean shouldTip = layoutLivestreamChatTip.getVisibility() == View.VISIBLE; @@ -1779,8 +1789,16 @@ public void run() { // TODO: show a successful tip message or no? } + // Channel Sign chat message + JSONObject channelSignParams = new JSONObject(); + channelSignParams.put("auth_token", Lbryio.AUTH_TOKEN); + JSONObject jsonChannelSign = Comments.channelSignPrivate( + channelSignParams, channel.getClaimId(), + channel.getName(), chatMessage + ); + // Then on to comment creation - Map params = new HashMap<>(); + JSONObject params = new JSONObject(); params.put("claim_id", actualClaim.getClaimId()); params.put("channel_id", channel.getClaimId()); params.put("comment", chatMessage); @@ -1788,9 +1806,14 @@ public void run() { params.put("support_tx_id", supportTxId); } - Lbry.authenticatedGenericApiCall(Lbry.METHOD_COMMENT_CREATE, params, Lbryio.AUTH_TOKEN); + if (jsonChannelSign.has("signature") && jsonChannelSign.has("signing_ts")) { + params.put("signature", jsonChannelSign.getString("signature")); + params.put("signing_ts", jsonChannelSign.getString("signing_ts")); + } + + JSONObject response = (JSONObject) Lbry.parseResponse(Comments.performRequest(params, "comment.Create")); finishChatSend(true); - } catch (ApiCallException | ClassCastException ex) { + } catch (ApiCallException | LbryResponseException | JSONException | IOException ex) { showError(getString(R.string.could_not_send_chat_message)); finishChatSend(false); }