Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add local follows | Convert some Kraken functions to Helix #240

Merged
merged 48 commits into from
Feb 16, 2022

Conversation

Nickwasused
Copy link
Contributor

@Nickwasused Nickwasused commented Aug 7, 2021

How this works

With Account:

  • Your Follows get imported from Twitch
  • You can´t unfollow someone that you followed on Twitch
  • Wiping follows dosen´t remove Twitch follows from the Database
  • You can follow new Channels from within the App
  • You can unfollow the Channels that you followed in the App
  • Follows from within the App are not synced (because Deprecation of Create and Delete Follows API Endpoints #230)

Without Account:

  • You can do nothing, because of Helix.
    - You can follow new Channels from within the App
    - You can unfollow the Channels that you followed in the App
    - Your Channels get shown in the My Streams Tab when they are live

Problems with Helix

Showcase

With Account

youtube

  • Ubisoft and Bobross are Channels that got imported from Twitch

Without Account

youtube

  • Bob Ross is used as Showcase Channel

Problems

As mentioned in #236 when V5 is shutting down then everything is going to require an Auth Token. So you can´t make the required API requests without a Twitch Account logged in. But local follows should still be working with the new API.

Fixing

This should be closing:
#239
#230
(Maybee #81 and #124)

To-Do

@RickyM7
Copy link
Contributor

RickyM7 commented Aug 7, 2021

This is amazing! A question, will an option be added to export/import the list of followed channels?

Btw I just tested and saw that when you are not logged in, the channels you follow remain as followed, but when you log in, the channels you followed offline disappear and if you follow any channel when you are logged in, that channel does not remain as followed (does not appear in 'Followed Streamers' or 'My Streams'). (Everything fixed in
327c723
)

don´t wipe follows on logout
don´t remove follows that are not imported from twitch on sync
@Nickwasused
Copy link
Contributor Author

Nickwasused commented Aug 12, 2021

I have added basic export/import functions in acc3ac7

The follows get exported/imported to/from the Twire data folder.

@RickyM7
Copy link
Contributor

RickyM7 commented Aug 12, 2021

I have added basic export/import functions in acc3ac7

The follows get exported/imported to/from the Twire data folder.

I just tested it. Export works normally, but import doesn't work and the app even crashes sometimes when using this option.

@RickyM7
Copy link
Contributor

RickyM7 commented Aug 12, 2021

The error continues (I tested the last apk generated). I also have a suggestion, is there a way to make a popup message appear whenever we export/import channels?

time: 1628769584734 msg: java.lang.AssertionError: Could not execute method for android:onClick stacktrace: java.lang.IllegalStateException: Could not execute method for android:onClick at android.view.View$DeclaredOnClickListener.onClick(View.java:6268) at android.view.View.performClick(View.java:7448) at com.balysv.materialripple.MaterialRippleLayout$PerformClickEvent.run(MaterialRippleLayout.java:648) at com.balysv.materialripple.MaterialRippleLayout.onTouchEvent(MaterialRippleLayout.java:227) at android.view.View.dispatchTouchEvent(View.java:14309) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3112) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2785) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at android.view.ViewGroup.dispatchTransformedTouchEvent(ViewGroup.java:3118) at android.view.ViewGroup.dispatchTouchEvent(ViewGroup.java:2799) at com.android.internal.policy.DecorView.superDispatchTouchEvent(DecorView.java:488) at com.android.internal.policy.PhoneWindow.superDispatchTouchEvent(PhoneWindow.java:1873) at android.app.Activity.dispatchTouchEvent(Activity.java:4125) at androidx.appcompat.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:69) at androidx.appcompat.view.WindowCallbackWrapper.dispatchTouchEvent(WindowCallbackWrapper.java:69) at com.android.internal.policy.DecorView.dispatchTouchEvent(DecorView.java:446) at android.view.View.dispatchPointerEvent(View.java:14568) at android.view.ViewRootImpl$ViewPostImeInputStage.processPointerEvent(ViewRootImpl.java:6027) at android.view.ViewRootImpl$ViewPostImeInputStage.onProcess(ViewRootImpl.java:5825) at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5316) at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5373) at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5339) at android.view.ViewRootImpl$AsyncInputStage.forward(ViewRootImpl.java:5491) at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:5347) at android.view.ViewRootImpl$AsyncInputStage.apply(ViewRootImpl.java:5548) at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5320) at android.view.ViewRootImpl$InputStage.onDeliverToNext(ViewRootImpl.java:5373) at android.view.ViewRootImpl$InputStage.forward(ViewRootImpl.java:5339) at android.view.ViewRootImpl$InputStage.apply(ViewRootImpl.java:5347) at android.view.ViewRootImpl$InputStage.deliver(ViewRootImpl.java:5320) at android.view.ViewRootImpl.deliverInputEvent(ViewRootImpl.java:8091) at android.view.ViewRootImpl.doProcessInputEvents(ViewRootImpl.java:8042) at android.view.ViewRootImpl.enqueueInputEvent(ViewRootImpl.java:8003) at android.view.ViewRootImpl$WindowInputEventReceiver.onInputEvent(ViewRootImpl.java:8214) at android.view.InputEventReceiver.dispatchInputEvent(InputEventReceiver.java:220) at android.os.MessageQueue.nativePollOnce(Native Method) at android.os.MessageQueue.next(MessageQueue.java:335) at android.os.Looper.loop(Looper.java:183) at android.app.ActivityThread.main(ActivityThread.java:7665) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:594) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947) Caused by: java.lang.reflect.InvocationTargetException at java.lang.reflect.Method.invoke(Native Method) at android.view.View$DeclaredOnClickListener.onClick(View.java:6263) ... 54 more Caused by: java.lang.AssertionError at com.perflyst.twire.service.SubscriptionsDbHelper.onImport(SubscriptionsDbHelper.java:116) at com.perflyst.twire.activities.settings.SettingsGeneralActivity.onImport(SettingsGeneralActivity.java:168) ... 56 more

@RickyM7
Copy link
Contributor

RickyM7 commented Aug 12, 2021

Tested f2f24d8 artifact. The Import option still doesn't work.

time: 1628787268123 msg: java.lang.AssertionError stacktrace: java.lang.AssertionError at com.perflyst.twire.service.SubscriptionsDbHelper.onImport(SubscriptionsDbHelper.java:134) at com.perflyst.twire.activities.settings.SettingsGeneralActivity.lambda$onImport$7$SettingsGeneralActivity(SettingsGeneralActivity.java:191) at com.perflyst.twire.activities.settings.-$$Lambda$SettingsGeneralActivity$8UY9iNiS7RYCzRPXobFxZ1XwcPs.onClick(Unknown Source:2) at com.afollestad.materialdialogs.MaterialDialog.onClick(MaterialDialog.java:343) at android.view.View.performClick(View.java:7448) at android.view.View.performClickInternal(View.java:7425) at android.view.View.access$3600(View.java:810) at android.view.View$PerformClick.run(View.java:28305) at android.os.Handler.handleCallback(Handler.java:938) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:223) at android.app.ActivityThread.main(ActivityThread.java:7665) at java.lang.reflect.Method.invoke(Native Method) at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:594) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:947)

Fixed in 1fe4d2f

Copy link
Collaborator

@samfundev samfundev left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I haven't checked through everything, but I'm going to stop my review for now so that these initial comments can be worked on.

@Nickwasused Nickwasused linked an issue Feb 11, 2022 that may be closed by this pull request
@Nickwasused Nickwasused self-assigned this Feb 11, 2022
@Nickwasused Nickwasused changed the title Add offline follows | Convert some Kraken functions to Helix [WIP] Add offline follows | Convert all Kraken functions to Helix [WIP] Feb 11, 2022
@Nickwasused Nickwasused changed the title Add offline follows | Convert all Kraken functions to Helix [WIP] Add local follows | Convert all Kraken functions to Helix [WIP] Feb 12, 2022
@samfundev
Copy link
Collaborator

@Nickwasused Should I continue reviewing this or are you still working on it? Some stuff is still unresolved from the previous review.

@Nickwasused
Copy link
Contributor Author

@samfundev I think you can start to review, the only thing left is to move the search to helix.

Copy link
Collaborator

@samfundev samfundev left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hopefully the last review.

@Nickwasused Nickwasused linked an issue Feb 16, 2022 that may be closed by this pull request
@Nickwasused Nickwasused changed the title Add local follows | Convert all Kraken functions to Helix [WIP] Add local follows | Convert all Kraken functions to Helix Feb 16, 2022
@Nickwasused Nickwasused changed the title Add local follows | Convert all Kraken functions to Helix Add local follows | Convert some Kraken functions to Helix Feb 16, 2022
@Nickwasused Nickwasused merged commit 4d16976 into twireapp:master Feb 16, 2022
@samfundev
Copy link
Collaborator

samfundev commented Feb 16, 2022

@Nickwasused Oh wait, are you going to migrate the search to helix as well? If you want, I could do it.

@Nickwasused
Copy link
Contributor Author

@samfundev It would be great if you can take a look at it.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
3 participants