In this article we are going to address the topic of MediaWiki talk:Gadget-BugStatusUpdate.js, a topic that has gained relevance in recent years. MediaWiki talk:Gadget-BugStatusUpdate.js is a topic that interests many people for different reasons, whether due to its impact on society, the economy or the environment. Throughout this article, we will explore different aspects of MediaWiki talk:Gadget-BugStatusUpdate.js, from its history and evolution, to its implications today. We will also analyze how MediaWiki talk:Gadget-BugStatusUpdate.js has generated debate and controversy, as well as possible solutions and future prospects. We hope this article is a useful resource for those seeking to better understand MediaWiki talk:Gadget-BugStatusUpdate.js and its implications in today's world.
Webservice restart instructions
Sometimes the webservice needs to be restarted. For people with access, the commands are:
When a bug is marked as "RESOLVED", it would be useful to have the resolution available to know if it is a FIXED, INVALID, WONTFIX, DUPLICATED or a WORKSFORME. Helder11:25, 25 January 2013 (UTC)
Stepping up to the plate...
Helder, I see you have made many scattered requests for enhancements/fixes to this template/gadget. I'm going to be working through trying to accomodate as many of them as I can, and would appreciate if you could go through the bulleted list here and make sure I don't miss any. Thanks Technical 13 (talk) 18:32, 18 June 2013 (UTC)
I've actually asked AKlapper (WMF) for some input, and he said he knows little about the actual api. I actually got distracted from this project, and you can see what I did manage to get done in my version in the list below. I've also made some adjustments to the template and started working on "resolutions" but have had the time to write the code to scrape the html of the bugs to get it (since it isn't returned by the api). I also looked at and thought about ways to indicate "security" bugs based on the error message returned by the api, but haven't gotten around to implementing it just yet. Technical 13 (talk) 17:47, 11 September 2013 (UTC)
A short time ago, this gadget is failing in chrome with the following error: Uncaught TypeError: Cannot read property 'bugs' of null on the line if(data.result.bugs).... Firefox has the same problem. I can find no recent edits that would cause this, but I can see no definition for 'result'. Anyone knows whats going on? — Edokter (talk) — 10:39, 22 June 2013 (UTC)
It only seems to be broken at the Village Pump when viewed as a whole, so it must be something on the page itself. — Edokter (talk) — 13:12, 23 June 2013 (UTC)
Okay, I am using a test script I've been working on (see above section) and didn't see the error on other pages... I flipped my script off and tried again with the live script on VPT. I went through one section at a time until I came across T51741 which wouldn't load up with just that section. I've deactivated the {{Tracked}} for that bug and think I know what is going on. I think that is a "security" related bug which you can't see the details of (neither can I for that matter), and it is bugging the whole thing out. I'm already working on a patch/fix for that above, but the api returns a completely different result for those, so it may be a bit for my to formulate it. Let me know if commenting it out fixed VPT for you. Technical 13 (talk) 00:11, 24 June 2013 (UTC)
I hadn't even created a user account on Phabricator until just now. I'm very interested in this however, but I may have a slow learning curve as I don't have a lot of free time at the moment with all my 300 level classes at school weighing me down in homework. If others are interested, I'd happily defer it to them, otherwise, there's no real deadline I suppose... — {{U|Technical 13}} (e • t • c)17:22, 8 September 2014 (UTC)
That is just the template which auto-links to either Bugzilla od Phabricator (which does not work at the moment as it is in the process of moving). The Gadget queries the status of the bug/ticket and needs an API to communicate with. -- ] {{talk}}19:37, 9 September 2014 (UTC)
I've cast a glance at how to do the same thing with phabricator as with bugzilla. First, the API (conduit) “auto”-documentation is very light; second, we'll need an additional step to get a CSRF token, even for read-only requests (I still wonder why); third, I haven't found yet how to query information for several tasks at the same time (I certainly wouldn't use the gadget if it was doing one request per task) — but again, the documentation is subpar.
Example, request for bugzilla was this one, now it'll be like this one (except that it only gets information for one task and that some other query — which one and why, I've no idea — is required first to get the CSRF token).
I dunno if we had to patch bugzilla in the past, but I've the feeling that we'll have to contribute to phabricator in the future…
This is done. I've ported it over; the new version is it at User:Mattflaschen (WMF)/Gadget-BugStatusUpdate.js. It uses a simple JSONP service I implemented on Tool Labs. The new gadget does not support Bugzilla at all (the template still does); all Bugzilla bugs have been migrated to the Phabricator site, and any Bugzilla statuses are potentially out of date, so I don't think it's necessary.
Note: I asked Bryan, who said "I think I got it back up and running. it was a bit more complex than just restart". However, whilst a query now works (example), the gadget still does not work and shows this error in console: https://i.imgur.com/fwJhjXr.png Or text: https://ghostbin.com/paste/a4bzf/raw
I've also added a section at the top of this page, for any further maintenance notes/clues you might be able to add.
@Xaosflux: No, but now it's returning internal service errors (500); and the listed maintainer hasn't edited anywhere since 2019. Any ideas on how to get a suitable kick administered to the tool? Xover (talk) 17:16, 5 August 2021 (UTC)
@Xover: it is working for me right now, are you seeing this problem now? The local script can produce a 500 error for a timeout upstream. — xaosfluxTalk17:19, 5 August 2021 (UTC)
@Xaosflux: AIUI phabricator-bug-status.toolforge.org was developed specifically as the backend for enwp's Gadget-BugStatusUpdate.js, and points here from the tool description. The (only) maintainer listed there and here is Mattflaschen, who hasn't edited on any project since 2019 (cf. #Webservice restart instructions above). Now granted I was following up a problem reported over on enWS, but if it's starting to bitrot it's going to start affecting enWP too. In any case, since it apparently isn't completely down I'll do some more poking and try to quantify it before filing in Phab. Xover (talk) 18:21, 5 August 2021 (UTC)
@Xover: only option really, the editors and admins of enwiki can't do anything about that, if it goes down for good all we can do is disable this gadget or retarget it if someone else makes a status tool - would probably be better to not have to use a toolforge shunt and just fetch the values from phab directly. — xaosfluxTalk18:37, 5 August 2021 (UTC)
@Xaosflux: Looking into this, it turns out Phabricator supports neither JSONP nor CORS, and it requires a manually assigned per-user Conduit API key, so in practice it's not possible to query this from JS in a web browser. I also cannot find that the code for the proxy is available anywhere (it's not on Matt's Github, for example), but I imagine that it is in essence just providing the API key and JSONP bits of that. It also, incidentally, massages the data coming from Conduit before returning it to the client, presumably to cater to clients written for Bugzilla's API. But, bottom line, the only way to get at the 500 errors is to either usurp the phabricator-bug-status tool, or to replace it with a new tool based on cors-anywhere or something similar.That being said, in debugging why enWS's gadget was seemingly completely broken while enwp's only failed on occasional 500 errors I ended up rewriting {{tracked}} in Lua, moving hardcoded formatting into TemplateStyles, and cleaning up the code. The gadget itself is now down to about ~55 lines of fairly readable code (and inline comments), faster (not that it matters), more robust (possibly matters), and should deal better with multiple tracked templates on a single page.If there's any interest, the updated code is at s:MediaWiki:Gadget-BugStatusUpdate.js, s:Template:Tracked, s:Module:Tracked, s:Template:Tracked/styles.css, and it's probably a good idea to grab the testcases too: s:Template:Tracked/testcases. I'm happy to help bringing it over, but since I'm not currently very active on enwp I don't want to pull the trigger on that unilaterally. It also requires updating the gadget and the template concurrently meaning it requires someone with the right bits turned on on their account. Xover (talk) 07:38, 13 August 2021 (UTC)