René's URL Explorer Experiment


Title: Fix issue 132 and refactor entry point detection logic. by rahlk · Pull Request #133 · codellm-devkit/codeanalyzer-java · GitHub

Open Graph Title: Fix issue 132 and refactor entry point detection logic. by rahlk · Pull Request #133 · codellm-devkit/codeanalyzer-java

X Title: Fix issue 132 and refactor entry point detection logic. by rahlk · Pull Request #133 · codellm-devkit/codeanalyzer-java

Description: Motivation and Context This change addresses Issue #132, which reported that codeanalyzer fails to detect certain JakartaEE methods (e.g., doPost(...)) as valid entrypoints even though the surrounding class is correctly recognized as an entrypoint class. The root cause was a flawed heuristic in the isEntrypointMethod(...) implementation that required both: the presence of request/response parameters, and an annotation containing the string "Override". Since methods like doPost(...) override HttpServlet methods but may not explicitly include the @Override annotation (which is optional in Java), the AND condition resulted in false negatives. This PR removes the faulty annotation check and ensures servlet entrypoints are correctly discovered. Additionally, this change refactors discovery logic to leverage a new EntrypointFinderFactory, improving modularity and extensibility for multi-framework support. How Has This Been Tested? Ran the updated codeanalyzer against a JakartaEE sample application with HttpServlet subclasses. Verified that doPost(...), doGet(...), and similar methods are now correctly marked as entrypoints. Confirmed no regressions in Spring or JAX-RS entrypoint detection. Breaking Changes No breaking changes. This is a non-breaking behavioral fix that improves the correctness of entrypoint detection in JakartaEE applications. Types of changes Bug fix (non-breaking change which fixes an issue) New feature (non-breaking change which adds functionality) Breaking change (fix or feature that would cause existing functionality to change) Documentation update Checklist I have read the Codellm-Devkit Documentation My code follows the repository's style guidelines New and existing tests pass locally I have added appropriate error handling I have added or updated documentation as needed Additional context The use of EntrypointFinderFactory now cleanly supports framework-specific entrypoint logic (e.g., Spring, JAX-RS, Jakarta). This abstraction will make future enhancements (e.g., Struts, Camel) easier to plug in. Minor cleanups also improve maintainability by localizing entrypoint logic to its respective finder class.

Open Graph Description: Motivation and Context This change addresses Issue #132, which reported that codeanalyzer fails to detect certain JakartaEE methods (e.g., doPost(...)) as valid entrypoints even though the surround...

X Description: Motivation and Context This change addresses Issue #132, which reported that codeanalyzer fails to detect certain JakartaEE methods (e.g., doPost(...)) as valid entrypoints even though the surround...

Opengraph URL: https://github.com/codellm-devkit/codeanalyzer-java/pull/133

X: @github

direct link

Domain: github.com

route-pattern/:user_id/:repository/pull/:id/files(.:format)
route-controllerpull_requests
route-actionfiles
fetch-noncev2:66bdfa00-e728-c307-d0f6-e182a3a95655
current-catalog-service-hashae870bc5e265a340912cde392f23dad3671a0a881730ffdadd82f2f57d81641b
request-id950E:6EBCD:1139DE4:1634570:698FD889
html-safe-noncec74d264d3bcac114e241906929635c8a61ed2b966836f057eec56f6fb0330fea
visitor-payloadeyJyZWZlcnJlciI6IiIsInJlcXVlc3RfaWQiOiI5NTBFOjZFQkNEOjExMzlERTQ6MTYzNDU3MDo2OThGRDg4OSIsInZpc2l0b3JfaWQiOiI0NjQzNzk1Nzg4NDA4ODA1NTEzIiwicmVnaW9uX2VkZ2UiOiJpYWQiLCJyZWdpb25fcmVuZGVyIjoiaWFkIn0=
visitor-hmacb8f1e2e4923bf9e9fd775467448fcd44163e8da36668fd8f399f6b8497d486c4
hovercard-subject-tagpull_request:2464176147
github-keyboard-shortcutsrepository,pull-request-list,pull-request-conversation,pull-request-files-changed,copilot
google-site-verificationApib7-x98H0j5cPqHWwSMm6dNU4GmODRoqxLiDzdx9I
octolytics-urlhttps://collector.github.com/github/collect
analytics-location///pull_requests/show/files
fb:app_id1401488693436528
apple-itunes-appapp-id=1477376905, app-argument=https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
twitter:imagehttps://avatars.githubusercontent.com/u/1433964?s=400&v=4
twitter:cardsummary_large_image
og:imagehttps://avatars.githubusercontent.com/u/1433964?s=400&v=4
og:image:altMotivation and Context This change addresses Issue #132, which reported that codeanalyzer fails to detect certain JakartaEE methods (e.g., doPost(...)) as valid entrypoints even though the surround...
og:site_nameGitHub
og:typeobject
hostnamegithub.com
expected-hostnamegithub.com
None42c603b9d642c4a9065a51770f75e5e27132fef0e858607f5c9cb7e422831a7b
turbo-cache-controlno-preview
diff-viewunified
go-importgithub.com/codellm-devkit/codeanalyzer-java git https://github.com/codellm-devkit/codeanalyzer-java.git
octolytics-dimension-user_id197800760
octolytics-dimension-user_logincodellm-devkit
octolytics-dimension-repository_id731300153
octolytics-dimension-repository_nwocodellm-devkit/codeanalyzer-java
octolytics-dimension-repository_publictrue
octolytics-dimension-repository_is_forkfalse
octolytics-dimension-repository_network_root_id731300153
octolytics-dimension-repository_network_root_nwocodellm-devkit/codeanalyzer-java
turbo-body-classeslogged-out env-production page-responsive full-width
disable-turbotrue
browser-stats-urlhttps://api.github.com/_private/browser/stats
browser-errors-urlhttps://api.github.com/_private/browser/errors
released320682233dfd4d28c0b30554a564c2fcd229032
ui-targetfull
theme-color#1e2327
color-schemelight dark

Links:

Skip to contenthttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#start-of-content
https://github.com/
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fcodellm-devkit%2Fcodeanalyzer-java%2Fpull%2F133%2Ffiles
GitHub CopilotWrite better code with AIhttps://github.com/features/copilot
GitHub SparkBuild and deploy intelligent appshttps://github.com/features/spark
GitHub ModelsManage and compare promptshttps://github.com/features/models
MCP RegistryNewIntegrate external toolshttps://github.com/mcp
ActionsAutomate any workflowhttps://github.com/features/actions
CodespacesInstant dev environmentshttps://github.com/features/codespaces
IssuesPlan and track workhttps://github.com/features/issues
Code ReviewManage code changeshttps://github.com/features/code-review
GitHub Advanced SecurityFind and fix vulnerabilitieshttps://github.com/security/advanced-security
Code securitySecure your code as you buildhttps://github.com/security/advanced-security/code-security
Secret protectionStop leaks before they starthttps://github.com/security/advanced-security/secret-protection
Why GitHubhttps://github.com/why-github
Documentationhttps://docs.github.com
Bloghttps://github.blog
Changeloghttps://github.blog/changelog
Marketplacehttps://github.com/marketplace
View all featureshttps://github.com/features
Enterpriseshttps://github.com/enterprise
Small and medium teamshttps://github.com/team
Startupshttps://github.com/enterprise/startups
Nonprofitshttps://github.com/solutions/industry/nonprofits
App Modernizationhttps://github.com/solutions/use-case/app-modernization
DevSecOpshttps://github.com/solutions/use-case/devsecops
DevOpshttps://github.com/solutions/use-case/devops
CI/CDhttps://github.com/solutions/use-case/ci-cd
View all use caseshttps://github.com/solutions/use-case
Healthcarehttps://github.com/solutions/industry/healthcare
Financial serviceshttps://github.com/solutions/industry/financial-services
Manufacturinghttps://github.com/solutions/industry/manufacturing
Governmenthttps://github.com/solutions/industry/government
View all industrieshttps://github.com/solutions/industry
View all solutionshttps://github.com/solutions
AIhttps://github.com/resources/articles?topic=ai
Software Developmenthttps://github.com/resources/articles?topic=software-development
DevOpshttps://github.com/resources/articles?topic=devops
Securityhttps://github.com/resources/articles?topic=security
View all topicshttps://github.com/resources/articles
Customer storieshttps://github.com/customer-stories
Events & webinarshttps://github.com/resources/events
Ebooks & reportshttps://github.com/resources/whitepapers
Business insightshttps://github.com/solutions/executive-insights
GitHub Skillshttps://skills.github.com
Documentationhttps://docs.github.com
Customer supporthttps://support.github.com
Community forumhttps://github.com/orgs/community/discussions
Trust centerhttps://github.com/trust-center
Partnershttps://github.com/partners
GitHub SponsorsFund open source developershttps://github.com/sponsors
Security Labhttps://securitylab.github.com
Maintainer Communityhttps://maintainers.github.com
Acceleratorhttps://github.com/accelerator
Archive Programhttps://archiveprogram.github.com
Topicshttps://github.com/topics
Trendinghttps://github.com/trending
Collectionshttps://github.com/collections
Enterprise platformAI-powered developer platformhttps://github.com/enterprise
GitHub Advanced SecurityEnterprise-grade security featureshttps://github.com/security/advanced-security
Copilot for BusinessEnterprise-grade AI featureshttps://github.com/features/copilot/copilot-business
Premium SupportEnterprise-grade 24/7 supporthttps://github.com/premium-support
Pricinghttps://github.com/pricing
Search syntax tipshttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
documentationhttps://docs.github.com/search-github/github-code-search/understanding-github-code-search-syntax
Sign in https://github.com/login?return_to=https%3A%2F%2Fgithub.com%2Fcodellm-devkit%2Fcodeanalyzer-java%2Fpull%2F133%2Ffiles
Sign up https://github.com/signup?ref_cta=Sign+up&ref_loc=header+logged+out&ref_page=%2F%3Cuser-name%3E%2F%3Crepo-name%3E%2Fpull_requests%2Fshow%2Ffiles&source=header-repo&source_repo=codellm-devkit%2Fcodeanalyzer-java
Reloadhttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
Reloadhttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
Reloadhttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
codellm-devkit https://github.com/codellm-devkit
codeanalyzer-javahttps://github.com/codellm-devkit/codeanalyzer-java
Notifications https://github.com/login?return_to=%2Fcodellm-devkit%2Fcodeanalyzer-java
Fork 1 https://github.com/login?return_to=%2Fcodellm-devkit%2Fcodeanalyzer-java
Star 5 https://github.com/login?return_to=%2Fcodellm-devkit%2Fcodeanalyzer-java
Code https://github.com/codellm-devkit/codeanalyzer-java
Issues 10 https://github.com/codellm-devkit/codeanalyzer-java/issues
Pull requests 0 https://github.com/codellm-devkit/codeanalyzer-java/pulls
Actions https://github.com/codellm-devkit/codeanalyzer-java/actions
Projects 0 https://github.com/codellm-devkit/codeanalyzer-java/projects
Security 0 https://github.com/codellm-devkit/codeanalyzer-java/security
Insights https://github.com/codellm-devkit/codeanalyzer-java/pulse
Code https://github.com/codellm-devkit/codeanalyzer-java
Issues https://github.com/codellm-devkit/codeanalyzer-java/issues
Pull requests https://github.com/codellm-devkit/codeanalyzer-java/pulls
Actions https://github.com/codellm-devkit/codeanalyzer-java/actions
Projects https://github.com/codellm-devkit/codeanalyzer-java/projects
Security https://github.com/codellm-devkit/codeanalyzer-java/security
Insights https://github.com/codellm-devkit/codeanalyzer-java/pulse
Sign up for GitHub https://github.com/signup?return_to=%2Fcodellm-devkit%2Fcodeanalyzer-java%2Fissues%2Fnew%2Fchoose
terms of servicehttps://docs.github.com/terms
privacy statementhttps://docs.github.com/privacy
Sign inhttps://github.com/login?return_to=%2Fcodellm-devkit%2Fcodeanalyzer-java%2Fissues%2Fnew%2Fchoose
rahlkhttps://github.com/rahlk
mainhttps://github.com/codellm-devkit/codeanalyzer-java/tree/main
132-unable-to-find-all-entrypoint-methodshttps://github.com/codellm-devkit/codeanalyzer-java/tree/132-unable-to-find-all-entrypoint-methods
Conversation 1 https://github.com/codellm-devkit/codeanalyzer-java/pull/133
Commits 1 https://github.com/codellm-devkit/codeanalyzer-java/pull/133/commits
Checks 0 https://github.com/codellm-devkit/codeanalyzer-java/pull/133/checks
Files changed https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
Please reload this pagehttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
Fix issue 132 and refactor entry point detection logic. https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#top
Show all changes 1 commit https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
4a4108d Fix issue 132 and refactor entrypoint detection logic. rahlk Apr 16, 2025 https://github.com/codellm-devkit/codeanalyzer-java/pull/133/commits/4a4108d8107ec2a7e9fc4e673623d36ca74bfb28
Clear filters https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
Please reload this pagehttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
Please reload this pagehttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
gradle.properties https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-3d103fc7c312a3e136f88e81cef592424b8af2464c468116545c4d22d6edcf19
SymbolTable.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
EntrypointsFinderFactory.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-b6a0f1aa1ed5cd7c4b01b27a7f77d85266a29391f40fac37d3931c38efb6f438
CamelEntrypointFinder.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-293443f2f4bd7ceb17c14f9928d432bcf01ec996cf12acc58c56dfa16141cea9
JakartaEntrypointFinder.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-c7f338eea2510855761811206462e6d029440a13e47c11fa1ce40b4bdcd9ef1f
JaxRsEntrypointFinder.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-3b0ca2e819b3a46774d9982df8b5a5c353d00d42ccafbffbcd0cf53ac17f0440
SpringEntrypointFinder.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-561c1a75ab20715bedbf2b8b4519a0d825111df77cf421fea046682db617e501
StrutsEntrypointFinder.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-a1a98024db7262b03c37fc4958ce03922d038ca6013a4cc8559aa0779d874cbd
AbstractEntrypointFinder.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-9c1ce8a74bcb471d853cb2e9669da0c43ee32978bf44402704e83634928f33b4
BuildProject.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-c83bb6d04ee1392139c4551a60bb821c3071f4650bdc568a0ab7591fdcc26883
CodeAnalyzerIntegrationTest.java https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-719d480ab97e2b88e62638d3abbfd0f5cf99513726415468b9e39271969b61a9
.gitignore https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-e7b135b567d95e87dad2824642bb52185bbbc477e669d6c4559c04606689d4be
gradle.propertieshttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-3d103fc7c312a3e136f88e81cef592424b8af2464c468116545c4d22d6edcf19
View file https://github.com/codellm-devkit/codeanalyzer-java/blob/4a4108d8107ec2a7e9fc4e673623d36ca74bfb28/gradle.properties
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/{{ revealButtonHref }}
src/main/java/com/ibm/cldk/SymbolTable.javahttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
View file https://github.com/codellm-devkit/codeanalyzer-java/blob/4a4108d8107ec2a7e9fc4e673623d36ca74bfb28/src/main/java/com/ibm/cldk/SymbolTable.java
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/{{ revealButtonHref }}
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-eb530dc3fb8e2fba1a9d823b6ea72821eb6affefa2271ae8eca5a4d13715d6d3
src/main/java/com/ibm/cldk/javaee/EntrypointsFinderFactory.javahttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-b6a0f1aa1ed5cd7c4b01b27a7f77d85266a29391f40fac37d3931c38efb6f438
View file https://github.com/codellm-devkit/codeanalyzer-java/blob/4a4108d8107ec2a7e9fc4e673623d36ca74bfb28/src/main/java/com/ibm/cldk/javaee/EntrypointsFinderFactory.java
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/{{ revealButtonHref }}
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-b6a0f1aa1ed5cd7c4b01b27a7f77d85266a29391f40fac37d3931c38efb6f438
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-b6a0f1aa1ed5cd7c4b01b27a7f77d85266a29391f40fac37d3931c38efb6f438
src/main/java/com/ibm/cldk/javaee/camel/CamelEntrypointFinder.javahttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files#diff-293443f2f4bd7ceb17c14f9928d432bcf01ec996cf12acc58c56dfa16141cea9
View file https://github.com/codellm-devkit/codeanalyzer-java/blob/4a4108d8107ec2a7e9fc4e673623d36ca74bfb28/src/main/java/com/ibm/cldk/javaee/camel/CamelEntrypointFinder.java
Open in desktop https://desktop.github.com
https://github.co/hiddenchars
https://github.com/codellm-devkit/codeanalyzer-java/pull/133/{{ revealButtonHref }}
Please reload this pagehttps://github.com/codellm-devkit/codeanalyzer-java/pull/133/files
https://github.com
Termshttps://docs.github.com/site-policy/github-terms/github-terms-of-service
Privacyhttps://docs.github.com/site-policy/privacy-policies/github-privacy-statement
Securityhttps://github.com/security
Statushttps://www.githubstatus.com/
Communityhttps://github.community/
Docshttps://docs.github.com/
Contacthttps://support.github.com?tags=dotcom-footer

Viewport: width=device-width


URLs of crawlers that visited me.