gtypee 1.0.0

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 (464) hide show
  1. package/LICENSE +15 -0
  2. package/README.md +1442 -0
  3. package/dist/bin/gtypee.d.ts +3 -0
  4. package/dist/bin/gtypee.d.ts.map +1 -0
  5. package/dist/bin/gtypee.js +18 -0
  6. package/dist/bin/gtypee.js.map +1 -0
  7. package/dist/src/authclient/authclient.d.ts +11 -0
  8. package/dist/src/authclient/authclient.d.ts.map +1 -0
  9. package/dist/src/authclient/authclient.js +26 -0
  10. package/dist/src/authclient/authclient.js.map +1 -0
  11. package/dist/src/cmd/agent/commands.d.ts +3 -0
  12. package/dist/src/cmd/agent/commands.d.ts.map +1 -0
  13. package/dist/src/cmd/agent/commands.js +16 -0
  14. package/dist/src/cmd/agent/commands.js.map +1 -0
  15. package/dist/src/cmd/appscript/commands.d.ts +24 -0
  16. package/dist/src/cmd/appscript/commands.d.ts.map +1 -0
  17. package/dist/src/cmd/appscript/commands.js +116 -0
  18. package/dist/src/cmd/appscript/commands.js.map +1 -0
  19. package/dist/src/cmd/appscript/runtime.d.ts +4 -0
  20. package/dist/src/cmd/appscript/runtime.d.ts.map +1 -0
  21. package/dist/src/cmd/appscript/runtime.js +64 -0
  22. package/dist/src/cmd/appscript/runtime.js.map +1 -0
  23. package/dist/src/cmd/auth/commands.d.ts +67 -0
  24. package/dist/src/cmd/auth/commands.d.ts.map +1 -0
  25. package/dist/src/cmd/auth/commands.js +184 -0
  26. package/dist/src/cmd/auth/commands.js.map +1 -0
  27. package/dist/src/cmd/auth/runtime.d.ts +20 -0
  28. package/dist/src/cmd/auth/runtime.d.ts.map +1 -0
  29. package/dist/src/cmd/auth/runtime.js +237 -0
  30. package/dist/src/cmd/auth/runtime.js.map +1 -0
  31. package/dist/src/cmd/calendar/commands.d.ts +58 -0
  32. package/dist/src/cmd/calendar/commands.d.ts.map +1 -0
  33. package/dist/src/cmd/calendar/commands.js +161 -0
  34. package/dist/src/cmd/calendar/commands.js.map +1 -0
  35. package/dist/src/cmd/calendar/runtime.d.ts +4 -0
  36. package/dist/src/cmd/calendar/runtime.d.ts.map +1 -0
  37. package/dist/src/cmd/calendar/runtime.js +164 -0
  38. package/dist/src/cmd/calendar/runtime.js.map +1 -0
  39. package/dist/src/cmd/chat/commands.d.ts +27 -0
  40. package/dist/src/cmd/chat/commands.d.ts.map +1 -0
  41. package/dist/src/cmd/chat/commands.js +113 -0
  42. package/dist/src/cmd/chat/commands.js.map +1 -0
  43. package/dist/src/cmd/chat/runtime.d.ts +4 -0
  44. package/dist/src/cmd/chat/runtime.d.ts.map +1 -0
  45. package/dist/src/cmd/chat/runtime.js +67 -0
  46. package/dist/src/cmd/chat/runtime.js.map +1 -0
  47. package/dist/src/cmd/classroom/commands.d.ts +22 -0
  48. package/dist/src/cmd/classroom/commands.d.ts.map +1 -0
  49. package/dist/src/cmd/classroom/commands.js +91 -0
  50. package/dist/src/cmd/classroom/commands.js.map +1 -0
  51. package/dist/src/cmd/classroom/runtime.d.ts +4 -0
  52. package/dist/src/cmd/classroom/runtime.d.ts.map +1 -0
  53. package/dist/src/cmd/classroom/runtime.js +67 -0
  54. package/dist/src/cmd/classroom/runtime.js.map +1 -0
  55. package/dist/src/cmd/command-registry.d.ts +8 -0
  56. package/dist/src/cmd/command-registry.d.ts.map +1 -0
  57. package/dist/src/cmd/command-registry.js +40 -0
  58. package/dist/src/cmd/command-registry.js.map +1 -0
  59. package/dist/src/cmd/completion/commands.d.ts +3 -0
  60. package/dist/src/cmd/completion/commands.d.ts.map +1 -0
  61. package/dist/src/cmd/completion/commands.js +29 -0
  62. package/dist/src/cmd/completion/commands.js.map +1 -0
  63. package/dist/src/cmd/config/commands.d.ts +10 -0
  64. package/dist/src/cmd/config/commands.d.ts.map +1 -0
  65. package/dist/src/cmd/config/commands.js +106 -0
  66. package/dist/src/cmd/config/commands.js.map +1 -0
  67. package/dist/src/cmd/contacts/commands.d.ts +18 -0
  68. package/dist/src/cmd/contacts/commands.d.ts.map +1 -0
  69. package/dist/src/cmd/contacts/commands.js +79 -0
  70. package/dist/src/cmd/contacts/commands.js.map +1 -0
  71. package/dist/src/cmd/contacts/runtime.d.ts +4 -0
  72. package/dist/src/cmd/contacts/runtime.d.ts.map +1 -0
  73. package/dist/src/cmd/contacts/runtime.js +67 -0
  74. package/dist/src/cmd/contacts/runtime.js.map +1 -0
  75. package/dist/src/cmd/docs/commands.d.ts +24 -0
  76. package/dist/src/cmd/docs/commands.d.ts.map +1 -0
  77. package/dist/src/cmd/docs/commands.js +82 -0
  78. package/dist/src/cmd/docs/commands.js.map +1 -0
  79. package/dist/src/cmd/docs/runtime.d.ts +4 -0
  80. package/dist/src/cmd/docs/runtime.d.ts.map +1 -0
  81. package/dist/src/cmd/docs/runtime.js +77 -0
  82. package/dist/src/cmd/docs/runtime.js.map +1 -0
  83. package/dist/src/cmd/drive/commands.d.ts +112 -0
  84. package/dist/src/cmd/drive/commands.d.ts.map +1 -0
  85. package/dist/src/cmd/drive/commands.js +431 -0
  86. package/dist/src/cmd/drive/commands.js.map +1 -0
  87. package/dist/src/cmd/drive/runtime.d.ts +4 -0
  88. package/dist/src/cmd/drive/runtime.d.ts.map +1 -0
  89. package/dist/src/cmd/drive/runtime.js +336 -0
  90. package/dist/src/cmd/drive/runtime.js.map +1 -0
  91. package/dist/src/cmd/execution-context.d.ts +33 -0
  92. package/dist/src/cmd/execution-context.d.ts.map +1 -0
  93. package/dist/src/cmd/execution-context.js +31 -0
  94. package/dist/src/cmd/execution-context.js.map +1 -0
  95. package/dist/src/cmd/exit-codes/commands.d.ts +5 -0
  96. package/dist/src/cmd/exit-codes/commands.d.ts.map +1 -0
  97. package/dist/src/cmd/exit-codes/commands.js +25 -0
  98. package/dist/src/cmd/exit-codes/commands.js.map +1 -0
  99. package/dist/src/cmd/exit-codes.d.ts +4 -0
  100. package/dist/src/cmd/exit-codes.d.ts.map +1 -0
  101. package/dist/src/cmd/exit-codes.js +4 -0
  102. package/dist/src/cmd/exit-codes.js.map +1 -0
  103. package/dist/src/cmd/exit.d.ts +7 -0
  104. package/dist/src/cmd/exit.d.ts.map +1 -0
  105. package/dist/src/cmd/exit.js +19 -0
  106. package/dist/src/cmd/exit.js.map +1 -0
  107. package/dist/src/cmd/forms/commands.d.ts +19 -0
  108. package/dist/src/cmd/forms/commands.d.ts.map +1 -0
  109. package/dist/src/cmd/forms/commands.js +73 -0
  110. package/dist/src/cmd/forms/commands.js.map +1 -0
  111. package/dist/src/cmd/forms/runtime.d.ts +4 -0
  112. package/dist/src/cmd/forms/runtime.d.ts.map +1 -0
  113. package/dist/src/cmd/forms/runtime.js +38 -0
  114. package/dist/src/cmd/forms/runtime.js.map +1 -0
  115. package/dist/src/cmd/gmail/commands.d.ts +187 -0
  116. package/dist/src/cmd/gmail/commands.d.ts.map +1 -0
  117. package/dist/src/cmd/gmail/commands.js +767 -0
  118. package/dist/src/cmd/gmail/commands.js.map +1 -0
  119. package/dist/src/cmd/gmail/runtime.d.ts +9 -0
  120. package/dist/src/cmd/gmail/runtime.d.ts.map +1 -0
  121. package/dist/src/cmd/gmail/runtime.js +644 -0
  122. package/dist/src/cmd/gmail/runtime.js.map +1 -0
  123. package/dist/src/cmd/groups/commands.d.ts +26 -0
  124. package/dist/src/cmd/groups/commands.d.ts.map +1 -0
  125. package/dist/src/cmd/groups/commands.js +105 -0
  126. package/dist/src/cmd/groups/commands.js.map +1 -0
  127. package/dist/src/cmd/groups/runtime.d.ts +4 -0
  128. package/dist/src/cmd/groups/runtime.d.ts.map +1 -0
  129. package/dist/src/cmd/groups/runtime.js +61 -0
  130. package/dist/src/cmd/groups/runtime.js.map +1 -0
  131. package/dist/src/cmd/keep/commands.d.ts +23 -0
  132. package/dist/src/cmd/keep/commands.d.ts.map +1 -0
  133. package/dist/src/cmd/keep/commands.js +111 -0
  134. package/dist/src/cmd/keep/commands.js.map +1 -0
  135. package/dist/src/cmd/keep/runtime.d.ts +4 -0
  136. package/dist/src/cmd/keep/runtime.d.ts.map +1 -0
  137. package/dist/src/cmd/keep/runtime.js +82 -0
  138. package/dist/src/cmd/keep/runtime.js.map +1 -0
  139. package/dist/src/cmd/people/commands.d.ts +22 -0
  140. package/dist/src/cmd/people/commands.d.ts.map +1 -0
  141. package/dist/src/cmd/people/commands.js +96 -0
  142. package/dist/src/cmd/people/commands.js.map +1 -0
  143. package/dist/src/cmd/people/runtime.d.ts +4 -0
  144. package/dist/src/cmd/people/runtime.d.ts.map +1 -0
  145. package/dist/src/cmd/people/runtime.js +65 -0
  146. package/dist/src/cmd/people/runtime.js.map +1 -0
  147. package/dist/src/cmd/rewrite-desire-path-args.d.ts +2 -0
  148. package/dist/src/cmd/rewrite-desire-path-args.d.ts.map +1 -0
  149. package/dist/src/cmd/rewrite-desire-path-args.js +75 -0
  150. package/dist/src/cmd/rewrite-desire-path-args.js.map +1 -0
  151. package/dist/src/cmd/root.d.ts +10 -0
  152. package/dist/src/cmd/root.d.ts.map +1 -0
  153. package/dist/src/cmd/root.js +341 -0
  154. package/dist/src/cmd/root.js.map +1 -0
  155. package/dist/src/cmd/schema/commands.d.ts +3 -0
  156. package/dist/src/cmd/schema/commands.d.ts.map +1 -0
  157. package/dist/src/cmd/schema/commands.js +21 -0
  158. package/dist/src/cmd/schema/commands.js.map +1 -0
  159. package/dist/src/cmd/script-path.d.ts +2 -0
  160. package/dist/src/cmd/script-path.d.ts.map +1 -0
  161. package/dist/src/cmd/script-path.js +4 -0
  162. package/dist/src/cmd/script-path.js.map +1 -0
  163. package/dist/src/cmd/sheets/commands.d.ts +20 -0
  164. package/dist/src/cmd/sheets/commands.d.ts.map +1 -0
  165. package/dist/src/cmd/sheets/commands.js +79 -0
  166. package/dist/src/cmd/sheets/commands.js.map +1 -0
  167. package/dist/src/cmd/sheets/runtime.d.ts +4 -0
  168. package/dist/src/cmd/sheets/runtime.d.ts.map +1 -0
  169. package/dist/src/cmd/sheets/runtime.js +37 -0
  170. package/dist/src/cmd/sheets/runtime.js.map +1 -0
  171. package/dist/src/cmd/slides/commands.d.ts +24 -0
  172. package/dist/src/cmd/slides/commands.d.ts.map +1 -0
  173. package/dist/src/cmd/slides/commands.js +90 -0
  174. package/dist/src/cmd/slides/commands.js.map +1 -0
  175. package/dist/src/cmd/slides/runtime.d.ts +4 -0
  176. package/dist/src/cmd/slides/runtime.d.ts.map +1 -0
  177. package/dist/src/cmd/slides/runtime.js +92 -0
  178. package/dist/src/cmd/slides/runtime.js.map +1 -0
  179. package/dist/src/cmd/tasks/commands.d.ts +28 -0
  180. package/dist/src/cmd/tasks/commands.d.ts.map +1 -0
  181. package/dist/src/cmd/tasks/commands.js +103 -0
  182. package/dist/src/cmd/tasks/commands.js.map +1 -0
  183. package/dist/src/cmd/tasks/runtime.d.ts +4 -0
  184. package/dist/src/cmd/tasks/runtime.d.ts.map +1 -0
  185. package/dist/src/cmd/tasks/runtime.js +56 -0
  186. package/dist/src/cmd/tasks/runtime.js.map +1 -0
  187. package/dist/src/cmd/time/commands.d.ts +17 -0
  188. package/dist/src/cmd/time/commands.d.ts.map +1 -0
  189. package/dist/src/cmd/time/commands.js +88 -0
  190. package/dist/src/cmd/time/commands.js.map +1 -0
  191. package/dist/src/cmd/version/commands.d.ts +3 -0
  192. package/dist/src/cmd/version/commands.d.ts.map +1 -0
  193. package/dist/src/cmd/version/commands.js +17 -0
  194. package/dist/src/cmd/version/commands.js.map +1 -0
  195. package/dist/src/cmd/workspace/commands.d.ts +222 -0
  196. package/dist/src/cmd/workspace/commands.d.ts.map +1 -0
  197. package/dist/src/cmd/workspace/commands.js +685 -0
  198. package/dist/src/cmd/workspace/commands.js.map +1 -0
  199. package/dist/src/cmd/workspace/runtime.d.ts +8 -0
  200. package/dist/src/cmd/workspace/runtime.d.ts.map +1 -0
  201. package/dist/src/cmd/workspace/runtime.js +852 -0
  202. package/dist/src/cmd/workspace/runtime.js.map +1 -0
  203. package/dist/src/config/clients.d.ts +8 -0
  204. package/dist/src/config/clients.d.ts.map +1 -0
  205. package/dist/src/config/clients.js +95 -0
  206. package/dist/src/config/clients.js.map +1 -0
  207. package/dist/src/config/config.d.ts +11 -0
  208. package/dist/src/config/config.d.ts.map +1 -0
  209. package/dist/src/config/config.js +54 -0
  210. package/dist/src/config/config.js.map +1 -0
  211. package/dist/src/config/credentials.d.ts +16 -0
  212. package/dist/src/config/credentials.d.ts.map +1 -0
  213. package/dist/src/config/credentials.js +97 -0
  214. package/dist/src/config/credentials.js.map +1 -0
  215. package/dist/src/config/migration.d.ts +13 -0
  216. package/dist/src/config/migration.d.ts.map +1 -0
  217. package/dist/src/config/migration.js +70 -0
  218. package/dist/src/config/migration.js.map +1 -0
  219. package/dist/src/config/paths.d.ts +11 -0
  220. package/dist/src/config/paths.d.ts.map +1 -0
  221. package/dist/src/config/paths.js +74 -0
  222. package/dist/src/config/paths.js.map +1 -0
  223. package/dist/src/googleapi/auth-factory.d.ts +46 -0
  224. package/dist/src/googleapi/auth-factory.d.ts.map +1 -0
  225. package/dist/src/googleapi/auth-factory.js +88 -0
  226. package/dist/src/googleapi/auth-factory.js.map +1 -0
  227. package/dist/src/googleapi/calendar.d.ts +3 -0
  228. package/dist/src/googleapi/calendar.d.ts.map +1 -0
  229. package/dist/src/googleapi/calendar.js +21 -0
  230. package/dist/src/googleapi/calendar.js.map +1 -0
  231. package/dist/src/googleapi/circuitbreaker.d.ts +19 -0
  232. package/dist/src/googleapi/circuitbreaker.d.ts.map +1 -0
  233. package/dist/src/googleapi/circuitbreaker.js +43 -0
  234. package/dist/src/googleapi/circuitbreaker.js.map +1 -0
  235. package/dist/src/googleapi/client.d.ts +17 -0
  236. package/dist/src/googleapi/client.d.ts.map +1 -0
  237. package/dist/src/googleapi/client.js +18 -0
  238. package/dist/src/googleapi/client.js.map +1 -0
  239. package/dist/src/googleapi/drive.d.ts +3 -0
  240. package/dist/src/googleapi/drive.d.ts.map +1 -0
  241. package/dist/src/googleapi/drive.js +11 -0
  242. package/dist/src/googleapi/drive.js.map +1 -0
  243. package/dist/src/googleapi/errors.d.ts +37 -0
  244. package/dist/src/googleapi/errors.d.ts.map +1 -0
  245. package/dist/src/googleapi/errors.js +93 -0
  246. package/dist/src/googleapi/errors.js.map +1 -0
  247. package/dist/src/googleapi/retry-constants.d.ts +5 -0
  248. package/dist/src/googleapi/retry-constants.d.ts.map +1 -0
  249. package/dist/src/googleapi/retry-constants.js +5 -0
  250. package/dist/src/googleapi/retry-constants.js.map +1 -0
  251. package/dist/src/googleapi/transport.d.ts +3 -0
  252. package/dist/src/googleapi/transport.d.ts.map +1 -0
  253. package/dist/src/googleapi/transport.js +39 -0
  254. package/dist/src/googleapi/transport.js.map +1 -0
  255. package/dist/src/googleauth/oauth-flow.d.ts +62 -0
  256. package/dist/src/googleauth/oauth-flow.d.ts.map +1 -0
  257. package/dist/src/googleauth/oauth-flow.js +262 -0
  258. package/dist/src/googleauth/oauth-flow.js.map +1 -0
  259. package/dist/src/googleauth/service.d.ts +28 -0
  260. package/dist/src/googleauth/service.d.ts.map +1 -0
  261. package/dist/src/googleauth/service.js +345 -0
  262. package/dist/src/googleauth/service.js.map +1 -0
  263. package/dist/src/index.d.ts +2 -0
  264. package/dist/src/index.d.ts.map +1 -0
  265. package/dist/src/index.js +2 -0
  266. package/dist/src/index.js.map +1 -0
  267. package/dist/src/outfmt/outfmt.d.ts +8 -0
  268. package/dist/src/outfmt/outfmt.d.ts.map +1 -0
  269. package/dist/src/outfmt/outfmt.js +66 -0
  270. package/dist/src/outfmt/outfmt.js.map +1 -0
  271. package/dist/src/secrets/store.d.ts +61 -0
  272. package/dist/src/secrets/store.d.ts.map +1 -0
  273. package/dist/src/secrets/store.js +247 -0
  274. package/dist/src/secrets/store.js.map +1 -0
  275. package/dist/test/authclient/authclient.test.d.ts +2 -0
  276. package/dist/test/authclient/authclient.test.d.ts.map +1 -0
  277. package/dist/test/authclient/authclient.test.js +14 -0
  278. package/dist/test/authclient/authclient.test.js.map +1 -0
  279. package/dist/test/bin/gtypee-entrypoint.test.d.ts +2 -0
  280. package/dist/test/bin/gtypee-entrypoint.test.d.ts.map +1 -0
  281. package/dist/test/bin/gtypee-entrypoint.test.js +17 -0
  282. package/dist/test/bin/gtypee-entrypoint.test.js.map +1 -0
  283. package/dist/test/cmd/agent/commands.test.d.ts +2 -0
  284. package/dist/test/cmd/agent/commands.test.d.ts.map +1 -0
  285. package/dist/test/cmd/agent/commands.test.js +12 -0
  286. package/dist/test/cmd/agent/commands.test.js.map +1 -0
  287. package/dist/test/cmd/appscript/commands.test.d.ts +2 -0
  288. package/dist/test/cmd/appscript/commands.test.d.ts.map +1 -0
  289. package/dist/test/cmd/appscript/commands.test.js +104 -0
  290. package/dist/test/cmd/appscript/commands.test.js.map +1 -0
  291. package/dist/test/cmd/auth/commands.test.d.ts +2 -0
  292. package/dist/test/cmd/auth/commands.test.d.ts.map +1 -0
  293. package/dist/test/cmd/auth/commands.test.js +142 -0
  294. package/dist/test/cmd/auth/commands.test.js.map +1 -0
  295. package/dist/test/cmd/auth/runtime.test.d.ts +2 -0
  296. package/dist/test/cmd/auth/runtime.test.d.ts.map +1 -0
  297. package/dist/test/cmd/auth/runtime.test.js +214 -0
  298. package/dist/test/cmd/auth/runtime.test.js.map +1 -0
  299. package/dist/test/cmd/calendar/commands.test.d.ts +2 -0
  300. package/dist/test/cmd/calendar/commands.test.d.ts.map +1 -0
  301. package/dist/test/cmd/calendar/commands.test.js +121 -0
  302. package/dist/test/cmd/calendar/commands.test.js.map +1 -0
  303. package/dist/test/cmd/chat/commands.test.d.ts +2 -0
  304. package/dist/test/cmd/chat/commands.test.d.ts.map +1 -0
  305. package/dist/test/cmd/chat/commands.test.js +57 -0
  306. package/dist/test/cmd/chat/commands.test.js.map +1 -0
  307. package/dist/test/cmd/classroom/commands.test.d.ts +2 -0
  308. package/dist/test/cmd/classroom/commands.test.d.ts.map +1 -0
  309. package/dist/test/cmd/classroom/commands.test.js +61 -0
  310. package/dist/test/cmd/classroom/commands.test.js.map +1 -0
  311. package/dist/test/cmd/completion/commands.test.d.ts +2 -0
  312. package/dist/test/cmd/completion/commands.test.d.ts.map +1 -0
  313. package/dist/test/cmd/completion/commands.test.js +30 -0
  314. package/dist/test/cmd/completion/commands.test.js.map +1 -0
  315. package/dist/test/cmd/config/commands.test.d.ts +2 -0
  316. package/dist/test/cmd/config/commands.test.d.ts.map +1 -0
  317. package/dist/test/cmd/config/commands.test.js +21 -0
  318. package/dist/test/cmd/config/commands.test.js.map +1 -0
  319. package/dist/test/cmd/contacts/commands.test.d.ts +2 -0
  320. package/dist/test/cmd/contacts/commands.test.d.ts.map +1 -0
  321. package/dist/test/cmd/contacts/commands.test.js +51 -0
  322. package/dist/test/cmd/contacts/commands.test.js.map +1 -0
  323. package/dist/test/cmd/docs/commands.test.d.ts +2 -0
  324. package/dist/test/cmd/docs/commands.test.d.ts.map +1 -0
  325. package/dist/test/cmd/docs/commands.test.js +39 -0
  326. package/dist/test/cmd/docs/commands.test.js.map +1 -0
  327. package/dist/test/cmd/drive/commands.test.d.ts +2 -0
  328. package/dist/test/cmd/drive/commands.test.d.ts.map +1 -0
  329. package/dist/test/cmd/drive/commands.test.js +409 -0
  330. package/dist/test/cmd/drive/commands.test.js.map +1 -0
  331. package/dist/test/cmd/execution-context.test.d.ts +2 -0
  332. package/dist/test/cmd/execution-context.test.d.ts.map +1 -0
  333. package/dist/test/cmd/execution-context.test.js +29 -0
  334. package/dist/test/cmd/execution-context.test.js.map +1 -0
  335. package/dist/test/cmd/exit-codes/commands.test.d.ts +2 -0
  336. package/dist/test/cmd/exit-codes/commands.test.d.ts.map +1 -0
  337. package/dist/test/cmd/exit-codes/commands.test.js +19 -0
  338. package/dist/test/cmd/exit-codes/commands.test.js.map +1 -0
  339. package/dist/test/cmd/exit.test.d.ts +2 -0
  340. package/dist/test/cmd/exit.test.d.ts.map +1 -0
  341. package/dist/test/cmd/exit.test.js +14 -0
  342. package/dist/test/cmd/exit.test.js.map +1 -0
  343. package/dist/test/cmd/forms/commands.test.d.ts +2 -0
  344. package/dist/test/cmd/forms/commands.test.d.ts.map +1 -0
  345. package/dist/test/cmd/forms/commands.test.js +42 -0
  346. package/dist/test/cmd/forms/commands.test.js.map +1 -0
  347. package/dist/test/cmd/gmail/commands.test.d.ts +2 -0
  348. package/dist/test/cmd/gmail/commands.test.d.ts.map +1 -0
  349. package/dist/test/cmd/gmail/commands.test.js +315 -0
  350. package/dist/test/cmd/gmail/commands.test.js.map +1 -0
  351. package/dist/test/cmd/groups/commands.test.d.ts +2 -0
  352. package/dist/test/cmd/groups/commands.test.d.ts.map +1 -0
  353. package/dist/test/cmd/groups/commands.test.js +79 -0
  354. package/dist/test/cmd/groups/commands.test.js.map +1 -0
  355. package/dist/test/cmd/keep/commands.test.d.ts +2 -0
  356. package/dist/test/cmd/keep/commands.test.d.ts.map +1 -0
  357. package/dist/test/cmd/keep/commands.test.js +87 -0
  358. package/dist/test/cmd/keep/commands.test.js.map +1 -0
  359. package/dist/test/cmd/people/commands.test.d.ts +2 -0
  360. package/dist/test/cmd/people/commands.test.d.ts.map +1 -0
  361. package/dist/test/cmd/people/commands.test.js +52 -0
  362. package/dist/test/cmd/people/commands.test.js.map +1 -0
  363. package/dist/test/cmd/rewrite-desire-path-args.test.d.ts +2 -0
  364. package/dist/test/cmd/rewrite-desire-path-args.test.d.ts.map +1 -0
  365. package/dist/test/cmd/rewrite-desire-path-args.test.js +21 -0
  366. package/dist/test/cmd/rewrite-desire-path-args.test.js.map +1 -0
  367. package/dist/test/cmd/root.test.d.ts +2 -0
  368. package/dist/test/cmd/root.test.d.ts.map +1 -0
  369. package/dist/test/cmd/root.test.js +323 -0
  370. package/dist/test/cmd/root.test.js.map +1 -0
  371. package/dist/test/cmd/runtime-scopes.test.d.ts +2 -0
  372. package/dist/test/cmd/runtime-scopes.test.d.ts.map +1 -0
  373. package/dist/test/cmd/runtime-scopes.test.js +133 -0
  374. package/dist/test/cmd/runtime-scopes.test.js.map +1 -0
  375. package/dist/test/cmd/schema/commands.test.d.ts +2 -0
  376. package/dist/test/cmd/schema/commands.test.d.ts.map +1 -0
  377. package/dist/test/cmd/schema/commands.test.js +31 -0
  378. package/dist/test/cmd/schema/commands.test.js.map +1 -0
  379. package/dist/test/cmd/sheets/commands.test.d.ts +2 -0
  380. package/dist/test/cmd/sheets/commands.test.d.ts.map +1 -0
  381. package/dist/test/cmd/sheets/commands.test.js +39 -0
  382. package/dist/test/cmd/sheets/commands.test.js.map +1 -0
  383. package/dist/test/cmd/slides/commands.test.d.ts +2 -0
  384. package/dist/test/cmd/slides/commands.test.d.ts.map +1 -0
  385. package/dist/test/cmd/slides/commands.test.js +48 -0
  386. package/dist/test/cmd/slides/commands.test.js.map +1 -0
  387. package/dist/test/cmd/tasks/commands.test.d.ts +2 -0
  388. package/dist/test/cmd/tasks/commands.test.d.ts.map +1 -0
  389. package/dist/test/cmd/tasks/commands.test.js +74 -0
  390. package/dist/test/cmd/tasks/commands.test.js.map +1 -0
  391. package/dist/test/cmd/time/commands.test.d.ts +2 -0
  392. package/dist/test/cmd/time/commands.test.d.ts.map +1 -0
  393. package/dist/test/cmd/time/commands.test.js +52 -0
  394. package/dist/test/cmd/time/commands.test.js.map +1 -0
  395. package/dist/test/cmd/version/commands.test.d.ts +2 -0
  396. package/dist/test/cmd/version/commands.test.d.ts.map +1 -0
  397. package/dist/test/cmd/version/commands.test.js +12 -0
  398. package/dist/test/cmd/version/commands.test.js.map +1 -0
  399. package/dist/test/cmd/workspace/commands.test.d.ts +2 -0
  400. package/dist/test/cmd/workspace/commands.test.d.ts.map +1 -0
  401. package/dist/test/cmd/workspace/commands.test.js +285 -0
  402. package/dist/test/cmd/workspace/commands.test.js.map +1 -0
  403. package/dist/test/config/clients.test.d.ts +2 -0
  404. package/dist/test/config/clients.test.d.ts.map +1 -0
  405. package/dist/test/config/clients.test.js +42 -0
  406. package/dist/test/config/clients.test.js.map +1 -0
  407. package/dist/test/config/config.test.d.ts +2 -0
  408. package/dist/test/config/config.test.d.ts.map +1 -0
  409. package/dist/test/config/config.test.js +80 -0
  410. package/dist/test/config/config.test.js.map +1 -0
  411. package/dist/test/config/credentials.test.d.ts +2 -0
  412. package/dist/test/config/credentials.test.d.ts.map +1 -0
  413. package/dist/test/config/credentials.test.js +78 -0
  414. package/dist/test/config/credentials.test.js.map +1 -0
  415. package/dist/test/config/migration.test.d.ts +2 -0
  416. package/dist/test/config/migration.test.d.ts.map +1 -0
  417. package/dist/test/config/migration.test.js +136 -0
  418. package/dist/test/config/migration.test.js.map +1 -0
  419. package/dist/test/config/paths.test.d.ts +2 -0
  420. package/dist/test/config/paths.test.d.ts.map +1 -0
  421. package/dist/test/config/paths.test.js +31 -0
  422. package/dist/test/config/paths.test.js.map +1 -0
  423. package/dist/test/googleapi/auth-factory.test.d.ts +2 -0
  424. package/dist/test/googleapi/auth-factory.test.d.ts.map +1 -0
  425. package/dist/test/googleapi/auth-factory.test.js +215 -0
  426. package/dist/test/googleapi/auth-factory.test.js.map +1 -0
  427. package/dist/test/googleapi/circuitbreaker.test.d.ts +2 -0
  428. package/dist/test/googleapi/circuitbreaker.test.d.ts.map +1 -0
  429. package/dist/test/googleapi/circuitbreaker.test.js +30 -0
  430. package/dist/test/googleapi/circuitbreaker.test.js.map +1 -0
  431. package/dist/test/googleapi/client.test.d.ts +2 -0
  432. package/dist/test/googleapi/client.test.d.ts.map +1 -0
  433. package/dist/test/googleapi/client.test.js +16 -0
  434. package/dist/test/googleapi/client.test.js.map +1 -0
  435. package/dist/test/googleapi/errors.test.d.ts +2 -0
  436. package/dist/test/googleapi/errors.test.d.ts.map +1 -0
  437. package/dist/test/googleapi/errors.test.js +21 -0
  438. package/dist/test/googleapi/errors.test.js.map +1 -0
  439. package/dist/test/googleapi/transport.test.d.ts +2 -0
  440. package/dist/test/googleapi/transport.test.d.ts.map +1 -0
  441. package/dist/test/googleapi/transport.test.js +25 -0
  442. package/dist/test/googleapi/transport.test.js.map +1 -0
  443. package/dist/test/googleauth/oauth-flow.test.d.ts +2 -0
  444. package/dist/test/googleauth/oauth-flow.test.d.ts.map +1 -0
  445. package/dist/test/googleauth/oauth-flow.test.js +85 -0
  446. package/dist/test/googleauth/oauth-flow.test.js.map +1 -0
  447. package/dist/test/googleauth/service.test.d.ts +2 -0
  448. package/dist/test/googleauth/service.test.d.ts.map +1 -0
  449. package/dist/test/googleauth/service.test.js +51 -0
  450. package/dist/test/googleauth/service.test.js.map +1 -0
  451. package/dist/test/outfmt/outfmt.test.d.ts +2 -0
  452. package/dist/test/outfmt/outfmt.test.d.ts.map +1 -0
  453. package/dist/test/outfmt/outfmt.test.js +41 -0
  454. package/dist/test/outfmt/outfmt.test.js.map +1 -0
  455. package/dist/test/secrets/store.test.d.ts +2 -0
  456. package/dist/test/secrets/store.test.d.ts.map +1 -0
  457. package/dist/test/secrets/store.test.js +164 -0
  458. package/dist/test/secrets/store.test.js.map +1 -0
  459. package/dist/vitest.config.d.ts +3 -0
  460. package/dist/vitest.config.d.ts.map +1 -0
  461. package/dist/vitest.config.js +11 -0
  462. package/dist/vitest.config.js.map +1 -0
  463. package/logo.svg +16 -0
  464. package/package.json +69 -0
@@ -0,0 +1,644 @@
1
+ import { google } from "googleapis";
2
+ import { ServiceRuntime } from "../../googleapi/auth-factory.js";
3
+ import { scopes } from "../../googleauth/service.js";
4
+ export function buildGmailCommandDeps(options) {
5
+ const runtime = new ServiceRuntime(options);
6
+ return {
7
+ sendEmail: async (input) => {
8
+ const auth = await runtime.getClient(scopes("gmail"));
9
+ const gmail = google.gmail({ version: "v1", auth });
10
+ const rawMessage = [
11
+ `To: ${input.to}`,
12
+ `Subject: ${input.subject}`,
13
+ "Content-Type: text/plain; charset=utf-8",
14
+ "",
15
+ input.body,
16
+ ].join("\r\n");
17
+ const encodedMessage = Buffer.from(rawMessage).toString("base64url");
18
+ const response = await gmail.users.messages.send({
19
+ userId: "me",
20
+ requestBody: { raw: encodedMessage },
21
+ });
22
+ return {
23
+ id: response.data.id ?? "",
24
+ threadId: response.data.threadId ?? "",
25
+ accepted: response.status === 200,
26
+ };
27
+ },
28
+ searchEmails: async (query) => {
29
+ const auth = await runtime.getClient(scopes("gmail"));
30
+ const gmail = google.gmail({ version: "v1", auth });
31
+ const listResponse = await gmail.users.messages.list({
32
+ userId: "me",
33
+ q: query,
34
+ maxResults: 50,
35
+ });
36
+ const messageIds = listResponse.data.messages ?? [];
37
+ if (messageIds.length === 0)
38
+ return [];
39
+ const results = await Promise.all(messageIds.map(async (msg) => {
40
+ const detail = await gmail.users.messages.get({
41
+ userId: "me",
42
+ id: msg.id,
43
+ format: "metadata",
44
+ metadataHeaders: ["Subject"],
45
+ });
46
+ const subjectHeader = detail.data.payload?.headers?.find((h) => h.name?.toLowerCase() === "subject");
47
+ return {
48
+ id: detail.data.id ?? "",
49
+ threadId: detail.data.threadId ?? "",
50
+ subject: subjectHeader?.value ?? "(no subject)",
51
+ };
52
+ }));
53
+ return results;
54
+ },
55
+ listLabels: async () => {
56
+ const auth = await runtime.getClient(scopes("gmail"));
57
+ const gmail = google.gmail({ version: "v1", auth });
58
+ const response = await gmail.users.labels.list({ userId: "me" });
59
+ const labels = response.data.labels ?? [];
60
+ return labels.map((label) => ({
61
+ id: label.id ?? "",
62
+ name: label.name ?? "",
63
+ }));
64
+ },
65
+ getMessage: async (messageId) => {
66
+ const auth = await runtime.getClient(scopes("gmail"));
67
+ const gmail = google.gmail({ version: "v1", auth });
68
+ const response = await gmail.users.messages.get({
69
+ userId: "me",
70
+ id: messageId,
71
+ format: "full",
72
+ });
73
+ const headers = response.data.payload?.headers ?? [];
74
+ const getHeader = (name) => {
75
+ const header = headers.find((h) => h.name?.toLowerCase() === name.toLowerCase());
76
+ return header?.value ?? "";
77
+ };
78
+ // Extract text body from the message
79
+ let body = "";
80
+ const payload = response.data.payload;
81
+ if (payload?.body?.data) {
82
+ // Simple text/plain message
83
+ body = Buffer.from(payload.body.data, "base64url").toString("utf-8");
84
+ }
85
+ else if (payload?.parts) {
86
+ // Multipart message - find text/plain part
87
+ const textPart = payload.parts.find((part) => part.mimeType === "text/plain" || part.mimeType?.startsWith("text/plain"));
88
+ if (textPart?.body?.data) {
89
+ body = Buffer.from(textPart.body.data, "base64url").toString("utf-8");
90
+ }
91
+ else if (payload.parts[0]?.body?.data) {
92
+ // Fallback to first part
93
+ body = Buffer.from(payload.parts[0].body.data, "base64url").toString("utf-8");
94
+ }
95
+ }
96
+ return {
97
+ id: response.data.id ?? "",
98
+ threadId: response.data.threadId ?? "",
99
+ from: getHeader("from"),
100
+ to: getHeader("to"),
101
+ subject: getHeader("subject") || "(no subject)",
102
+ date: getHeader("date"),
103
+ body,
104
+ };
105
+ },
106
+ deleteMessage: async (messageId) => {
107
+ const auth = await runtime.getClient(scopes("gmail"));
108
+ const gmail = google.gmail({ version: "v1", auth });
109
+ try {
110
+ await gmail.users.messages.delete({
111
+ userId: "me",
112
+ id: messageId,
113
+ });
114
+ return { id: messageId, applied: true };
115
+ }
116
+ catch {
117
+ return { id: messageId, applied: false };
118
+ }
119
+ },
120
+ trashMessage: async (messageId) => {
121
+ const auth = await runtime.getClient(scopes("gmail"));
122
+ const gmail = google.gmail({ version: "v1", auth });
123
+ try {
124
+ await gmail.users.messages.trash({
125
+ userId: "me",
126
+ id: messageId,
127
+ });
128
+ return { id: messageId, applied: true };
129
+ }
130
+ catch {
131
+ return { id: messageId, applied: false };
132
+ }
133
+ },
134
+ untrashMessage: async (messageId) => {
135
+ const auth = await runtime.getClient(scopes("gmail"));
136
+ const gmail = google.gmail({ version: "v1", auth });
137
+ try {
138
+ await gmail.users.messages.untrash({
139
+ userId: "me",
140
+ id: messageId,
141
+ });
142
+ return { id: messageId, applied: true };
143
+ }
144
+ catch {
145
+ return { id: messageId, applied: false };
146
+ }
147
+ },
148
+ modifyMessage: async (messageId, addLabels, removeLabels) => {
149
+ const auth = await runtime.getClient(scopes("gmail"));
150
+ const gmail = google.gmail({ version: "v1", auth });
151
+ try {
152
+ await gmail.users.messages.modify({
153
+ userId: "me",
154
+ id: messageId,
155
+ requestBody: {
156
+ addLabelIds: addLabels ?? null,
157
+ removeLabelIds: removeLabels ?? null,
158
+ },
159
+ });
160
+ return {
161
+ id: messageId,
162
+ addedLabels: addLabels ?? [],
163
+ removedLabels: removeLabels ?? [],
164
+ applied: true,
165
+ };
166
+ }
167
+ catch {
168
+ return {
169
+ id: messageId,
170
+ addedLabels: addLabels ?? [],
171
+ removedLabels: removeLabels ?? [],
172
+ applied: false,
173
+ };
174
+ }
175
+ },
176
+ };
177
+ }
178
+ /**
179
+ * Helper function to extract message details from Gmail API response
180
+ */
181
+ function extractMessageDetail(message) {
182
+ const headers = message.payload?.headers ?? [];
183
+ const getHeader = (name) => {
184
+ const header = headers.find((h) => h.name?.toLowerCase() === name.toLowerCase());
185
+ return header?.value ?? "";
186
+ };
187
+ // Extract text body from the message
188
+ let body = "";
189
+ const payload = message.payload;
190
+ if (payload?.body?.data) {
191
+ body = Buffer.from(payload.body.data, "base64url").toString("utf-8");
192
+ }
193
+ else if (payload?.parts) {
194
+ const textPart = payload.parts.find((part) => part.mimeType === "text/plain" || part.mimeType?.startsWith("text/plain"));
195
+ if (textPart?.body?.data) {
196
+ body = Buffer.from(textPart.body.data, "base64url").toString("utf-8");
197
+ }
198
+ else if (payload.parts[0]?.body?.data) {
199
+ body = Buffer.from(payload.parts[0].body.data, "base64url").toString("utf-8");
200
+ }
201
+ }
202
+ return {
203
+ id: message.id ?? "",
204
+ threadId: message.threadId ?? "",
205
+ from: getHeader("from"),
206
+ to: getHeader("to"),
207
+ subject: getHeader("subject") || "(no subject)",
208
+ date: getHeader("date"),
209
+ body,
210
+ };
211
+ }
212
+ export function buildGmailDraftDeps(options) {
213
+ const runtime = new ServiceRuntime(options);
214
+ return {
215
+ createDraft: async (input) => {
216
+ const auth = await runtime.getClient(scopes("gmail"));
217
+ const gmail = google.gmail({ version: "v1", auth });
218
+ const rawMessage = [
219
+ `To: ${input.to}`,
220
+ `Subject: ${input.subject}`,
221
+ "Content-Type: text/plain; charset=utf-8",
222
+ "",
223
+ input.body,
224
+ ].join("\r\n");
225
+ const encodedMessage = Buffer.from(rawMessage).toString("base64url");
226
+ try {
227
+ const response = await gmail.users.drafts.create({
228
+ userId: "me",
229
+ requestBody: {
230
+ message: { raw: encodedMessage },
231
+ },
232
+ });
233
+ return {
234
+ id: response.data.id ?? "",
235
+ message: {
236
+ id: response.data.message?.id ?? "",
237
+ threadId: response.data.message?.threadId ?? "",
238
+ subject: input.subject,
239
+ },
240
+ applied: true,
241
+ };
242
+ }
243
+ catch {
244
+ return {
245
+ id: "",
246
+ message: { id: "", threadId: "", subject: "" },
247
+ applied: false,
248
+ };
249
+ }
250
+ },
251
+ listDrafts: async () => {
252
+ const auth = await runtime.getClient(scopes("gmail"));
253
+ const gmail = google.gmail({ version: "v1", auth });
254
+ try {
255
+ const response = await gmail.users.drafts.list({
256
+ userId: "me",
257
+ maxResults: 100,
258
+ });
259
+ const drafts = response.data.drafts ?? [];
260
+ const results = await Promise.all(drafts.map(async (draft) => {
261
+ const detail = await gmail.users.drafts.get({
262
+ userId: "me",
263
+ id: draft.id,
264
+ format: "metadata",
265
+ });
266
+ const subjectHeader = detail.data.message?.payload?.headers?.find((h) => h.name?.toLowerCase() === "subject");
267
+ return {
268
+ id: draft.id ?? "",
269
+ message: {
270
+ id: detail.data.message?.id ?? "",
271
+ threadId: detail.data.message?.threadId ?? "",
272
+ subject: subjectHeader?.value ?? "(no subject)",
273
+ },
274
+ };
275
+ }));
276
+ return results;
277
+ }
278
+ catch {
279
+ return [];
280
+ }
281
+ },
282
+ getDraft: async (draftId) => {
283
+ const auth = await runtime.getClient(scopes("gmail"));
284
+ const gmail = google.gmail({ version: "v1", auth });
285
+ const response = await gmail.users.drafts.get({
286
+ userId: "me",
287
+ id: draftId,
288
+ format: "full",
289
+ });
290
+ return {
291
+ id: response.data.id ?? "",
292
+ message: extractMessageDetail(response.data.message),
293
+ };
294
+ },
295
+ deleteDraft: async (draftId) => {
296
+ const auth = await runtime.getClient(scopes("gmail"));
297
+ const gmail = google.gmail({ version: "v1", auth });
298
+ try {
299
+ await gmail.users.drafts.delete({
300
+ userId: "me",
301
+ id: draftId,
302
+ });
303
+ return { id: draftId, applied: true };
304
+ }
305
+ catch {
306
+ return { id: draftId, applied: false };
307
+ }
308
+ },
309
+ sendDraft: async (draftId) => {
310
+ const auth = await runtime.getClient(scopes("gmail"));
311
+ const gmail = google.gmail({ version: "v1", auth });
312
+ try {
313
+ const response = await gmail.users.drafts.send({
314
+ userId: "me",
315
+ requestBody: { id: draftId },
316
+ });
317
+ return {
318
+ id: response.data.id ?? "",
319
+ threadId: response.data.threadId ?? "",
320
+ sent: response.status === 200,
321
+ };
322
+ }
323
+ catch {
324
+ return {
325
+ id: "",
326
+ threadId: "",
327
+ sent: false,
328
+ };
329
+ }
330
+ },
331
+ };
332
+ }
333
+ export function buildGmailThreadDeps(options) {
334
+ const runtime = new ServiceRuntime(options);
335
+ return {
336
+ listThreads: async (query) => {
337
+ const auth = await runtime.getClient(scopes("gmail"));
338
+ const gmail = google.gmail({ version: "v1", auth });
339
+ try {
340
+ const params = {
341
+ userId: "me",
342
+ maxResults: 100,
343
+ };
344
+ if (query) {
345
+ params.q = query;
346
+ }
347
+ const response = await gmail.users.threads.list(params);
348
+ const threads = response.data.threads ?? [];
349
+ const results = await Promise.all(threads.map(async (thread) => {
350
+ const detail = await gmail.users.threads.get({
351
+ userId: "me",
352
+ id: thread.id,
353
+ format: "metadata",
354
+ });
355
+ return {
356
+ id: thread.id ?? "",
357
+ snippet: detail.data.snippet ?? "",
358
+ messageCount: detail.data.messages?.length ?? 0,
359
+ };
360
+ }));
361
+ return results;
362
+ }
363
+ catch {
364
+ return [];
365
+ }
366
+ },
367
+ getThread: async (threadId) => {
368
+ const auth = await runtime.getClient(scopes("gmail"));
369
+ const gmail = google.gmail({ version: "v1", auth });
370
+ const response = await gmail.users.threads.get({
371
+ userId: "me",
372
+ id: threadId,
373
+ format: "full",
374
+ });
375
+ const messages = response.data.messages ?? [];
376
+ return {
377
+ id: response.data.id ?? "",
378
+ messages: messages.map((msg) => extractMessageDetail(msg)),
379
+ };
380
+ },
381
+ };
382
+ }
383
+ export function buildGmailLabelDeps(options) {
384
+ const runtime = new ServiceRuntime(options);
385
+ return {
386
+ createLabel: async (input) => {
387
+ const auth = await runtime.getClient(scopes("gmail"));
388
+ const gmail = google.gmail({ version: "v1", auth });
389
+ try {
390
+ const requestBody = {
391
+ name: input.name,
392
+ };
393
+ if (input.textColor && input.backgroundColor) {
394
+ requestBody.color = {
395
+ textColor: input.textColor,
396
+ backgroundColor: input.backgroundColor,
397
+ };
398
+ }
399
+ const response = await gmail.users.labels.create({
400
+ userId: "me",
401
+ requestBody,
402
+ });
403
+ return {
404
+ id: response.data.id ?? "",
405
+ name: response.data.name ?? "",
406
+ applied: true,
407
+ };
408
+ }
409
+ catch {
410
+ return {
411
+ id: "",
412
+ name: input.name,
413
+ applied: false,
414
+ };
415
+ }
416
+ },
417
+ getLabel: async (labelId) => {
418
+ const auth = await runtime.getClient(scopes("gmail"));
419
+ const gmail = google.gmail({ version: "v1", auth });
420
+ const response = await gmail.users.labels.get({
421
+ userId: "me",
422
+ id: labelId,
423
+ });
424
+ const result = {
425
+ id: response.data.id ?? "",
426
+ name: response.data.name ?? "",
427
+ type: response.data.type ?? "",
428
+ };
429
+ if (response.data.messagesTotal != null) {
430
+ result.messagesTotal = response.data.messagesTotal;
431
+ }
432
+ if (response.data.messagesUnread != null) {
433
+ result.messagesUnread = response.data.messagesUnread;
434
+ }
435
+ if (response.data.threadsTotal != null) {
436
+ result.threadsTotal = response.data.threadsTotal;
437
+ }
438
+ if (response.data.threadsUnread != null) {
439
+ result.threadsUnread = response.data.threadsUnread;
440
+ }
441
+ if (response.data.color) {
442
+ result.color = {
443
+ textColor: response.data.color.textColor ?? "",
444
+ backgroundColor: response.data.color.backgroundColor ?? "",
445
+ };
446
+ }
447
+ return result;
448
+ },
449
+ updateLabel: async (labelId, name, textColor, backgroundColor) => {
450
+ const auth = await runtime.getClient(scopes("gmail"));
451
+ const gmail = google.gmail({ version: "v1", auth });
452
+ try {
453
+ const requestBody = {
454
+ name,
455
+ };
456
+ if (textColor && backgroundColor) {
457
+ requestBody.color = {
458
+ textColor,
459
+ backgroundColor,
460
+ };
461
+ }
462
+ const response = await gmail.users.labels.update({
463
+ userId: "me",
464
+ id: labelId,
465
+ requestBody,
466
+ });
467
+ return {
468
+ id: response.data.id ?? "",
469
+ name: response.data.name ?? "",
470
+ applied: true,
471
+ };
472
+ }
473
+ catch {
474
+ return {
475
+ id: labelId,
476
+ name,
477
+ applied: false,
478
+ };
479
+ }
480
+ },
481
+ deleteLabel: async (labelId) => {
482
+ const auth = await runtime.getClient(scopes("gmail"));
483
+ const gmail = google.gmail({ version: "v1", auth });
484
+ try {
485
+ await gmail.users.labels.delete({
486
+ userId: "me",
487
+ id: labelId,
488
+ });
489
+ return { id: labelId, applied: true };
490
+ }
491
+ catch {
492
+ return { id: labelId, applied: false };
493
+ }
494
+ },
495
+ };
496
+ }
497
+ export function buildGmailFilterDeps(options) {
498
+ const runtime = new ServiceRuntime(options);
499
+ return {
500
+ listFilters: async () => {
501
+ const auth = await runtime.getClient(scopes("gmail"));
502
+ const gmail = google.gmail({ version: "v1", auth });
503
+ try {
504
+ const response = await gmail.users.settings.filters.list({
505
+ userId: "me",
506
+ });
507
+ const filters = response.data.filter ?? [];
508
+ return filters.map((filter) => ({
509
+ id: filter.id ?? "",
510
+ query: filter.criteria?.query ?? "",
511
+ addLabelIds: filter.action?.addLabelIds ?? [],
512
+ }));
513
+ }
514
+ catch {
515
+ return [];
516
+ }
517
+ },
518
+ createFilter: async (query, addLabelIds) => {
519
+ const auth = await runtime.getClient(scopes("gmail"));
520
+ const gmail = google.gmail({ version: "v1", auth });
521
+ try {
522
+ const response = await gmail.users.settings.filters.create({
523
+ userId: "me",
524
+ requestBody: {
525
+ criteria: { query },
526
+ action: { addLabelIds },
527
+ },
528
+ });
529
+ return {
530
+ id: response.data.id ?? "",
531
+ query,
532
+ addLabelIds,
533
+ applied: true,
534
+ };
535
+ }
536
+ catch {
537
+ return {
538
+ id: "",
539
+ query,
540
+ addLabelIds,
541
+ applied: false,
542
+ };
543
+ }
544
+ },
545
+ deleteFilter: async (filterId) => {
546
+ const auth = await runtime.getClient(scopes("gmail"));
547
+ const gmail = google.gmail({ version: "v1", auth });
548
+ try {
549
+ await gmail.users.settings.filters.delete({
550
+ userId: "me",
551
+ id: filterId,
552
+ });
553
+ return { id: filterId, applied: true };
554
+ }
555
+ catch {
556
+ return { id: filterId, applied: false };
557
+ }
558
+ },
559
+ };
560
+ }
561
+ export function buildGmailSignatureDeps(options) {
562
+ const runtime = new ServiceRuntime(options);
563
+ return {
564
+ listSendAs: async () => {
565
+ const auth = await runtime.getClient(scopes("gmail"));
566
+ const gmail = google.gmail({ version: "v1", auth });
567
+ try {
568
+ const response = await gmail.users.settings.sendAs.list({
569
+ userId: "me",
570
+ });
571
+ const aliases = response.data.sendAs ?? [];
572
+ return aliases.map((alias) => {
573
+ const result = {
574
+ sendAsEmail: alias.sendAsEmail ?? "",
575
+ isPrimary: alias.isPrimary ?? false,
576
+ };
577
+ if (alias.displayName != null) {
578
+ result.displayName = alias.displayName;
579
+ }
580
+ if (alias.signature != null) {
581
+ result.signature = alias.signature;
582
+ }
583
+ if (alias.isDefault != null) {
584
+ result.isDefault = alias.isDefault;
585
+ }
586
+ if (alias.treatAsAlias != null) {
587
+ result.treatAsAlias = alias.treatAsAlias;
588
+ }
589
+ if (alias.verificationStatus != null) {
590
+ result.verificationStatus = alias.verificationStatus;
591
+ }
592
+ return result;
593
+ });
594
+ }
595
+ catch {
596
+ return [];
597
+ }
598
+ },
599
+ getSendAs: async (email) => {
600
+ const auth = await runtime.getClient(scopes("gmail"));
601
+ const gmail = google.gmail({ version: "v1", auth });
602
+ const response = await gmail.users.settings.sendAs.get({
603
+ userId: "me",
604
+ sendAsEmail: email,
605
+ });
606
+ const result = {
607
+ sendAsEmail: response.data.sendAsEmail ?? "",
608
+ isPrimary: response.data.isPrimary ?? false,
609
+ };
610
+ if (response.data.displayName != null) {
611
+ result.displayName = response.data.displayName;
612
+ }
613
+ if (response.data.signature != null) {
614
+ result.signature = response.data.signature;
615
+ }
616
+ if (response.data.isDefault != null) {
617
+ result.isDefault = response.data.isDefault;
618
+ }
619
+ if (response.data.treatAsAlias != null) {
620
+ result.treatAsAlias = response.data.treatAsAlias;
621
+ }
622
+ if (response.data.verificationStatus != null) {
623
+ result.verificationStatus = response.data.verificationStatus;
624
+ }
625
+ return result;
626
+ },
627
+ setSignature: async (email, signature) => {
628
+ const auth = await runtime.getClient(scopes("gmail"));
629
+ const gmail = google.gmail({ version: "v1", auth });
630
+ try {
631
+ await gmail.users.settings.sendAs.update({
632
+ userId: "me",
633
+ sendAsEmail: email,
634
+ requestBody: { signature },
635
+ });
636
+ return { email, applied: true };
637
+ }
638
+ catch {
639
+ return { email, applied: false };
640
+ }
641
+ },
642
+ };
643
+ }
644
+ //# sourceMappingURL=runtime.js.map