class Analyzer::Javascript::Sveltekit

Overview

SvelteKit is a filesystem-routed framework. Routes live under src/routes/ and the URL is derived from the directory layout:

src/routes/+page.svelte → GET / src/routes/about/+page.svelte → GET /about src/routes/users/[id]/+page.svelte → GET /users/{id} src/routes/users/+server.ts → exports drive verbs src/routes/[...slug]/+page.svelte → GET /{slug} src/routes/(group)/foo/+page.svelte → GET /foo (group hidden)

Two file kinds matter:

Out of scope for this first cut: per-handler request-helper scanning (SvelteKit endpoints take { request, params, cookies, url } — accurate read tracking needs cross-call value flow), rest parameters with matchers ([id=integer]), and (group)-with-+layout.server.ts cookie-protected endpoints (the route still fires; auth tagging is the tagger's job).

Defined in:

analyzer/analyzers/javascript/sveltekit.cr

Constant Summary

API_EXTENSIONS = [".ts", ".js", ".mjs"]
EXPORT_BRACE_RES = HTTP_METHODS.map do |m| {m, /export\s+\{\s*[^}]*\b#{m}\b[^}]*\}/} end.to_h
EXPORT_CONST_RES = HTTP_METHODS.map do |m| {m, /export\s+(?:const|let|var)\s+#{m}\b\s*(?::[^=]+)?=/} end.to_h
EXPORT_FUNCTION_RES = HTTP_METHODS.map do |m| {m, /export\s+(?:async\s+)?function\s+#{m}\b/} end.to_h

Compiled once per verb — interpolated regex literals would otherwise be rebuilt (full PCRE2 compile) for every method on every file.

EXTENSIONS = PAGE_EXTENSIONS + API_EXTENSIONS
FALLBACK_API_METHODS = ["GET", "POST", "PUT", "DELETE", "PATCH"]
FORM_ACTIONS_DECL_RE = /export\s+(?:const|let|var|(?:async\s+)?function)\s+actions\b/
HTTP_METHODS = ["GET", "POST", "PUT", "DELETE", "PATCH", "HEAD", "OPTIONS"]
PAGE_EXTENSIONS = [".svelte", ".svx", ".md"]
PARAM_GROUP_RE = /\[+(?:\.{3})?(\w+)(?:=\w+)?\]+/

SvelteKit param group inside a route segment. Replaced in place so one segment can hold static text around it (foo-[id], @[user]) and so every form normalizes to {name}: [id] [id=int] [...rest] [[opt]] [[opt=int]] [[...rest]]

Instance Method Summary

Instance methods inherited from class Analyzer

analyze analyze, base_path : String base_path, base_paths : Array(String) base_paths, callees_needed? : Bool callees_needed?, logger : NoirLogger logger, parallel_analyze(files : Array(String), &block : String -> Nil) parallel_analyze, read_file_content(path : String) : String read_file_content, result : Array(Endpoint) result, url : String url

Constructor methods inherited from class Analyzer

new(options : Hash(String, YAML::Any)) new

Macros inherited from class Analyzer

define_getter_methods(names) define_getter_methods

Instance methods inherited from module FileHelper

all_files : Array(String) all_files, get_files_by_extension(extension : String) : Array(String) get_files_by_extension, get_files_by_prefix(prefix : String) : Array(String) get_files_by_prefix, get_files_by_prefix_and_extension(prefix : String, extension : String) : Array(String) get_files_by_prefix_and_extension, get_public_dir_files(base_path : String, folder : String) : Array(String) get_public_dir_files, get_public_files(base_path : String, anchors : Array(String) = ["shard.yml", "Gemfile"]) : Array(String) get_public_files

Instance Method Detail

def analyze #

[View source]