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

No browser data in Activity view using Vivaldi #321

Closed
alexgarbarev opened this issue Dec 15, 2019 · 17 comments
Closed

No browser data in Activity view using Vivaldi #321

alexgarbarev opened this issue Dec 15, 2019 · 17 comments

Comments

@alexgarbarev
Copy link

Hi, I'm running 0.8.4 version on Linux and it works mostly fine!
The only problem is that Browser data is empty in Activity tab.
I'm using chrome plugin and data exists in the database: it shows correctly in "Timeline" and "Raw Data".
I was expected to see data under "Top Browser Domains" and "Browser" sections.

Any help appreciated!

@ErikBjare
Copy link
Member

ErikBjare commented Dec 15, 2019

What Linux distro? What is the app name of your browser?

If you'd have searched you'd know that there are several similar issues (like this one: #314) that outline the information we need to fix bugs like this 🙂

@alexgarbarev
Copy link
Author

Thanks for response! And thanks for linked issue - I've tried to search but couldn't find it :-)

Environment

Browser: Vivaldi | 2.9.1705.41 (Stable channel) (64-bit)
Operating System: KDE neon 5.17
KDE Plasma Version: 5.17.4
KDE Frameworks Version: 5.65.0
Qt Version: 5.13.2
Kernel Version: 5.0.0-37-generic
OS Type: 64-bit

Debug info from plugin

Number of active tabs: 1
Tabs:
{
    "active": true,
    "audible": false,
    "autoDiscardable": true,
    "discarded": false,
    "extData": "{\"useDefaultIcon\":false,\"read\":true,\"urlForThumbnail\":\"https://github.com/ActivityWatch/activitywatch/issues/321#issuecomment-565786599\",\"thumbnail\":\"\",\"ext_id\":\"ck46rk9t500343i5of3sxfbcw\"}",
    "favIconUrl": "https://github.githubassets.com/favicon.ico",
    "height": 1006,
    "highlighted": true,
    "id": 51,
    "incognito": false,
    "index": 4,
    "mutedInfo": {
        "muted": false,
        "reason": "capture"
    },
    "pinned": false,
    "selected": true,
    "status": "complete",
    "title": "No Browser data in activity · Issue #321 · ActivityWatch/activitywatch",
    "url": "https://github.com/ActivityWatch/activitywatch/issues/321",
    "width": 1829,
    "windowId": 15
}

{"testing":null,"lastSyncSuccess":true}

Screenshots

Screenshot_20191215_145237

Screenshot_20191215_145212

Let me know if anything else I can help you with.

@ErikBjare
Copy link
Member

You left out the one thing I needed: The exact app name as reported by the window watcher (in the 'Summary' or Raw data -> aw-watcher-window).

@alexgarbarev
Copy link
Author

This one?
Screenshot_20191215_154540

I've installed Vivaldi using their official repo for Ubuntu:

http://repo.vivaldi.com/stable/deb/ stable main

@ErikBjare
Copy link
Member

There it is, thanks!

It's strange though, since that is already included in the relevant file (aw-webui/src/queries.js, example PR here: ActivityWatch/aw-webui#158), so I'm not quite sure what is going wrong here.

@stale
Copy link

stale bot commented Jun 12, 2020

This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Thank you for your contributions.

@stale stale bot added the stale label Jun 12, 2020
@stale stale bot closed this as completed Jun 26, 2020
@johan-bjareholt
Copy link
Member

This should work now, if someone finds that it doesn't feel free to add a comment and I'll reopen this issue.

@Hashnoob
Copy link

Windows 10
Vivaldi: 3.5.2115.81 (Stable channel) (64-bit) - Running in standalone mode.
AW Version: v0.10.0 / AW Chrome extension installed, connected and syncing.

aw-watcher-window - App Name: "app: vivaldi.exe"

Bucket ID for Vivaldi: "aw-watcher-web-chrome"

"buckets": {
  "aw-watcher-web-chrome": {
    "id": "aw-watcher-web-chrome",
    "created": "#",
    "name": null,
    "type": "web.tab.current",
    "client": "aw-client-web",
    "hostname": "unknown",
    "events": [
      {
        "timestamp": "#",
        "duration": 20.000,
        "data": {
          "url": "http://localhost:5600/#/buckets/aw-watcher-web-chrome",
          "title": "ActivityWatch",
          "audible": false,
          "incognito": false,
          "tabCount": 1
        }
      },

Issues:
Top Browser URLs: No data
Top Browser Domains: No data

Any help would be appreciated!

@johan-bjareholt
Copy link
Member

johan-bjareholt commented Dec 31, 2020

@Hashnoob The issue in your case seems to be that Vivaldi tries to hide itself as being "chrome" while in fact it's not. Maybe that's something that has recently changed with Vivaldi? Because this has not been the case before.

We have the same issue with Brave browser and there is no fix. The reason why we can't fix it is if we handled Brave/Vivaldi the same as Chrome and if someone would run Chrome and Brave at the same time and they both report themselves as Chrome we would corrupt the browser activity as both browsers would report to the same bucket.

So I'd try to contact the Vivaldi devs about this and ask them to revert that change.

@Hashnoob
Copy link

@johan-bjareholt I think I understand the issue regarding corruption. Does that same issue occur when you run for example two instances of FireFox?

What does ActivityWatch use to dictate what browser you are using from the extension, the User-Agent?

This is what Vivaldi is reporting:
Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.107 Safari/537.36

@Hashnoob
Copy link

Hashnoob commented Dec 31, 2020

@johan-bjareholt

It looks like the team at Vivaldi disguised itself as "Chrome" back in December of last year as not doing so would be "misused by some web developers and occasionally even abused by the bigger tech companies, in positions of power.".

Luckily it looks like Vivaldi has the option to start it with a custom User-Agent.

Add to Vivaldi Shortcut - Example:
--user-agent="Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.107 Safari/537.36 Vivaldi/3.5.2115.81"

Issues Fixed:

  • Top Browser URLs: No data
  • Top Browser Domains: No data

And the correct bucket gets created. - aw-watcher-web-vivaldi

Are there any downsides to this solution?

@johan-bjareholt
Copy link
Member

johan-bjareholt commented Jan 1, 2021

Are there any downsides to this solution?

Well, the downsides are the reason you mentioned that Vivaldi developers decided to hide it, because it is often "misused by some web developers and occasionally even abused by the bigger tech companies, in positions of power."

For example, websites like microsoft teams and skype don't care about your browser actually supports but only looks at if it's Chrome or not. So that will likely stop working if you start Vivaldi like this. Another thing would be that users using Vivaldi will be easier to track by ad companies with fingerprinting as there's a smaller amount of users using Vivaldi. I'm sure that there are other examples too.

A proper solution would be if you could select user-agent only for the extension, but as far as I know that's not possible in Vivaldi.

@M1zzu
Copy link

M1zzu commented Jan 4, 2022

Wouldn't one option be to let the user specify their browser inside the extension settings and ignore the user-agent if that option is set? I.e. after the extension is installed, display the message "This plugin cannot detect whether you are running Chrome or one of its derivatives like Vivaldi or Brave. Chrome is assumed. If it is one of the others, please choose from this list or enter a custom string".


For what it's worth, one can export the bucket's raw data and change the beginning of the JSON from

{
    "buckets": {
        "aw-watcher-web-chrome": {
            "id": "aw-watcher-web-chrome",

to

{
    "buckets": {
        "aw-watcher-web-vivaldi": {
            "id": "aw-watcher-web-vivaldi",

and then you can re-import that bucket and it works for that past data. I.e. it creates a vivaldi bucket with the imported data that is then displayed in the activity view. (I have some doubts though as to whether the re-import operation is repeatable, because of name conflicts)


For the uninitiated: Browser URL/Domain view in the activity tab is broken because AW builds that information by correlating your focused window (info which it gets from the window-watcher) with the data that is being sent by the browser plugin (which is being sent regardless of focus), so if your focused-window says Vivaldi and your plugin says chrome, it cannot know that those belong to the same thing (it can't just mush them together because if the user is also running chrome that's gonna screw everything up). You can verify this like so: If you have a tab open in Vivaldi-with-plugin and open an empty chromium-without-plugin in the foreground and focus it for like a minute, the URL that's open in Vivaldi during that minute will show up in the activity view (because Vivaldi's watcher plugin says "I'm chrome and this URL is currently open" and the window watcher says "The currently focused window is chrome", so AW assumes that URL is open in chrome).

(Somewhere I've read a statement that browsers do not expose to plugins whether the window is in focus. I'd like to note that Leechblock NG is a browser extension that is capable of determining that, so it seems possible. Apparently it uses document.hasFocus(). I've no clue about mouse movement and such)

@wzaielamri
Copy link

Hi, are there any updates or workarounds regarding this issue? It looks like the Vivaldi (chrome) extension is still not updated.

@BelKed
Copy link
Contributor

BelKed commented Feb 11, 2025

It has been fixed in ActivityWatch/aw-watcher-web#154

You can build from source of wait for the release

@wzaielamri
Copy link

wzaielamri commented Feb 11, 2025

@BelKed
It looks like there is a problem with the makefile
after doing the following:

git clone --recurse-submodules https://github.com/ActivityWatch/aw-watcher-web.git
cd aw-watcher-web
make build

I get the following error:

make: Nothing to be done for 'build'.

Same for:

make build-chrome

gives this output:

npm ci
npm ERR! Cannot read property 'aw-client' of undefined

npm ERR! A complete log of this run can be found in:
npm ERR!     /home/zai/.npm/_logs/2025-02-11T17_14_10_999Z-debug.log
make: *** [Makefile:4: install] Error 1

This is the content of the log:

0 info it worked if it ends with ok
1 verbose cli [ '/usr/bin/node', '/usr/bin/npm', 'ci' ]
2 info using [email protected]
3 info using [email protected]
4 verbose npm-session 975d62666e57f116
5 info prepare initializing installer
6 verbose prepare starting workers
7 verbose prepare installation prefix: /opt/activitywatch/aw-watcher-web
8 verbose prepare using package-lock.json
9 verbose checkLock verifying package-lock data
10 verbose teardown shutting down workers.
11 info teardown Done in 0s
12 verbose stack TypeError: Cannot read property 'aw-client' of undefined
12 verbose stack     at Object.keys.forEach.name (/usr/share/npm/node_modules/lock-verify/index.js:27:40)
12 verbose stack     at Array.forEach (<anonymous>)
12 verbose stack     at Promise.all.then.result (/usr/share/npm/node_modules/lock-verify/index.js:25:25)
13 verbose cwd /opt/activitywatch/aw-watcher-web
14 verbose Linux 5.15.0-131-generic
15 verbose argv "/usr/bin/node" "/usr/bin/npm" "ci"
16 verbose node v10.19.0
17 verbose npm  v6.14.4
18 error Cannot read property 'aw-client' of undefined
19 verbose exit [ 1, true ]

Any idea what i am missing?

@BelKed
Copy link
Contributor

BelKed commented Feb 11, 2025

You are using an outdated version of node. Upgrade to latest and it should work :)

$ node -v
v23.5.0
$ npm -v
11.1.0

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

No branches or pull requests

7 participants