Commit 2aadd49
authored
feat(IDE-1701): settings page auth flow — bridge persist and forward apiUrl (#366)
* feat: inject __ideExecuteCommand__ bridge in settings page and bump protocol version to 25 [IDE-1701]
Replace __ideLogin__/__ideLogout__ BrowserFunctions with a generic
__ideExecuteCommand__ bridge that dispatches any LS command with
callback support. Bump REQUIRED_LS_PROTOCOL_VERSION to 25.
* refactor: extract ExecuteCommandBridge to shared class for browser reuse [IDE-1701]
Move the __ideExecuteCommandBridge__ BrowserFunction and JS wrapper injection
into a standalone ExecuteCommandBridge class. HTMLSettingsPreferencePage
delegates to ExecuteCommandBridge.install(browser), enabling any future
SWT Browser panel (e.g. tree view) to reuse the same bridge.
* feat(IDE-1701): save login args from settings page and remove persist flag
- Remove persist field from HasAuthenticatedParam — always saves token and apiUrl
- Restore original hasAuthenticated flow: always stores endpoint + token, calls
configurationUpdater.configurationChanged(), triggers scan when conditions met
- Keep notifyAuthTokenChanged(token, apiUrl) with apiUrl param — settings page
webview always shows current token after auth
- Add bridge persist in ExecuteCommandBridge.registerBridgeFunction: when snyk.login
called with 3+ args, save authMethod/endpoint/insecure to Preferences directly
(no configurationChanged() → no didChangeConfiguration to LS)
- Remove setPersist() calls and persist-related tests from SnykExtendedLanguageClientTest
- Add saveLoginArgs() tests to ExecuteCommandBridgeTest covering auth method mapping,
endpoint, and insecure saving
* feat(IDE-1701): forward apiUrl in notifyAuthTokenChanged for settings page browser
Pass apiUrl alongside token when calling window.setAuthToken in the browser
so the settings page can update both the token and apiUrl fields after auth.
* feat(IDE-1701): apply auth bridge pattern to both settings pages
- Add singleton + notifyAuthTokenChanged to native PreferencesPage so the
SWT token field is updated live when hasAuthenticated fires, not just the
HTML webview
- Reorder hasAuthenticated() to update UIs before persisting to storage,
avoiding race conditions where a settings-changed event re-reads stale values
- Escape token and apiUrl before JS interpolation in notifyAuthTokenChanged
to guard against single-quote injection
- Fix dispose() identity check (== instead of .equals()) in both settings pages
* fix: add updateToken method to TokenFieldEditor and fix Java 21 Mockito compatibility
- Add public updateToken() method to TokenFieldEditor to expose
setStringValue() from outside the class (setStringValue is protected
in StringFieldEditor)
- Fix test failures on Java 21 by adding -XX:+EnableDynamicAgentLoading
to tycho-surefire-plugin argLine, required for mockito-inline 4.5.1
to do byte-buddy instrumentation
* fix: lint
* fix: remove stale PMD.CompareObjectsWithEquals suppression
* fix: catch specific JsonProcessingException instead of generic Exception in ExecuteCommandBridge
* security: restrict webview executeCommand bridge to snyk.* namespace
Prevents XSS-to-arbitrary-command escalation by rejecting any command
not prefixed with "snyk." before it reaches the Language Server.
* refactor: extract JS string escaping into reusable utility method
Pull escapeForJsString() into ExecuteCommandBridge and replace inline
escaping in both ExecuteCommandBridge and HTMLSettingsPreferencePage.
Add explicit test for default (oauth) auth method fallback.1 parent 348544b commit 2aadd49
File tree
10 files changed
+382
-56
lines changed- plugin/src/main/java/io/snyk
- eclipse/plugin
- html
- preferences
- views/snyktoolview
- languageserver
- download
- protocolextension
- tests
- src/test/java/io/snyk/eclipse/plugin/html
10 files changed
+382
-56
lines changedLines changed: 10 additions & 8 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
1 | 1 | | |
2 | 2 | | |
3 | | - | |
4 | | - | |
5 | | - | |
6 | | - | |
7 | | - | |
8 | | - | |
9 | | - | |
10 | | - | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
11 | 13 | | |
Lines changed: 189 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
| 1 | + | |
| 2 | + | |
| 3 | + | |
| 4 | + | |
| 5 | + | |
| 6 | + | |
| 7 | + | |
| 8 | + | |
| 9 | + | |
| 10 | + | |
| 11 | + | |
| 12 | + | |
| 13 | + | |
| 14 | + | |
| 15 | + | |
| 16 | + | |
| 17 | + | |
| 18 | + | |
| 19 | + | |
| 20 | + | |
| 21 | + | |
| 22 | + | |
| 23 | + | |
| 24 | + | |
| 25 | + | |
| 26 | + | |
| 27 | + | |
| 28 | + | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
| 33 | + | |
| 34 | + | |
| 35 | + | |
| 36 | + | |
| 37 | + | |
| 38 | + | |
| 39 | + | |
| 40 | + | |
| 41 | + | |
| 42 | + | |
| 43 | + | |
| 44 | + | |
| 45 | + | |
| 46 | + | |
| 47 | + | |
| 48 | + | |
| 49 | + | |
| 50 | + | |
| 51 | + | |
| 52 | + | |
| 53 | + | |
| 54 | + | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
| 83 | + | |
| 84 | + | |
| 85 | + | |
| 86 | + | |
| 87 | + | |
| 88 | + | |
| 89 | + | |
| 90 | + | |
| 91 | + | |
| 92 | + | |
| 93 | + | |
| 94 | + | |
| 95 | + | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
| 106 | + | |
| 107 | + | |
| 108 | + | |
| 109 | + | |
| 110 | + | |
| 111 | + | |
| 112 | + | |
| 113 | + | |
| 114 | + | |
| 115 | + | |
| 116 | + | |
| 117 | + | |
| 118 | + | |
| 119 | + | |
| 120 | + | |
| 121 | + | |
| 122 | + | |
| 123 | + | |
| 124 | + | |
| 125 | + | |
| 126 | + | |
| 127 | + | |
| 128 | + | |
| 129 | + | |
| 130 | + | |
| 131 | + | |
| 132 | + | |
| 133 | + | |
| 134 | + | |
| 135 | + | |
| 136 | + | |
| 137 | + | |
| 138 | + | |
| 139 | + | |
| 140 | + | |
| 141 | + | |
| 142 | + | |
| 143 | + | |
| 144 | + | |
| 145 | + | |
| 146 | + | |
| 147 | + | |
| 148 | + | |
| 149 | + | |
| 150 | + | |
| 151 | + | |
| 152 | + | |
| 153 | + | |
| 154 | + | |
| 155 | + | |
| 156 | + | |
| 157 | + | |
| 158 | + | |
| 159 | + | |
| 160 | + | |
| 161 | + | |
| 162 | + | |
| 163 | + | |
| 164 | + | |
| 165 | + | |
| 166 | + | |
| 167 | + | |
| 168 | + | |
| 169 | + | |
| 170 | + | |
| 171 | + | |
| 172 | + | |
| 173 | + | |
| 174 | + | |
| 175 | + | |
| 176 | + | |
| 177 | + | |
| 178 | + | |
| 179 | + | |
| 180 | + | |
| 181 | + | |
| 182 | + | |
| 183 | + | |
| 184 | + | |
| 185 | + | |
| 186 | + | |
| 187 | + | |
| 188 | + | |
| 189 | + | |
Lines changed: 9 additions & 41 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
3 | 3 | | |
4 | 4 | | |
5 | 5 | | |
| 6 | + | |
6 | 7 | | |
7 | 8 | | |
8 | 9 | | |
| |||
37 | 38 | | |
38 | 39 | | |
39 | 40 | | |
40 | | - | |
41 | 41 | | |
42 | 42 | | |
43 | 43 | | |
| |||
75 | 75 | | |
76 | 76 | | |
77 | 77 | | |
78 | | - | |
79 | | - | |
80 | | - | |
81 | | - | |
82 | | - | |
83 | | - | |
84 | | - | |
85 | | - | |
86 | | - | |
87 | | - | |
88 | | - | |
89 | | - | |
90 | | - | |
91 | | - | |
92 | | - | |
93 | | - | |
94 | | - | |
95 | | - | |
96 | | - | |
97 | | - | |
98 | | - | |
99 | | - | |
100 | | - | |
101 | | - | |
102 | | - | |
103 | | - | |
104 | | - | |
105 | | - | |
106 | | - | |
107 | | - | |
108 | | - | |
109 | | - | |
110 | | - | |
111 | | - | |
112 | | - | |
113 | | - | |
114 | | - | |
| 78 | + | |
115 | 79 | | |
116 | 80 | | |
117 | 81 | | |
| |||
389 | 353 | | |
390 | 354 | | |
391 | 355 | | |
392 | | - | |
| 356 | + | |
393 | 357 | | |
394 | 358 | | |
395 | 359 | | |
396 | 360 | | |
397 | 361 | | |
398 | | - | |
| 362 | + | |
399 | 363 | | |
400 | 364 | | |
401 | 365 | | |
402 | 366 | | |
403 | 367 | | |
404 | 368 | | |
405 | 369 | | |
| 370 | + | |
| 371 | + | |
406 | 372 | | |
407 | 373 | | |
408 | | - | |
| 374 | + | |
| 375 | + | |
| 376 | + | |
409 | 377 | | |
410 | 378 | | |
411 | 379 | | |
| |||
Lines changed: 23 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
| 29 | + | |
| 30 | + | |
29 | 31 | | |
30 | 32 | | |
31 | 33 | | |
| |||
34 | 36 | | |
35 | 37 | | |
36 | 38 | | |
| 39 | + | |
37 | 40 | | |
38 | 41 | | |
| 42 | + | |
39 | 43 | | |
40 | 44 | | |
41 | 45 | | |
| |||
197 | 201 | | |
198 | 202 | | |
199 | 203 | | |
| 204 | + | |
| 205 | + | |
| 206 | + | |
| 207 | + | |
| 208 | + | |
| 209 | + | |
| 210 | + | |
| 211 | + | |
| 212 | + | |
| 213 | + | |
| 214 | + | |
| 215 | + | |
| 216 | + | |
| 217 | + | |
| 218 | + | |
| 219 | + | |
| 220 | + | |
| 221 | + | |
| 222 | + | |
200 | 223 | | |
201 | 224 | | |
202 | 225 | | |
| |||
Lines changed: 4 additions & 0 deletions
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
26 | 26 | | |
27 | 27 | | |
28 | 28 | | |
| 29 | + | |
| 30 | + | |
| 31 | + | |
| 32 | + | |
29 | 33 | | |
30 | 34 | | |
31 | 35 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
353 | 353 | | |
354 | 354 | | |
355 | 355 | | |
356 | | - | |
| 356 | + | |
357 | 357 | | |
358 | 358 | | |
359 | 359 | | |
| |||
Lines changed: 1 addition & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
8 | 8 | | |
9 | 9 | | |
10 | 10 | | |
11 | | - | |
| 11 | + | |
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
| |||
0 commit comments