Jump to content

Important / Interesting Updates


adrian
 Share

Recommended Posts

Hi all,

I won't always post here when I update Tracy, but I will when I think the update is an important bug fix that you really should update to.

There was a bug in the new 2.8 branch of core Tracy package that was sometimes causing recursion and really slow load times and sometimes memory exceeding errors. This has been fixed and is available in 4.21.41 of Tracy released today.

  • Like 6
Link to comment
Share on other sites

  • 1 month later...

v4.21.52 fixes an issue with uploading images to repeatermatrix fields. This fix might also take care of a few other randomly seen bugs, although only time will tell with those. Regardless, I think this is a pretty important update for everyone.

  • Like 3
Link to comment
Share on other sites

  • 8 months later...

Hi everyone,

I just committed to new versions.

  • 4.22.23 - updates Tracy core to 2.8.10
  • 4.23.0 - updates Tracy core to 2.9.0

I think everything should be fine in 4.23.0, but the new Tracy core 2.9 major version means that Tracy works without PHP sessions. This means that I was able remove several hacky workarounds to make this module compatible with PW's SessionHandlerDB module. I think I have everything working as expected, but wanted to also release a version with what I assume will be the last version of 2.8.x of the Tracy core.

Please let me know if you find any issues with the new 4.23.0 version and if you have any problems that I can't solve quickly, you can always drop back to 4.22.23.

Happy holidays! 

 

  • Like 5
Link to comment
Share on other sites

  • 1 month later...

Not really an important update, but I wanted to highlight a new feature in the Console panel that lets you override it's default behavior where it handles and reports exceptions in the results pane. This is generally more convenient, but sometimes it's helpful to see the full stack trace in Tracy's "bluescreen". I've added a new checkbox to enable this. One important thing to note is that the bluescreen breaks the Console panel - to get it working again, you can minimise/hide the bluescreen (down arrow at the top right), or reload the page. I feel like I should be able to solve this so it doesn't break the Console panel, but for now, this is the workaround if you use this feature.

  • Like 3
Link to comment
Share on other sites

  • 2 weeks later...

IMPORTANT!!!!! 

Hi everyone. I've made a few changes in the latest version that are worth mentioning, with the first one being a possible (although unlikely) security fix.

1) A couple of the panels (User Switcher and PageRecorder) store info in the module's config settings JSON, but when using these, it would also save any of the settings set via $config->tracy. In general this is probably just annoying, but in the case of the $config->tracy['forceIsLocal'] setting (introduced in Nov, 2021), this override could also be saved to the module's main config settings. Hopefully if you have used this setting, you have only used it locally with things like Docker where the normal isLocal() method fails, but please check your sites if you have ever enabled this somewhere live. In particular I know that @teppo and @netcarver (and I think @Robin S) have been using this feature, but pretty sure still only on local machines.

2) Even though that forceIsLocal setting is potentially dangerous, I decided to add it to the config settings (with a warning) as well so it's more transparent. Note that the debug bar displays a yellow warning icon on the left side if this setting is enabled. 

3) I also added a table that lists out any $config->tracy overrides in an effort to make it more obvious what overrides in place.

4) I've revamped the Log panels further with better logic to control when the yellow / red colors are applied to the icon. I have improved the sort logic within each specific log file and I have added the yellow / red highlighting to the lines that are new since you last loaded them. I have also increased the default number of lines from 10 to 100 - this makes these panels much more useful and because of other recent changes it is now performant enough to do this. Note that upgrading from an old version of Tracy won't increase this, so you might want to do that yourselves in the settings.

Thanks everything and sorry for the override settings getting save to the default one issue!

  • Like 7
  • Thanks 1
Link to comment
Share on other sites

  • 1 month later...

Hi everyone,

Just announcing a couple of new features that have actually been live for a week or so.

1) Guest dumps

This allows any calls to bd() be() etc by guest users (regular visitors, webhook calls etc) to be logged and displayed in the Dumps Recorder panel. This panel will open automatically (on page reload) on another browser tab (where you are logged in). To turn this feature on, click the "Enable Guest Dumps" toggle button on the Panel Selector. The cog icon for this panel will change to orange to let you know it's on. There is no security risk having it enabled, but if you have a well trafficked site and it is left on, the file that stores the recorded dumps could become very large so you won't want to leave this on.

This is my favorite new feature in a very long time so be sure to try it out.

2) Automatic includes

Any files you place in /templates/TracyDebugger/includes/ will be automatically included. You could have a file with some helper functions or the file could have an include statement to pull in a site-wide functions file. This will give you access to any functions in these files via the Console panel.

  • Like 9
Link to comment
Share on other sites

  • 2 years later...

Just a note to say that I've added a new Page Meta section to the Request Info panel. This displays all meta entries for the page, along with links to open the entries for editing directly in Adminer.

image.png.10036f7672525e19f083fd9c4b8df7a2.png

Speaking of Adminer - it was recently updated to AdminerEvo and I changed the way links from Tracy to open Adminer work - they now open the bar panel version which I believe is a much nicer experience than the standalone Adminer page.

I also added links to edit the values of all fields within the Page Edit interface.

image.thumb.png.ac37ca3fd1b3ff22257252efcd30a976.png

If the field has multiple values, it will open Adminer showing all entries instead.

image.thumb.png.dbcc949234a570d77c8b4068a1365e79.png

This is of course optional, so you can visit the Adminer settings (now merged into Tracy's settings) to turn this off if you prefer.

Please note that when you first upgrade, you will likely need to do a modules > refresh to get Adminer to load properly the first time.

  • Like 4
  • Thanks 1
Link to comment
Share on other sites

  • adrian changed the title to Important / Interesting Updates
  • 4 weeks later...

Lots more Adminer updates in the last couple of weeks, but the key things are:

1) Shift-click on the DB icon links will now open Adminer in full mode rather than with the Tracy panel

2) Page, template, field, etc ID within Adminer table views are now linked - note the page title (and path) and the link to edit that page - this comes from hovering on any of the id, parent_id, templates_id, created_users_id, modified_users_id, etc. These sorts of links are present throughout including linking to modules from the "modules" table, hanna_code, pages_meta, etc. It also works for all Page Reference field's page IDs in Profields Table "field_table" tables, Profields Combo, repeater, RM fields, etc.

Hopefully you'll all find this as useful as I am.

image.thumb.png.a950f1bbac9fbdbfa4f8eece7f58ac7f.png

  • Like 7
Link to comment
Share on other sites

  • 2 months later...

There have been a few useful updates to the PW and Tracy logs panels.

1) Display json as interactive "dumped" array.

2) Support for @Robin S awesome new CustomLogs module.

3) New options to exclude certain logs from being displayed. By default "modules", "sessions", and "file-compiler" are excluded. I think this is a major improvement because often these logs overwhelm the more important alert/warning/error type logs.

image.thumb.png.e67bff67a05b915f69978a994f4df5d8.png

image.thumb.png.58f468245ec917c597541ae6f304cd2a.png

  • Like 5
Link to comment
Share on other sites

  • 5 months later...

Happy new year everyone!

I've been working on adding multiple tab support for the console panel. It works in conjunction with the snippets panel so you can load up multiple snippets, or create any number of temporary (unsaved) tabs of code. Each tab has its own execution history stack and the last result for each tab is also maintained so you can flip between tabs to see the differences between results. It automatically names tabs like a typical code editor does: Untitled-1 initially, and then using the first line of code. Of course when you save the tab to a snippet, the tab name will be that of the snippet filename saved to disk.

I'll push it live soon, but if anyone sees this and would like to test and provide feedback beforehand, please take a look at this branch: https://github.com/adrianbj/TracyDebugger/tree/console-tabs

Thanks!

image.thumb.png.fd5255be51aa68f87548e733a6af6c50.png

  • Like 6
Link to comment
Share on other sites

1 hour ago, adrian said:

I've been working on adding multiple tab support for the console panel.

This is awesome, thanks!

A few things I noticed when testing:

1. After updating from a previous TracyDebugger version, the console window is only 1 line high and there's an error in the browser console.

image.png.eb67fa40ee65bacbdfbc5a645ebcc33c.png

image.png.82394ba5a93a2811f96d435feda36b76.png

Probably a browser cache issue because if I do a hard reload the issues are gone.

2. Is it expected that clicking on a snippet that's already open in the console will open another copy of the snippet? Perhaps instead it should focus the already open tab?

image.png.5a24930c708887c38a24e9d6de662905.png

3. The "Go Back" arrow never seems to become activated after executions or changes to the code. It's always greyed out for me.

4. Very minor and I think it's not a new thing, but for some reason the right arrow button is 1 pixel higher than the left arrow button.

image.png.5367eb446f71937e213ebc4421803cd5.png

Link to comment
Share on other sites

Thanks @Robin S for the testing, much appreciated.

1) Sorry, I thought I had dealt with all upgrade issues but missed that one

2) Yeah, that is the intended behaviour - I was treating it as a way of loading up the saved version in a separate tab without losing any potential changes to the currently open version. I know it's different to how VSCode (and probably other editors) work though, so maybe I should reconsider. Anyone else have thoughts?

3) This was also an upgrade issue - the structure of the history stack needed updating but wasn't being overwritten if it already existed.

4) I am not seeing this pixel issue - any chance you could help narrow that down:

image.png.dfbe0eeec4edf73308fef4cc009c7336.png

Latest commit should fix 1 & 3

Thanks again.

  • Like 1
Link to comment
Share on other sites

@Robin S - just occurred to me that my fix for the history issue won't work if you upgrade your already upgraded version, so if you do that, please delete these localStorage items manually so that they will be automatically re-created in the right format.

https://github.com/adrianbj/TracyDebugger/commit/9d7d42501ead93460d27cda4829eed780239c2aa

 

  • Like 1
Link to comment
Share on other sites

@adrian, thanks, the history is working for me now.

7 hours ago, adrian said:

I am not seeing this pixel issue - any chance you could help narrow that down

I think this is caused by a combination of the button height being in fractional pixels and the scaleX(-1) transform on the right arrow. This causes Chrome to round the two arrow buttons to different numbers of whole pixels.

image.png.508ae862cff798a58547c4868492ce57.png

There would be a several different ways to solve this, but perhaps the easiest thing would be to use the FontAwesome right arrow character for second arrow button rather than flipping a left arrow character. You'd also then tweak the margin and border on that button seeing as it would no longer be flipped. 

Leaving the coloured border on all sides and adjusting to margin-left: -12px looks good to me.

image.png.8e0a63aa371e5bd3fc5d069bef3734be.png

image.png.33f47a87baa6d76f232c2f704960b5f7.png

 

  • Like 1
Link to comment
Share on other sites

Thanks @Robin S - I have fixed the history forward icon - I honestly have no idea why I used the left arrow and flipped it :)

I have also changed the behaviour if a snippet is already open in a tab and also added scroll into view for the tabs as needed (if lots are open and some are out of view due to horizontal scrolling).

Anything else you can see that needs attention before release?

Link to comment
Share on other sites

  • 2 weeks later...

Well, it took a long time, but the Console tabs are now available in the latest version - turns out there were actually a lot of things left to do which took way longer than I expected.

If anyone finds any issues, please let me know.

Please note that you will have to do a hard reload to get the tab CSS working - the way the core Tracy package loads CSS I can't seem to figure out how to bust the caching of it.

  • Like 1
  • Thanks 1
Link to comment
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
 Share

  • Recently Browsing   0 members

    • No registered users viewing this page.
×
×
  • Create New...