@mweinbach/apple-docs-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 +21 -0
  2. package/README.md +560 -0
  3. package/dist/constants/browser-headers.d.ts +48 -0
  4. package/dist/constants/browser-headers.d.ts.map +1 -0
  5. package/dist/constants/browser-headers.js +166 -0
  6. package/dist/constants/browser-headers.js.map +1 -0
  7. package/dist/index.d.ts +83 -0
  8. package/dist/index.d.ts.map +1 -0
  9. package/dist/index.js +215 -0
  10. package/dist/index.js.map +1 -0
  11. package/dist/schemas/analyze-api.schema.d.ts +42 -0
  12. package/dist/schemas/analyze-api.schema.d.ts.map +1 -0
  13. package/dist/schemas/analyze-api.schema.js +23 -0
  14. package/dist/schemas/analyze-api.schema.js.map +1 -0
  15. package/dist/schemas/apple-docs.schema.d.ts +18 -0
  16. package/dist/schemas/apple-docs.schema.d.ts.map +1 -0
  17. package/dist/schemas/apple-docs.schema.js +10 -0
  18. package/dist/schemas/apple-docs.schema.js.map +1 -0
  19. package/dist/schemas/doc-content.schema.d.ts +24 -0
  20. package/dist/schemas/doc-content.schema.d.ts.map +1 -0
  21. package/dist/schemas/doc-content.schema.js +10 -0
  22. package/dist/schemas/doc-content.schema.js.map +1 -0
  23. package/dist/schemas/documentation-updates.schema.d.ts +27 -0
  24. package/dist/schemas/documentation-updates.schema.d.ts.map +1 -0
  25. package/dist/schemas/documentation-updates.schema.js +12 -0
  26. package/dist/schemas/documentation-updates.schema.js.map +1 -0
  27. package/dist/schemas/framework-symbols.schema.d.ts +24 -0
  28. package/dist/schemas/framework-symbols.schema.d.ts.map +1 -0
  29. package/dist/schemas/framework-symbols.schema.js +11 -0
  30. package/dist/schemas/framework-symbols.schema.js.map +1 -0
  31. package/dist/schemas/index.d.ts +15 -0
  32. package/dist/schemas/index.d.ts.map +1 -0
  33. package/dist/schemas/index.js +15 -0
  34. package/dist/schemas/index.js.map +1 -0
  35. package/dist/schemas/platform-compatibility.schema.d.ts +18 -0
  36. package/dist/schemas/platform-compatibility.schema.d.ts.map +1 -0
  37. package/dist/schemas/platform-compatibility.schema.js +8 -0
  38. package/dist/schemas/platform-compatibility.schema.js.map +1 -0
  39. package/dist/schemas/references.schema.d.ts +18 -0
  40. package/dist/schemas/references.schema.d.ts.map +1 -0
  41. package/dist/schemas/references.schema.js +9 -0
  42. package/dist/schemas/references.schema.js.map +1 -0
  43. package/dist/schemas/related-apis.schema.d.ts +21 -0
  44. package/dist/schemas/related-apis.schema.d.ts.map +1 -0
  45. package/dist/schemas/related-apis.schema.js +9 -0
  46. package/dist/schemas/related-apis.schema.js.map +1 -0
  47. package/dist/schemas/sample-code.schema.d.ts +21 -0
  48. package/dist/schemas/sample-code.schema.d.ts.map +1 -0
  49. package/dist/schemas/sample-code.schema.js +10 -0
  50. package/dist/schemas/sample-code.schema.js.map +1 -0
  51. package/dist/schemas/search.schema.d.ts +15 -0
  52. package/dist/schemas/search.schema.d.ts.map +1 -0
  53. package/dist/schemas/search.schema.js +8 -0
  54. package/dist/schemas/search.schema.js.map +1 -0
  55. package/dist/schemas/similar-apis.schema.d.ts +21 -0
  56. package/dist/schemas/similar-apis.schema.d.ts.map +1 -0
  57. package/dist/schemas/similar-apis.schema.js +9 -0
  58. package/dist/schemas/similar-apis.schema.js.map +1 -0
  59. package/dist/schemas/technologies.schema.d.ts +21 -0
  60. package/dist/schemas/technologies.schema.d.ts.map +1 -0
  61. package/dist/schemas/technologies.schema.js +10 -0
  62. package/dist/schemas/technologies.schema.js.map +1 -0
  63. package/dist/schemas/technology-overviews.schema.d.ts +24 -0
  64. package/dist/schemas/technology-overviews.schema.d.ts.map +1 -0
  65. package/dist/schemas/technology-overviews.schema.js +11 -0
  66. package/dist/schemas/technology-overviews.schema.js.map +1 -0
  67. package/dist/schemas/wwdc.schemas.d.ts +208 -0
  68. package/dist/schemas/wwdc.schemas.d.ts.map +1 -0
  69. package/dist/schemas/wwdc.schemas.js +97 -0
  70. package/dist/schemas/wwdc.schemas.js.map +1 -0
  71. package/dist/tools/definitions.d.ts +10 -0
  72. package/dist/tools/definitions.d.ts.map +1 -0
  73. package/dist/tools/definitions.js +690 -0
  74. package/dist/tools/definitions.js.map +1 -0
  75. package/dist/tools/doc-fetcher.d.ts +19 -0
  76. package/dist/tools/doc-fetcher.d.ts.map +1 -0
  77. package/dist/tools/doc-fetcher.js +487 -0
  78. package/dist/tools/doc-fetcher.js.map +1 -0
  79. package/dist/tools/doc-formatter.d.ts +69 -0
  80. package/dist/tools/doc-formatter.d.ts.map +1 -0
  81. package/dist/tools/doc-formatter.js +208 -0
  82. package/dist/tools/doc-formatter.js.map +1 -0
  83. package/dist/tools/find-similar-apis.d.ts +5 -0
  84. package/dist/tools/find-similar-apis.d.ts.map +1 -0
  85. package/dist/tools/find-similar-apis.js +275 -0
  86. package/dist/tools/find-similar-apis.js.map +1 -0
  87. package/dist/tools/get-documentation-updates.d.ts +5 -0
  88. package/dist/tools/get-documentation-updates.d.ts.map +1 -0
  89. package/dist/tools/get-documentation-updates.js +244 -0
  90. package/dist/tools/get-documentation-updates.js.map +1 -0
  91. package/dist/tools/get-platform-compatibility.d.ts +5 -0
  92. package/dist/tools/get-platform-compatibility.d.ts.map +1 -0
  93. package/dist/tools/get-platform-compatibility.js +205 -0
  94. package/dist/tools/get-platform-compatibility.js.map +1 -0
  95. package/dist/tools/get-related-apis.d.ts +5 -0
  96. package/dist/tools/get-related-apis.d.ts.map +1 -0
  97. package/dist/tools/get-related-apis.js +155 -0
  98. package/dist/tools/get-related-apis.js.map +1 -0
  99. package/dist/tools/get-sample-code.d.ts +5 -0
  100. package/dist/tools/get-sample-code.d.ts.map +1 -0
  101. package/dist/tools/get-sample-code.js +375 -0
  102. package/dist/tools/get-sample-code.js.map +1 -0
  103. package/dist/tools/get-technology-overviews.d.ts +5 -0
  104. package/dist/tools/get-technology-overviews.d.ts.map +1 -0
  105. package/dist/tools/get-technology-overviews.js +306 -0
  106. package/dist/tools/get-technology-overviews.js.map +1 -0
  107. package/dist/tools/handlers.d.ts +29 -0
  108. package/dist/tools/handlers.d.ts.map +1 -0
  109. package/dist/tools/handlers.js +350 -0
  110. package/dist/tools/handlers.js.map +1 -0
  111. package/dist/tools/list-technologies.d.ts +5 -0
  112. package/dist/tools/list-technologies.d.ts.map +1 -0
  113. package/dist/tools/list-technologies.js +165 -0
  114. package/dist/tools/list-technologies.js.map +1 -0
  115. package/dist/tools/resolve-references-batch.d.ts +5 -0
  116. package/dist/tools/resolve-references-batch.d.ts.map +1 -0
  117. package/dist/tools/resolve-references-batch.js +199 -0
  118. package/dist/tools/resolve-references-batch.js.map +1 -0
  119. package/dist/tools/search-framework-symbols.d.ts +7 -0
  120. package/dist/tools/search-framework-symbols.d.ts.map +1 -0
  121. package/dist/tools/search-framework-symbols.js +235 -0
  122. package/dist/tools/search-framework-symbols.js.map +1 -0
  123. package/dist/tools/search-parser.d.ts +15 -0
  124. package/dist/tools/search-parser.d.ts.map +1 -0
  125. package/dist/tools/search-parser.js +188 -0
  126. package/dist/tools/search-parser.js.map +1 -0
  127. package/dist/tools/search-result-parser.d.ts +52 -0
  128. package/dist/tools/search-result-parser.d.ts.map +1 -0
  129. package/dist/tools/search-result-parser.js +137 -0
  130. package/dist/tools/search-result-parser.js.map +1 -0
  131. package/dist/tools/tools-guide.d.ts +124 -0
  132. package/dist/tools/tools-guide.d.ts.map +1 -0
  133. package/dist/tools/tools-guide.js +389 -0
  134. package/dist/tools/tools-guide.js.map +1 -0
  135. package/dist/tools/wwdc/content-extractor.d.ts +9 -0
  136. package/dist/tools/wwdc/content-extractor.d.ts.map +1 -0
  137. package/dist/tools/wwdc/content-extractor.js +520 -0
  138. package/dist/tools/wwdc/content-extractor.js.map +1 -0
  139. package/dist/tools/wwdc/topics-extractor.d.ts +32 -0
  140. package/dist/tools/wwdc/topics-extractor.d.ts.map +1 -0
  141. package/dist/tools/wwdc/topics-extractor.js +146 -0
  142. package/dist/tools/wwdc/topics-extractor.js.map +1 -0
  143. package/dist/tools/wwdc/video-list-extractor.d.ts +13 -0
  144. package/dist/tools/wwdc/video-list-extractor.d.ts.map +1 -0
  145. package/dist/tools/wwdc/video-list-extractor.js +238 -0
  146. package/dist/tools/wwdc/video-list-extractor.js.map +1 -0
  147. package/dist/tools/wwdc/wwdc-handlers.d.ts +32 -0
  148. package/dist/tools/wwdc/wwdc-handlers.d.ts.map +1 -0
  149. package/dist/tools/wwdc/wwdc-handlers.js +791 -0
  150. package/dist/tools/wwdc/wwdc-handlers.js.map +1 -0
  151. package/dist/types/apple-docs.d.ts +112 -0
  152. package/dist/types/apple-docs.d.ts.map +1 -0
  153. package/dist/types/apple-docs.js +5 -0
  154. package/dist/types/apple-docs.js.map +1 -0
  155. package/dist/types/cache.d.ts +28 -0
  156. package/dist/types/cache.d.ts.map +1 -0
  157. package/dist/types/cache.js +5 -0
  158. package/dist/types/cache.js.map +1 -0
  159. package/dist/types/content-sections.d.ts +37 -0
  160. package/dist/types/content-sections.d.ts.map +1 -0
  161. package/dist/types/content-sections.js +5 -0
  162. package/dist/types/content-sections.js.map +1 -0
  163. package/dist/types/error.d.ts +39 -0
  164. package/dist/types/error.d.ts.map +1 -0
  165. package/dist/types/error.js +21 -0
  166. package/dist/types/error.js.map +1 -0
  167. package/dist/types/headers.d.ts +95 -0
  168. package/dist/types/headers.d.ts.map +1 -0
  169. package/dist/types/headers.js +5 -0
  170. package/dist/types/headers.js.map +1 -0
  171. package/dist/types/http.d.ts +31 -0
  172. package/dist/types/http.d.ts.map +1 -0
  173. package/dist/types/http.js +5 -0
  174. package/dist/types/http.js.map +1 -0
  175. package/dist/types/index.d.ts +11 -0
  176. package/dist/types/index.d.ts.map +1 -0
  177. package/dist/types/index.js +12 -0
  178. package/dist/types/index.js.map +1 -0
  179. package/dist/types/search.d.ts +62 -0
  180. package/dist/types/search.d.ts.map +1 -0
  181. package/dist/types/search.js +5 -0
  182. package/dist/types/search.js.map +1 -0
  183. package/dist/types/sections.d.ts +64 -0
  184. package/dist/types/sections.d.ts.map +1 -0
  185. package/dist/types/sections.js +5 -0
  186. package/dist/types/sections.js.map +1 -0
  187. package/dist/types/tools/platform.d.ts +33 -0
  188. package/dist/types/tools/platform.d.ts.map +1 -0
  189. package/dist/types/tools/platform.js +5 -0
  190. package/dist/types/tools/platform.js.map +1 -0
  191. package/dist/types/tools/sample-code.d.ts +23 -0
  192. package/dist/types/tools/sample-code.d.ts.map +1 -0
  193. package/dist/types/tools/sample-code.js +5 -0
  194. package/dist/types/tools/sample-code.js.map +1 -0
  195. package/dist/types/tools/technology.d.ts +18 -0
  196. package/dist/types/tools/technology.d.ts.map +1 -0
  197. package/dist/types/tools/technology.js +5 -0
  198. package/dist/types/tools/technology.js.map +1 -0
  199. package/dist/types/tools/updates.d.ts +23 -0
  200. package/dist/types/tools/updates.d.ts.map +1 -0
  201. package/dist/types/tools/updates.js +5 -0
  202. package/dist/types/tools/updates.js.map +1 -0
  203. package/dist/types/wwdc.d.ts +200 -0
  204. package/dist/types/wwdc.d.ts.map +1 -0
  205. package/dist/types/wwdc.js +5 -0
  206. package/dist/types/wwdc.js.map +1 -0
  207. package/dist/utils/cache-warmer.d.ts +22 -0
  208. package/dist/utils/cache-warmer.d.ts.map +1 -0
  209. package/dist/utils/cache-warmer.js +115 -0
  210. package/dist/utils/cache-warmer.js.map +1 -0
  211. package/dist/utils/cache.d.ts +109 -0
  212. package/dist/utils/cache.d.ts.map +1 -0
  213. package/dist/utils/cache.js +302 -0
  214. package/dist/utils/cache.js.map +1 -0
  215. package/dist/utils/constants.d.ts +178 -0
  216. package/dist/utils/constants.d.ts.map +1 -0
  217. package/dist/utils/constants.js +266 -0
  218. package/dist/utils/constants.js.map +1 -0
  219. package/dist/utils/error-handler.d.ts +80 -0
  220. package/dist/utils/error-handler.d.ts.map +1 -0
  221. package/dist/utils/error-handler.js +437 -0
  222. package/dist/utils/error-handler.js.map +1 -0
  223. package/dist/utils/framework-mapper.d.ts +84 -0
  224. package/dist/utils/framework-mapper.d.ts.map +1 -0
  225. package/dist/utils/framework-mapper.js +534 -0
  226. package/dist/utils/framework-mapper.js.map +1 -0
  227. package/dist/utils/http-client.d.ts +130 -0
  228. package/dist/utils/http-client.d.ts.map +1 -0
  229. package/dist/utils/http-client.js +464 -0
  230. package/dist/utils/http-client.js.map +1 -0
  231. package/dist/utils/http-headers-generator.d.ts +151 -0
  232. package/dist/utils/http-headers-generator.d.ts.map +1 -0
  233. package/dist/utils/http-headers-generator.js +407 -0
  234. package/dist/utils/http-headers-generator.js.map +1 -0
  235. package/dist/utils/logger.d.ts +44 -0
  236. package/dist/utils/logger.d.ts.map +1 -0
  237. package/dist/utils/logger.js +73 -0
  238. package/dist/utils/logger.js.map +1 -0
  239. package/dist/utils/preloader.d.ts +20 -0
  240. package/dist/utils/preloader.d.ts.map +1 -0
  241. package/dist/utils/preloader.js +82 -0
  242. package/dist/utils/preloader.js.map +1 -0
  243. package/dist/utils/rate-limiter.d.ts +28 -0
  244. package/dist/utils/rate-limiter.d.ts.map +1 -0
  245. package/dist/utils/rate-limiter.js +48 -0
  246. package/dist/utils/rate-limiter.js.map +1 -0
  247. package/dist/utils/topic-mapper.d.ts +18 -0
  248. package/dist/utils/topic-mapper.d.ts.map +1 -0
  249. package/dist/utils/topic-mapper.js +182 -0
  250. package/dist/utils/topic-mapper.js.map +1 -0
  251. package/dist/utils/url-converter.d.ts +22 -0
  252. package/dist/utils/url-converter.d.ts.map +1 -0
  253. package/dist/utils/url-converter.js +70 -0
  254. package/dist/utils/url-converter.js.map +1 -0
  255. package/dist/utils/user-agent-pool.d.ts +241 -0
  256. package/dist/utils/user-agent-pool.d.ts.map +1 -0
  257. package/dist/utils/user-agent-pool.js +557 -0
  258. package/dist/utils/user-agent-pool.js.map +1 -0
  259. package/dist/utils/wwdc-data-source-path.d.ts +9 -0
  260. package/dist/utils/wwdc-data-source-path.d.ts.map +1 -0
  261. package/dist/utils/wwdc-data-source-path.js +22 -0
  262. package/dist/utils/wwdc-data-source-path.js.map +1 -0
  263. package/dist/utils/wwdc-data-source.d.ts +36 -0
  264. package/dist/utils/wwdc-data-source.d.ts.map +1 -0
  265. package/dist/utils/wwdc-data-source.js +133 -0
  266. package/dist/utils/wwdc-data-source.js.map +1 -0
  267. package/package.json +83 -0
@@ -0,0 +1,244 @@
1
+ import { updatesCache, generateUrlCacheKey } from '../utils/cache.js';
2
+ import { APPLE_URLS } from '../utils/constants.js';
3
+ import { httpClient } from '../utils/http-client.js';
4
+ import { logger } from '../utils/logger.js';
5
+ /**
6
+ * Handle get documentation updates
7
+ */
8
+ export async function handleGetDocumentationUpdates(category = 'all', technology, year, searchQuery, includeBeta = true, limit = 50) {
9
+ try {
10
+ logger.info('Fetching documentation updates...');
11
+ // Generate cache key
12
+ const cacheKey = generateUrlCacheKey('documentation-updates', {
13
+ category,
14
+ technology,
15
+ year,
16
+ searchQuery,
17
+ includeBeta,
18
+ limit,
19
+ });
20
+ // Try to get from cache first
21
+ const cachedResult = updatesCache.get(cacheKey);
22
+ if (cachedResult) {
23
+ logger.debug('Updates cache hit');
24
+ return cachedResult;
25
+ }
26
+ // Fetch both updates data files
27
+ const [updatesData, updatesIndex] = await Promise.all([
28
+ httpClient.getJson(APPLE_URLS.UPDATES_JSON),
29
+ httpClient.getJson(APPLE_URLS.UPDATES_INDEX_JSON),
30
+ ]);
31
+ // Parse and filter updates
32
+ const updates = parseUpdates(updatesData, updatesIndex);
33
+ const filteredUpdates = applyUpdatesFilters(updates, {
34
+ category,
35
+ technology,
36
+ year,
37
+ searchQuery,
38
+ includeBeta,
39
+ limit,
40
+ });
41
+ // Format output
42
+ const result = formatUpdatesList(filteredUpdates);
43
+ // Cache the result
44
+ updatesCache.set(cacheKey, result);
45
+ return result;
46
+ }
47
+ catch (error) {
48
+ const errorMessage = error instanceof Error ? error.message : JSON.stringify(error);
49
+ logger.error('Error fetching documentation updates:', error);
50
+ return `Error: Failed to fetch documentation updates: ${errorMessage}`;
51
+ }
52
+ }
53
+ /**
54
+ * Parse updates data
55
+ */
56
+ function parseUpdates(updatesData, updatesIndex) {
57
+ const updates = [];
58
+ // Process main updates sections
59
+ if (updatesData.topicSections) {
60
+ updatesData.topicSections.forEach(section => {
61
+ const sectionCategory = getSectionCategory(section.title);
62
+ section.identifiers.forEach(identifier => {
63
+ const reference = updatesData.references[identifier];
64
+ if (reference) {
65
+ const updateItem = {
66
+ title: reference.title,
67
+ url: reference.url ? `https://developer.apple.com${reference.url}` : '',
68
+ description: reference.abstract?.[0]?.text ?? '',
69
+ category: sectionCategory,
70
+ type: reference.kind ?? 'update',
71
+ identifier,
72
+ images: reference.images,
73
+ };
74
+ // Extract year from WWDC titles
75
+ if (sectionCategory === 'wwdc' && reference.title) {
76
+ const yearMatch = reference.title.match(/WWDC(\d{2,4})/);
77
+ if (yearMatch) {
78
+ updateItem.year = yearMatch[1].length === 2 ? `20${yearMatch[1]}` : yearMatch[1];
79
+ }
80
+ }
81
+ updates.push(updateItem);
82
+ }
83
+ });
84
+ });
85
+ }
86
+ // Process index data for additional details and beta information
87
+ if (updatesIndex.interfaceLanguages?.swift) {
88
+ processIndexSection(updatesIndex.interfaceLanguages.swift, updates);
89
+ }
90
+ return updates;
91
+ }
92
+ /**
93
+ * Process index section recursively
94
+ */
95
+ function processIndexSection(sections, updates) {
96
+ sections.forEach(section => {
97
+ // Find corresponding update item
98
+ const matchingUpdate = updates.find(u => u.url.includes(section.path) ||
99
+ u.title === section.title);
100
+ if (matchingUpdate) {
101
+ matchingUpdate.beta = section.beta ?? false;
102
+ matchingUpdate.technology = extractTechnologyFromPath(section.path);
103
+ }
104
+ // Process children
105
+ if (section.children) {
106
+ processIndexSection(section.children, updates);
107
+ }
108
+ });
109
+ }
110
+ /**
111
+ * Get section category
112
+ */
113
+ function getSectionCategory(title) {
114
+ const lowerTitle = title.toLowerCase();
115
+ if (lowerTitle.includes('wwdc')) {
116
+ return 'wwdc';
117
+ }
118
+ if (lowerTitle.includes('release notes')) {
119
+ return 'release-notes';
120
+ }
121
+ if (lowerTitle.includes('technology')) {
122
+ return 'technology';
123
+ }
124
+ return 'other';
125
+ }
126
+ /**
127
+ * Extract technology from path
128
+ */
129
+ function extractTechnologyFromPath(path) {
130
+ const match = path.match(/\/documentation\/updates\/([^/]+)/i);
131
+ if (match?.[1]) {
132
+ // Convert to proper case
133
+ return match[1].replace(/-/g, ' ')
134
+ .split(' ')
135
+ .map(word => word.charAt(0).toUpperCase() + word.slice(1))
136
+ .join(' ');
137
+ }
138
+ return undefined;
139
+ }
140
+ /**
141
+ * Apply filters to updates
142
+ */
143
+ function applyUpdatesFilters(updates, filters) {
144
+ let filtered = [...updates];
145
+ // Category filter
146
+ if (filters.category && filters.category !== 'all') {
147
+ filtered = filtered.filter(update => update.category === filters.category);
148
+ }
149
+ // Technology filter
150
+ if (filters.technology) {
151
+ const techLower = filters.technology.toLowerCase();
152
+ filtered = filtered.filter(update => (update.technology?.toLowerCase().includes(techLower)) ||
153
+ update.title.toLowerCase().includes(techLower) ||
154
+ update.description.toLowerCase().includes(techLower));
155
+ }
156
+ // Year filter (for WWDC)
157
+ if (filters.year) {
158
+ filtered = filtered.filter(update => update.year === filters.year);
159
+ }
160
+ // Search query filter
161
+ if (filters.searchQuery) {
162
+ const queryLower = filters.searchQuery.toLowerCase();
163
+ filtered = filtered.filter(update => update.title.toLowerCase().includes(queryLower) ||
164
+ update.description.toLowerCase().includes(queryLower));
165
+ }
166
+ // Beta filter
167
+ if (!filters.includeBeta) {
168
+ filtered = filtered.filter(update => !update.beta);
169
+ }
170
+ // Apply limit
171
+ if (filters.limit && filters.limit > 0) {
172
+ filtered = filtered.slice(0, filters.limit);
173
+ }
174
+ return filtered;
175
+ }
176
+ /**
177
+ * Format updates list
178
+ */
179
+ function formatUpdatesList(updates) {
180
+ if (updates.length === 0) {
181
+ return 'No documentation updates found matching the specified criteria.';
182
+ }
183
+ let content = '# Apple Developer Documentation Updates\n\n';
184
+ // Group by category
185
+ const grouped = updates.reduce((acc, update) => {
186
+ const category = update.category;
187
+ if (!acc[category]) {
188
+ acc[category] = [];
189
+ }
190
+ acc[category].push(update);
191
+ return acc;
192
+ }, {});
193
+ // Format each category
194
+ const categoryTitles = {
195
+ 'wwdc': 'WWDC',
196
+ 'technology': 'Technology Updates',
197
+ 'release-notes': 'Release Notes',
198
+ 'other': 'Other Updates',
199
+ };
200
+ Object.entries(grouped).forEach(([category, items]) => {
201
+ content += `## ${categoryTitles[category] ?? category}\n\n`;
202
+ // Add WWDC-specific suggestion
203
+ if (category === 'wwdc' && items.length > 0) {
204
+ content += '> **💡 Tip:** For comprehensive WWDC video content with full transcripts and code examples, use the dedicated WWDC tools:\n';
205
+ content += '> - `list_wwdc_videos` - Browse videos by year, topic, or code availability\n';
206
+ content += '> - `search_wwdc_content` - Search through video transcripts and code\n';
207
+ content += '> - `browse_wwdc_topics` - Explore videos by topic categories\n\n';
208
+ }
209
+ items.forEach(item => {
210
+ // Build title with badges
211
+ let titleLine = `### [${item.title}](${item.url})`;
212
+ const badges = [];
213
+ if (item.beta) {
214
+ badges.push('Beta');
215
+ }
216
+ if (item.images?.some(img => img.identifier === 'new.svg')) {
217
+ badges.push('New');
218
+ }
219
+ if (badges.length > 0) {
220
+ titleLine += ` *${badges.join(' | ')}*`;
221
+ }
222
+ content += titleLine + '\n';
223
+ // Add description
224
+ if (item.description) {
225
+ content += `${item.description}\n`;
226
+ }
227
+ // Add metadata
228
+ const metadata = [];
229
+ if (item.technology && item.category !== 'technology') {
230
+ metadata.push(`Technology: ${item.technology}`);
231
+ }
232
+ if (item.year && item.category === 'wwdc') {
233
+ metadata.push(`Year: ${item.year}`);
234
+ }
235
+ if (metadata.length > 0) {
236
+ content += `*${metadata.join(' | ')}*\n`;
237
+ }
238
+ content += '\n';
239
+ });
240
+ });
241
+ content += '\n---\n\n[View all updates on Apple Developer](https://developer.apple.com/documentation/updates)';
242
+ return content;
243
+ }
244
+ //# sourceMappingURL=get-documentation-updates.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-documentation-updates.js","sourceRoot":"","sources":["../../src/tools/get-documentation-updates.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,mBAAmB,CAAC;AACtE,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAuC5C;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,6BAA6B,CACjD,WAAmB,KAAK,EACxB,UAAmB,EACnB,IAAa,EACb,WAAoB,EACpB,cAAuB,IAAI,EAC3B,QAAgB,EAAE;IAElB,IAAI,CAAC;QACH,MAAM,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;QAEjD,qBAAqB;QACrB,MAAM,QAAQ,GAAG,mBAAmB,CAAC,uBAAuB,EAAE;YAC5D,QAAQ;YACR,UAAU;YACV,IAAI;YACJ,WAAW;YACX,WAAW;YACX,KAAK;SACN,CAAC,CAAC;QAEH,8BAA8B;QAC9B,MAAM,YAAY,GAAG,YAAY,CAAC,GAAG,CAAS,QAAQ,CAAC,CAAC;QACxD,IAAI,YAAY,EAAE,CAAC;YACjB,MAAM,CAAC,KAAK,CAAC,mBAAmB,CAAC,CAAC;YAClC,OAAO,YAAY,CAAC;QACtB,CAAC;QAED,gCAAgC;QAChC,MAAM,CAAC,WAAW,EAAE,YAAY,CAAC,GAAG,MAAM,OAAO,CAAC,GAAG,CAAC;YACpD,UAAU,CAAC,OAAO,CAAc,UAAU,CAAC,YAAY,CAAC;YACxD,UAAU,CAAC,OAAO,CAAmB,UAAU,CAAC,kBAAkB,CAAC;SACpE,CAAC,CAAC;QAEH,2BAA2B;QAC3B,MAAM,OAAO,GAAG,YAAY,CAAC,WAAW,EAAE,YAAY,CAAC,CAAC;QACxD,MAAM,eAAe,GAAG,mBAAmB,CAAC,OAAO,EAAE;YACnD,QAAQ;YACR,UAAU;YACV,IAAI;YACJ,WAAW;YACX,WAAW;YACX,KAAK;SACN,CAAC,CAAC;QAEH,gBAAgB;QAChB,MAAM,MAAM,GAAG,iBAAiB,CAAC,eAAe,CAAC,CAAC;QAElD,mBAAmB;QACnB,YAAY,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;QAEnC,OAAO,MAAM,CAAC;IAEhB,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,YAAY,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACpF,MAAM,CAAC,KAAK,CAAC,uCAAuC,EAAE,KAAK,CAAC,CAAC;QAC7D,OAAO,iDAAiD,YAAY,EAAE,CAAC;IACzE,CAAC;AACH,CAAC;AAED;;GAEG;AACH,SAAS,YAAY,CAAC,WAAwB,EAAE,YAA8B;IAC5E,MAAM,OAAO,GAAiB,EAAE,CAAC;IAEjC,gCAAgC;IAChC,IAAI,WAAW,CAAC,aAAa,EAAE,CAAC;QAC9B,WAAW,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YAC1C,MAAM,eAAe,GAAG,kBAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;YAE1D,OAAO,CAAC,WAAW,CAAC,OAAO,CAAC,UAAU,CAAC,EAAE;gBACvC,MAAM,SAAS,GAAG,WAAW,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;gBACrD,IAAI,SAAS,EAAE,CAAC;oBACd,MAAM,UAAU,GAAe;wBAC7B,KAAK,EAAE,SAAS,CAAC,KAAK;wBACtB,GAAG,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,8BAA8B,SAAS,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,EAAE;wBACvE,WAAW,EAAE,SAAS,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,IAAI,IAAI,EAAE;wBAChD,QAAQ,EAAE,eAAe;wBACzB,IAAI,EAAE,SAAS,CAAC,IAAI,IAAI,QAAQ;wBAChC,UAAU;wBACV,MAAM,EAAE,SAAS,CAAC,MAAM;qBACzB,CAAC;oBAEF,gCAAgC;oBAChC,IAAI,eAAe,KAAK,MAAM,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;wBAClD,MAAM,SAAS,GAAG,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC;wBACzD,IAAI,SAAS,EAAE,CAAC;4BACd,UAAU,CAAC,IAAI,GAAG,SAAS,CAAC,CAAC,CAAC,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;wBACnF,CAAC;oBACH,CAAC;oBAED,OAAO,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBAC3B,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,iEAAiE;IACjE,IAAI,YAAY,CAAC,kBAAkB,EAAE,KAAK,EAAE,CAAC;QAC3C,mBAAmB,CAAC,YAAY,CAAC,kBAAkB,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;IACtE,CAAC;IAED,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;GAEG;AACH,SAAS,mBAAmB,CAAC,QAA+B,EAAE,OAAqB;IACjF,QAAQ,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;QACzB,iCAAiC;QACjC,MAAM,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CACtC,CAAC,CAAC,GAAG,CAAC,QAAQ,CAAC,OAAO,CAAC,IAAI,CAAC;YAC5B,CAAC,CAAC,KAAK,KAAK,OAAO,CAAC,KAAK,CAC1B,CAAC;QAEF,IAAI,cAAc,EAAE,CAAC;YACnB,cAAc,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,IAAI,KAAK,CAAC;YAC5C,cAAc,CAAC,UAAU,GAAG,yBAAyB,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QACtE,CAAC;QAED,mBAAmB;QACnB,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACrB,mBAAmB,CAAC,OAAO,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAC;QACjD,CAAC;IACH,CAAC,CAAC,CAAC;AACL,CAAC;AAED;;GAEG;AACH,SAAS,kBAAkB,CAAC,KAAa;IACvC,MAAM,UAAU,GAAG,KAAK,CAAC,WAAW,EAAE,CAAC;IACvC,IAAI,UAAU,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE,CAAC;QAChC,OAAO,MAAM,CAAC;IAChB,CAAC;IACD,IAAI,UAAU,CAAC,QAAQ,CAAC,eAAe,CAAC,EAAE,CAAC;QACzC,OAAO,eAAe,CAAC;IACzB,CAAC;IACD,IAAI,UAAU,CAAC,QAAQ,CAAC,YAAY,CAAC,EAAE,CAAC;QACtC,OAAO,YAAY,CAAC;IACtB,CAAC;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;GAEG;AACH,SAAS,yBAAyB,CAAC,IAAY;IAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;IAC/D,IAAI,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;QACf,yBAAyB;QACzB,OAAO,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC;aAC/B,KAAK,CAAC,GAAG,CAAC;aACV,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;aACzD,IAAI,CAAC,GAAG,CAAC,CAAC;IACf,CAAC;IACD,OAAO,SAAS,CAAC;AACnB,CAAC;AAED;;GAEG;AACH,SAAS,mBAAmB,CAC1B,OAAqB,EACrB,OAOC;IAED,IAAI,QAAQ,GAAG,CAAC,GAAG,OAAO,CAAC,CAAC;IAE5B,kBAAkB;IAClB,IAAI,OAAO,CAAC,QAAQ,IAAI,OAAO,CAAC,QAAQ,KAAK,KAAK,EAAE,CAAC;QACnD,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,QAAQ,KAAK,OAAO,CAAC,QAAQ,CAAC,CAAC;IAC7E,CAAC;IAED,oBAAoB;IACpB,IAAI,OAAO,CAAC,UAAU,EAAE,CAAC;QACvB,MAAM,SAAS,GAAG,OAAO,CAAC,UAAU,CAAC,WAAW,EAAE,CAAC;QACnD,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAClC,CAAC,MAAM,CAAC,UAAU,EAAE,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;YACtD,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC;YAC9C,MAAM,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,CACrD,CAAC;IACJ,CAAC;IAED,yBAAyB;IACzB,IAAI,OAAO,CAAC,IAAI,EAAE,CAAC;QACjB,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACrE,CAAC;IAED,sBAAsB;IACtB,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;QACxB,MAAM,UAAU,GAAG,OAAO,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC;QACrD,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAClC,MAAM,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC;YAC/C,MAAM,CAAC,WAAW,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,CACtD,CAAC;IACJ,CAAC;IAED,cAAc;IACd,IAAI,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;QACzB,QAAQ,GAAG,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACrD,CAAC;IAED,cAAc;IACd,IAAI,OAAO,CAAC,KAAK,IAAI,OAAO,CAAC,KAAK,GAAG,CAAC,EAAE,CAAC;QACvC,QAAQ,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,SAAS,iBAAiB,CAAC,OAAqB;IAC9C,IAAI,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QACzB,OAAO,iEAAiE,CAAC;IAC3E,CAAC;IAED,IAAI,OAAO,GAAG,6CAA6C,CAAC;IAE5D,oBAAoB;IACpB,MAAM,OAAO,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,MAAM,EAAE,EAAE;QAC7C,MAAM,QAAQ,GAAG,MAAM,CAAC,QAAQ,CAAC;QACjC,IAAI,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;YACnB,GAAG,CAAC,QAAQ,CAAC,GAAG,EAAE,CAAC;QACrB,CAAC;QACD,GAAG,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;QAC3B,OAAO,GAAG,CAAC;IACb,CAAC,EAAE,EAAkC,CAAC,CAAC;IAEvC,uBAAuB;IACvB,MAAM,cAAc,GAA2B;QAC7C,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,oBAAoB;QAClC,eAAe,EAAE,eAAe;QAChC,OAAO,EAAE,eAAe;KACzB,CAAC;IAEF,MAAM,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,QAAQ,EAAE,KAAK,CAAC,EAAE,EAAE;QACpD,OAAO,IAAI,MAAM,cAAc,CAAC,QAAQ,CAAC,IAAI,QAAQ,MAAM,CAAC;QAE5D,+BAA+B;QAC/B,IAAI,QAAQ,KAAK,MAAM,IAAI,KAAK,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC5C,OAAO,IAAI,6HAA6H,CAAC;YACzI,OAAO,IAAI,+EAA+E,CAAC;YAC3F,OAAO,IAAI,yEAAyE,CAAC;YACrF,OAAO,IAAI,mEAAmE,CAAC;QACjF,CAAC;QAED,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACnB,0BAA0B;YAC1B,IAAI,SAAS,GAAG,QAAQ,IAAI,CAAC,KAAK,KAAK,IAAI,CAAC,GAAG,GAAG,CAAC;YAEnD,MAAM,MAAM,GAAG,EAAE,CAAC;YAClB,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC;gBACd,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;YACtB,CAAC;YACD,IAAI,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,UAAU,KAAK,SAAS,CAAC,EAAE,CAAC;gBAC3D,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YACrB,CAAC;YAED,IAAI,MAAM,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtB,SAAS,IAAI,KAAK,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC;YAC1C,CAAC;YAED,OAAO,IAAI,SAAS,GAAG,IAAI,CAAC;YAE5B,kBAAkB;YAClB,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC;gBACrB,OAAO,IAAI,GAAG,IAAI,CAAC,WAAW,IAAI,CAAC;YACrC,CAAC;YAED,eAAe;YACf,MAAM,QAAQ,GAAG,EAAE,CAAC;YACpB,IAAI,IAAI,CAAC,UAAU,IAAI,IAAI,CAAC,QAAQ,KAAK,YAAY,EAAE,CAAC;gBACtD,QAAQ,CAAC,IAAI,CAAC,eAAe,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;YAClD,CAAC;YACD,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC;gBAC1C,QAAQ,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;YACtC,CAAC;YAED,IAAI,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACxB,OAAO,IAAI,IAAI,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;YAC3C,CAAC;YAED,OAAO,IAAI,IAAI,CAAC;QAClB,CAAC,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,OAAO,IAAI,mGAAmG,CAAC;IAE/G,OAAO,OAAO,CAAC;AACjB,CAAC"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * 获取平台兼容性分析
3
+ */
4
+ export declare function handleGetPlatformCompatibility(apiUrl: string, compareMode?: string, includeRelated?: boolean): Promise<string>;
5
+ //# sourceMappingURL=get-platform-compatibility.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-platform-compatibility.d.ts","sourceRoot":"","sources":["../../src/tools/get-platform-compatibility.ts"],"names":[],"mappings":"AA4CA;;GAEG;AACH,wBAAsB,8BAA8B,CAClD,MAAM,EAAE,MAAM,EACd,WAAW,GAAE,MAAiB,EAC9B,cAAc,GAAE,OAAe,GAC9B,OAAO,CAAC,MAAM,CAAC,CAcjB"}
@@ -0,0 +1,205 @@
1
+ import { convertToJsonApiUrl } from '../utils/url-converter.js';
2
+ import { httpClient } from '../utils/http-client.js';
3
+ import { logger } from '../utils/logger.js';
4
+ import { PROCESSING_LIMITS } from '../utils/constants.js';
5
+ /**
6
+ * 获取平台兼容性分析
7
+ */
8
+ export async function handleGetPlatformCompatibility(apiUrl, compareMode = 'single', includeRelated = false) {
9
+ try {
10
+ logger.info(`Analyzing platform compatibility for: ${apiUrl}`);
11
+ if (compareMode === 'framework') {
12
+ return await analyzeFrameworkCompatibility(apiUrl, includeRelated);
13
+ }
14
+ else {
15
+ return await analyzeSingleApiCompatibility(apiUrl, includeRelated);
16
+ }
17
+ }
18
+ catch (error) {
19
+ const errorMessage = error instanceof Error ? error.message : String(error);
20
+ return `Error: Failed to analyze platform compatibility: ${errorMessage}`;
21
+ }
22
+ }
23
+ /**
24
+ * 分析单个API的平台兼容性
25
+ */
26
+ async function analyzeSingleApiCompatibility(apiUrl, includeRelated) {
27
+ const jsonApiUrl = convertToJsonApiUrl(apiUrl);
28
+ if (!jsonApiUrl) {
29
+ throw new Error('Invalid Apple Developer Documentation URL');
30
+ }
31
+ const data = await httpClient.getJson(jsonApiUrl);
32
+ if (!data.metadata?.platforms) {
33
+ return `No platform information available for: ${apiUrl}`;
34
+ }
35
+ const analysis = analyzeCompatibility(data.metadata.title || 'Unknown API', apiUrl, data.metadata.platforms);
36
+ let result = formatCompatibilityAnalysis(analysis);
37
+ // 如果需要包含相关API的兼容性信息
38
+ if (includeRelated && data.topicSections) {
39
+ const relatedAnalyses = await analyzeRelatedCompatibility(data, 3); // 限制3个相关API
40
+ if (relatedAnalyses.length > 0) {
41
+ result += '\n\n## Related APIs Compatibility\n\n';
42
+ for (const relatedAnalysis of relatedAnalyses) {
43
+ result += formatCompatibilityAnalysis(relatedAnalysis, true) + '\n';
44
+ }
45
+ }
46
+ }
47
+ return result;
48
+ }
49
+ /**
50
+ * 分析框架的平台兼容性
51
+ */
52
+ async function analyzeFrameworkCompatibility(frameworkUrl, includeRelated) {
53
+ // 这里可以扩展为分析整个框架的兼容性
54
+ // 暂时使用单API分析作为基础
55
+ return await analyzeSingleApiCompatibility(frameworkUrl, includeRelated || true);
56
+ }
57
+ /**
58
+ * 分析相关API的兼容性
59
+ */
60
+ async function analyzeRelatedCompatibility(data, maxRelated = 3) {
61
+ const analyses = [];
62
+ if (!data.topicSections || !data.references) {
63
+ return analyses;
64
+ }
65
+ let count = 0;
66
+ for (const section of data.topicSections) {
67
+ if (count >= maxRelated) {
68
+ break;
69
+ }
70
+ for (const identifier of section.identifiers.slice(0, PROCESSING_LIMITS.MAX_PLATFORM_COMPATIBILITY_ITEMS)) { // 每个section最多2个
71
+ if (count >= maxRelated) {
72
+ break;
73
+ }
74
+ const ref = data.references[identifier];
75
+ if (ref?.url) {
76
+ try {
77
+ const relatedUrl = `https://developer.apple.com${ref.url}`;
78
+ const relatedJsonUrl = convertToJsonApiUrl(relatedUrl);
79
+ if (!relatedJsonUrl) {
80
+ logger.warn(`Failed to convert URL: ${relatedUrl}`);
81
+ continue;
82
+ }
83
+ const relatedData = await httpClient.getJson(relatedJsonUrl);
84
+ if (relatedData.metadata?.platforms) {
85
+ const analysis = analyzeCompatibility(ref.title || 'Unknown', relatedUrl, relatedData.metadata.platforms);
86
+ analyses.push(analysis);
87
+ count++;
88
+ }
89
+ }
90
+ catch (error) {
91
+ // 忽略单个相关API的错误
92
+ logger.error(`Failed to fetch related API ${identifier}:`, error);
93
+ }
94
+ }
95
+ }
96
+ }
97
+ return analyses;
98
+ }
99
+ /**
100
+ * 分析兼容性数据
101
+ */
102
+ function analyzeCompatibility(apiName, apiUrl, platforms) {
103
+ const supportedPlatforms = [];
104
+ const betaPlatforms = [];
105
+ const deprecatedPlatforms = [];
106
+ const minVersions = {};
107
+ for (const platform of platforms) {
108
+ supportedPlatforms.push(platform.name);
109
+ if (platform.beta) {
110
+ betaPlatforms.push(platform.name);
111
+ }
112
+ if (platform.deprecated) {
113
+ deprecatedPlatforms.push(platform.name);
114
+ }
115
+ if (platform.introducedAt) {
116
+ minVersions[platform.name] = platform.introducedAt;
117
+ }
118
+ }
119
+ return {
120
+ apiName,
121
+ apiUrl,
122
+ platforms,
123
+ supportedPlatforms,
124
+ betaPlatforms,
125
+ deprecatedPlatforms,
126
+ minVersions,
127
+ crossPlatformSupport: supportedPlatforms.length > 1,
128
+ };
129
+ }
130
+ /**
131
+ * 格式化兼容性分析结果
132
+ */
133
+ function formatCompatibilityAnalysis(analysis, isRelated = false) {
134
+ const prefix = isRelated ? '### ' : '# ';
135
+ let content = `${prefix}Platform Compatibility: ${analysis.apiName}\n\n`;
136
+ if (!isRelated) {
137
+ content += `**API:** [${analysis.apiUrl}](${analysis.apiUrl})\n\n`;
138
+ }
139
+ // 平台支持概览
140
+ content += '## Platform Support Summary\n\n';
141
+ content += `**Supported Platforms:** ${analysis.supportedPlatforms.join(', ')}\n`;
142
+ content += `**Cross-Platform:** ${analysis.crossPlatformSupport ? 'Yes' : 'No'}\n`;
143
+ if (analysis.betaPlatforms.length > 0) {
144
+ content += `**Beta Platforms:** ${analysis.betaPlatforms.join(', ')}\n`;
145
+ }
146
+ if (analysis.deprecatedPlatforms.length > 0) {
147
+ content += `**Deprecated Platforms:** ${analysis.deprecatedPlatforms.join(', ')}\n`;
148
+ }
149
+ content += '\n';
150
+ // 详细平台信息
151
+ content += '## Detailed Platform Information\n\n';
152
+ for (const platform of analysis.platforms) {
153
+ content += `**${platform.name}**\n`;
154
+ if (platform.introducedAt) {
155
+ content += `- Introduced: ${platform.introducedAt}\n`;
156
+ }
157
+ if (platform.deprecatedAt) {
158
+ content += `- Deprecated: ${platform.deprecatedAt}\n`;
159
+ }
160
+ if (platform.obsoletedAt) {
161
+ content += `- Obsoleted: ${platform.obsoletedAt}\n`;
162
+ }
163
+ const status = [];
164
+ if (platform.beta) {
165
+ status.push('Beta');
166
+ }
167
+ if (platform.deprecated) {
168
+ status.push('Deprecated');
169
+ }
170
+ if (platform.unavailable) {
171
+ status.push('Unavailable');
172
+ }
173
+ if (status.length > 0) {
174
+ content += `- Status: ${status.join(', ')}\n`;
175
+ }
176
+ if (platform.message) {
177
+ content += `- Note: ${platform.message}\n`;
178
+ }
179
+ content += '\n';
180
+ }
181
+ // 兼容性建议
182
+ content += '## Compatibility Recommendations\n\n';
183
+ if (analysis.crossPlatformSupport) {
184
+ content += `✅ **Cross-platform compatible** - This API works across ${analysis.supportedPlatforms.length} platforms\n\n`;
185
+ }
186
+ else {
187
+ content += `⚠️ **Platform-specific** - This API is only available on ${analysis.supportedPlatforms[0]}\n\n`;
188
+ }
189
+ if (analysis.betaPlatforms.length > 0) {
190
+ content += '🚧 **Beta platforms** - Some platforms are in beta, expect changes\n\n';
191
+ }
192
+ if (analysis.deprecatedPlatforms.length > 0) {
193
+ content += '⚠️ **Deprecated platforms** - Consider migration plans for deprecated platforms\n\n';
194
+ }
195
+ // 最低版本要求
196
+ if (Object.keys(analysis.minVersions).length > 0) {
197
+ content += '## Minimum Version Requirements\n\n';
198
+ for (const [platform, version] of Object.entries(analysis.minVersions)) {
199
+ content += `- **${platform}:** ${version}+\n`;
200
+ }
201
+ content += '\n';
202
+ }
203
+ return content;
204
+ }
205
+ //# sourceMappingURL=get-platform-compatibility.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-platform-compatibility.js","sourceRoot":"","sources":["../../src/tools/get-platform-compatibility.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * 获取相关API
3
+ */
4
+ export declare function handleGetRelatedApis(apiUrl: string, includeInherited?: boolean, includeConformance?: boolean, includeSeeAlso?: boolean): Promise<string>;
5
+ //# sourceMappingURL=get-related-apis.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-related-apis.d.ts","sourceRoot":"","sources":["../../src/tools/get-related-apis.ts"],"names":[],"mappings":"AAsCA;;GAEG;AACH,wBAAsB,oBAAoB,CACxC,MAAM,EAAE,MAAM,EACd,gBAAgB,GAAE,OAAc,EAChC,kBAAkB,GAAE,OAAc,EAClC,cAAc,GAAE,OAAc,GAC7B,OAAO,CAAC,MAAM,CAAC,CA0EjB"}
@@ -0,0 +1,155 @@
1
+ import { convertToJsonApiUrl } from '../utils/url-converter.js';
2
+ import { httpClient } from '../utils/http-client.js';
3
+ import { logger } from '../utils/logger.js';
4
+ import { PROCESSING_LIMITS } from '../utils/constants.js';
5
+ /**
6
+ * 获取相关API
7
+ */
8
+ export async function handleGetRelatedApis(apiUrl, includeInherited = true, includeConformance = true, includeSeeAlso = true) {
9
+ try {
10
+ logger.info(`Fetching related APIs for: ${apiUrl}`);
11
+ // 将网页URL转换为JSON API URL
12
+ const jsonApiUrl = convertToJsonApiUrl(apiUrl);
13
+ if (!jsonApiUrl) {
14
+ throw new Error('Invalid Apple Developer Documentation URL');
15
+ }
16
+ const data = await httpClient.getJson(jsonApiUrl);
17
+ // 收集所有相关API
18
+ const relatedApis = [];
19
+ // 处理关系部分(继承、一致性等)
20
+ if (data.relationshipsSections) {
21
+ for (const section of data.relationshipsSections) {
22
+ const shouldInclude = (includeInherited && (section.type === 'inheritsFrom' || section.type === 'inheritedBy')) ||
23
+ (includeConformance && (section.type === 'conformsTo' || section.type === 'conformingTypes'));
24
+ if (shouldInclude && section.identifiers) {
25
+ for (const identifier of section.identifiers) {
26
+ const api = extractApiFromIdentifier(identifier, section.title, data.references);
27
+ if (api) {
28
+ relatedApis.push(api);
29
+ }
30
+ }
31
+ }
32
+ }
33
+ }
34
+ // 处理"另请参阅"部分
35
+ if (includeSeeAlso && data.seeAlsoSections) {
36
+ for (const section of data.seeAlsoSections) {
37
+ if (section.identifiers) {
38
+ for (const identifier of section.identifiers) {
39
+ const api = extractApiFromIdentifier(identifier, `See Also: ${section.title}`, data.references);
40
+ if (api) {
41
+ relatedApis.push(api);
42
+ }
43
+ }
44
+ }
45
+ }
46
+ }
47
+ // 处理主题部分的相关API
48
+ if (data.topicSections) {
49
+ for (const section of data.topicSections) {
50
+ if (section.identifiers && section.identifiers.length > 0) {
51
+ // 只取前3个,避免过多
52
+ const limitedIdentifiers = section.identifiers.slice(0, PROCESSING_LIMITS.MAX_RELATED_APIS_PER_SECTION);
53
+ for (const identifier of limitedIdentifiers) {
54
+ const api = extractApiFromIdentifier(identifier, `Related: ${section.title}`, data.references);
55
+ if (api) {
56
+ relatedApis.push(api);
57
+ }
58
+ }
59
+ }
60
+ }
61
+ }
62
+ // 去重
63
+ const uniqueApis = deduplicateApis(relatedApis);
64
+ // 格式化输出
65
+ return formatRelatedApis(apiUrl, uniqueApis);
66
+ }
67
+ catch (error) {
68
+ const errorMessage = error instanceof Error ? error.message : String(error);
69
+ return `Error: Failed to get related APIs: ${errorMessage}`;
70
+ }
71
+ }
72
+ /**
73
+ * 从标识符提取API信息
74
+ */
75
+ function extractApiFromIdentifier(identifier, relationship, references) {
76
+ // 先从references中查找
77
+ if (references?.[identifier]) {
78
+ const ref = references[identifier];
79
+ return {
80
+ title: ref.title || 'Unknown',
81
+ url: ref.url ? `https://developer.apple.com${ref.url}` : '#',
82
+ identifier,
83
+ type: ref.kind || ref.type || 'unknown',
84
+ relationship,
85
+ abstract: ref.abstract ? ref.abstract.map((a) => a.text || '').join(' ').trim() : undefined,
86
+ };
87
+ }
88
+ // 如果references中没有,尝试解析标识符
89
+ if (identifier.startsWith('doc://')) {
90
+ const parts = identifier.split('/');
91
+ const apiName = parts[parts.length - 1] || 'Unknown';
92
+ const pathPart = identifier.replace(/^doc:\/\/[^\/]+\/documentation\//, '');
93
+ return {
94
+ title: apiName,
95
+ url: `https://developer.apple.com/documentation/${pathPart}`,
96
+ identifier,
97
+ type: 'symbol',
98
+ relationship,
99
+ };
100
+ }
101
+ return null;
102
+ }
103
+ /**
104
+ * 去重API列表
105
+ */
106
+ function deduplicateApis(apis) {
107
+ const seen = new Set();
108
+ return apis.filter(api => {
109
+ if (seen.has(api.identifier)) {
110
+ return false;
111
+ }
112
+ seen.add(api.identifier);
113
+ return true;
114
+ });
115
+ }
116
+ /**
117
+ * 格式化相关API输出
118
+ */
119
+ function formatRelatedApis(originalUrl, relatedApis) {
120
+ if (relatedApis.length === 0) {
121
+ return `No related APIs found for: ${originalUrl}`;
122
+ }
123
+ const apiName = new URL(originalUrl).pathname.split('/').pop() || 'API';
124
+ let content = `# Related APIs for ${apiName}\n\n`;
125
+ content += `**Source:** [${originalUrl}](${originalUrl})\n\n`;
126
+ content += `**Found ${relatedApis.length} related APIs:**\n\n`;
127
+ // 按关系类型分组
128
+ const groupedApis = groupApisByRelationship(relatedApis);
129
+ for (const [relationship, apis] of Object.entries(groupedApis)) {
130
+ content += `## ${relationship}\n\n`;
131
+ for (const api of apis) {
132
+ content += `### [${api.title}](${api.url})\n`;
133
+ if (api.abstract) {
134
+ content += `${api.abstract}\n\n`;
135
+ }
136
+ content += `*Type: ${api.type}*\n\n`;
137
+ }
138
+ }
139
+ content += `---\n\n*Total: ${relatedApis.length} related APIs*`;
140
+ return content;
141
+ }
142
+ /**
143
+ * 按关系类型分组API
144
+ */
145
+ function groupApisByRelationship(apis) {
146
+ const groups = {};
147
+ for (const api of apis) {
148
+ if (!groups[api.relationship]) {
149
+ groups[api.relationship] = [];
150
+ }
151
+ groups[api.relationship].push(api);
152
+ }
153
+ return groups;
154
+ }
155
+ //# sourceMappingURL=get-related-apis.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"get-related-apis.js","sourceRoot":"","sources":["../../src/tools/get-related-apis.ts"],"names":[],"mappings":"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"}