@juspay/shooter 1.8.0 → 1.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (125) hide show
  1. package/.claude/hooks/notifier.cjs +490 -136
  2. package/bin/shooter.cjs +50 -14
  3. package/build/client/_app/immutable/chunks/3EfvnCrr.js +1 -0
  4. package/build/client/_app/immutable/chunks/3EfvnCrr.js.br +0 -0
  5. package/build/client/_app/immutable/chunks/3EfvnCrr.js.gz +0 -0
  6. package/build/client/_app/immutable/chunks/{B6b4w6vf.js → DaomQix1.js} +1 -1
  7. package/build/client/_app/immutable/chunks/DaomQix1.js.br +0 -0
  8. package/build/client/_app/immutable/chunks/{B6b4w6vf.js.gz → DaomQix1.js.gz} +0 -0
  9. package/build/client/_app/immutable/chunks/Dfn9ME_a.js +3 -0
  10. package/build/client/_app/immutable/chunks/Dfn9ME_a.js.br +0 -0
  11. package/build/client/_app/immutable/chunks/Dfn9ME_a.js.gz +0 -0
  12. package/build/client/_app/immutable/chunks/{C7SeOWDG.js → DuaEmHXZ.js} +1 -1
  13. package/build/client/_app/immutable/chunks/DuaEmHXZ.js.br +0 -0
  14. package/build/client/_app/immutable/chunks/DuaEmHXZ.js.gz +0 -0
  15. package/build/client/_app/immutable/entry/{app.CP7226A7.js → app.C23A4_LP.js} +2 -2
  16. package/build/client/_app/immutable/entry/app.C23A4_LP.js.br +0 -0
  17. package/build/client/_app/immutable/entry/app.C23A4_LP.js.gz +0 -0
  18. package/build/client/_app/immutable/entry/start.Dzoby1AT.js +1 -0
  19. package/build/client/_app/immutable/entry/start.Dzoby1AT.js.br +2 -0
  20. package/build/client/_app/immutable/entry/start.Dzoby1AT.js.gz +0 -0
  21. package/build/client/_app/immutable/nodes/{0.DwU44ZAj.js → 0.BgwfOZTV.js} +1 -1
  22. package/build/client/_app/immutable/nodes/0.BgwfOZTV.js.br +0 -0
  23. package/build/client/_app/immutable/nodes/0.BgwfOZTV.js.gz +0 -0
  24. package/build/client/_app/immutable/nodes/{1.CChG-n6d.js → 1.DunuP0ec.js} +1 -1
  25. package/build/client/_app/immutable/nodes/1.DunuP0ec.js.br +0 -0
  26. package/build/client/_app/immutable/nodes/1.DunuP0ec.js.gz +0 -0
  27. package/build/client/_app/immutable/nodes/{2.CzexDbwp.js → 2.dWYUfDXP.js} +2 -2
  28. package/build/client/_app/immutable/nodes/2.dWYUfDXP.js.br +0 -0
  29. package/build/client/_app/immutable/nodes/2.dWYUfDXP.js.gz +0 -0
  30. package/build/client/_app/immutable/nodes/{3.DC3WghxB.js → 3.rBWJMWFr.js} +3 -3
  31. package/build/client/_app/immutable/nodes/3.rBWJMWFr.js.br +0 -0
  32. package/build/client/_app/immutable/nodes/3.rBWJMWFr.js.gz +0 -0
  33. package/build/client/_app/immutable/nodes/5.BN2SM61w.js +1 -0
  34. package/build/client/_app/immutable/nodes/5.BN2SM61w.js.br +0 -0
  35. package/build/client/_app/immutable/nodes/5.BN2SM61w.js.gz +0 -0
  36. package/build/client/_app/immutable/nodes/{6.C4aXlZQd.js → 6.DDMVIiVk.js} +1 -1
  37. package/build/client/_app/immutable/nodes/6.DDMVIiVk.js.br +0 -0
  38. package/build/client/_app/immutable/nodes/6.DDMVIiVk.js.gz +0 -0
  39. package/build/client/_app/immutable/nodes/{7.DfniCleW.js → 7.DijtBcpt.js} +1 -1
  40. package/build/client/_app/immutable/nodes/7.DijtBcpt.js.br +0 -0
  41. package/build/client/_app/immutable/nodes/7.DijtBcpt.js.gz +0 -0
  42. package/build/client/_app/immutable/nodes/{8.D4AzZWcq.js → 8.Y_8EIs9h.js} +1 -1
  43. package/build/client/_app/immutable/nodes/8.Y_8EIs9h.js.br +0 -0
  44. package/build/client/_app/immutable/nodes/8.Y_8EIs9h.js.gz +0 -0
  45. package/build/client/_app/immutable/nodes/{9.gV8oJWv_.js → 9.BoJIHqox.js} +1 -1
  46. package/build/client/_app/immutable/nodes/9.BoJIHqox.js.br +0 -0
  47. package/build/client/_app/immutable/nodes/9.BoJIHqox.js.gz +0 -0
  48. package/build/client/_app/version.json +1 -1
  49. package/build/client/_app/version.json.br +0 -0
  50. package/build/client/_app/version.json.gz +0 -0
  51. package/build/server/chunks/{0-XyVDlEyN.js → 0-0CZFKlE-.js} +2 -2
  52. package/build/server/chunks/{0-XyVDlEyN.js.map → 0-0CZFKlE-.js.map} +1 -1
  53. package/build/server/chunks/{1-C3vZx9QL.js → 1-DLzdA7q9.js} +2 -2
  54. package/build/server/chunks/{1-C3vZx9QL.js.map → 1-DLzdA7q9.js.map} +1 -1
  55. package/build/server/chunks/{2-LWO3Q9-s.js → 2-DssNCbHE.js} +2 -2
  56. package/build/server/chunks/{2-LWO3Q9-s.js.map → 2-DssNCbHE.js.map} +1 -1
  57. package/build/server/chunks/{3-3WzO52IA.js → 3-xYdrp1JC.js} +2 -2
  58. package/build/server/chunks/{3-3WzO52IA.js.map → 3-xYdrp1JC.js.map} +1 -1
  59. package/build/server/chunks/{5-Bj49x3to.js → 5-DRhcUdp_.js} +2 -2
  60. package/build/server/chunks/{5-Bj49x3to.js.map → 5-DRhcUdp_.js.map} +1 -1
  61. package/build/server/chunks/{6-DjPIWYcj.js → 6-DpmjM0Zz.js} +2 -2
  62. package/build/server/chunks/{6-DjPIWYcj.js.map → 6-DpmjM0Zz.js.map} +1 -1
  63. package/build/server/chunks/{7-DF5FUXhP.js → 7-fZr6V0jx.js} +2 -2
  64. package/build/server/chunks/{7-DF5FUXhP.js.map → 7-fZr6V0jx.js.map} +1 -1
  65. package/build/server/chunks/{8-CejJgM0l.js → 8-C92Y2pM_.js} +2 -2
  66. package/build/server/chunks/{8-CejJgM0l.js.map → 8-C92Y2pM_.js.map} +1 -1
  67. package/build/server/chunks/{9-D1YMozmH.js → 9-xiLWXynw.js} +2 -2
  68. package/build/server/chunks/{9-D1YMozmH.js.map → 9-xiLWXynw.js.map} +1 -1
  69. package/build/server/chunks/{_server.ts-G8OeADGj.js → _server.ts-BMcbwZ2r.js} +8 -3
  70. package/build/server/chunks/_server.ts-BMcbwZ2r.js.map +1 -0
  71. package/build/server/chunks/{_server.ts-A9_tRR-K.js → _server.ts-D-vgx5UZ.js} +5 -3
  72. package/build/server/chunks/{_server.ts-A9_tRR-K.js.map → _server.ts-D-vgx5UZ.js.map} +1 -1
  73. package/build/server/chunks/library-apns-Dl3iRE2h.js +157 -0
  74. package/build/server/chunks/library-apns-Dl3iRE2h.js.map +1 -0
  75. package/build/server/index.js +1 -1
  76. package/build/server/index.js.map +1 -1
  77. package/build/server/manifest.js +12 -12
  78. package/build/server/manifest.js.map +1 -1
  79. package/package.json +1 -2
  80. package/server.ts +55 -3
  81. package/src/lib/modules/client/activity/summarizer.ts +1 -1
  82. package/src/lib/modules/client/dashboard/summarizer.ts +1 -2
  83. package/src/lib/modules/client/neurolink/cdn.ts +6 -0
  84. package/src/lib/modules/client/terminal/LaunchSheet.svelte +5 -12
  85. package/src/lib/modules/server/apn/library-apns.ts +138 -77
  86. package/src/lib/modules/server/fcm/fcm-service.ts +1 -0
  87. package/src/lib/types/apn.ts +11 -0
  88. package/src/routes/api/notify/+server.ts +2 -0
  89. package/src/routes/neurolink/+page.svelte +4 -6
  90. package/build/client/_app/immutable/chunks/B6b4w6vf.js.br +0 -0
  91. package/build/client/_app/immutable/chunks/BEa4nlMF.js +0 -3
  92. package/build/client/_app/immutable/chunks/BEa4nlMF.js.br +0 -0
  93. package/build/client/_app/immutable/chunks/BEa4nlMF.js.gz +0 -0
  94. package/build/client/_app/immutable/chunks/C7SeOWDG.js.br +0 -0
  95. package/build/client/_app/immutable/chunks/C7SeOWDG.js.gz +0 -0
  96. package/build/client/_app/immutable/chunks/DQM017d5.js +0 -1
  97. package/build/client/_app/immutable/chunks/DQM017d5.js.br +0 -0
  98. package/build/client/_app/immutable/chunks/DQM017d5.js.gz +0 -0
  99. package/build/client/_app/immutable/entry/app.CP7226A7.js.br +0 -0
  100. package/build/client/_app/immutable/entry/app.CP7226A7.js.gz +0 -0
  101. package/build/client/_app/immutable/entry/start.mGPvkOah.js +0 -1
  102. package/build/client/_app/immutable/entry/start.mGPvkOah.js.br +0 -2
  103. package/build/client/_app/immutable/entry/start.mGPvkOah.js.gz +0 -0
  104. package/build/client/_app/immutable/nodes/0.DwU44ZAj.js.br +0 -0
  105. package/build/client/_app/immutable/nodes/0.DwU44ZAj.js.gz +0 -0
  106. package/build/client/_app/immutable/nodes/1.CChG-n6d.js.br +0 -0
  107. package/build/client/_app/immutable/nodes/1.CChG-n6d.js.gz +0 -0
  108. package/build/client/_app/immutable/nodes/2.CzexDbwp.js.br +0 -0
  109. package/build/client/_app/immutable/nodes/2.CzexDbwp.js.gz +0 -0
  110. package/build/client/_app/immutable/nodes/3.DC3WghxB.js.br +0 -0
  111. package/build/client/_app/immutable/nodes/3.DC3WghxB.js.gz +0 -0
  112. package/build/client/_app/immutable/nodes/5.DRvLQ5NR.js +0 -1
  113. package/build/client/_app/immutable/nodes/5.DRvLQ5NR.js.br +0 -0
  114. package/build/client/_app/immutable/nodes/5.DRvLQ5NR.js.gz +0 -0
  115. package/build/client/_app/immutable/nodes/6.C4aXlZQd.js.br +0 -0
  116. package/build/client/_app/immutable/nodes/6.C4aXlZQd.js.gz +0 -0
  117. package/build/client/_app/immutable/nodes/7.DfniCleW.js.br +0 -0
  118. package/build/client/_app/immutable/nodes/7.DfniCleW.js.gz +0 -0
  119. package/build/client/_app/immutable/nodes/8.D4AzZWcq.js.br +0 -0
  120. package/build/client/_app/immutable/nodes/8.D4AzZWcq.js.gz +0 -0
  121. package/build/client/_app/immutable/nodes/9.gV8oJWv_.js.br +0 -0
  122. package/build/client/_app/immutable/nodes/9.gV8oJWv_.js.gz +0 -0
  123. package/build/server/chunks/_server.ts-G8OeADGj.js.map +0 -1
  124. package/build/server/chunks/library-apns-Cf-E-DhM.js +0 -107
  125. package/build/server/chunks/library-apns-Cf-E-DhM.js.map +0 -1
@@ -10,18 +10,18 @@ return {
10
10
  assets: new Set(["app-icon.png","apple-touch-icon.png","favicon.png","favicon.svg","manifest.json","pwa-192x192.png","pwa-512x512.png"]),
11
11
  mimeTypes: {".png":"image/png",".svg":"image/svg+xml",".json":"application/json"},
12
12
  _: {
13
- client: {start:"_app/immutable/entry/start.mGPvkOah.js",app:"_app/immutable/entry/app.CP7226A7.js",imports:["_app/immutable/entry/start.mGPvkOah.js","_app/immutable/chunks/BEa4nlMF.js","_app/immutable/chunks/Ce0VRwE1.js","_app/immutable/entry/app.CP7226A7.js","_app/immutable/chunks/PPVm8Dsz.js","_app/immutable/chunks/Ce0VRwE1.js","_app/immutable/chunks/3MMtouT7.js"],stylesheets:[],fonts:[],uses_env_dynamic_public:false},
13
+ client: {start:"_app/immutable/entry/start.Dzoby1AT.js",app:"_app/immutable/entry/app.C23A4_LP.js",imports:["_app/immutable/entry/start.Dzoby1AT.js","_app/immutable/chunks/Dfn9ME_a.js","_app/immutable/chunks/Ce0VRwE1.js","_app/immutable/entry/app.C23A4_LP.js","_app/immutable/chunks/PPVm8Dsz.js","_app/immutable/chunks/Ce0VRwE1.js","_app/immutable/chunks/3MMtouT7.js"],stylesheets:[],fonts:[],uses_env_dynamic_public:false},
14
14
  nodes: [
15
- __memo(() => import('./chunks/0-XyVDlEyN.js')),
16
- __memo(() => import('./chunks/1-C3vZx9QL.js')),
17
- __memo(() => import('./chunks/2-LWO3Q9-s.js')),
18
- __memo(() => import('./chunks/3-3WzO52IA.js')),
15
+ __memo(() => import('./chunks/0-0CZFKlE-.js')),
16
+ __memo(() => import('./chunks/1-DLzdA7q9.js')),
17
+ __memo(() => import('./chunks/2-DssNCbHE.js')),
18
+ __memo(() => import('./chunks/3-xYdrp1JC.js')),
19
19
  __memo(() => import('./chunks/4-DXZnoGK3.js')),
20
- __memo(() => import('./chunks/5-Bj49x3to.js')),
21
- __memo(() => import('./chunks/6-DjPIWYcj.js')),
22
- __memo(() => import('./chunks/7-DF5FUXhP.js')),
23
- __memo(() => import('./chunks/8-CejJgM0l.js')),
24
- __memo(() => import('./chunks/9-D1YMozmH.js'))
20
+ __memo(() => import('./chunks/5-DRhcUdp_.js')),
21
+ __memo(() => import('./chunks/6-DpmjM0Zz.js')),
22
+ __memo(() => import('./chunks/7-fZr6V0jx.js')),
23
+ __memo(() => import('./chunks/8-C92Y2pM_.js')),
24
+ __memo(() => import('./chunks/9-xiLWXynw.js'))
25
25
  ],
26
26
  remotes: {
27
27
 
@@ -46,7 +46,7 @@ return {
46
46
  pattern: /^\/api\/debug\/?$/,
47
47
  params: [],
48
48
  page: null,
49
- endpoint: __memo(() => import('./chunks/_server.ts-A9_tRR-K.js'))
49
+ endpoint: __memo(() => import('./chunks/_server.ts-D-vgx5UZ.js'))
50
50
  },
51
51
  {
52
52
  id: "/api/device-token",
@@ -74,7 +74,7 @@ return {
74
74
  pattern: /^\/api\/notify\/?$/,
75
75
  params: [],
76
76
  page: null,
77
- endpoint: __memo(() => import('./chunks/_server.ts-G8OeADGj.js'))
77
+ endpoint: __memo(() => import('./chunks/_server.ts-BMcbwZ2r.js'))
78
78
  },
79
79
  {
80
80
  id: "/api/qr-config",
@@ -1 +1 @@
1
- {"version":3,"file":"manifest.js","sources":["../../.svelte-kit/adapter-node/manifest.js"],"sourcesContent":["export const manifest = (() => {\nfunction __memo(fn) {\n\tlet value;\n\treturn () => value ??= (value = fn());\n}\n\nreturn {\n\tappDir: \"_app\",\n\tappPath: \"_app\",\n\tassets: new Set([\"app-icon.png\",\"apple-touch-icon.png\",\"favicon.png\",\"favicon.svg\",\"manifest.json\",\"pwa-192x192.png\",\"pwa-512x512.png\"]),\n\tmimeTypes: {\".png\":\"image/png\",\".svg\":\"image/svg+xml\",\".json\":\"application/json\"},\n\t_: {\n\t\tclient: {start:\"_app/immutable/entry/start.mGPvkOah.js\",app:\"_app/immutable/entry/app.CP7226A7.js\",imports:[\"_app/immutable/entry/start.mGPvkOah.js\",\"_app/immutable/chunks/BEa4nlMF.js\",\"_app/immutable/chunks/Ce0VRwE1.js\",\"_app/immutable/entry/app.CP7226A7.js\",\"_app/immutable/chunks/PPVm8Dsz.js\",\"_app/immutable/chunks/Ce0VRwE1.js\",\"_app/immutable/chunks/3MMtouT7.js\"],stylesheets:[],fonts:[],uses_env_dynamic_public:false},\n\t\tnodes: [\n\t\t\t__memo(() => import('./nodes/0.js')),\n\t\t\t__memo(() => import('./nodes/1.js')),\n\t\t\t__memo(() => import('./nodes/2.js')),\n\t\t\t__memo(() => import('./nodes/3.js')),\n\t\t\t__memo(() => import('./nodes/4.js')),\n\t\t\t__memo(() => import('./nodes/5.js')),\n\t\t\t__memo(() => import('./nodes/6.js')),\n\t\t\t__memo(() => import('./nodes/7.js')),\n\t\t\t__memo(() => import('./nodes/8.js')),\n\t\t\t__memo(() => import('./nodes/9.js'))\n\t\t],\n\t\tremotes: {\n\t\t\t\n\t\t},\n\t\troutes: [\n\t\t\t{\n\t\t\t\tid: \"/\",\n\t\t\t\tpattern: /^\\/$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 2 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/activity\",\n\t\t\t\tpattern: /^\\/activity\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 3 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/debug\",\n\t\t\t\tpattern: /^\\/api\\/debug\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/debug/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/device-token\",\n\t\t\t\tpattern: /^\\/api\\/device-token\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/device-token/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/health\",\n\t\t\t\tpattern: /^\\/api\\/health\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/health/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/neurolink-proxy\",\n\t\t\t\tpattern: /^\\/api\\/neurolink-proxy\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/neurolink-proxy/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/notify\",\n\t\t\t\tpattern: /^\\/api\\/notify\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/notify/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/qr-config\",\n\t\t\t\tpattern: /^\\/api\\/qr-config\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/qr-config/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/response\",\n\t\t\t\tpattern: /^\\/api\\/response\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/response/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/sessions\",\n\t\t\t\tpattern: /^\\/api\\/sessions\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/sessions/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/sessions/connect\",\n\t\t\t\tpattern: /^\\/api\\/sessions\\/connect\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/sessions/connect/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/sessions/detect\",\n\t\t\t\tpattern: /^\\/api\\/sessions\\/detect\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/sessions/detect/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals/[id]\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/([^/]+?)\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_id_/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals/[id]/paste-image\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/([^/]+?)\\/paste-image\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_id_/paste-image/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals/[id]/resize\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/([^/]+?)\\/resize\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_id_/resize/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/webhook\",\n\t\t\t\tpattern: /^\\/api\\/webhook\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/webhook/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/ws-status\",\n\t\t\t\tpattern: /^\\/api\\/ws-status\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/ws-status/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/ws-ticket\",\n\t\t\t\tpattern: /^\\/api\\/ws-ticket\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/ws-ticket/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/config\",\n\t\t\t\tpattern: /^\\/config\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 4 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/neurolink\",\n\t\t\t\tpattern: /^\\/neurolink\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 5 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/project\",\n\t\t\t\tpattern: /^\\/project\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 6 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/session/[id]\",\n\t\t\t\tpattern: /^\\/session\\/([^/]+?)\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 7 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/terminals\",\n\t\t\t\tpattern: /^\\/terminals\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 8 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/terminals/[id]\",\n\t\t\t\tpattern: /^\\/terminals\\/([^/]+?)\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 9 },\n\t\t\t\tendpoint: null\n\t\t\t}\n\t\t],\n\t\tprerendered_routes: new Set([]),\n\t\tmatchers: async () => {\n\t\t\t\n\t\t\treturn { };\n\t\t},\n\t\tserver_assets: {}\n\t}\n}\n})();\n\nexport const prerendered = new Set([]);\n\nexport const base = \"\";"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"manifest.js","sources":["../../.svelte-kit/adapter-node/manifest.js"],"sourcesContent":["export const manifest = (() => {\nfunction __memo(fn) {\n\tlet value;\n\treturn () => value ??= (value = fn());\n}\n\nreturn {\n\tappDir: \"_app\",\n\tappPath: \"_app\",\n\tassets: new Set([\"app-icon.png\",\"apple-touch-icon.png\",\"favicon.png\",\"favicon.svg\",\"manifest.json\",\"pwa-192x192.png\",\"pwa-512x512.png\"]),\n\tmimeTypes: {\".png\":\"image/png\",\".svg\":\"image/svg+xml\",\".json\":\"application/json\"},\n\t_: {\n\t\tclient: {start:\"_app/immutable/entry/start.Dzoby1AT.js\",app:\"_app/immutable/entry/app.C23A4_LP.js\",imports:[\"_app/immutable/entry/start.Dzoby1AT.js\",\"_app/immutable/chunks/Dfn9ME_a.js\",\"_app/immutable/chunks/Ce0VRwE1.js\",\"_app/immutable/entry/app.C23A4_LP.js\",\"_app/immutable/chunks/PPVm8Dsz.js\",\"_app/immutable/chunks/Ce0VRwE1.js\",\"_app/immutable/chunks/3MMtouT7.js\"],stylesheets:[],fonts:[],uses_env_dynamic_public:false},\n\t\tnodes: [\n\t\t\t__memo(() => import('./nodes/0.js')),\n\t\t\t__memo(() => import('./nodes/1.js')),\n\t\t\t__memo(() => import('./nodes/2.js')),\n\t\t\t__memo(() => import('./nodes/3.js')),\n\t\t\t__memo(() => import('./nodes/4.js')),\n\t\t\t__memo(() => import('./nodes/5.js')),\n\t\t\t__memo(() => import('./nodes/6.js')),\n\t\t\t__memo(() => import('./nodes/7.js')),\n\t\t\t__memo(() => import('./nodes/8.js')),\n\t\t\t__memo(() => import('./nodes/9.js'))\n\t\t],\n\t\tremotes: {\n\t\t\t\n\t\t},\n\t\troutes: [\n\t\t\t{\n\t\t\t\tid: \"/\",\n\t\t\t\tpattern: /^\\/$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 2 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/activity\",\n\t\t\t\tpattern: /^\\/activity\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 3 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/debug\",\n\t\t\t\tpattern: /^\\/api\\/debug\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/debug/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/device-token\",\n\t\t\t\tpattern: /^\\/api\\/device-token\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/device-token/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/health\",\n\t\t\t\tpattern: /^\\/api\\/health\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/health/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/neurolink-proxy\",\n\t\t\t\tpattern: /^\\/api\\/neurolink-proxy\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/neurolink-proxy/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/notify\",\n\t\t\t\tpattern: /^\\/api\\/notify\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/notify/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/qr-config\",\n\t\t\t\tpattern: /^\\/api\\/qr-config\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/qr-config/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/response\",\n\t\t\t\tpattern: /^\\/api\\/response\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/response/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/sessions\",\n\t\t\t\tpattern: /^\\/api\\/sessions\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/sessions/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/sessions/connect\",\n\t\t\t\tpattern: /^\\/api\\/sessions\\/connect\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/sessions/connect/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/sessions/detect\",\n\t\t\t\tpattern: /^\\/api\\/sessions\\/detect\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/sessions/detect/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals/[id]\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/([^/]+?)\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_id_/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals/[id]/paste-image\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/([^/]+?)\\/paste-image\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_id_/paste-image/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/terminals/[id]/resize\",\n\t\t\t\tpattern: /^\\/api\\/terminals\\/([^/]+?)\\/resize\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/terminals/_id_/resize/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/webhook\",\n\t\t\t\tpattern: /^\\/api\\/webhook\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/webhook/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/ws-status\",\n\t\t\t\tpattern: /^\\/api\\/ws-status\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/ws-status/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/api/ws-ticket\",\n\t\t\t\tpattern: /^\\/api\\/ws-ticket\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: null,\n\t\t\t\tendpoint: __memo(() => import('./entries/endpoints/api/ws-ticket/_server.ts.js'))\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/config\",\n\t\t\t\tpattern: /^\\/config\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 4 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/neurolink\",\n\t\t\t\tpattern: /^\\/neurolink\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 5 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/project\",\n\t\t\t\tpattern: /^\\/project\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 6 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/session/[id]\",\n\t\t\t\tpattern: /^\\/session\\/([^/]+?)\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 7 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/terminals\",\n\t\t\t\tpattern: /^\\/terminals\\/?$/,\n\t\t\t\tparams: [],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 8 },\n\t\t\t\tendpoint: null\n\t\t\t},\n\t\t\t{\n\t\t\t\tid: \"/terminals/[id]\",\n\t\t\t\tpattern: /^\\/terminals\\/([^/]+?)\\/?$/,\n\t\t\t\tparams: [{\"name\":\"id\",\"optional\":false,\"rest\":false,\"chained\":false}],\n\t\t\t\tpage: { layouts: [0,], errors: [1,], leaf: 9 },\n\t\t\t\tendpoint: null\n\t\t\t}\n\t\t],\n\t\tprerendered_routes: new Set([]),\n\t\tmatchers: async () => {\n\t\t\t\n\t\t\treturn { };\n\t\t},\n\t\tserver_assets: {}\n\t}\n}\n})();\n\nexport const prerendered = new Set([]);\n\nexport const base = \"\";"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@juspay/shooter",
3
- "version": "1.8.0",
3
+ "version": "1.9.1",
4
4
  "description": "Bidirectional communication server for Claude Code and iOS — push notifications, remote terminal, session viewing",
5
5
  "type": "module",
6
6
  "packageManager": "pnpm@10.28.2",
@@ -105,7 +105,6 @@
105
105
  },
106
106
  "dependencies": {
107
107
  "@juspay/svelte-ui-components": "^2.18.0",
108
- "@parse/node-apn": "^7.1.0",
109
108
  "@xterm/addon-fit": "^0.10.0",
110
109
  "@xterm/addon-web-links": "^0.11.0",
111
110
  "@xterm/xterm": "^5.5.0",
package/server.ts CHANGED
@@ -141,11 +141,63 @@ server.on('upgrade', (request, socket, head) => {
141
141
  startKeepalive();
142
142
 
143
143
  // ── Listen ───────────────────────────────────────────────────────────
144
+ // Port resolution priority: CLI flag (--port / -p) > PORT env > default.
145
+ // Server fails fast on EADDRINUSE so the CLI's tunnel can stay in sync
146
+ // with the actual listen port.
147
+
148
+ function parseEnvPort(): number | undefined {
149
+ const raw = process.env.PORT;
150
+ if (!raw) return undefined;
151
+ const n = parseInt(raw, 10);
152
+ return Number.isInteger(n) && n >= 0 && n < 65536 ? n : undefined;
153
+ }
154
+
155
+ // Keep in sync with `parsePortFlag` in bin/shooter.cjs.
156
+ function parsePortArg(): number | undefined {
157
+ const argv = process.argv.slice(2);
158
+ const isValid = (n: number): boolean => Number.isInteger(n) && n >= 0 && n < 65536;
159
+ const fail = (raw: string): never => {
160
+ console.error(`Error: invalid --port value "${raw}" — expected an integer in 0–65535.`);
161
+ process.exit(2);
162
+ };
163
+ for (let i = 0; i < argv.length; i++) {
164
+ const a = argv[i];
165
+ if ((a === '--port' || a === '-p') && argv[i + 1] !== undefined) {
166
+ const raw = argv[i + 1];
167
+ const n = parseInt(raw, 10);
168
+ if (!isValid(n)) fail(raw);
169
+ return n;
170
+ } else if (a.startsWith('--port=')) {
171
+ const raw = a.slice('--port='.length);
172
+ const n = parseInt(raw, 10);
173
+ if (!isValid(n)) fail(raw);
174
+ return n;
175
+ } else if (a.startsWith('-p=')) {
176
+ const raw = a.slice('-p='.length);
177
+ const n = parseInt(raw, 10);
178
+ if (!isValid(n)) fail(raw);
179
+ return n;
180
+ }
181
+ }
182
+ return undefined;
183
+ }
144
184
 
145
- const port = parseInt(process.env.PORT || '54007', 10);
185
+ const DEFAULT_PORT = 54007;
186
+ const requestedPort = parsePortArg() ?? parseEnvPort() ?? DEFAULT_PORT;
187
+
188
+ server.once('error', (err: NodeJS.ErrnoException): void => {
189
+ if (err.code === 'EADDRINUSE') {
190
+ console.error(
191
+ `Error: Port ${requestedPort} is already in use. Stop the existing process or pass --port <num>.`
192
+ );
193
+ process.exit(1);
194
+ }
195
+ console.error('Server error:', err);
196
+ process.exit(1);
197
+ });
146
198
 
147
- server.listen(port, () => {
148
- console.log(`Shooter server running on http://localhost:${port}`);
199
+ server.listen(requestedPort, () => {
200
+ console.log(`Shooter server running on http://localhost:${requestedPort}`);
149
201
  });
150
202
 
151
203
  // ── Graceful shutdown ────────────────────────────────────────────────
@@ -4,10 +4,10 @@
4
4
 
5
5
  import type { ActivityEvent, ActivitySummaryResult } from '$lib/types';
6
6
 
7
+ import { NEUROLINK_CDN_URL } from '$lib/modules/client/neurolink/cdn';
7
8
  import { installFetchProxy } from '$lib/modules/client/neurolink/fetch-proxy';
8
9
  import { detectActiveProvider } from '$lib/modules/client/neurolink/provider-config';
9
10
 
10
- const NEUROLINK_CDN_URL = 'https://unpkg.com/@juspay/neurolink/dist/browser/neurolink.min.js';
11
11
  const LOAD_FAILURE_COOLDOWN_MS = 60_000;
12
12
  const MAX_LOAD_ATTEMPTS = 3;
13
13
 
@@ -7,13 +7,12 @@
7
7
 
8
8
  import type { SummaryContext, SummaryResult } from '$lib/types';
9
9
 
10
+ import { NEUROLINK_CDN_URL } from '$lib/modules/client/neurolink/cdn';
10
11
  import { installFetchProxy } from '$lib/modules/client/neurolink/fetch-proxy';
11
12
  import { detectActiveProvider } from '$lib/modules/client/neurolink/provider-config';
12
13
 
13
14
  // ── CDN loading ───────────────────────────────────────────────────────────────
14
15
 
15
- const NEUROLINK_CDN_URL = 'https://unpkg.com/@juspay/neurolink/dist/browser/neurolink.min.js';
16
-
17
16
  // Significant event types that trigger conversational tone
18
17
  const SIGNIFICANT_EVENT_TYPES = new Set(['agent-question', 'terminal-exited', 'tool-failed']);
19
18
 
@@ -0,0 +1,6 @@
1
+ // Single source of truth for the NeuroLink browser bundle URL.
2
+ // Bump the version here to upgrade the SDK across all callers
3
+ // (activity summarizer, dashboard summarizer, /neurolink playground).
4
+
5
+ export const NEUROLINK_CDN_URL =
6
+ 'https://unpkg.com/@juspay/neurolink@9.61.1/dist/browser/neurolink.min.js';
@@ -107,17 +107,9 @@
107
107
  launching = false;
108
108
  }
109
109
  }
110
-
111
-
112
110
  </script>
113
111
 
114
- <Sheet
115
- bind:open
116
- side="bottom"
117
- title="New Terminal"
118
- onclose={onClose}
119
- classes="launch-sheet"
120
- >
112
+ <Sheet bind:open side="bottom" title="New Terminal" onclose={onClose} classes="launch-sheet">
121
113
  {#snippet content()}
122
114
  <div class="section">
123
115
  <span class="section-label">Quick Launch</span>
@@ -126,7 +118,7 @@
126
118
  <Choicebox
127
119
  mode="radio"
128
120
  selected={selectedPreset === i}
129
- onclick={() => {
121
+ onclick={(): void => {
130
122
  selectPreset(i);
131
123
  }}
132
124
  classes="preset-choice"
@@ -145,7 +137,7 @@
145
137
  : [{ id: '', label: 'No recent projects' }]}
146
138
  value={selectedCwd ? [selectedCwd] : projectPaths.length > 0 ? [projectPaths[0]] : ['']}
147
139
  placeholder="Select a project"
148
- onchange={(value) => {
140
+ onchange={(value: string[]): void => {
149
141
  selectedCwd = value[0] || '';
150
142
  }}
151
143
  classes="launch-select"
@@ -193,7 +185,8 @@
193
185
  --sheet-title-color: var(--text-primary);
194
186
  --sheet-close-button-color: var(--text-secondary);
195
187
  --sheet-close-button-hover-background: var(--component-bg-hover);
196
- --sheet-content-padding: 0 var(--space-5) calc(var(--space-8, 32px) + env(safe-area-inset-bottom, 0px));
188
+ --sheet-content-padding: 0 var(--space-5)
189
+ calc(var(--space-8, 32px) + env(safe-area-inset-bottom, 0px));
197
190
  }
198
191
 
199
192
  /* Desktop: override bottom sheet to appear as centered modal */
@@ -1,17 +1,33 @@
1
- import type { LibraryResult as APNsLibraryResult, NotificationPayload } from '$lib/types';
1
+ import type { APNsSendResult, NotificationPayload } from '$lib/types';
2
2
 
3
3
  import { env } from '$env/dynamic/private';
4
- // APNs service using proven library instead of manual implementation
5
- import apn from '@parse/node-apn';
4
+ import { execFile, execFileSync } from 'child_process';
5
+ import jwt from 'jsonwebtoken';
6
+ import { promisify } from 'util';
6
7
 
7
8
  import { toErrorMessage } from '../utils/error';
8
9
 
10
+ // APNs delivery via curl. Replaces @parse/node-apn (which times out on Node 24
11
+ // regardless of version: 7.1.0, 8.1.0, both reproduce). Node's native http2 +
12
+ // TLS clients also fail to connect to api.push.apple.com / api.sandbox.push.apple.com
13
+ // while curl, openssl s_client, and nc all succeed — strongly Apple-specific TLS
14
+ // quirk in Node. curl uses libnghttp2 + system TLS and connects in ~1s.
15
+
16
+ const execFileAsync = promisify(execFile);
17
+
18
+ const APNS_HOST_PROD = 'api.push.apple.com';
19
+ const APNS_HOST_SANDBOX = 'api.sandbox.push.apple.com';
20
+ const JWT_REFRESH_INTERVAL_MS = 30 * 60 * 1000;
21
+ const REQUEST_TIMEOUT_SECONDS = 15;
22
+
9
23
  export class LibraryAPNsService {
10
24
  private bundleId: string | undefined;
25
+ private cachedJwt: null | string = null;
26
+ private cachedJwtAt = 0;
11
27
  private configured = false;
28
+ private host = '';
12
29
  private keyId: string | undefined;
13
30
  private privateKey: string | undefined;
14
- private provider: apn.Provider | null = null;
15
31
  private teamId: string | undefined;
16
32
 
17
33
  constructor() {
@@ -29,21 +45,30 @@ export class LibraryAPNsService {
29
45
  }
30
46
 
31
47
  const production = env.APNS_PRODUCTION === 'true';
32
- const options = {
33
- production,
34
- token: {
35
- key: this.privateKey,
36
- keyId: this.keyId,
37
- teamId: this.teamId,
38
- },
39
- };
48
+ this.host = production ? APNS_HOST_PROD : APNS_HOST_SANDBOX;
49
+
50
+ // Verify curl is available before declaring the service ready. Without this
51
+ // probe, isConfigured() flips true on a host missing curl and every send
52
+ // fails with ENOENT at runtime instead of at startup.
53
+ try {
54
+ execFileSync('curl', ['--version'], { stdio: 'ignore' });
55
+ } catch (error) {
56
+ console.error(
57
+ '[apns] curl binary not found — install curl to enable APNs delivery:',
58
+ toErrorMessage(error)
59
+ );
60
+ this.configured = false;
61
+ return;
62
+ }
40
63
 
41
64
  try {
42
- this.provider = new apn.Provider(options);
65
+ this.getJwt();
43
66
  this.configured = true;
44
- console.log(`[apns] Provider initialized (${production ? 'production' : 'sandbox'} mode)`);
67
+ console.log(
68
+ `[apns] Provider initialized (${production ? 'production' : 'sandbox'} mode, curl transport)`
69
+ );
45
70
  } catch (error) {
46
- console.error('[apns] Failed to create provider:', toErrorMessage(error));
71
+ console.error('[apns] Failed to initialize:', toErrorMessage(error));
47
72
  this.configured = false;
48
73
  }
49
74
  }
@@ -55,86 +80,122 @@ export class LibraryAPNsService {
55
80
  async sendNotification(
56
81
  deviceToken: string,
57
82
  payload: NotificationPayload
58
- ): Promise<{
59
- details?: unknown[];
60
- error?: string;
61
- failed: number;
62
- sent: number;
63
- success: boolean;
64
- }> {
65
- if (!this.configured || !this.provider) {
83
+ ): Promise<APNsSendResult> {
84
+ if (!this.configured) {
66
85
  throw new Error('APNs service not configured properly');
67
86
  }
68
-
69
87
  if (!deviceToken || !payload) {
70
88
  throw new Error('Device token and payload are required');
71
89
  }
72
90
 
73
- const notification = new apn.Notification();
74
-
75
- notification.alert = {
76
- body: payload.body ?? payload.message ?? '',
77
- title: payload.title,
91
+ const aps: Record<string, unknown> = {
92
+ alert: {
93
+ body: payload.body ?? payload.message ?? '',
94
+ title: payload.title,
95
+ ...(payload.subtitle ? { subtitle: payload.subtitle } : {}),
96
+ },
97
+ badge: payload.badge ?? 1,
98
+ sound: payload.sound ?? 'default',
78
99
  };
79
-
80
- notification.badge = payload.badge ?? 1;
81
- notification.sound = payload.sound ?? 'default';
82
- if (!this.bundleId) {
83
- throw new Error('APNs bundleId is required but was not configured');
84
- }
85
- notification.topic = this.bundleId;
86
-
87
100
  if (payload.category) {
88
- notification.aps.category = payload.category;
101
+ aps.category = payload.category;
89
102
  }
90
103
 
104
+ const body: Record<string, unknown> = { aps };
91
105
  if (payload.data) {
92
- notification.payload = payload.data;
93
- }
94
-
95
- const result = (await this.provider.send(notification, deviceToken)) as APNsLibraryResult;
96
-
97
- if (result.failed && result.failed.length > 0) {
98
- console.error(`[apns] Full failed result: ${JSON.stringify(result.failed[0])}`);
99
- const failedItem = result.failed[0] as unknown as Record<string, unknown>;
100
- const rawReason =
101
- (failedItem?.response as Record<string, unknown>)?.reason ??
102
- failedItem?.status ??
103
- failedItem?.error;
104
- const reason =
105
- typeof rawReason === 'string' ? rawReason : JSON.stringify(rawReason ?? failedItem);
106
- console.error(`[apns] Delivery failed: ${reason}`);
107
-
108
- return {
109
- error: reason,
110
- failed: result.failed?.length || 0,
111
- sent: result.sent?.length || 0,
112
- success: false,
113
- };
106
+ // Drop any caller-supplied `aps` so it can't replace the alert envelope
107
+ // we just built (would otherwise produce silent or malformed pushes).
108
+ const { aps: _ignoredAps, ...customData } = payload.data;
109
+ void _ignoredAps;
110
+ Object.assign(body, customData);
114
111
  }
112
+ const bodyJson = JSON.stringify(body);
113
+ const jwtToken = this.getJwt();
114
+ const url = `https://${this.host}/3/device/${deviceToken}`;
115
+
116
+ const args = [
117
+ '-sS',
118
+ '--http2',
119
+ '--max-time',
120
+ String(REQUEST_TIMEOUT_SECONDS),
121
+ '-X',
122
+ 'POST',
123
+ '-H',
124
+ 'content-type: application/json',
125
+ '-H',
126
+ `apns-topic: ${this.bundleId}`,
127
+ '-H',
128
+ `authorization: bearer ${jwtToken}`,
129
+ '-H',
130
+ 'apns-push-type: alert',
131
+ '-H',
132
+ 'apns-priority: 10',
133
+ '-d',
134
+ bodyJson,
135
+ '-w',
136
+ '\n__SHOOTER_HTTP_STATUS__:%{http_code}\n',
137
+ url,
138
+ ];
115
139
 
116
- if (result.sent && result.sent.length > 0) {
117
- return {
118
- details: result.sent,
119
- failed: 0,
120
- sent: result.sent.length,
121
- success: true,
122
- };
140
+ try {
141
+ const { stdout } = await execFileAsync('curl', args, {
142
+ maxBuffer: 1024 * 1024,
143
+ timeout: (REQUEST_TIMEOUT_SECONDS + 5) * 1000,
144
+ });
145
+
146
+ const statusMatch = /__SHOOTER_HTTP_STATUS__:(\d+)/.exec(stdout);
147
+ const status = statusMatch ? parseInt(statusMatch[1], 10) : 0;
148
+ const bodyText = stdout.replace(/\n?__SHOOTER_HTTP_STATUS__:\d+\n?$/, '').trim();
149
+
150
+ if (status === 200) {
151
+ // Intentionally omit `details` here — including the raw 64-char
152
+ // device token would leak it through API responses and downstream
153
+ // logs, undercutting the redaction we do in the notifier.
154
+ return { failed: 0, sent: 1, success: true };
155
+ }
156
+
157
+ let reason: string = bodyText;
158
+ try {
159
+ const parsed: unknown = JSON.parse(bodyText);
160
+ if (
161
+ parsed &&
162
+ typeof parsed === 'object' &&
163
+ 'reason' in parsed &&
164
+ typeof (parsed as { reason: unknown }).reason === 'string'
165
+ ) {
166
+ reason = (parsed as { reason: string }).reason;
167
+ }
168
+ } catch {
169
+ // raw body
170
+ }
171
+ console.error(`[apns] Delivery failed (status=${status}): ${reason}`);
172
+ return { error: reason, failed: 1, sent: 0, success: false };
173
+ } catch (err) {
174
+ const msg = toErrorMessage(err);
175
+ console.error(`[apns] curl transport error: ${msg}`);
176
+ return { error: msg, failed: 1, sent: 0, success: false };
123
177
  }
124
-
125
- return {
126
- details: [result as unknown as Record<string, unknown>],
127
- error: 'Unexpected result format',
128
- failed: 1,
129
- sent: 0,
130
- success: false,
131
- };
132
178
  }
133
179
 
134
180
  shutdown(): void {
135
- if (this.provider) {
136
- void this.provider.shutdown();
181
+ // No persistent state to release.
182
+ }
183
+
184
+ private getJwt(): string {
185
+ const now = Date.now();
186
+ if (this.cachedJwt && now - this.cachedJwtAt < JWT_REFRESH_INTERVAL_MS) {
187
+ return this.cachedJwt;
188
+ }
189
+ if (!this.privateKey || !this.keyId || !this.teamId) {
190
+ throw new Error('APNs credentials missing');
137
191
  }
192
+ const token = jwt.sign({ iat: Math.floor(now / 1000), iss: this.teamId }, this.privateKey, {
193
+ algorithm: 'ES256',
194
+ header: { alg: 'ES256', kid: this.keyId },
195
+ });
196
+ this.cachedJwt = token;
197
+ this.cachedJwtAt = now;
198
+ return token;
138
199
  }
139
200
  }
140
201
 
@@ -36,6 +36,7 @@ export async function sendFCMNotification(
36
36
  project: typeof payload.data?.project === 'string' ? payload.data.project : '',
37
37
  requestId: typeof payload.data?.requestId === 'string' ? payload.data.requestId : '',
38
38
  source: typeof payload.data?.source === 'string' ? payload.data.source : '',
39
+ subtitle: payload.subtitle ?? '',
39
40
  timestamp: new Date().toISOString(),
40
41
  title: payload.title,
41
42
  toolInput: payload.data?.toolInput ? JSON.stringify(payload.data.toolInput) : '',
@@ -11,6 +11,16 @@ import type {
11
11
  SentDetail,
12
12
  } from './generated';
13
13
 
14
+ // Result shape returned by LibraryAPNsService.sendNotification — kept narrow
15
+ // because callers (notify endpoint) treat it as a small success/error summary.
16
+ export interface APNsSendResult {
17
+ details?: unknown[];
18
+ error?: string;
19
+ failed: number;
20
+ sent: number;
21
+ success: boolean;
22
+ }
23
+
14
24
  export interface LibraryResult {
15
25
  failed: LibraryFailedItem[];
16
26
  sent: LibrarySentItem[];
@@ -23,6 +33,7 @@ export interface NotificationPayload {
23
33
  data: null | Record<string, unknown>;
24
34
  message: null | string;
25
35
  sound: null | string;
36
+ subtitle?: null | string;
26
37
  title: string;
27
38
  }
28
39
 
@@ -289,6 +289,7 @@ export const POST: RequestHandler = async ({ request }) => {
289
289
  const requestDeviceToken = body.deviceToken as string | undefined;
290
290
  const message = body.message as string;
291
291
  const title = body.title as string;
292
+ const subtitle = typeof body.subtitle === 'string' ? body.subtitle : undefined;
292
293
 
293
294
  // Coerce skipPush and waitForResponse to booleans — string "false" would
294
295
  // be truthy so we require an actual boolean, defaulting to false otherwise.
@@ -379,6 +380,7 @@ export const POST: RequestHandler = async ({ request }) => {
379
380
  },
380
381
  message: null,
381
382
  sound: 'default' as const,
383
+ ...(subtitle ? { subtitle } : {}),
382
384
  title,
383
385
  };
384
386
 
@@ -1,13 +1,11 @@
1
1
  <script lang="ts">
2
- import { installFetchProxy } from '$lib/modules/client/neurolink/fetch-proxy';
3
- import { Button, Input, Pill } from '@juspay/svelte-ui-components';
4
- import { onMount } from 'svelte';
5
-
6
- const NEUROLINK_CDN_URL = 'https://unpkg.com/@juspay/neurolink/dist/browser/neurolink.min.js';
7
-
8
2
  import type { ProviderId } from '$lib/types';
9
3
 
4
+ import { NEUROLINK_CDN_URL } from '$lib/modules/client/neurolink/cdn';
5
+ import { installFetchProxy } from '$lib/modules/client/neurolink/fetch-proxy';
10
6
  import { PROVIDERS } from '$lib/modules/client/neurolink/provider-config';
7
+ import { Button, Input, Pill } from '@juspay/svelte-ui-components';
8
+ import { onMount } from 'svelte';
11
9
 
12
10
  const { data } = $props<{
13
11
  data: {