@cesteral/tiktok-mcp 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 (267) hide show
  1. package/LICENSE.md +201 -0
  2. package/README.md +347 -0
  3. package/dist/auth/index.d.ts +3 -0
  4. package/dist/auth/index.d.ts.map +1 -0
  5. package/dist/auth/index.js +3 -0
  6. package/dist/auth/index.js.map +1 -0
  7. package/dist/auth/tiktok-auth-adapter.d.ts +40 -0
  8. package/dist/auth/tiktok-auth-adapter.d.ts.map +1 -0
  9. package/dist/auth/tiktok-auth-adapter.js +126 -0
  10. package/dist/auth/tiktok-auth-adapter.js.map +1 -0
  11. package/dist/auth/tiktok-auth-strategy.d.ts +14 -0
  12. package/dist/auth/tiktok-auth-strategy.d.ts.map +1 -0
  13. package/dist/auth/tiktok-auth-strategy.js +54 -0
  14. package/dist/auth/tiktok-auth-strategy.js.map +1 -0
  15. package/dist/config/index.d.ts +120 -0
  16. package/dist/config/index.d.ts.map +1 -0
  17. package/dist/config/index.js +55 -0
  18. package/dist/config/index.js.map +1 -0
  19. package/dist/index.d.ts +3 -0
  20. package/dist/index.d.ts.map +1 -0
  21. package/dist/index.js +47 -0
  22. package/dist/index.js.map +1 -0
  23. package/dist/mcp-server/prompts/definitions/bulk-operations-workflow.prompt.d.ts +4 -0
  24. package/dist/mcp-server/prompts/definitions/bulk-operations-workflow.prompt.d.ts.map +1 -0
  25. package/dist/mcp-server/prompts/definitions/bulk-operations-workflow.prompt.js +127 -0
  26. package/dist/mcp-server/prompts/definitions/bulk-operations-workflow.prompt.js.map +1 -0
  27. package/dist/mcp-server/prompts/definitions/campaign-setup-workflow.prompt.d.ts +4 -0
  28. package/dist/mcp-server/prompts/definitions/campaign-setup-workflow.prompt.d.ts.map +1 -0
  29. package/dist/mcp-server/prompts/definitions/campaign-setup-workflow.prompt.js +104 -0
  30. package/dist/mcp-server/prompts/definitions/campaign-setup-workflow.prompt.js.map +1 -0
  31. package/dist/mcp-server/prompts/definitions/creative-upload-workflow.prompt.d.ts +4 -0
  32. package/dist/mcp-server/prompts/definitions/creative-upload-workflow.prompt.d.ts.map +1 -0
  33. package/dist/mcp-server/prompts/definitions/creative-upload-workflow.prompt.js +121 -0
  34. package/dist/mcp-server/prompts/definitions/creative-upload-workflow.prompt.js.map +1 -0
  35. package/dist/mcp-server/prompts/definitions/cross-platform-campaign-setup.prompt.d.ts +4 -0
  36. package/dist/mcp-server/prompts/definitions/cross-platform-campaign-setup.prompt.d.ts.map +1 -0
  37. package/dist/mcp-server/prompts/definitions/cross-platform-campaign-setup.prompt.js +299 -0
  38. package/dist/mcp-server/prompts/definitions/cross-platform-campaign-setup.prompt.js.map +1 -0
  39. package/dist/mcp-server/prompts/definitions/cross-platform-performance.prompt.d.ts +4 -0
  40. package/dist/mcp-server/prompts/definitions/cross-platform-performance.prompt.d.ts.map +1 -0
  41. package/dist/mcp-server/prompts/definitions/cross-platform-performance.prompt.js +170 -0
  42. package/dist/mcp-server/prompts/definitions/cross-platform-performance.prompt.js.map +1 -0
  43. package/dist/mcp-server/prompts/definitions/entity-duplication-workflow.prompt.d.ts +4 -0
  44. package/dist/mcp-server/prompts/definitions/entity-duplication-workflow.prompt.d.ts.map +1 -0
  45. package/dist/mcp-server/prompts/definitions/entity-duplication-workflow.prompt.js +198 -0
  46. package/dist/mcp-server/prompts/definitions/entity-duplication-workflow.prompt.js.map +1 -0
  47. package/dist/mcp-server/prompts/definitions/entity-update-workflow.prompt.d.ts +4 -0
  48. package/dist/mcp-server/prompts/definitions/entity-update-workflow.prompt.d.ts.map +1 -0
  49. package/dist/mcp-server/prompts/definitions/entity-update-workflow.prompt.js +189 -0
  50. package/dist/mcp-server/prompts/definitions/entity-update-workflow.prompt.js.map +1 -0
  51. package/dist/mcp-server/prompts/definitions/reporting-workflow.prompt.d.ts +4 -0
  52. package/dist/mcp-server/prompts/definitions/reporting-workflow.prompt.d.ts.map +1 -0
  53. package/dist/mcp-server/prompts/definitions/reporting-workflow.prompt.js +126 -0
  54. package/dist/mcp-server/prompts/definitions/reporting-workflow.prompt.js.map +1 -0
  55. package/dist/mcp-server/prompts/definitions/targeting-discovery-workflow.prompt.d.ts +4 -0
  56. package/dist/mcp-server/prompts/definitions/targeting-discovery-workflow.prompt.d.ts.map +1 -0
  57. package/dist/mcp-server/prompts/definitions/targeting-discovery-workflow.prompt.js +200 -0
  58. package/dist/mcp-server/prompts/definitions/targeting-discovery-workflow.prompt.js.map +1 -0
  59. package/dist/mcp-server/prompts/definitions/tool-schema-exploration.prompt.d.ts +4 -0
  60. package/dist/mcp-server/prompts/definitions/tool-schema-exploration.prompt.d.ts.map +1 -0
  61. package/dist/mcp-server/prompts/definitions/tool-schema-exploration.prompt.js +93 -0
  62. package/dist/mcp-server/prompts/definitions/tool-schema-exploration.prompt.js.map +1 -0
  63. package/dist/mcp-server/prompts/definitions/troubleshoot-entity.prompt.d.ts +4 -0
  64. package/dist/mcp-server/prompts/definitions/troubleshoot-entity.prompt.d.ts.map +1 -0
  65. package/dist/mcp-server/prompts/definitions/troubleshoot-entity.prompt.js +111 -0
  66. package/dist/mcp-server/prompts/definitions/troubleshoot-entity.prompt.js.map +1 -0
  67. package/dist/mcp-server/prompts/index.d.ts +9 -0
  68. package/dist/mcp-server/prompts/index.d.ts.map +1 -0
  69. package/dist/mcp-server/prompts/index.js +97 -0
  70. package/dist/mcp-server/prompts/index.js.map +1 -0
  71. package/dist/mcp-server/resources/definitions/entity-examples.resource.d.ts +4 -0
  72. package/dist/mcp-server/resources/definitions/entity-examples.resource.d.ts.map +1 -0
  73. package/dist/mcp-server/resources/definitions/entity-examples.resource.js +182 -0
  74. package/dist/mcp-server/resources/definitions/entity-examples.resource.js.map +1 -0
  75. package/dist/mcp-server/resources/definitions/entity-hierarchy.resource.d.ts +3 -0
  76. package/dist/mcp-server/resources/definitions/entity-hierarchy.resource.d.ts.map +1 -0
  77. package/dist/mcp-server/resources/definitions/entity-hierarchy.resource.js +147 -0
  78. package/dist/mcp-server/resources/definitions/entity-hierarchy.resource.js.map +1 -0
  79. package/dist/mcp-server/resources/definitions/entity-schemas.resource.d.ts +4 -0
  80. package/dist/mcp-server/resources/definitions/entity-schemas.resource.d.ts.map +1 -0
  81. package/dist/mcp-server/resources/definitions/entity-schemas.resource.js +135 -0
  82. package/dist/mcp-server/resources/definitions/entity-schemas.resource.js.map +1 -0
  83. package/dist/mcp-server/resources/definitions/index.d.ts +8 -0
  84. package/dist/mcp-server/resources/definitions/index.d.ts.map +1 -0
  85. package/dist/mcp-server/resources/definitions/index.js +79 -0
  86. package/dist/mcp-server/resources/definitions/index.js.map +1 -0
  87. package/dist/mcp-server/resources/definitions/reporting-reference.resource.d.ts +3 -0
  88. package/dist/mcp-server/resources/definitions/reporting-reference.resource.d.ts.map +1 -0
  89. package/dist/mcp-server/resources/definitions/reporting-reference.resource.js +165 -0
  90. package/dist/mcp-server/resources/definitions/reporting-reference.resource.js.map +1 -0
  91. package/dist/mcp-server/resources/definitions/targeting-reference.resource.d.ts +3 -0
  92. package/dist/mcp-server/resources/definitions/targeting-reference.resource.d.ts.map +1 -0
  93. package/dist/mcp-server/resources/definitions/targeting-reference.resource.js +134 -0
  94. package/dist/mcp-server/resources/definitions/targeting-reference.resource.js.map +1 -0
  95. package/dist/mcp-server/resources/index.d.ts +3 -0
  96. package/dist/mcp-server/resources/index.d.ts.map +1 -0
  97. package/dist/mcp-server/resources/index.js +2 -0
  98. package/dist/mcp-server/resources/index.js.map +1 -0
  99. package/dist/mcp-server/resources/types.d.ts +8 -0
  100. package/dist/mcp-server/resources/types.d.ts.map +1 -0
  101. package/dist/mcp-server/resources/types.js +2 -0
  102. package/dist/mcp-server/resources/types.js.map +1 -0
  103. package/dist/mcp-server/server.d.ts +5 -0
  104. package/dist/mcp-server/server.d.ts.map +1 -0
  105. package/dist/mcp-server/server.js +134 -0
  106. package/dist/mcp-server/server.js.map +1 -0
  107. package/dist/mcp-server/tools/definitions/adjust-bids.tool.d.ts +209 -0
  108. package/dist/mcp-server/tools/definitions/adjust-bids.tool.d.ts.map +1 -0
  109. package/dist/mcp-server/tools/definitions/adjust-bids.tool.js +141 -0
  110. package/dist/mcp-server/tools/definitions/adjust-bids.tool.js.map +1 -0
  111. package/dist/mcp-server/tools/definitions/bulk-create-entities.tool.d.ts +151 -0
  112. package/dist/mcp-server/tools/definitions/bulk-create-entities.tool.d.ts.map +1 -0
  113. package/dist/mcp-server/tools/definitions/bulk-create-entities.tool.js +112 -0
  114. package/dist/mcp-server/tools/definitions/bulk-create-entities.tool.js.map +1 -0
  115. package/dist/mcp-server/tools/definitions/bulk-update-entities.tool.d.ts +193 -0
  116. package/dist/mcp-server/tools/definitions/bulk-update-entities.tool.d.ts.map +1 -0
  117. package/dist/mcp-server/tools/definitions/bulk-update-entities.tool.js +130 -0
  118. package/dist/mcp-server/tools/definitions/bulk-update-entities.tool.js.map +1 -0
  119. package/dist/mcp-server/tools/definitions/bulk-update-status.tool.d.ts +153 -0
  120. package/dist/mcp-server/tools/definitions/bulk-update-status.tool.d.ts.map +1 -0
  121. package/dist/mcp-server/tools/definitions/bulk-update-status.tool.js +137 -0
  122. package/dist/mcp-server/tools/definitions/bulk-update-status.tool.js.map +1 -0
  123. package/dist/mcp-server/tools/definitions/check-report-status.tool.d.ts +119 -0
  124. package/dist/mcp-server/tools/definitions/check-report-status.tool.d.ts.map +1 -0
  125. package/dist/mcp-server/tools/definitions/check-report-status.tool.js +89 -0
  126. package/dist/mcp-server/tools/definitions/check-report-status.tool.js.map +1 -0
  127. package/dist/mcp-server/tools/definitions/create-entity.tool.d.ts +115 -0
  128. package/dist/mcp-server/tools/definitions/create-entity.tool.d.ts.map +1 -0
  129. package/dist/mcp-server/tools/definitions/create-entity.tool.js +103 -0
  130. package/dist/mcp-server/tools/definitions/create-entity.tool.js.map +1 -0
  131. package/dist/mcp-server/tools/definitions/delete-entity.tool.d.ts +100 -0
  132. package/dist/mcp-server/tools/definitions/delete-entity.tool.d.ts.map +1 -0
  133. package/dist/mcp-server/tools/definitions/delete-entity.tool.js +110 -0
  134. package/dist/mcp-server/tools/definitions/delete-entity.tool.js.map +1 -0
  135. package/dist/mcp-server/tools/definitions/download-report.tool.d.ts +297 -0
  136. package/dist/mcp-server/tools/definitions/download-report.tool.d.ts.map +1 -0
  137. package/dist/mcp-server/tools/definitions/download-report.tool.js +105 -0
  138. package/dist/mcp-server/tools/definitions/download-report.tool.js.map +1 -0
  139. package/dist/mcp-server/tools/definitions/duplicate-entity.tool.d.ts +105 -0
  140. package/dist/mcp-server/tools/definitions/duplicate-entity.tool.d.ts.map +1 -0
  141. package/dist/mcp-server/tools/definitions/duplicate-entity.tool.js +85 -0
  142. package/dist/mcp-server/tools/definitions/duplicate-entity.tool.js.map +1 -0
  143. package/dist/mcp-server/tools/definitions/get-ad-preview.tool.d.ts +89 -0
  144. package/dist/mcp-server/tools/definitions/get-ad-preview.tool.d.ts.map +1 -0
  145. package/dist/mcp-server/tools/definitions/get-ad-preview.tool.js +74 -0
  146. package/dist/mcp-server/tools/definitions/get-ad-preview.tool.js.map +1 -0
  147. package/dist/mcp-server/tools/definitions/get-ad-previews.tool.d.ts +89 -0
  148. package/dist/mcp-server/tools/definitions/get-ad-previews.tool.d.ts.map +1 -0
  149. package/dist/mcp-server/tools/definitions/get-ad-previews.tool.js +83 -0
  150. package/dist/mcp-server/tools/definitions/get-ad-previews.tool.js.map +1 -0
  151. package/dist/mcp-server/tools/definitions/get-audience-estimate.tool.d.ts +85 -0
  152. package/dist/mcp-server/tools/definitions/get-audience-estimate.tool.d.ts.map +1 -0
  153. package/dist/mcp-server/tools/definitions/get-audience-estimate.tool.js +88 -0
  154. package/dist/mcp-server/tools/definitions/get-audience-estimate.tool.js.map +1 -0
  155. package/dist/mcp-server/tools/definitions/get-entity.tool.d.ts +76 -0
  156. package/dist/mcp-server/tools/definitions/get-entity.tool.d.ts.map +1 -0
  157. package/dist/mcp-server/tools/definitions/get-entity.tool.js +71 -0
  158. package/dist/mcp-server/tools/definitions/get-entity.tool.js.map +1 -0
  159. package/dist/mcp-server/tools/definitions/get-report-breakdowns.tool.d.ts +295 -0
  160. package/dist/mcp-server/tools/definitions/get-report-breakdowns.tool.d.ts.map +1 -0
  161. package/dist/mcp-server/tools/definitions/get-report-breakdowns.tool.js +174 -0
  162. package/dist/mcp-server/tools/definitions/get-report-breakdowns.tool.js.map +1 -0
  163. package/dist/mcp-server/tools/definitions/get-report.tool.d.ts +303 -0
  164. package/dist/mcp-server/tools/definitions/get-report.tool.d.ts.map +1 -0
  165. package/dist/mcp-server/tools/definitions/get-report.tool.js +178 -0
  166. package/dist/mcp-server/tools/definitions/get-report.tool.js.map +1 -0
  167. package/dist/mcp-server/tools/definitions/get-targeting-options.tool.d.ts +127 -0
  168. package/dist/mcp-server/tools/definitions/get-targeting-options.tool.d.ts.map +1 -0
  169. package/dist/mcp-server/tools/definitions/get-targeting-options.tool.js +120 -0
  170. package/dist/mcp-server/tools/definitions/get-targeting-options.tool.js.map +1 -0
  171. package/dist/mcp-server/tools/definitions/index.d.ts +26 -0
  172. package/dist/mcp-server/tools/definitions/index.d.ts.map +1 -0
  173. package/dist/mcp-server/tools/definitions/index.js +78 -0
  174. package/dist/mcp-server/tools/definitions/index.js.map +1 -0
  175. package/dist/mcp-server/tools/definitions/list-advertisers.tool.d.ts +54 -0
  176. package/dist/mcp-server/tools/definitions/list-advertisers.tool.d.ts.map +1 -0
  177. package/dist/mcp-server/tools/definitions/list-advertisers.tool.js +58 -0
  178. package/dist/mcp-server/tools/definitions/list-advertisers.tool.js.map +1 -0
  179. package/dist/mcp-server/tools/definitions/list-entities.tool.d.ts +167 -0
  180. package/dist/mcp-server/tools/definitions/list-entities.tool.d.ts.map +1 -0
  181. package/dist/mcp-server/tools/definitions/list-entities.tool.js +114 -0
  182. package/dist/mcp-server/tools/definitions/list-entities.tool.js.map +1 -0
  183. package/dist/mcp-server/tools/definitions/search-targeting.tool.d.ts +131 -0
  184. package/dist/mcp-server/tools/definitions/search-targeting.tool.d.ts.map +1 -0
  185. package/dist/mcp-server/tools/definitions/search-targeting.tool.js +123 -0
  186. package/dist/mcp-server/tools/definitions/search-targeting.tool.js.map +1 -0
  187. package/dist/mcp-server/tools/definitions/submit-report.tool.d.ts +153 -0
  188. package/dist/mcp-server/tools/definitions/submit-report.tool.d.ts.map +1 -0
  189. package/dist/mcp-server/tools/definitions/submit-report.tool.js +117 -0
  190. package/dist/mcp-server/tools/definitions/submit-report.tool.js.map +1 -0
  191. package/dist/mcp-server/tools/definitions/update-entity.tool.d.ts +111 -0
  192. package/dist/mcp-server/tools/definitions/update-entity.tool.d.ts.map +1 -0
  193. package/dist/mcp-server/tools/definitions/update-entity.tool.js +89 -0
  194. package/dist/mcp-server/tools/definitions/update-entity.tool.js.map +1 -0
  195. package/dist/mcp-server/tools/definitions/upload-image.tool.d.ts +87 -0
  196. package/dist/mcp-server/tools/definitions/upload-image.tool.d.ts.map +1 -0
  197. package/dist/mcp-server/tools/definitions/upload-image.tool.js +82 -0
  198. package/dist/mcp-server/tools/definitions/upload-image.tool.js.map +1 -0
  199. package/dist/mcp-server/tools/definitions/upload-video.tool.d.ts +88 -0
  200. package/dist/mcp-server/tools/definitions/upload-video.tool.d.ts.map +1 -0
  201. package/dist/mcp-server/tools/definitions/upload-video.tool.js +113 -0
  202. package/dist/mcp-server/tools/definitions/upload-video.tool.js.map +1 -0
  203. package/dist/mcp-server/tools/definitions/validate-entity.tool.d.ts +197 -0
  204. package/dist/mcp-server/tools/definitions/validate-entity.tool.d.ts.map +1 -0
  205. package/dist/mcp-server/tools/definitions/validate-entity.tool.js +237 -0
  206. package/dist/mcp-server/tools/definitions/validate-entity.tool.js.map +1 -0
  207. package/dist/mcp-server/tools/index.d.ts +2 -0
  208. package/dist/mcp-server/tools/index.d.ts.map +1 -0
  209. package/dist/mcp-server/tools/index.js +2 -0
  210. package/dist/mcp-server/tools/index.js.map +1 -0
  211. package/dist/mcp-server/tools/utils/entity-mapping.d.ts +22 -0
  212. package/dist/mcp-server/tools/utils/entity-mapping.d.ts.map +1 -0
  213. package/dist/mcp-server/tools/utils/entity-mapping.js +121 -0
  214. package/dist/mcp-server/tools/utils/entity-mapping.js.map +1 -0
  215. package/dist/mcp-server/tools/utils/resolve-session.d.ts +4 -0
  216. package/dist/mcp-server/tools/utils/resolve-session.d.ts.map +1 -0
  217. package/dist/mcp-server/tools/utils/resolve-session.js +6 -0
  218. package/dist/mcp-server/tools/utils/resolve-session.js.map +1 -0
  219. package/dist/mcp-server/transports/streamable-http-transport.d.ts +59 -0
  220. package/dist/mcp-server/transports/streamable-http-transport.d.ts.map +1 -0
  221. package/dist/mcp-server/transports/streamable-http-transport.js +107 -0
  222. package/dist/mcp-server/transports/streamable-http-transport.js.map +1 -0
  223. package/dist/services/session-services.d.ts +21 -0
  224. package/dist/services/session-services.d.ts.map +1 -0
  225. package/dist/services/session-services.js +25 -0
  226. package/dist/services/session-services.js.map +1 -0
  227. package/dist/services/tiktok/tiktok-http-client.d.ts +19 -0
  228. package/dist/services/tiktok/tiktok-http-client.d.ts.map +1 -0
  229. package/dist/services/tiktok/tiktok-http-client.js +184 -0
  230. package/dist/services/tiktok/tiktok-http-client.js.map +1 -0
  231. package/dist/services/tiktok/tiktok-reporting-service.d.ts +62 -0
  232. package/dist/services/tiktok/tiktok-reporting-service.d.ts.map +1 -0
  233. package/dist/services/tiktok/tiktok-reporting-service.js +129 -0
  234. package/dist/services/tiktok/tiktok-reporting-service.js.map +1 -0
  235. package/dist/services/tiktok/tiktok-service.d.ts +86 -0
  236. package/dist/services/tiktok/tiktok-service.d.ts.map +1 -0
  237. package/dist/services/tiktok/tiktok-service.js +217 -0
  238. package/dist/services/tiktok/tiktok-service.js.map +1 -0
  239. package/dist/services/tiktok/types.d.ts +161 -0
  240. package/dist/services/tiktok/types.d.ts.map +1 -0
  241. package/dist/services/tiktok/types.js +31 -0
  242. package/dist/services/tiktok/types.js.map +1 -0
  243. package/dist/types-global/mcp.d.ts +2 -0
  244. package/dist/types-global/mcp.d.ts.map +1 -0
  245. package/dist/types-global/mcp.js +2 -0
  246. package/dist/types-global/mcp.js.map +1 -0
  247. package/dist/utils/errors/index.d.ts +2 -0
  248. package/dist/utils/errors/index.d.ts.map +1 -0
  249. package/dist/utils/errors/index.js +2 -0
  250. package/dist/utils/errors/index.js.map +1 -0
  251. package/dist/utils/platform.d.ts +3 -0
  252. package/dist/utils/platform.d.ts.map +1 -0
  253. package/dist/utils/platform.js +5 -0
  254. package/dist/utils/platform.js.map +1 -0
  255. package/dist/utils/security/rate-limiter.d.ts +3 -0
  256. package/dist/utils/security/rate-limiter.d.ts.map +1 -0
  257. package/dist/utils/security/rate-limiter.js +5 -0
  258. package/dist/utils/security/rate-limiter.js.map +1 -0
  259. package/dist/utils/telemetry/index.d.ts +2 -0
  260. package/dist/utils/telemetry/index.d.ts.map +1 -0
  261. package/dist/utils/telemetry/index.js +2 -0
  262. package/dist/utils/telemetry/index.js.map +1 -0
  263. package/dist/utils/telemetry/tracing.d.ts +3 -0
  264. package/dist/utils/telemetry/tracing.d.ts.map +1 -0
  265. package/dist/utils/telemetry/tracing.js +4 -0
  266. package/dist/utils/telemetry/tracing.js.map +1 -0
  267. package/package.json +55 -0
@@ -0,0 +1,71 @@
1
+ import { z } from "zod";
2
+ import { resolveSessionServices } from "../utils/resolve-session.js";
3
+ import { getEntityTypeEnum } from "../utils/entity-mapping.js";
4
+ const TOOL_NAME = "tiktok_get_entity";
5
+ const TOOL_TITLE = "Get TikTok Ads Entity";
6
+ const TOOL_DESCRIPTION = `Get a single TikTok Ads entity by ID.
7
+
8
+ **Supported entity types:** ${getEntityTypeEnum().join(", ")}`;
9
+ export const GetEntityInputSchema = z
10
+ .object({
11
+ entityType: z.enum(getEntityTypeEnum()).describe("Type of entity to retrieve"),
12
+ advertiserId: z.string().min(1).describe("TikTok Advertiser ID"),
13
+ entityId: z.string().min(1).describe("The entity ID to retrieve"),
14
+ })
15
+ .describe("Parameters for getting a TikTok Ads entity");
16
+ export const GetEntityOutputSchema = z
17
+ .object({
18
+ entity: z.record(z.any()).describe("Retrieved entity data"),
19
+ timestamp: z.string().datetime(),
20
+ })
21
+ .describe("Entity retrieval result");
22
+ export async function getEntityLogic(input, context, sdkContext) {
23
+ const { tiktokService } = resolveSessionServices(sdkContext);
24
+ const entity = await tiktokService.getEntity(input.entityType, input.entityId, context);
25
+ return {
26
+ entity: entity,
27
+ timestamp: new Date().toISOString(),
28
+ };
29
+ }
30
+ export function getEntityResponseFormatter(result) {
31
+ return [
32
+ {
33
+ type: "text",
34
+ text: `Entity retrieved\n${JSON.stringify(result.entity, null, 2)}\n\nTimestamp: ${result.timestamp}`,
35
+ },
36
+ ];
37
+ }
38
+ export const getEntityTool = {
39
+ name: TOOL_NAME,
40
+ title: TOOL_TITLE,
41
+ description: TOOL_DESCRIPTION,
42
+ inputSchema: GetEntityInputSchema,
43
+ outputSchema: GetEntityOutputSchema,
44
+ annotations: {
45
+ readOnlyHint: true,
46
+ openWorldHint: false,
47
+ idempotentHint: true,
48
+ destructiveHint: false,
49
+ },
50
+ inputExamples: [
51
+ {
52
+ label: "Get a campaign by ID",
53
+ input: {
54
+ entityType: "campaign",
55
+ advertiserId: "1234567890",
56
+ entityId: "1800123456789",
57
+ },
58
+ },
59
+ {
60
+ label: "Get an ad group by ID",
61
+ input: {
62
+ entityType: "adGroup",
63
+ advertiserId: "1234567890",
64
+ entityId: "1700123456789",
65
+ },
66
+ },
67
+ ],
68
+ logic: getEntityLogic,
69
+ responseFormatter: getEntityResponseFormatter,
70
+ };
71
+ //# sourceMappingURL=get-entity.tool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-entity.tool.js","sourceRoot":"","sources":["../../../../src/mcp-server/tools/definitions/get-entity.tool.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EAAE,iBAAiB,EAAyB,MAAM,4BAA4B,CAAC;AAItF,MAAM,SAAS,GAAG,mBAAmB,CAAC;AACtC,MAAM,UAAU,GAAG,uBAAuB,CAAC;AAC3C,MAAM,gBAAgB,GAAG;;8BAEK,iBAAiB,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;AAE/D,MAAM,CAAC,MAAM,oBAAoB,GAAG,CAAC;KAClC,MAAM,CAAC;IACN,UAAU,EAAE,CAAC,CAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAC,QAAQ,CAAC,4BAA4B,CAAC;IAC9E,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,sBAAsB,CAAC;IAChE,QAAQ,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,2BAA2B,CAAC;CAClE,CAAC;KACD,QAAQ,CAAC,4CAA4C,CAAC,CAAC;AAE1D,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC;KACnC,MAAM,CAAC;IACN,MAAM,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,QAAQ,CAAC,uBAAuB,CAAC;IAC3D,SAAS,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,QAAQ,EAAE;CACjC,CAAC;KACD,QAAQ,CAAC,yBAAyB,CAAC,CAAC;AAKvC,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAqB,EACrB,OAAuB,EACvB,UAAuB;IAEvB,MAAM,EAAE,aAAa,EAAE,GAAG,sBAAsB,CAAC,UAAU,CAAC,CAAC;IAE7D,MAAM,MAAM,GAAG,MAAM,aAAa,CAAC,SAAS,CAC1C,KAAK,CAAC,UAA8B,EACpC,KAAK,CAAC,QAAQ,EACd,OAAO,CACR,CAAC;IAEF,OAAO;QACL,MAAM,EAAE,MAA4C;QACpD,SAAS,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;KACpC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,0BAA0B,CAAC,MAAuB;IAChE,OAAO;QACL;YACE,IAAI,EAAE,MAAe;YACrB,IAAI,EAAE,qBAAqB,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC,kBAAkB,MAAM,CAAC,SAAS,EAAE;SACtG;KACF,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,SAAS;IACf,KAAK,EAAE,UAAU;IACjB,WAAW,EAAE,gBAAgB;IAC7B,WAAW,EAAE,oBAAoB;IACjC,YAAY,EAAE,qBAAqB;IACnC,WAAW,EAAE;QACX,YAAY,EAAE,IAAI;QAClB,aAAa,EAAE,KAAK;QACpB,cAAc,EAAE,IAAI;QACpB,eAAe,EAAE,KAAK;KACvB;IACD,aAAa,EAAE;QACb;YACE,KAAK,EAAE,sBAAsB;YAC7B,KAAK,EAAE;gBACL,UAAU,EAAE,UAAU;gBACtB,YAAY,EAAE,YAAY;gBAC1B,QAAQ,EAAE,eAAe;aAC1B;SACF;QACD;YACE,KAAK,EAAE,uBAAuB;YAC9B,KAAK,EAAE;gBACL,UAAU,EAAE,SAAS;gBACrB,YAAY,EAAE,YAAY;gBAC1B,QAAQ,EAAE,eAAe;aAC1B;SACF;KACF;IACD,KAAK,EAAE,cAAc;IACrB,iBAAiB,EAAE,0BAA0B;CAC9C,CAAC"}
@@ -0,0 +1,295 @@
1
+ import { z } from "zod";
2
+ import type { RequestContext, McpTextContent } from "@cesteral/shared";
3
+ import type { SdkContext } from "@cesteral/shared";
4
+ export declare const GetReportBreakdownsInputSchema: z.ZodEffects<z.ZodObject<{
5
+ advertiserId: z.ZodString;
6
+ reportType: z.ZodDefault<z.ZodOptional<z.ZodEnum<["BASIC", "AUDIENCE", "PLAYABLE_MATERIAL"]>>>;
7
+ dimensions: z.ZodArray<z.ZodString, "many">;
8
+ breakdowns: z.ZodArray<z.ZodString, "many">;
9
+ metrics: z.ZodArray<z.ZodString, "many">;
10
+ datePreset: z.ZodOptional<z.ZodEnum<["TODAY", "YESTERDAY", "LAST_7_DAYS", "LAST_14_DAYS", "LAST_30_DAYS", "THIS_MONTH", "LAST_MONTH", "LAST_90_DAYS"]>>;
11
+ startDate: z.ZodOptional<z.ZodString>;
12
+ endDate: z.ZodOptional<z.ZodString>;
13
+ includeComputedMetrics: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
14
+ } & {
15
+ mode: z.ZodDefault<z.ZodOptional<z.ZodEnum<["summary", "rows"]>>>;
16
+ columns: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
17
+ offset: z.ZodOptional<z.ZodNumber>;
18
+ maxRows: z.ZodOptional<z.ZodNumber>;
19
+ aggregateBy: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
20
+ aggregateMetrics: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodEnum<["sum", "avg", "count", "min", "max"]>>>;
21
+ }, "strip", z.ZodTypeAny, {
22
+ dimensions: string[];
23
+ metrics: string[];
24
+ advertiserId: string;
25
+ reportType: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL";
26
+ includeComputedMetrics: boolean;
27
+ mode: "rows" | "summary";
28
+ breakdowns: string[];
29
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
30
+ startDate?: string | undefined;
31
+ endDate?: string | undefined;
32
+ columns?: string[] | undefined;
33
+ offset?: number | undefined;
34
+ maxRows?: number | undefined;
35
+ aggregateBy?: string[] | undefined;
36
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
37
+ }, {
38
+ dimensions: string[];
39
+ metrics: string[];
40
+ advertiserId: string;
41
+ breakdowns: string[];
42
+ reportType?: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL" | undefined;
43
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
44
+ startDate?: string | undefined;
45
+ endDate?: string | undefined;
46
+ includeComputedMetrics?: boolean | undefined;
47
+ mode?: "rows" | "summary" | undefined;
48
+ columns?: string[] | undefined;
49
+ offset?: number | undefined;
50
+ maxRows?: number | undefined;
51
+ aggregateBy?: string[] | undefined;
52
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
53
+ }>, {
54
+ dimensions: string[];
55
+ metrics: string[];
56
+ advertiserId: string;
57
+ reportType: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL";
58
+ includeComputedMetrics: boolean;
59
+ mode: "rows" | "summary";
60
+ breakdowns: string[];
61
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
62
+ startDate?: string | undefined;
63
+ endDate?: string | undefined;
64
+ columns?: string[] | undefined;
65
+ offset?: number | undefined;
66
+ maxRows?: number | undefined;
67
+ aggregateBy?: string[] | undefined;
68
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
69
+ }, {
70
+ dimensions: string[];
71
+ metrics: string[];
72
+ advertiserId: string;
73
+ breakdowns: string[];
74
+ reportType?: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL" | undefined;
75
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
76
+ startDate?: string | undefined;
77
+ endDate?: string | undefined;
78
+ includeComputedMetrics?: boolean | undefined;
79
+ mode?: "rows" | "summary" | undefined;
80
+ columns?: string[] | undefined;
81
+ offset?: number | undefined;
82
+ maxRows?: number | undefined;
83
+ aggregateBy?: string[] | undefined;
84
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
85
+ }>;
86
+ export declare const GetReportBreakdownsOutputSchema: z.ZodObject<{
87
+ appliedDimensions: z.ZodArray<z.ZodString, "many">;
88
+ timestamp: z.ZodString;
89
+ totalRows: z.ZodNumber;
90
+ returnedRows: z.ZodNumber;
91
+ truncated: z.ZodBoolean;
92
+ nextOffset: z.ZodNullable<z.ZodNumber>;
93
+ headers: z.ZodArray<z.ZodString, "many">;
94
+ selectedColumns: z.ZodArray<z.ZodString, "many">;
95
+ mode: z.ZodEnum<["summary", "rows"]>;
96
+ previewRows: z.ZodOptional<z.ZodArray<z.ZodRecord<z.ZodString, z.ZodAny>, "many">>;
97
+ rows: z.ZodOptional<z.ZodArray<z.ZodRecord<z.ZodString, z.ZodAny>, "many">>;
98
+ warnings: z.ZodArray<z.ZodString, "many">;
99
+ taskId: z.ZodString;
100
+ }, "strip", z.ZodTypeAny, {
101
+ taskId: string;
102
+ totalRows: number;
103
+ headers: string[];
104
+ timestamp: string;
105
+ mode: "rows" | "summary";
106
+ returnedRows: number;
107
+ truncated: boolean;
108
+ nextOffset: number | null;
109
+ selectedColumns: string[];
110
+ warnings: string[];
111
+ appliedDimensions: string[];
112
+ rows?: Record<string, any>[] | undefined;
113
+ previewRows?: Record<string, any>[] | undefined;
114
+ }, {
115
+ taskId: string;
116
+ totalRows: number;
117
+ headers: string[];
118
+ timestamp: string;
119
+ mode: "rows" | "summary";
120
+ returnedRows: number;
121
+ truncated: boolean;
122
+ nextOffset: number | null;
123
+ selectedColumns: string[];
124
+ warnings: string[];
125
+ appliedDimensions: string[];
126
+ rows?: Record<string, any>[] | undefined;
127
+ previewRows?: Record<string, any>[] | undefined;
128
+ }>;
129
+ type GetReportBreakdownsInput = z.infer<typeof GetReportBreakdownsInputSchema>;
130
+ type GetReportBreakdownsOutput = z.infer<typeof GetReportBreakdownsOutputSchema>;
131
+ export declare function getReportBreakdownsLogic(input: GetReportBreakdownsInput, context: RequestContext, sdkContext?: SdkContext): Promise<GetReportBreakdownsOutput>;
132
+ export declare function getReportBreakdownsResponseFormatter(result: GetReportBreakdownsOutput): McpTextContent[];
133
+ export declare const getReportBreakdownsTool: {
134
+ name: string;
135
+ title: string;
136
+ description: string;
137
+ inputSchema: z.ZodEffects<z.ZodObject<{
138
+ advertiserId: z.ZodString;
139
+ reportType: z.ZodDefault<z.ZodOptional<z.ZodEnum<["BASIC", "AUDIENCE", "PLAYABLE_MATERIAL"]>>>;
140
+ dimensions: z.ZodArray<z.ZodString, "many">;
141
+ breakdowns: z.ZodArray<z.ZodString, "many">;
142
+ metrics: z.ZodArray<z.ZodString, "many">;
143
+ datePreset: z.ZodOptional<z.ZodEnum<["TODAY", "YESTERDAY", "LAST_7_DAYS", "LAST_14_DAYS", "LAST_30_DAYS", "THIS_MONTH", "LAST_MONTH", "LAST_90_DAYS"]>>;
144
+ startDate: z.ZodOptional<z.ZodString>;
145
+ endDate: z.ZodOptional<z.ZodString>;
146
+ includeComputedMetrics: z.ZodDefault<z.ZodOptional<z.ZodBoolean>>;
147
+ } & {
148
+ mode: z.ZodDefault<z.ZodOptional<z.ZodEnum<["summary", "rows"]>>>;
149
+ columns: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
150
+ offset: z.ZodOptional<z.ZodNumber>;
151
+ maxRows: z.ZodOptional<z.ZodNumber>;
152
+ aggregateBy: z.ZodOptional<z.ZodArray<z.ZodString, "many">>;
153
+ aggregateMetrics: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodEnum<["sum", "avg", "count", "min", "max"]>>>;
154
+ }, "strip", z.ZodTypeAny, {
155
+ dimensions: string[];
156
+ metrics: string[];
157
+ advertiserId: string;
158
+ reportType: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL";
159
+ includeComputedMetrics: boolean;
160
+ mode: "rows" | "summary";
161
+ breakdowns: string[];
162
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
163
+ startDate?: string | undefined;
164
+ endDate?: string | undefined;
165
+ columns?: string[] | undefined;
166
+ offset?: number | undefined;
167
+ maxRows?: number | undefined;
168
+ aggregateBy?: string[] | undefined;
169
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
170
+ }, {
171
+ dimensions: string[];
172
+ metrics: string[];
173
+ advertiserId: string;
174
+ breakdowns: string[];
175
+ reportType?: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL" | undefined;
176
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
177
+ startDate?: string | undefined;
178
+ endDate?: string | undefined;
179
+ includeComputedMetrics?: boolean | undefined;
180
+ mode?: "rows" | "summary" | undefined;
181
+ columns?: string[] | undefined;
182
+ offset?: number | undefined;
183
+ maxRows?: number | undefined;
184
+ aggregateBy?: string[] | undefined;
185
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
186
+ }>, {
187
+ dimensions: string[];
188
+ metrics: string[];
189
+ advertiserId: string;
190
+ reportType: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL";
191
+ includeComputedMetrics: boolean;
192
+ mode: "rows" | "summary";
193
+ breakdowns: string[];
194
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
195
+ startDate?: string | undefined;
196
+ endDate?: string | undefined;
197
+ columns?: string[] | undefined;
198
+ offset?: number | undefined;
199
+ maxRows?: number | undefined;
200
+ aggregateBy?: string[] | undefined;
201
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
202
+ }, {
203
+ dimensions: string[];
204
+ metrics: string[];
205
+ advertiserId: string;
206
+ breakdowns: string[];
207
+ reportType?: "BASIC" | "AUDIENCE" | "PLAYABLE_MATERIAL" | undefined;
208
+ datePreset?: "TODAY" | "YESTERDAY" | "LAST_7_DAYS" | "LAST_14_DAYS" | "LAST_30_DAYS" | "THIS_MONTH" | "LAST_MONTH" | "LAST_90_DAYS" | undefined;
209
+ startDate?: string | undefined;
210
+ endDate?: string | undefined;
211
+ includeComputedMetrics?: boolean | undefined;
212
+ mode?: "rows" | "summary" | undefined;
213
+ columns?: string[] | undefined;
214
+ offset?: number | undefined;
215
+ maxRows?: number | undefined;
216
+ aggregateBy?: string[] | undefined;
217
+ aggregateMetrics?: Record<string, "count" | "sum" | "avg" | "min" | "max"> | undefined;
218
+ }>;
219
+ outputSchema: z.ZodObject<{
220
+ appliedDimensions: z.ZodArray<z.ZodString, "many">;
221
+ timestamp: z.ZodString;
222
+ totalRows: z.ZodNumber;
223
+ returnedRows: z.ZodNumber;
224
+ truncated: z.ZodBoolean;
225
+ nextOffset: z.ZodNullable<z.ZodNumber>;
226
+ headers: z.ZodArray<z.ZodString, "many">;
227
+ selectedColumns: z.ZodArray<z.ZodString, "many">;
228
+ mode: z.ZodEnum<["summary", "rows"]>;
229
+ previewRows: z.ZodOptional<z.ZodArray<z.ZodRecord<z.ZodString, z.ZodAny>, "many">>;
230
+ rows: z.ZodOptional<z.ZodArray<z.ZodRecord<z.ZodString, z.ZodAny>, "many">>;
231
+ warnings: z.ZodArray<z.ZodString, "many">;
232
+ taskId: z.ZodString;
233
+ }, "strip", z.ZodTypeAny, {
234
+ taskId: string;
235
+ totalRows: number;
236
+ headers: string[];
237
+ timestamp: string;
238
+ mode: "rows" | "summary";
239
+ returnedRows: number;
240
+ truncated: boolean;
241
+ nextOffset: number | null;
242
+ selectedColumns: string[];
243
+ warnings: string[];
244
+ appliedDimensions: string[];
245
+ rows?: Record<string, any>[] | undefined;
246
+ previewRows?: Record<string, any>[] | undefined;
247
+ }, {
248
+ taskId: string;
249
+ totalRows: number;
250
+ headers: string[];
251
+ timestamp: string;
252
+ mode: "rows" | "summary";
253
+ returnedRows: number;
254
+ truncated: boolean;
255
+ nextOffset: number | null;
256
+ selectedColumns: string[];
257
+ warnings: string[];
258
+ appliedDimensions: string[];
259
+ rows?: Record<string, any>[] | undefined;
260
+ previewRows?: Record<string, any>[] | undefined;
261
+ }>;
262
+ annotations: {
263
+ readOnlyHint: boolean;
264
+ openWorldHint: boolean;
265
+ idempotentHint: boolean;
266
+ destructiveHint: boolean;
267
+ };
268
+ inputExamples: ({
269
+ label: string;
270
+ input: {
271
+ advertiserId: string;
272
+ dimensions: string[];
273
+ breakdowns: string[];
274
+ metrics: string[];
275
+ datePreset: string;
276
+ startDate?: undefined;
277
+ endDate?: undefined;
278
+ };
279
+ } | {
280
+ label: string;
281
+ input: {
282
+ advertiserId: string;
283
+ dimensions: string[];
284
+ breakdowns: string[];
285
+ metrics: string[];
286
+ startDate: string;
287
+ endDate: string;
288
+ datePreset?: undefined;
289
+ };
290
+ })[];
291
+ logic: typeof getReportBreakdownsLogic;
292
+ responseFormatter: typeof getReportBreakdownsResponseFormatter;
293
+ };
294
+ export {};
295
+ //# sourceMappingURL=get-report-breakdowns.tool.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-report-breakdowns.tool.d.ts","sourceRoot":"","sources":["../../../../src/mcp-server/tools/definitions/get-report-breakdowns.tool.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AAaxB,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AACvE,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,kBAAkB,CAAC;AAYnD,eAAO,MAAM,8BAA8B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EA8CiC,CAAC;AAE7E,eAAO,MAAM,+BAA+B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;EAOA,CAAC;AAE7C,KAAK,wBAAwB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,8BAA8B,CAAC,CAAC;AAC/E,KAAK,yBAAyB,GAAG,CAAC,CAAC,KAAK,CAAC,OAAO,+BAA+B,CAAC,CAAC;AAsCjF,wBAAsB,wBAAwB,CAC5C,KAAK,EAAE,wBAAwB,EAC/B,OAAO,EAAE,cAAc,EACvB,UAAU,CAAC,EAAE,UAAU,GACtB,OAAO,CAAC,yBAAyB,CAAC,CA0CpC;AAED,wBAAgB,oCAAoC,CAClD,MAAM,EAAE,yBAAyB,GAChC,cAAc,EAAE,CAOlB;AAED,eAAO,MAAM,uBAAuB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAqCnC,CAAC"}
@@ -0,0 +1,174 @@
1
+ import { z } from "zod";
2
+ import { resolveSessionServices } from "../utils/resolve-session.js";
3
+ import { arrayRowsToRecords, computeMetrics, createReportView, formatReportViewResponse, getReportViewFetchLimit, resolveDatePreset, DATE_PRESET_VALUES, ReportViewInputSchema, ReportViewOutputSchema, } from "@cesteral/shared";
4
+ const TOOL_NAME = "tiktok_get_report_breakdowns";
5
+ const TOOL_TITLE = "Get TikTok Ads Report with Breakdowns";
6
+ const TOOL_DESCRIPTION = `Submit and retrieve an async TikTok Ads report with dimensional breakdowns.
7
+
8
+ Like \`tiktok_get_report\` but adds breakdown dimensions for more granular data.
9
+
10
+ **Common breakdown dimensions:** country_code, platform, gender, age, interest_category, placement
11
+
12
+ Results are broken down by each combination of base dimensions + breakdown dimensions.`;
13
+ export const GetReportBreakdownsInputSchema = z
14
+ .object({
15
+ advertiserId: z.string().min(1).describe("TikTok Advertiser ID"),
16
+ reportType: z
17
+ .enum(["BASIC", "AUDIENCE", "PLAYABLE_MATERIAL"])
18
+ .optional()
19
+ .default("BASIC")
20
+ .describe("Report type (default: BASIC)"),
21
+ dimensions: z
22
+ .array(z.string())
23
+ .min(1)
24
+ .describe("Base dimensions for the report (e.g., ['campaign_id', 'stat_time_day'])"),
25
+ breakdowns: z
26
+ .array(z.string())
27
+ .min(1)
28
+ .describe("Breakdown dimensions to add (e.g., ['country_code', 'gender'])"),
29
+ metrics: z
30
+ .array(z.string())
31
+ .min(1)
32
+ .describe("Metrics to include (e.g., ['impressions', 'clicks', 'spend'])"),
33
+ datePreset: z
34
+ .enum(DATE_PRESET_VALUES)
35
+ .optional()
36
+ .describe("Preset date range. Use this OR startDate+endDate (not both)"),
37
+ startDate: z
38
+ .string()
39
+ .regex(/^\d{4}-\d{2}-\d{2}$/)
40
+ .optional()
41
+ .describe("Start date (YYYY-MM-DD, required if datePreset not provided)"),
42
+ endDate: z
43
+ .string()
44
+ .regex(/^\d{4}-\d{2}-\d{2}$/)
45
+ .optional()
46
+ .describe("End date (YYYY-MM-DD, required if datePreset not provided)"),
47
+ includeComputedMetrics: z
48
+ .boolean()
49
+ .optional()
50
+ .default(false)
51
+ .describe("Include computed CPA, ROAS, CPM, CTR, CPC derived from raw metrics"),
52
+ })
53
+ .merge(ReportViewInputSchema)
54
+ .refine((data) => data.datePreset !== undefined || (data.startDate !== undefined && data.endDate !== undefined), { message: "Provide either datePreset or both startDate and endDate" })
55
+ .describe("Parameters for generating a TikTok Ads report with breakdowns");
56
+ export const GetReportBreakdownsOutputSchema = z
57
+ .object({
58
+ taskId: z.string().describe("Report task ID"),
59
+ ...ReportViewOutputSchema.shape,
60
+ appliedDimensions: z.array(z.string()).describe("All dimensions used (base + breakdowns)"),
61
+ timestamp: z.string().datetime(),
62
+ })
63
+ .describe("Report with breakdowns result");
64
+ function appendComputedMetricsToRows(headers, rows) {
65
+ const idx = (name) => headers.findIndex((h) => h.toLowerCase() === name.toLowerCase());
66
+ const spendIdx = idx("spend");
67
+ const impIdx = idx("impressions");
68
+ const clickIdx = idx("clicks");
69
+ const convIdx = idx("conversions");
70
+ const newHeaders = [
71
+ ...headers,
72
+ "computed_cpa",
73
+ "computed_roas",
74
+ "computed_cpm",
75
+ "computed_ctr",
76
+ "computed_cpc",
77
+ ];
78
+ const newRows = rows.map((row) => {
79
+ const cost = spendIdx >= 0 ? Number(row[spendIdx] || 0) : 0;
80
+ const impressions = impIdx >= 0 ? Number(row[impIdx] || 0) : 0;
81
+ const clicks = clickIdx >= 0 ? Number(row[clickIdx] || 0) : 0;
82
+ const conversions = convIdx >= 0 ? Number(row[convIdx] || 0) : 0;
83
+ const m = computeMetrics({ cost, impressions, clicks, conversions, conversionValue: 0 });
84
+ return [
85
+ ...row,
86
+ m.cpa !== null ? String(m.cpa) : "",
87
+ m.roas !== null ? String(m.roas) : "",
88
+ m.cpm !== null ? String(m.cpm) : "",
89
+ m.ctr !== null ? String(m.ctr) : "",
90
+ m.cpc !== null ? String(m.cpc) : "",
91
+ ];
92
+ });
93
+ return { headers: newHeaders, rows: newRows };
94
+ }
95
+ export async function getReportBreakdownsLogic(input, context, sdkContext) {
96
+ const { tiktokReportingService } = resolveSessionServices(sdkContext);
97
+ let resolvedStartDate = input.startDate;
98
+ let resolvedEndDate = input.endDate;
99
+ if (input.datePreset) {
100
+ const resolved = resolveDatePreset(input.datePreset);
101
+ resolvedStartDate = resolved.startDate;
102
+ resolvedEndDate = resolved.endDate;
103
+ }
104
+ const result = await tiktokReportingService.getReportBreakdowns({
105
+ report_type: input.reportType,
106
+ dimensions: input.dimensions,
107
+ metrics: input.metrics,
108
+ start_date: resolvedStartDate,
109
+ end_date: resolvedEndDate,
110
+ }, input.breakdowns, getReportViewFetchLimit(input), context);
111
+ let headers = result.headers;
112
+ let rows = result.rows;
113
+ if (input.includeComputedMetrics) {
114
+ ({ headers, rows } = appendComputedMetricsToRows(headers, rows));
115
+ }
116
+ return {
117
+ taskId: result.taskId,
118
+ ...createReportView({
119
+ headers,
120
+ rows: arrayRowsToRecords(headers, rows),
121
+ totalRows: result.totalRows,
122
+ input,
123
+ }),
124
+ appliedDimensions: [...input.dimensions, ...input.breakdowns],
125
+ timestamp: new Date().toISOString(),
126
+ };
127
+ }
128
+ export function getReportBreakdownsResponseFormatter(result) {
129
+ return [
130
+ {
131
+ type: "text",
132
+ text: `Report task: ${result.taskId}\nApplied dimensions: ${result.appliedDimensions.join(", ")}\n\n${formatReportViewResponse(result, "Report data")}`,
133
+ },
134
+ ];
135
+ }
136
+ export const getReportBreakdownsTool = {
137
+ name: TOOL_NAME,
138
+ title: TOOL_TITLE,
139
+ description: TOOL_DESCRIPTION,
140
+ inputSchema: GetReportBreakdownsInputSchema,
141
+ outputSchema: GetReportBreakdownsOutputSchema,
142
+ annotations: {
143
+ readOnlyHint: true,
144
+ openWorldHint: false,
145
+ idempotentHint: false,
146
+ destructiveHint: false,
147
+ },
148
+ inputExamples: [
149
+ {
150
+ label: "Campaign report broken down by country",
151
+ input: {
152
+ advertiserId: "1234567890",
153
+ dimensions: ["campaign_id", "stat_time_day"],
154
+ breakdowns: ["country_code"],
155
+ metrics: ["impressions", "clicks", "spend", "ctr"],
156
+ datePreset: "LAST_7_DAYS",
157
+ },
158
+ },
159
+ {
160
+ label: "Ad group report broken down by gender and age",
161
+ input: {
162
+ advertiserId: "1234567890",
163
+ dimensions: ["adgroup_id"],
164
+ breakdowns: ["gender", "age"],
165
+ metrics: ["impressions", "clicks", "spend", "conversions"],
166
+ startDate: "2026-03-01",
167
+ endDate: "2026-03-04",
168
+ },
169
+ },
170
+ ],
171
+ logic: getReportBreakdownsLogic,
172
+ responseFormatter: getReportBreakdownsResponseFormatter,
173
+ };
174
+ //# sourceMappingURL=get-report-breakdowns.tool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-report-breakdowns.tool.js","sourceRoot":"","sources":["../../../../src/mcp-server/tools/definitions/get-report-breakdowns.tool.ts"],"names":[],"mappings":"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"}