gtypee 1.0.2

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 +1431 -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,852 @@
1
+ import { google } from "googleapis";
2
+ import { ServiceRuntime } from "../../googleapi/auth-factory.js";
3
+ import { scopes } from "../../googleauth/service.js";
4
+ function generatePassword(length = 8) {
5
+ const chars = "ABCDEFGHJKLMNPQRSTUVWXYZabcdefghjkmnpqrstuvwxyz23456789";
6
+ let password = "";
7
+ for (let i = 0; i < length; i++) {
8
+ password += chars.charAt(Math.floor(Math.random() * chars.length));
9
+ }
10
+ return password;
11
+ }
12
+ export function buildWorkspaceUserCommandDeps(options) {
13
+ const runtime = new ServiceRuntime(options);
14
+ return {
15
+ listUsers: async (orgUnitPath) => {
16
+ const auth = await runtime.getClient(scopes("workspace"));
17
+ const admin = google.admin({ version: "directory_v1", auth });
18
+ let query = "isSuspended=false";
19
+ if (orgUnitPath) {
20
+ query = `orgUnitPath='${orgUnitPath}'`;
21
+ }
22
+ const response = await admin.users.list({
23
+ customer: "my_customer",
24
+ maxResults: 500,
25
+ orderBy: "email",
26
+ query,
27
+ });
28
+ const users = response.data.users ?? [];
29
+ const result = [];
30
+ for (const user of users) {
31
+ result.push({
32
+ id: user.id ?? "",
33
+ primaryEmail: user.primaryEmail ?? "",
34
+ name: {
35
+ givenName: user.name?.givenName ?? "",
36
+ familyName: user.name?.familyName ?? "",
37
+ },
38
+ suspended: user.suspended ?? false,
39
+ orgUnitPath: user.orgUnitPath ?? "/",
40
+ isAdmin: user.isAdmin ?? false,
41
+ });
42
+ }
43
+ return result;
44
+ },
45
+ createUser: async (input) => {
46
+ const auth = await runtime.getClient(scopes("workspace"));
47
+ const admin = google.admin({ version: "directory_v1", auth });
48
+ const password = input.password ?? generatePassword(8);
49
+ try {
50
+ const response = await admin.users.insert({
51
+ requestBody: {
52
+ primaryEmail: input.email,
53
+ name: {
54
+ givenName: input.firstName,
55
+ familyName: input.lastName,
56
+ },
57
+ password,
58
+ orgUnitPath: input.orgUnitPath ?? null,
59
+ },
60
+ });
61
+ const userId = response.data.id ?? "";
62
+ // Add to groups if specified
63
+ if (input.groups !== undefined && input.groups.length > 0) {
64
+ for (const groupEmail of input.groups) {
65
+ try {
66
+ await admin.members.insert({
67
+ groupKey: groupEmail,
68
+ requestBody: { email: input.email, role: "MEMBER" },
69
+ });
70
+ }
71
+ catch {
72
+ // Continue even if group add fails
73
+ }
74
+ }
75
+ }
76
+ // Make admin if specified
77
+ if (input.makeAdmin) {
78
+ try {
79
+ await admin.users.makeAdmin({
80
+ userKey: input.email,
81
+ requestBody: { status: true },
82
+ });
83
+ }
84
+ catch {
85
+ // Continue even if admin set fails
86
+ }
87
+ }
88
+ return {
89
+ userId,
90
+ primaryEmail: input.email,
91
+ password,
92
+ applied: true,
93
+ };
94
+ }
95
+ catch {
96
+ return {
97
+ userId: "",
98
+ primaryEmail: input.email,
99
+ password: "",
100
+ applied: false,
101
+ };
102
+ }
103
+ },
104
+ deleteUser: async (email) => {
105
+ const auth = await runtime.getClient(scopes("workspace"));
106
+ const admin = google.admin({ version: "directory_v1", auth });
107
+ try {
108
+ await admin.users.delete({ userKey: email });
109
+ return { email, applied: true };
110
+ }
111
+ catch {
112
+ return { email, applied: false };
113
+ }
114
+ },
115
+ suspendUser: async (email) => {
116
+ const auth = await runtime.getClient(scopes("workspace"));
117
+ const admin = google.admin({ version: "directory_v1", auth });
118
+ try {
119
+ await admin.users.update({
120
+ userKey: email,
121
+ requestBody: { suspended: true },
122
+ });
123
+ return { email, suspended: true, applied: true };
124
+ }
125
+ catch {
126
+ return { email, suspended: true, applied: false };
127
+ }
128
+ },
129
+ unsuspendUser: async (email) => {
130
+ const auth = await runtime.getClient(scopes("workspace"));
131
+ const admin = google.admin({ version: "directory_v1", auth });
132
+ try {
133
+ await admin.users.update({
134
+ userKey: email,
135
+ requestBody: { suspended: false },
136
+ });
137
+ return { email, suspended: false, applied: true };
138
+ }
139
+ catch {
140
+ return { email, suspended: false, applied: false };
141
+ }
142
+ },
143
+ setAdmin: async (email, makeAdmin) => {
144
+ const auth = await runtime.getClient(scopes("workspace"));
145
+ const admin = google.admin({ version: "directory_v1", auth });
146
+ try {
147
+ await admin.users.makeAdmin({
148
+ userKey: email,
149
+ requestBody: { status: makeAdmin },
150
+ });
151
+ return { email, isAdmin: makeAdmin, applied: true };
152
+ }
153
+ catch {
154
+ return { email, isAdmin: makeAdmin, applied: false };
155
+ }
156
+ },
157
+ resetPassword: async (email) => {
158
+ const auth = await runtime.getClient(scopes("workspace"));
159
+ const admin = google.admin({ version: "directory_v1", auth });
160
+ const newPassword = generatePassword(8);
161
+ try {
162
+ await admin.users.update({
163
+ userKey: email,
164
+ requestBody: { password: newPassword },
165
+ });
166
+ return { email, newPassword, applied: true };
167
+ }
168
+ catch {
169
+ return { email, newPassword: "", applied: false };
170
+ }
171
+ },
172
+ setOrgUnit: async (email, orgUnitPath) => {
173
+ const auth = await runtime.getClient(scopes("workspace"));
174
+ const admin = google.admin({ version: "directory_v1", auth });
175
+ try {
176
+ await admin.users.update({
177
+ userKey: email,
178
+ requestBody: { orgUnitPath },
179
+ });
180
+ return { email, orgUnitPath, applied: true };
181
+ }
182
+ catch {
183
+ return { email, orgUnitPath, applied: false };
184
+ }
185
+ },
186
+ listOrgUnits: async () => {
187
+ const auth = await runtime.getClient(scopes("workspace"));
188
+ const admin = google.admin({ version: "directory_v1", auth });
189
+ const response = await admin.orgunits.list({
190
+ customerId: "my_customer",
191
+ });
192
+ const units = response.data.organizationUnits ?? [];
193
+ return units.map((unit) => ({
194
+ orgUnitId: unit.orgUnitId ?? "",
195
+ name: unit.name ?? "",
196
+ orgUnitPath: unit.orgUnitPath ?? "",
197
+ parentOrgUnitId: unit.parentOrgUnitId ?? undefined,
198
+ }));
199
+ },
200
+ addAlias: async (email, alias) => {
201
+ const auth = await runtime.getClient(scopes("workspace"));
202
+ const admin = google.admin({ version: "directory_v1", auth });
203
+ try {
204
+ await admin.users.aliases.insert({
205
+ userKey: email,
206
+ requestBody: { alias },
207
+ });
208
+ return { alias, applied: true };
209
+ }
210
+ catch {
211
+ return { alias, applied: false };
212
+ }
213
+ },
214
+ listAliases: async (email) => {
215
+ const auth = await runtime.getClient(scopes("workspace"));
216
+ const admin = google.admin({ version: "directory_v1", auth });
217
+ try {
218
+ const response = await admin.users.aliases.list({ userKey: email });
219
+ return response.data.aliases ?? [];
220
+ }
221
+ catch {
222
+ return [];
223
+ }
224
+ },
225
+ deleteAlias: async (email, alias) => {
226
+ const auth = await runtime.getClient(scopes("workspace"));
227
+ const admin = google.admin({ version: "directory_v1", auth });
228
+ try {
229
+ await admin.users.aliases.delete({ userKey: email, alias });
230
+ return { alias, applied: true };
231
+ }
232
+ catch {
233
+ return { alias, applied: false };
234
+ }
235
+ },
236
+ setPhoto: async (email, _photoData) => {
237
+ const auth = await runtime.getClient(scopes("workspace"));
238
+ const admin = google.admin({ version: "directory_v1", auth });
239
+ try {
240
+ await admin.users.photos.update({
241
+ userKey: email,
242
+ requestBody: { photoData: _photoData },
243
+ });
244
+ return { email, applied: true };
245
+ }
246
+ catch {
247
+ return { email, applied: false };
248
+ }
249
+ },
250
+ deletePhoto: async (email) => {
251
+ const auth = await runtime.getClient(scopes("workspace"));
252
+ const admin = google.admin({ version: "directory_v1", auth });
253
+ try {
254
+ await admin.users.photos.delete({ userKey: email });
255
+ return { email, applied: true };
256
+ }
257
+ catch {
258
+ return { email, applied: false };
259
+ }
260
+ },
261
+ getPhoto: async (email) => {
262
+ const auth = await runtime.getClient(scopes("workspace"));
263
+ const admin = google.admin({ version: "directory_v1", auth });
264
+ try {
265
+ const response = await admin.users.photos.get({ userKey: email });
266
+ return response.data.photoData ?? "";
267
+ }
268
+ catch {
269
+ return "";
270
+ }
271
+ },
272
+ generateBackupCodes: async (email) => {
273
+ const auth = await runtime.getClient(scopes("workspace"));
274
+ const admin = google.admin({ version: "directory_v1", auth });
275
+ try {
276
+ await admin.verificationCodes.generate({ userKey: email });
277
+ const response = await admin.verificationCodes.list({ userKey: email });
278
+ const codes = response.data.items ?? [];
279
+ return { email, codes: codes.map((c) => c.verificationCode ?? ""), applied: true };
280
+ }
281
+ catch (err) {
282
+ console.error("generateBackupCodes error:", err);
283
+ return { email, codes: [], applied: false };
284
+ }
285
+ },
286
+ };
287
+ }
288
+ export function buildWorkspaceGroupCommandDeps(options) {
289
+ const runtime = new ServiceRuntime(options);
290
+ return {
291
+ createGroup: async (input) => {
292
+ const auth = await runtime.getClient(scopes("workspace"));
293
+ const admin = google.admin({ version: "directory_v1", auth });
294
+ try {
295
+ const response = await admin.groups.insert({
296
+ requestBody: {
297
+ email: input.email,
298
+ name: input.name,
299
+ },
300
+ });
301
+ return {
302
+ groupId: response.data.id ?? "",
303
+ email: input.email,
304
+ name: input.name,
305
+ applied: true,
306
+ };
307
+ }
308
+ catch {
309
+ return { groupId: "", email: input.email, name: input.name, applied: false };
310
+ }
311
+ },
312
+ deleteGroup: async (email) => {
313
+ const auth = await runtime.getClient(scopes("workspace"));
314
+ const admin = google.admin({ version: "directory_v1", auth });
315
+ try {
316
+ await admin.groups.delete({ groupKey: email });
317
+ return { email, applied: true };
318
+ }
319
+ catch {
320
+ return { email, applied: false };
321
+ }
322
+ },
323
+ updateGroup: async (email, name) => {
324
+ const auth = await runtime.getClient(scopes("workspace"));
325
+ const admin = google.admin({ version: "directory_v1", auth });
326
+ try {
327
+ await admin.groups.update({
328
+ groupKey: email,
329
+ requestBody: { name },
330
+ });
331
+ return { email, name, applied: true };
332
+ }
333
+ catch {
334
+ return { email, name, applied: false };
335
+ }
336
+ },
337
+ getGroup: async (email) => {
338
+ const auth = await runtime.getClient(scopes("workspace"));
339
+ const admin = google.admin({ version: "directory_v1", auth });
340
+ try {
341
+ const response = await admin.groups.get({ groupKey: email });
342
+ return {
343
+ id: response.data.id ?? "",
344
+ email: response.data.email ?? "",
345
+ name: response.data.name ?? "",
346
+ };
347
+ }
348
+ catch {
349
+ return { id: "", email: "", name: "" };
350
+ }
351
+ },
352
+ listGroups: async () => {
353
+ const auth = await runtime.getClient(scopes("workspace"));
354
+ const admin = google.admin({ version: "directory_v1", auth });
355
+ try {
356
+ const response = await admin.groups.list({ customer: "my_customer" });
357
+ const groups = response.data.groups ?? [];
358
+ return groups.map((g) => ({
359
+ id: g.id ?? "",
360
+ email: g.email ?? "",
361
+ name: g.name ?? "",
362
+ }));
363
+ }
364
+ catch {
365
+ return [];
366
+ }
367
+ },
368
+ addGroupMember: async (groupEmail, memberEmail, role) => {
369
+ const auth = await runtime.getClient(scopes("workspace"));
370
+ const admin = google.admin({ version: "directory_v1", auth });
371
+ try {
372
+ await admin.members.insert({
373
+ groupKey: groupEmail,
374
+ requestBody: { email: memberEmail, role },
375
+ });
376
+ return { groupEmail, memberEmail, role, applied: true };
377
+ }
378
+ catch {
379
+ return { groupEmail, memberEmail, role, applied: false };
380
+ }
381
+ },
382
+ removeGroupMember: async (groupEmail, memberEmail) => {
383
+ const auth = await runtime.getClient(scopes("workspace"));
384
+ const admin = google.admin({ version: "directory_v1", auth });
385
+ try {
386
+ await admin.members.delete({
387
+ groupKey: groupEmail,
388
+ memberKey: memberEmail,
389
+ });
390
+ return { groupEmail, memberEmail, applied: true };
391
+ }
392
+ catch {
393
+ return { groupEmail, memberEmail, applied: false };
394
+ }
395
+ },
396
+ listGroupMembers: async (groupEmail) => {
397
+ const auth = await runtime.getClient(scopes("workspace"));
398
+ const admin = google.admin({ version: "directory_v1", auth });
399
+ try {
400
+ const response = await admin.members.list({ groupKey: groupEmail });
401
+ const members = response.data.members ?? [];
402
+ return members.map((m) => ({
403
+ email: m.email ?? "",
404
+ role: m.role ?? "",
405
+ status: m.status ?? "",
406
+ }));
407
+ }
408
+ catch {
409
+ return [];
410
+ }
411
+ },
412
+ };
413
+ }
414
+ function arrayToString(value) {
415
+ if (value === undefined || value === null)
416
+ return "";
417
+ return Array.isArray(value) ? value.join(", ") : value;
418
+ }
419
+ export function buildWorkspaceDeviceCommandDeps(options) {
420
+ const runtime = new ServiceRuntime(options);
421
+ return {
422
+ listDevices: async (input) => {
423
+ const auth = await runtime.getClient(scopes("workspace"));
424
+ const admin = google.admin({ version: "directory_v1", auth });
425
+ const result = [];
426
+ try {
427
+ if (input.type === "chromebook") {
428
+ const params = {
429
+ customerId: "my_customer",
430
+ maxResults: 500,
431
+ };
432
+ if (input.orgUnitPath) {
433
+ params.orgUnitPath = input.orgUnitPath;
434
+ }
435
+ const response = await admin.chromeosdevices.list(params);
436
+ const devices = response.data.chromeosdevices ?? [];
437
+ for (const d of devices) {
438
+ result.push({
439
+ deviceId: d.deviceId ?? "",
440
+ email: d.annotatedUser ?? "",
441
+ modelName: d.model ?? "",
442
+ osVersion: d.osVersion ?? "",
443
+ status: d.status ?? "",
444
+ orgUnitPath: d.orgUnitPath ?? "",
445
+ lastSync: d.lastSync ?? "",
446
+ });
447
+ }
448
+ }
449
+ else if (input.type === "mobile") {
450
+ const response = await admin.mobiledevices.list({
451
+ customerId: "my_customer",
452
+ maxResults: 500,
453
+ });
454
+ const devices = response.data.mobiledevices ?? [];
455
+ for (const d of devices) {
456
+ result.push({
457
+ deviceId: d.deviceId ?? "",
458
+ email: arrayToString(d.email),
459
+ modelName: arrayToString(d.model),
460
+ osVersion: arrayToString(d.os),
461
+ status: d.status ?? "",
462
+ orgUnitPath: "",
463
+ lastSync: d.lastSync ?? "",
464
+ });
465
+ }
466
+ }
467
+ else {
468
+ // Both types - fetch chromebooks and mobile
469
+ const chromeParams = {
470
+ customerId: "my_customer",
471
+ maxResults: 500,
472
+ };
473
+ if (input.orgUnitPath) {
474
+ chromeParams.orgUnitPath = input.orgUnitPath;
475
+ }
476
+ const [chromeResponse, mobileResponse] = await Promise.all([
477
+ admin.chromeosdevices.list(chromeParams),
478
+ admin.mobiledevices.list({
479
+ customerId: "my_customer",
480
+ maxResults: 500,
481
+ }),
482
+ ]);
483
+ const chromeDevices = chromeResponse.data.chromeosdevices ?? [];
484
+ for (const d of chromeDevices) {
485
+ result.push({
486
+ deviceId: d.deviceId ?? "",
487
+ email: d.annotatedUser ?? "",
488
+ modelName: d.model ?? "",
489
+ osVersion: d.osVersion ?? "",
490
+ status: d.status ?? "",
491
+ orgUnitPath: d.orgUnitPath ?? "",
492
+ lastSync: d.lastSync ?? "",
493
+ });
494
+ }
495
+ const mobileDevices = mobileResponse.data.mobiledevices ?? [];
496
+ for (const d of mobileDevices) {
497
+ result.push({
498
+ deviceId: d.deviceId ?? "",
499
+ email: arrayToString(d.email),
500
+ modelName: arrayToString(d.model),
501
+ osVersion: arrayToString(d.os),
502
+ status: d.status ?? "",
503
+ orgUnitPath: "",
504
+ lastSync: d.lastSync ?? "",
505
+ });
506
+ }
507
+ }
508
+ }
509
+ catch {
510
+ return [];
511
+ }
512
+ return result;
513
+ },
514
+ getDevice: async (deviceId) => {
515
+ const auth = await runtime.getClient(scopes("workspace"));
516
+ const admin = google.admin({ version: "directory_v1", auth });
517
+ // Try chromebook first
518
+ try {
519
+ const response = await admin.chromeosdevices.get({
520
+ customerId: "my_customer",
521
+ deviceId,
522
+ });
523
+ const d = response.data;
524
+ return {
525
+ deviceId: d.deviceId ?? "",
526
+ email: d.annotatedUser ?? "",
527
+ modelName: d.model ?? "",
528
+ osVersion: d.osVersion ?? "",
529
+ status: d.status ?? "",
530
+ orgUnitPath: d.orgUnitPath ?? "",
531
+ lastSync: d.lastSync ?? "",
532
+ };
533
+ }
534
+ catch {
535
+ // Try mobile device
536
+ try {
537
+ const response = await admin.mobiledevices.get({
538
+ customerId: "my_customer",
539
+ resourceId: deviceId,
540
+ });
541
+ const d = response.data;
542
+ return {
543
+ deviceId: d.deviceId ?? "",
544
+ email: arrayToString(d.email),
545
+ modelName: arrayToString(d.model),
546
+ osVersion: arrayToString(d.os),
547
+ status: d.status ?? "",
548
+ orgUnitPath: "",
549
+ lastSync: d.lastSync ?? "",
550
+ };
551
+ }
552
+ catch {
553
+ return { deviceId, email: "", modelName: "", osVersion: "", status: "", orgUnitPath: "", lastSync: "" };
554
+ }
555
+ }
556
+ },
557
+ wipeDevice: async (deviceId) => {
558
+ const auth = await runtime.getClient(scopes("workspace"));
559
+ const admin = google.admin({ version: "directory_v1", auth });
560
+ // Try mobile device wipe first
561
+ try {
562
+ await admin.mobiledevices.action({
563
+ customerId: "my_customer",
564
+ resourceId: deviceId,
565
+ requestBody: { action: "admin_remote_wipe" },
566
+ });
567
+ return { deviceId, applied: true };
568
+ }
569
+ catch {
570
+ // Try chromebook wipe
571
+ try {
572
+ await admin.chromeosdevices.action({
573
+ customerId: "my_customer",
574
+ resourceId: deviceId,
575
+ requestBody: { action: "wipe_users" },
576
+ });
577
+ return { deviceId, applied: true };
578
+ }
579
+ catch {
580
+ return { deviceId, applied: false };
581
+ }
582
+ }
583
+ },
584
+ disableDevice: async (deviceId) => {
585
+ const auth = await runtime.getClient(scopes("workspace"));
586
+ const admin = google.admin({ version: "directory_v1", auth });
587
+ // Try mobile device disable
588
+ try {
589
+ await admin.mobiledevices.action({
590
+ customerId: "my_customer",
591
+ resourceId: deviceId,
592
+ requestBody: { action: "disable" },
593
+ });
594
+ return { deviceId, applied: true };
595
+ }
596
+ catch {
597
+ // Try chromebook disable
598
+ try {
599
+ await admin.chromeosdevices.action({
600
+ customerId: "my_customer",
601
+ resourceId: deviceId,
602
+ requestBody: { action: "disable" },
603
+ });
604
+ return { deviceId, applied: true };
605
+ }
606
+ catch {
607
+ return { deviceId, applied: false };
608
+ }
609
+ }
610
+ },
611
+ };
612
+ }
613
+ export function buildWorkspaceReportCommandDeps(options) {
614
+ const runtime = new ServiceRuntime(options);
615
+ /**
616
+ * Calculate the start time for a given number of days ago in RFC 3339 format
617
+ */
618
+ function getStartTime(days) {
619
+ const date = new Date();
620
+ date.setDate(date.getDate() - days);
621
+ return date.toISOString();
622
+ }
623
+ return {
624
+ getLoginAudit: async (days) => {
625
+ const auth = await runtime.getClient(scopes("workspace"));
626
+ const admin = google.admin({ version: "reports_v1", auth });
627
+ const result = [];
628
+ try {
629
+ const response = await admin.activities.list({
630
+ userKey: "all",
631
+ applicationName: "login",
632
+ startTime: getStartTime(days),
633
+ maxResults: 1000,
634
+ });
635
+ const activities = response.data.items ?? [];
636
+ for (const activity of activities) {
637
+ const events = activity.events ?? [];
638
+ for (const event of events) {
639
+ // Extract IP address from the event parameters
640
+ const parameters = event.parameters ?? [];
641
+ const ipParam = parameters.find((p) => p.name === "ip_address");
642
+ const ipAddress = ipParam?.value ?? "";
643
+ // Determine if login was successful based on event name
644
+ const success = event.name === "login_success";
645
+ result.push({
646
+ userEmail: activity.actor?.email ?? "",
647
+ timestamp: activity.id?.time ?? "",
648
+ ipAddress: ipAddress,
649
+ success,
650
+ });
651
+ }
652
+ }
653
+ }
654
+ catch (err) {
655
+ console.error("getLoginAudit error:", err);
656
+ }
657
+ return result;
658
+ },
659
+ getAdminAudit: async (days) => {
660
+ const auth = await runtime.getClient(scopes("workspace"));
661
+ const admin = google.admin({ version: "reports_v1", auth });
662
+ const result = [];
663
+ try {
664
+ const response = await admin.activities.list({
665
+ userKey: "all",
666
+ applicationName: "admin",
667
+ startTime: getStartTime(days),
668
+ maxResults: 1000,
669
+ });
670
+ const activities = response.data.items ?? [];
671
+ for (const activity of activities) {
672
+ const events = activity.events ?? [];
673
+ for (const event of events) {
674
+ result.push({
675
+ userEmail: activity.actor?.email ?? "",
676
+ timestamp: activity.id?.time ?? "",
677
+ action: event.name ?? "",
678
+ resource: activity.id?.uniqueQualifier ?? "",
679
+ });
680
+ }
681
+ }
682
+ }
683
+ catch (err) {
684
+ console.error("getAdminAudit error:", err);
685
+ }
686
+ return result;
687
+ },
688
+ getDeletedUsers: async (days) => {
689
+ const auth = await runtime.getClient(scopes("workspace"));
690
+ const admin = google.admin({ version: "reports_v1", auth });
691
+ const result = [];
692
+ try {
693
+ const response = await admin.activities.list({
694
+ userKey: "all",
695
+ applicationName: "admin",
696
+ startTime: getStartTime(days),
697
+ maxResults: 1000,
698
+ });
699
+ const activities = response.data.items ?? [];
700
+ for (const activity of activities) {
701
+ const events = activity.events ?? [];
702
+ for (const event of events) {
703
+ // Filter for user deletion events
704
+ if (event.name === "DELETE_USER" || event.name === "delete_user") {
705
+ // Try to extract the deleted user's email from parameters
706
+ const parameters = event.parameters ?? [];
707
+ const userEmailParam = parameters.find((p) => p.name === "user_email" || p.name === "USER_EMAIL");
708
+ const userEmail = userEmailParam?.value ?? "";
709
+ if (userEmail) {
710
+ result.push({
711
+ userEmail: userEmail,
712
+ deletionTime: activity.id?.time ?? "",
713
+ });
714
+ }
715
+ }
716
+ }
717
+ }
718
+ }
719
+ catch (err) {
720
+ console.error("getDeletedUsers error:", err);
721
+ }
722
+ return result;
723
+ },
724
+ };
725
+ }
726
+ export function buildWorkspaceOrgUnitCommandDeps(options) {
727
+ const runtime = new ServiceRuntime(options);
728
+ return {
729
+ listOrgUnits: async () => {
730
+ const auth = await runtime.getClient(scopes("workspace"));
731
+ const admin = google.admin({ version: "directory_v1", auth });
732
+ const response = await admin.orgunits.list({
733
+ customerId: "my_customer",
734
+ });
735
+ const units = response.data.organizationUnits ?? [];
736
+ return units.map((unit) => ({
737
+ orgUnitId: unit.orgUnitId ?? "",
738
+ name: unit.name ?? "",
739
+ orgUnitPath: unit.orgUnitPath ?? "",
740
+ parentOrgUnitId: unit.parentOrgUnitId ?? undefined,
741
+ description: unit.description ?? undefined,
742
+ }));
743
+ },
744
+ createOrgUnit: async (input) => {
745
+ const auth = await runtime.getClient(scopes("workspace"));
746
+ const admin = google.admin({ version: "directory_v1", auth });
747
+ try {
748
+ const response = await admin.orgunits.insert({
749
+ customerId: "my_customer",
750
+ requestBody: {
751
+ name: input.name,
752
+ parentOrgUnitPath: input.parentOrgUnitPath,
753
+ description: input.description ?? null,
754
+ },
755
+ });
756
+ return {
757
+ orgUnitId: response.data.orgUnitId ?? "",
758
+ name: response.data.name ?? input.name,
759
+ orgUnitPath: response.data.orgUnitPath ?? "",
760
+ applied: true,
761
+ };
762
+ }
763
+ catch (err) {
764
+ console.error("createOrgUnit error:", err);
765
+ return {
766
+ orgUnitId: "",
767
+ name: input.name,
768
+ orgUnitPath: "",
769
+ applied: false,
770
+ };
771
+ }
772
+ },
773
+ getOrgUnit: async (orgUnitPath) => {
774
+ const auth = await runtime.getClient(scopes("workspace"));
775
+ const admin = google.admin({ version: "directory_v1", auth });
776
+ try {
777
+ const response = await admin.orgunits.get({
778
+ customerId: "my_customer",
779
+ orgUnitPath,
780
+ });
781
+ return {
782
+ orgUnitId: response.data.orgUnitId ?? "",
783
+ name: response.data.name ?? "",
784
+ orgUnitPath: response.data.orgUnitPath ?? "",
785
+ parentOrgUnitId: response.data.parentOrgUnitId ?? undefined,
786
+ description: response.data.description ?? undefined,
787
+ };
788
+ }
789
+ catch (err) {
790
+ console.error("getOrgUnit error:", err);
791
+ return {
792
+ orgUnitId: "",
793
+ name: "",
794
+ orgUnitPath: "",
795
+ };
796
+ }
797
+ },
798
+ updateOrgUnit: async (orgUnitPath, input) => {
799
+ const auth = await runtime.getClient(scopes("workspace"));
800
+ const admin = google.admin({ version: "directory_v1", auth });
801
+ try {
802
+ const requestBody = {};
803
+ if (input.name)
804
+ requestBody.name = input.name;
805
+ if (input.description)
806
+ requestBody.description = input.description;
807
+ if (input.parentOrgUnitId)
808
+ requestBody.parentOrgUnitId = input.parentOrgUnitId;
809
+ const response = await admin.orgunits.update({
810
+ customerId: "my_customer",
811
+ orgUnitPath,
812
+ requestBody,
813
+ });
814
+ return {
815
+ orgUnitId: response.data.orgUnitId ?? "",
816
+ name: response.data.name ?? "",
817
+ applied: true,
818
+ };
819
+ }
820
+ catch (err) {
821
+ console.error("updateOrgUnit error:", err);
822
+ return {
823
+ orgUnitId: "",
824
+ name: input.name ?? "",
825
+ applied: false,
826
+ };
827
+ }
828
+ },
829
+ deleteOrgUnit: async (orgUnitPath) => {
830
+ const auth = await runtime.getClient(scopes("workspace"));
831
+ const admin = google.admin({ version: "directory_v1", auth });
832
+ try {
833
+ await admin.orgunits.delete({
834
+ customerId: "my_customer",
835
+ orgUnitPath,
836
+ });
837
+ return {
838
+ orgUnitPath,
839
+ applied: true,
840
+ };
841
+ }
842
+ catch (err) {
843
+ console.error("deleteOrgUnit error:", err);
844
+ return {
845
+ orgUnitPath,
846
+ applied: false,
847
+ };
848
+ }
849
+ },
850
+ };
851
+ }
852
+ //# sourceMappingURL=runtime.js.map