Skip to content

Latest commit

 

History

History
52 lines (39 loc) · 2.28 KB

README.markdown

File metadata and controls

52 lines (39 loc) · 2.28 KB

Liferay JSP Spy

What is it?

Have you ever seen some html content in a Liferay page and wondered what JSP rendered that content? You can use JSP Spy to find out. If you have heard enough, just to the How to use it section.

For those that are interested, this repo contains:

  • An OSGi HTTP Whiteboard servlet filter that is specially crafted HT: @rotty3000 to intercept every JSP include dispatch in the Liferay framework and injects some inert HTML markup.
  • Some small configuration that is required for Liferay Portal.
  • A simple WebExtension that listens to Elements panel selection and displays the estimated JSP that rendered that node. This is not going to be correct 100% of the time and may require a little sleuthing through the nearby DOM. I hope to improve this and am welcoming contributions.

How to use it?

In order to use this the following 3 things are needed

  • Set the following in your portal-ext.properties
include-and-override=portal-developer.properties
direct.servlet.context.enabled=false
  • Build and deploy the jsp-spy module
  • Build the Chrome extension
  • Install the Chrome Extension in developer module.

Give me the exact steps to play around with this

  1. Clone this Git repository
  2. Install blade and yarn if you don't have them already.
  3. Make sure you are using Java 1.8.x, you can check by running java -version.
  4. Run blade server init
  5. Run blade server run
  6. Run blade deploy
  7. Run cd modules/jsp-spy-extension
  8. Run yarn install
  9. Run yarn dev chrome
  10. If you are using Chrome, go to chrome://extensions
  11. Enable developer mode (right hand side)
  12. Select "load unpacked" and browse to modules/jsp-spy-extension/dist/chrome folder
  13. Open portal page, then open Chrome Devtools Cmd+Option+I
  14. Use element selection to select a DOM element on the page
  15. On Elements Sidebar click the JSP Spy pane.

Screenshots

Markup injected in HTML



JSP Spy Elements Sidebar