@remix-gg/mcp 0.4.3

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 (139) hide show
  1. package/README.md +81 -0
  2. package/dist/client-helpers/index.d.ts +2 -0
  3. package/dist/client-helpers/index.d.ts.map +1 -0
  4. package/dist/client-helpers/index.js +2 -0
  5. package/dist/client-helpers/index.js.map +1 -0
  6. package/dist/config.d.ts +20 -0
  7. package/dist/config.d.ts.map +1 -0
  8. package/dist/config.js +58 -0
  9. package/dist/config.js.map +1 -0
  10. package/dist/core/api-client.d.ts +4 -0
  11. package/dist/core/api-client.d.ts.map +1 -0
  12. package/dist/core/api-client.js +12 -0
  13. package/dist/core/api-client.js.map +1 -0
  14. package/dist/core/config.d.ts +6 -0
  15. package/dist/core/config.d.ts.map +1 -0
  16. package/dist/core/config.js +19 -0
  17. package/dist/core/config.js.map +1 -0
  18. package/dist/core/index.d.ts +5 -0
  19. package/dist/core/index.d.ts.map +1 -0
  20. package/dist/core/index.js +4 -0
  21. package/dist/core/index.js.map +1 -0
  22. package/dist/core/skills.d.ts +22 -0
  23. package/dist/core/skills.d.ts.map +1 -0
  24. package/dist/core/skills.js +49 -0
  25. package/dist/core/skills.js.map +1 -0
  26. package/dist/core/tool-defs.d.ts +12 -0
  27. package/dist/core/tool-defs.d.ts.map +1 -0
  28. package/dist/core/tool-defs.js +356 -0
  29. package/dist/core/tool-defs.js.map +1 -0
  30. package/dist/core/tools/create-game.d.ts +9 -0
  31. package/dist/core/tools/create-game.d.ts.map +1 -0
  32. package/dist/core/tools/create-game.js +21 -0
  33. package/dist/core/tools/create-game.js.map +1 -0
  34. package/dist/core/tools/create-shop-item.d.ts +14 -0
  35. package/dist/core/tools/create-shop-item.d.ts.map +1 -0
  36. package/dist/core/tools/create-shop-item.js +78 -0
  37. package/dist/core/tools/create-shop-item.js.map +1 -0
  38. package/dist/core/tools/delete-shop-item.d.ts +9 -0
  39. package/dist/core/tools/delete-shop-item.d.ts.map +1 -0
  40. package/dist/core/tools/delete-shop-item.js +19 -0
  41. package/dist/core/tools/delete-shop-item.js.map +1 -0
  42. package/dist/core/tools/generate-image.d.ts +8 -0
  43. package/dist/core/tools/generate-image.d.ts.map +1 -0
  44. package/dist/core/tools/generate-image.js +32 -0
  45. package/dist/core/tools/generate-image.js.map +1 -0
  46. package/dist/core/tools/generate-sprite-sheet.d.ts +14 -0
  47. package/dist/core/tools/generate-sprite-sheet.d.ts.map +1 -0
  48. package/dist/core/tools/generate-sprite-sheet.js +29 -0
  49. package/dist/core/tools/generate-sprite-sheet.js.map +1 -0
  50. package/dist/core/tools/helpers.d.ts +60 -0
  51. package/dist/core/tools/helpers.d.ts.map +1 -0
  52. package/dist/core/tools/helpers.js +68 -0
  53. package/dist/core/tools/helpers.js.map +1 -0
  54. package/dist/core/tools/index.d.ts +13 -0
  55. package/dist/core/tools/index.d.ts.map +1 -0
  56. package/dist/core/tools/index.js +13 -0
  57. package/dist/core/tools/index.js.map +1 -0
  58. package/dist/core/tools/list-shop-items.d.ts +8 -0
  59. package/dist/core/tools/list-shop-items.d.ts.map +1 -0
  60. package/dist/core/tools/list-shop-items.js +17 -0
  61. package/dist/core/tools/list-shop-items.js.map +1 -0
  62. package/dist/core/tools/update-game.d.ts +11 -0
  63. package/dist/core/tools/update-game.d.ts.map +1 -0
  64. package/dist/core/tools/update-game.js +22 -0
  65. package/dist/core/tools/update-game.js.map +1 -0
  66. package/dist/core/tools/update-shop-item.d.ts +15 -0
  67. package/dist/core/tools/update-shop-item.d.ts.map +1 -0
  68. package/dist/core/tools/update-shop-item.js +24 -0
  69. package/dist/core/tools/update-shop-item.js.map +1 -0
  70. package/dist/core/tools/upload-game-asset.d.ts +8 -0
  71. package/dist/core/tools/upload-game-asset.d.ts.map +1 -0
  72. package/dist/core/tools/upload-game-asset.js +43 -0
  73. package/dist/core/tools/upload-game-asset.js.map +1 -0
  74. package/dist/core/tools/upload-version.d.ts +8 -0
  75. package/dist/core/tools/upload-version.d.ts.map +1 -0
  76. package/dist/core/tools/upload-version.js +20 -0
  77. package/dist/core/tools/upload-version.js.map +1 -0
  78. package/dist/core/tools/validate-game.d.ts +6 -0
  79. package/dist/core/tools/validate-game.d.ts.map +1 -0
  80. package/dist/core/tools/validate-game.js +41 -0
  81. package/dist/core/tools/validate-game.js.map +1 -0
  82. package/dist/core/tools.test.d.ts +2 -0
  83. package/dist/core/tools.test.d.ts.map +1 -0
  84. package/dist/core/tools.test.js +825 -0
  85. package/dist/core/tools.test.js.map +1 -0
  86. package/dist/generated/server-api.d.ts +3673 -0
  87. package/dist/generated/server-api.d.ts.map +1 -0
  88. package/dist/generated/server-api.js +2 -0
  89. package/dist/generated/server-api.js.map +1 -0
  90. package/dist/index.d.ts +3 -0
  91. package/dist/index.d.ts.map +1 -0
  92. package/dist/index.js +365 -0
  93. package/dist/index.js.map +1 -0
  94. package/dist/server/create-server.d.ts +12 -0
  95. package/dist/server/create-server.d.ts.map +1 -0
  96. package/dist/server/create-server.js +29 -0
  97. package/dist/server/create-server.js.map +1 -0
  98. package/dist/server/create-server.test.d.ts +2 -0
  99. package/dist/server/create-server.test.d.ts.map +1 -0
  100. package/dist/server/create-server.test.js +37 -0
  101. package/dist/server/create-server.test.js.map +1 -0
  102. package/dist/server/index.d.ts +3 -0
  103. package/dist/server/index.d.ts.map +1 -0
  104. package/dist/server/index.js +8 -0
  105. package/dist/server/index.js.map +1 -0
  106. package/dist/server/lib/config.d.ts +2 -0
  107. package/dist/server/lib/config.d.ts.map +1 -0
  108. package/dist/server/lib/config.js +2 -0
  109. package/dist/server/lib/config.js.map +1 -0
  110. package/dist/server/resources/skills.d.ts +3 -0
  111. package/dist/server/resources/skills.d.ts.map +1 -0
  112. package/dist/server/resources/skills.js +60 -0
  113. package/dist/server/resources/skills.js.map +1 -0
  114. package/dist/server/resources/skills.test.d.ts +2 -0
  115. package/dist/server/resources/skills.test.d.ts.map +1 -0
  116. package/dist/server/resources/skills.test.js +44 -0
  117. package/dist/server/resources/skills.test.js.map +1 -0
  118. package/dist/server/tools/register.d.ts +3 -0
  119. package/dist/server/tools/register.d.ts.map +1 -0
  120. package/dist/server/tools/register.js +26 -0
  121. package/dist/server/tools/register.js.map +1 -0
  122. package/dist/server/tools/register.test.d.ts +2 -0
  123. package/dist/server/tools/register.test.d.ts.map +1 -0
  124. package/dist/server/tools/register.test.js +85 -0
  125. package/dist/server/tools/register.test.js.map +1 -0
  126. package/dist/types.d.ts +73 -0
  127. package/dist/types.d.ts.map +1 -0
  128. package/dist/types.js +31 -0
  129. package/dist/types.js.map +1 -0
  130. package/package.json +38 -0
  131. package/skills/SKILL.md +82 -0
  132. package/skills/actions/open-game.md +18 -0
  133. package/skills/workflows/add-image-to-game.md +121 -0
  134. package/skills/workflows/add-sprite-to-game.md +127 -0
  135. package/skills/workflows/game-creation.md +124 -0
  136. package/skills/workflows/implement-multiplayer.md +355 -0
  137. package/skills/workflows/integrate-save-game.md +135 -0
  138. package/skills/workflows/manage-shop-items.md +246 -0
  139. package/skills/workflows/upload-game.md +74 -0
@@ -0,0 +1,29 @@
1
+ import { createServerApiClient } from '../api-client.js';
2
+ import { unwrapApiResponse } from './helpers.js';
3
+ export async function generateSpriteSheet(gameId, prompt, gridSize, imageUrl, config) {
4
+ const client = createServerApiClient(config);
5
+ const result = await unwrapApiResponse(client.POST('/v1/games/{gameId}/sprites/generate', {
6
+ params: { path: { gameId } },
7
+ body: {
8
+ prompt,
9
+ ...(gridSize != null ? { gridSize } : {}),
10
+ ...(imageUrl != null ? { imageUrl } : {}),
11
+ },
12
+ }));
13
+ const data = result.data;
14
+ if (!data.spriteUrl || !data.transparentSpriteUrl) {
15
+ throw new Error(`Unexpected API response — missing sprite URLs: ${JSON.stringify(result)}`);
16
+ }
17
+ return {
18
+ spriteUrl: data.spriteUrl,
19
+ transparentSpriteUrl: data.transparentSpriteUrl,
20
+ promptOriginal: data.promptOriginal ?? prompt,
21
+ promptRewritten: data.promptRewritten ?? prompt,
22
+ metadata: {
23
+ gridSize: data.metadata?.gridSize ?? gridSize ?? 4,
24
+ gridDimensions: data.metadata?.gridDimensions ?? `${gridSize ?? 4}x${gridSize ?? 4}`,
25
+ },
26
+ warnings: data.warnings ?? [],
27
+ };
28
+ }
29
+ //# sourceMappingURL=generate-sprite-sheet.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"generate-sprite-sheet.js","sourceRoot":"","sources":["../../../src/core/tools/generate-sprite-sheet.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAWhD,MAAM,CAAC,KAAK,UAAU,mBAAmB,CACvC,MAAc,EACd,MAAc,EACd,QAAiB,EACjB,QAAiB,EACjB,MAA6B;IAE7B,MAAM,MAAM,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,MAAM,iBAAiB,CACpC,MAAM,CAAC,IAAI,CAAC,qCAAqC,EAAE;QACjD,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE;QAC5B,IAAI,EAAE;YACJ,MAAM;YACN,GAAG,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACzC,GAAG,CAAC,QAAQ,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC1C;KACF,CAAC,CACH,CAAA;IAED,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAA;IACxB,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,oBAAoB,EAAE,CAAC;QAClD,MAAM,IAAI,KAAK,CAAC,kDAAkD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IAC7F,CAAC;IAED,OAAO;QACL,SAAS,EAAE,IAAI,CAAC,SAAS;QACzB,oBAAoB,EAAE,IAAI,CAAC,oBAAoB;QAC/C,cAAc,EAAE,IAAI,CAAC,cAAc,IAAI,MAAM;QAC7C,eAAe,EAAE,IAAI,CAAC,eAAe,IAAI,MAAM;QAC/C,QAAQ,EAAE;YACR,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,QAAQ,IAAI,QAAQ,IAAI,CAAC;YAClD,cAAc,EAAE,IAAI,CAAC,QAAQ,EAAE,cAAc,IAAI,GAAG,QAAQ,IAAI,CAAC,IAAI,QAAQ,IAAI,CAAC,EAAE;SACrF;QACD,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,EAAE;KAC9B,CAAA;AACH,CAAC"}
@@ -0,0 +1,60 @@
1
+ import type { RemixConfig } from '../config.js';
2
+ export type ShopItemStatus = 'ACTIVE' | 'PENDING' | 'INACTIVE';
3
+ export type ShopItemType = 'TIER_UNLOCK' | 'CONSUMABLE' | 'ONE_TIME';
4
+ export interface CreateShopItemResult {
5
+ id: string;
6
+ gameId: string;
7
+ name: string;
8
+ slug: string;
9
+ status: ShopItemStatus;
10
+ itemType: ShopItemType;
11
+ bitsCost: number | null;
12
+ description: string | null;
13
+ iconUrl: string | null;
14
+ tier: number | null;
15
+ createdAt: string;
16
+ updatedAt: string;
17
+ }
18
+ export declare function formatApiError(error: unknown, fallback: string): string;
19
+ export declare function unwrapApiResponse<T>(request: Promise<{
20
+ data?: T;
21
+ error?: unknown;
22
+ response: Response;
23
+ }>): Promise<T>;
24
+ export declare function uploadAssetFormData(gameId: string, formData: FormData, config?: Partial<RemixConfig>): Promise<{
25
+ success: true;
26
+ data: {
27
+ gameId: string;
28
+ asset: unknown;
29
+ };
30
+ }>;
31
+ export declare function asRecord(value: unknown): Record<string, unknown>;
32
+ export declare function getAssetUrl(value: unknown): string | undefined;
33
+ export declare function normalizeShopItem(item: Partial<{
34
+ id: string;
35
+ gameId: string;
36
+ name: string;
37
+ slug: string;
38
+ status: ShopItemStatus;
39
+ itemType: ShopItemType;
40
+ bitsCost: number | string | null;
41
+ description: string | null;
42
+ iconUrl: string | null;
43
+ tier: number | string | null;
44
+ createdAt: string;
45
+ updatedAt: string;
46
+ }>): {
47
+ id: string;
48
+ gameId: string;
49
+ name: string;
50
+ slug: string;
51
+ status: ShopItemStatus;
52
+ itemType: ShopItemType;
53
+ bitsCost: number | null;
54
+ description: string | null;
55
+ iconUrl: string | null;
56
+ tier: number | null;
57
+ createdAt: string;
58
+ updatedAt: string;
59
+ };
60
+ //# sourceMappingURL=helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../../src/core/tools/helpers.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAI/C,MAAM,MAAM,cAAc,GAAG,QAAQ,GAAG,SAAS,GAAG,UAAU,CAAA;AAC9D,MAAM,MAAM,YAAY,GAAG,aAAa,GAAG,YAAY,GAAG,UAAU,CAAA;AAEpE,MAAM,WAAW,oBAAoB;IACnC,EAAE,EAAE,MAAM,CAAA;IACV,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,cAAc,CAAA;IACtB,QAAQ,EAAE,YAAY,CAAA;IACtB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,IAAI,EAAE,MAAM,GAAG,IAAI,CAAA;IACnB,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;CAClB;AAID,wBAAgB,cAAc,CAAC,KAAK,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM,UAqB9D;AAED,wBAAsB,iBAAiB,CAAC,CAAC,EACvC,OAAO,EAAE,OAAO,CAAC;IAAE,IAAI,CAAC,EAAE,CAAC,CAAC;IAAC,KAAK,CAAC,EAAE,OAAO,CAAC;IAAC,QAAQ,EAAE,QAAQ,CAAA;CAAE,CAAC,GAClE,OAAO,CAAC,CAAC,CAAC,CAcZ;AAED,wBAAsB,mBAAmB,CACvC,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,QAAQ,EAClB,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC;IAAE,OAAO,EAAE,IAAI,CAAC;IAAC,IAAI,EAAE;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,OAAO,CAAA;KAAE,CAAA;CAAE,CAAC,CAWtE;AAED,wBAAgB,QAAQ,CAAC,KAAK,EAAE,OAAO,GAAG,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAEhE;AAED,wBAAgB,WAAW,CAAC,KAAK,EAAE,OAAO,sBAGzC;AAED,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,OAAO,CAAC;IACZ,EAAE,EAAE,MAAM,CAAA;IACV,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,IAAI,EAAE,MAAM,CAAA;IACZ,MAAM,EAAE,cAAc,CAAA;IACtB,QAAQ,EAAE,YAAY,CAAA;IACtB,QAAQ,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAA;IAChC,WAAW,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1B,OAAO,EAAE,MAAM,GAAG,IAAI,CAAA;IACtB,IAAI,EAAE,MAAM,GAAG,MAAM,GAAG,IAAI,CAAA;IAC5B,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;CAClB,CAAC;;;;;;;;;;;;;EAoBH"}
@@ -0,0 +1,68 @@
1
+ import { createServerApiClient } from '../api-client.js';
2
+ // ── Helper functions ─────────────────────────────────────────
3
+ export function formatApiError(error, fallback) {
4
+ if (!error)
5
+ return fallback;
6
+ if (typeof error === 'string')
7
+ return error;
8
+ if (typeof error === 'object') {
9
+ const errorBody = error;
10
+ if (errorBody.error?.message)
11
+ return errorBody.error.message;
12
+ if (errorBody.message)
13
+ return errorBody.message;
14
+ try {
15
+ return JSON.stringify(error);
16
+ }
17
+ catch {
18
+ return fallback;
19
+ }
20
+ }
21
+ return fallback;
22
+ }
23
+ export async function unwrapApiResponse(request) {
24
+ const { data, error, response } = await request;
25
+ if (!response.ok || error) {
26
+ throw new Error(`Remix API error (${response.status}): ${formatApiError(error, response.statusText)}`);
27
+ }
28
+ if (!data) {
29
+ throw new Error(`Unexpected API response (${response.status}): empty body`);
30
+ }
31
+ return data;
32
+ }
33
+ export async function uploadAssetFormData(gameId, formData, config) {
34
+ const client = createServerApiClient(config);
35
+ return unwrapApiResponse(client.POST('/v1/games/{gameId}/assets', {
36
+ params: { path: { gameId } },
37
+ // OpenAPI currently omits the multipart schema for this endpoint.
38
+ body: formData,
39
+ bodySerializer: (body) => body,
40
+ }));
41
+ }
42
+ export function asRecord(value) {
43
+ return typeof value === 'object' && value !== null ? value : {};
44
+ }
45
+ export function getAssetUrl(value) {
46
+ const asset = asRecord(value);
47
+ return typeof asset.url === 'string' ? asset.url : undefined;
48
+ }
49
+ export function normalizeShopItem(item) {
50
+ if (!item.id || !item.gameId || !item.name || !item.slug || !item.status || !item.itemType) {
51
+ throw new Error(`Unexpected API response — missing item fields: ${JSON.stringify(item)}`);
52
+ }
53
+ return {
54
+ id: item.id,
55
+ gameId: item.gameId,
56
+ name: item.name,
57
+ slug: item.slug,
58
+ status: item.status,
59
+ itemType: item.itemType,
60
+ bitsCost: item.bitsCost == null ? null : Number(item.bitsCost),
61
+ description: item.description ?? null,
62
+ iconUrl: item.iconUrl ?? null,
63
+ tier: item.tier == null ? null : Number(item.tier),
64
+ createdAt: item.createdAt ?? '',
65
+ updatedAt: item.updatedAt ?? '',
66
+ };
67
+ }
68
+ //# sourceMappingURL=helpers.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.js","sourceRoot":"","sources":["../../../src/core/tools/helpers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ export * from './helpers.js';
2
+ export * from './create-game.js';
3
+ export * from './update-game.js';
4
+ export * from './upload-version.js';
5
+ export * from './validate-game.js';
6
+ export * from './generate-image.js';
7
+ export * from './generate-sprite-sheet.js';
8
+ export * from './upload-game-asset.js';
9
+ export * from './create-shop-item.js';
10
+ export * from './list-shop-items.js';
11
+ export * from './update-shop-item.js';
12
+ export * from './delete-shop-item.js';
13
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/tools/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,qBAAqB,CAAA;AACnC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,sBAAsB,CAAA;AACpC,cAAc,uBAAuB,CAAA;AACrC,cAAc,uBAAuB,CAAA"}
@@ -0,0 +1,13 @@
1
+ export * from './helpers.js';
2
+ export * from './create-game.js';
3
+ export * from './update-game.js';
4
+ export * from './upload-version.js';
5
+ export * from './validate-game.js';
6
+ export * from './generate-image.js';
7
+ export * from './generate-sprite-sheet.js';
8
+ export * from './upload-game-asset.js';
9
+ export * from './create-shop-item.js';
10
+ export * from './list-shop-items.js';
11
+ export * from './update-shop-item.js';
12
+ export * from './delete-shop-item.js';
13
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/tools/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA;AAC5B,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA;AAChC,cAAc,qBAAqB,CAAA;AACnC,cAAc,oBAAoB,CAAA;AAClC,cAAc,qBAAqB,CAAA;AACnC,cAAc,4BAA4B,CAAA;AAC1C,cAAc,wBAAwB,CAAA;AACtC,cAAc,uBAAuB,CAAA;AACrC,cAAc,sBAAsB,CAAA;AACpC,cAAc,uBAAuB,CAAA;AACrC,cAAc,uBAAuB,CAAA"}
@@ -0,0 +1,8 @@
1
+ import type { RemixConfig } from '../config.js';
2
+ import { type CreateShopItemResult } from './helpers.js';
3
+ export interface ListShopItemsResult {
4
+ gameId: string;
5
+ items: CreateShopItemResult[];
6
+ }
7
+ export declare function listShopItems(gameId: string, config?: Partial<RemixConfig>): Promise<ListShopItemsResult>;
8
+ //# sourceMappingURL=list-shop-items.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-shop-items.d.ts","sourceRoot":"","sources":["../../../src/core/tools/list-shop-items.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAC/C,OAAO,EAAE,KAAK,oBAAoB,EAAwC,MAAM,cAAc,CAAA;AAE9F,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,oBAAoB,EAAE,CAAA;CAC9B;AAED,wBAAsB,aAAa,CACjC,MAAM,EAAE,MAAM,EACd,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,mBAAmB,CAAC,CAgB9B"}
@@ -0,0 +1,17 @@
1
+ import { createServerApiClient } from '../api-client.js';
2
+ import { normalizeShopItem, unwrapApiResponse } from './helpers.js';
3
+ export async function listShopItems(gameId, config) {
4
+ const client = createServerApiClient(config);
5
+ const result = await unwrapApiResponse(client.GET('/v1/games/{gameId}/items', {
6
+ params: {
7
+ path: {
8
+ gameId,
9
+ },
10
+ },
11
+ }));
12
+ return {
13
+ gameId: result.data.gameId,
14
+ items: result.data.items.map((item) => normalizeShopItem(item)),
15
+ };
16
+ }
17
+ //# sourceMappingURL=list-shop-items.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"list-shop-items.js","sourceRoot":"","sources":["../../../src/core/tools/list-shop-items.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,OAAO,EAA6B,iBAAiB,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAO9F,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,MAAc,EACd,MAA6B;IAE7B,MAAM,MAAM,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,MAAM,iBAAiB,CACpC,MAAM,CAAC,GAAG,CAAC,0BAA0B,EAAE;QACrC,MAAM,EAAE;YACN,IAAI,EAAE;gBACJ,MAAM;aACP;SACF;KACF,CAAC,CACH,CAAA;IAED,OAAO;QACL,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM;QAC1B,KAAK,EAAE,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,CAAC;KAChE,CAAA;AACH,CAAC"}
@@ -0,0 +1,11 @@
1
+ import type { RemixConfig } from '../config.js';
2
+ export interface UpdateGameResult {
3
+ gameId: string;
4
+ name: string;
5
+ isMultiplayer: boolean;
6
+ }
7
+ export declare function updateGame(gameId: string, fields: {
8
+ name?: string;
9
+ isMultiplayer?: boolean;
10
+ }, config?: Partial<RemixConfig>): Promise<UpdateGameResult>;
11
+ //# sourceMappingURL=update-game.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-game.d.ts","sourceRoot":"","sources":["../../../src/core/tools/update-game.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAG/C,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,aAAa,EAAE,OAAO,CAAA;CACvB;AAED,wBAAsB,UAAU,CAC9B,MAAM,EAAE,MAAM,EACd,MAAM,EAAE;IAAE,IAAI,CAAC,EAAE,MAAM,CAAC;IAAC,aAAa,CAAC,EAAE,OAAO,CAAA;CAAE,EAClD,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,gBAAgB,CAAC,CAsB3B"}
@@ -0,0 +1,22 @@
1
+ import { createServerApiClient } from '../api-client.js';
2
+ import { unwrapApiResponse } from './helpers.js';
3
+ export async function updateGame(gameId, fields, config) {
4
+ const client = createServerApiClient(config);
5
+ const result = await unwrapApiResponse(client.POST('/v1/games/{gameId}', {
6
+ params: { path: { gameId } },
7
+ body: {
8
+ ...(fields.name !== undefined ? { name: fields.name } : {}),
9
+ ...(fields.isMultiplayer !== undefined ? { isMultiplayer: fields.isMultiplayer } : {}),
10
+ },
11
+ }));
12
+ const game = result.data.game;
13
+ if (!game?.id) {
14
+ throw new Error(`Unexpected API response — missing game ID: ${JSON.stringify(result)}`);
15
+ }
16
+ return {
17
+ gameId: game.id,
18
+ name: game.name,
19
+ isMultiplayer: game.isMultiplayer,
20
+ };
21
+ }
22
+ //# sourceMappingURL=update-game.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-game.js","sourceRoot":"","sources":["../../../src/core/tools/update-game.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAQhD,MAAM,CAAC,KAAK,UAAU,UAAU,CAC9B,MAAc,EACd,MAAkD,EAClD,MAA6B;IAE7B,MAAM,MAAM,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,MAAM,iBAAiB,CACpC,MAAM,CAAC,IAAI,CAAC,oBAAoB,EAAE;QAChC,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,EAAE;QAC5B,IAAI,EAAE;YACJ,GAAG,CAAC,MAAM,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,MAAM,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC3D,GAAG,CAAC,MAAM,CAAC,aAAa,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,aAAa,EAAE,MAAM,CAAC,aAAa,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SACvF;KACF,CAAC,CACH,CAAA;IAED,MAAM,IAAI,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAA;IAC7B,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,8CAA8C,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IACzF,CAAC;IAED,OAAO;QACL,MAAM,EAAE,IAAI,CAAC,EAAE;QACf,IAAI,EAAE,IAAI,CAAC,IAAI;QACf,aAAa,EAAE,IAAI,CAAC,aAAa;KAClC,CAAA;AACH,CAAC"}
@@ -0,0 +1,15 @@
1
+ import type { RemixConfig } from '../config.js';
2
+ import { type CreateShopItemResult, type ShopItemType } from './helpers.js';
3
+ export interface UpdateShopItemInput {
4
+ gameId: string;
5
+ itemId: string;
6
+ name?: string;
7
+ slug?: string;
8
+ itemType?: ShopItemType;
9
+ bitsCost?: number;
10
+ description?: string | null;
11
+ iconUrl?: string | null;
12
+ tier?: number | null;
13
+ }
14
+ export declare function updateShopItem(input: UpdateShopItemInput, config?: Partial<RemixConfig>): Promise<CreateShopItemResult>;
15
+ //# sourceMappingURL=update-shop-item.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-shop-item.d.ts","sourceRoot":"","sources":["../../../src/core/tools/update-shop-item.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAC/C,OAAO,EACL,KAAK,oBAAoB,EACzB,KAAK,YAAY,EAGlB,MAAM,cAAc,CAAA;AAErB,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAA;IACd,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,YAAY,CAAA;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3B,OAAO,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;IACvB,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;CACrB;AAED,wBAAsB,cAAc,CAClC,KAAK,EAAE,mBAAmB,EAC1B,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,oBAAoB,CAAC,CAuB/B"}
@@ -0,0 +1,24 @@
1
+ import { createServerApiClient } from '../api-client.js';
2
+ import { normalizeShopItem, unwrapApiResponse, } from './helpers.js';
3
+ export async function updateShopItem(input, config) {
4
+ const client = createServerApiClient(config);
5
+ const result = await unwrapApiResponse(client.POST('/v1/games/{gameId}/items/{itemId}', {
6
+ params: {
7
+ path: {
8
+ gameId: input.gameId,
9
+ itemId: input.itemId,
10
+ },
11
+ },
12
+ body: {
13
+ ...(input.name !== undefined ? { name: input.name } : {}),
14
+ ...(input.slug !== undefined ? { slug: input.slug } : {}),
15
+ ...(input.itemType !== undefined ? { itemType: input.itemType } : {}),
16
+ ...(input.bitsCost !== undefined ? { bitsCost: input.bitsCost } : {}),
17
+ ...(input.description !== undefined ? { description: input.description } : {}),
18
+ ...(input.iconUrl !== undefined ? { iconUrl: input.iconUrl } : {}),
19
+ ...(input.tier !== undefined ? { tier: input.tier } : {}),
20
+ },
21
+ }));
22
+ return normalizeShopItem(result.data.item);
23
+ }
24
+ //# sourceMappingURL=update-shop-item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"update-shop-item.js","sourceRoot":"","sources":["../../../src/core/tools/update-shop-item.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,OAAO,EAGL,iBAAiB,EACjB,iBAAiB,GAClB,MAAM,cAAc,CAAA;AAcrB,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAA0B,EAC1B,MAA6B;IAE7B,MAAM,MAAM,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,MAAM,iBAAiB,CACpC,MAAM,CAAC,IAAI,CAAC,mCAAmC,EAAE;QAC/C,MAAM,EAAE;YACN,IAAI,EAAE;gBACJ,MAAM,EAAE,KAAK,CAAC,MAAM;gBACpB,MAAM,EAAE,KAAK,CAAC,MAAM;aACrB;SACF;QACD,IAAI,EAAE;YACJ,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACzD,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACzD,GAAG,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACrE,GAAG,CAAC,KAAK,CAAC,QAAQ,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YACrE,GAAG,CAAC,KAAK,CAAC,WAAW,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,WAAW,EAAE,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAC9E,GAAG,CAAC,KAAK,CAAC,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;YAClE,GAAG,CAAC,KAAK,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;SAC1D;KACF,CAAC,CACH,CAAA;IAED,OAAO,iBAAiB,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;AAC5C,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { RemixConfig } from '../config.js';
2
+ export interface UploadGameAssetResult {
3
+ fileName: string;
4
+ gameId: string;
5
+ response: Record<string, unknown>;
6
+ }
7
+ export declare function uploadGameAsset(gameId: string, filePath: string, assetName?: string, config?: Partial<RemixConfig>): Promise<UploadGameAssetResult>;
8
+ //# sourceMappingURL=upload-game-asset.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-game-asset.d.ts","sourceRoot":"","sources":["../../../src/core/tools/upload-game-asset.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAG/C,MAAM,WAAW,qBAAqB;IACpC,QAAQ,EAAE,MAAM,CAAA;IAChB,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAClC;AAmBD,wBAAsB,eAAe,CACnC,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,MAAM,EAChB,SAAS,CAAC,EAAE,MAAM,EAClB,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,qBAAqB,CAAC,CA6BhC"}
@@ -0,0 +1,43 @@
1
+ import { readFile, stat } from 'node:fs/promises';
2
+ import { basename, extname } from 'node:path';
3
+ import { asRecord, uploadAssetFormData } from './helpers.js';
4
+ const ALLOWED_EXTENSIONS = new Set([
5
+ '.jpg',
6
+ '.jpeg',
7
+ '.png',
8
+ '.webp',
9
+ '.mp3',
10
+ '.wav',
11
+ '.hrd',
12
+ '.glb',
13
+ '.gltf',
14
+ '.mp4',
15
+ '.mov',
16
+ '.avi',
17
+ ]);
18
+ const MAX_FILE_SIZE = 5 * 1024 * 1024; // 5 MB
19
+ export async function uploadGameAsset(gameId, filePath, assetName, config) {
20
+ const ext = extname(filePath).toLowerCase();
21
+ if (!ALLOWED_EXTENSIONS.has(ext)) {
22
+ throw new Error(`Unsupported file type "${ext}". Allowed extensions: ${[...ALLOWED_EXTENSIONS].join(', ')}`);
23
+ }
24
+ const fileStats = await stat(filePath);
25
+ if (fileStats.size > MAX_FILE_SIZE) {
26
+ const sizeMB = (fileStats.size / (1024 * 1024)).toFixed(1);
27
+ throw new Error(`File is too large (${sizeMB} MB). Maximum allowed size is 5 MB.`);
28
+ }
29
+ const fileBuffer = await readFile(filePath);
30
+ const fileBaseName = basename(filePath);
31
+ const formData = new FormData();
32
+ formData.append('file', new Blob([new Uint8Array(fileBuffer)]), fileBaseName);
33
+ if (assetName) {
34
+ formData.append('assetName', assetName);
35
+ }
36
+ const result = await uploadAssetFormData(gameId, formData, config);
37
+ return {
38
+ fileName: fileBaseName,
39
+ gameId,
40
+ response: asRecord(result),
41
+ };
42
+ }
43
+ //# sourceMappingURL=upload-game-asset.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-game-asset.js","sourceRoot":"","sources":["../../../src/core/tools/upload-game-asset.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,WAAW,CAAA;AAE7C,OAAO,EAAE,QAAQ,EAAE,mBAAmB,EAAE,MAAM,cAAc,CAAA;AAQ5D,MAAM,kBAAkB,GAAG,IAAI,GAAG,CAAC;IACjC,MAAM;IACN,OAAO;IACP,MAAM;IACN,OAAO;IACP,MAAM;IACN,MAAM;IACN,MAAM;IACN,MAAM;IACN,OAAO;IACP,MAAM;IACN,MAAM;IACN,MAAM;CACP,CAAC,CAAA;AAEF,MAAM,aAAa,GAAG,CAAC,GAAG,IAAI,GAAG,IAAI,CAAA,CAAC,OAAO;AAE7C,MAAM,CAAC,KAAK,UAAU,eAAe,CACnC,MAAc,EACd,QAAgB,EAChB,SAAkB,EAClB,MAA6B;IAE7B,MAAM,GAAG,GAAG,OAAO,CAAC,QAAQ,CAAC,CAAC,WAAW,EAAE,CAAA;IAC3C,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;QACjC,MAAM,IAAI,KAAK,CACb,0BAA0B,GAAG,0BAA0B,CAAC,GAAG,kBAAkB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAC5F,CAAA;IACH,CAAC;IAED,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,QAAQ,CAAC,CAAA;IACtC,IAAI,SAAS,CAAC,IAAI,GAAG,aAAa,EAAE,CAAC;QACnC,MAAM,MAAM,GAAG,CAAC,SAAS,CAAC,IAAI,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAA;QAC1D,MAAM,IAAI,KAAK,CAAC,sBAAsB,MAAM,qCAAqC,CAAC,CAAA;IACpF,CAAC;IAED,MAAM,UAAU,GAAG,MAAM,QAAQ,CAAC,QAAQ,CAAC,CAAA;IAC3C,MAAM,YAAY,GAAG,QAAQ,CAAC,QAAQ,CAAC,CAAA;IACvC,MAAM,QAAQ,GAAG,IAAI,QAAQ,EAAE,CAAA;IAC/B,QAAQ,CAAC,MAAM,CAAC,MAAM,EAAE,IAAI,IAAI,CAAC,CAAC,IAAI,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,YAAY,CAAC,CAAA;IAC7E,IAAI,SAAS,EAAE,CAAC;QACd,QAAQ,CAAC,MAAM,CAAC,WAAW,EAAE,SAAS,CAAC,CAAA;IACzC,CAAC;IAED,MAAM,MAAM,GAAG,MAAM,mBAAmB,CAAC,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,CAAA;IAElE,OAAO;QACL,QAAQ,EAAE,YAAY;QACtB,MAAM;QACN,QAAQ,EAAE,QAAQ,CAAC,MAAM,CAAC;KAC3B,CAAA;AACH,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { RemixConfig } from '../config.js';
2
+ export interface UploadVersionResult {
3
+ gameId: string;
4
+ versionId: string;
5
+ threadId?: string;
6
+ }
7
+ export declare function uploadVersion(gameId: string, versionId: string, filePath: string, config?: Partial<RemixConfig>): Promise<UploadVersionResult>;
8
+ //# sourceMappingURL=upload-version.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-version.d.ts","sourceRoot":"","sources":["../../../src/core/tools/upload-version.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,cAAc,CAAA;AAG/C,MAAM,WAAW,mBAAmB;IAClC,MAAM,EAAE,MAAM,CAAA;IACd,SAAS,EAAE,MAAM,CAAA;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAA;CAClB;AAED,wBAAsB,aAAa,CACjC,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,EACjB,QAAQ,EAAE,MAAM,EAChB,MAAM,CAAC,EAAE,OAAO,CAAC,WAAW,CAAC,GAC5B,OAAO,CAAC,mBAAmB,CAAC,CAmB9B"}
@@ -0,0 +1,20 @@
1
+ import { readFile } from 'node:fs/promises';
2
+ import { createServerApiClient } from '../api-client.js';
3
+ import { unwrapApiResponse } from './helpers.js';
4
+ export async function uploadVersion(gameId, versionId, filePath, config) {
5
+ const code = await readFile(filePath, 'utf-8');
6
+ const client = createServerApiClient(config);
7
+ const result = await unwrapApiResponse(client.POST('/v1/games/{gameId}/versions/{versionId}/code', {
8
+ params: { path: { gameId, versionId } },
9
+ body: { code },
10
+ }));
11
+ if (!result.data?.gameId || !result.data?.versionId) {
12
+ throw new Error(`Unexpected API response — missing expected fields: ${JSON.stringify(result)}`);
13
+ }
14
+ return {
15
+ gameId: result.data.gameId,
16
+ versionId: result.data.versionId,
17
+ threadId: undefined,
18
+ };
19
+ }
20
+ //# sourceMappingURL=upload-version.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"upload-version.js","sourceRoot":"","sources":["../../../src/core/tools/upload-version.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAC3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAExD,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAA;AAQhD,MAAM,CAAC,KAAK,UAAU,aAAa,CACjC,MAAc,EACd,SAAiB,EACjB,QAAgB,EAChB,MAA6B;IAE7B,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;IAC9C,MAAM,MAAM,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAA;IAC5C,MAAM,MAAM,GAAG,MAAM,iBAAiB,CACpC,MAAM,CAAC,IAAI,CAAC,8CAA8C,EAAE;QAC1D,MAAM,EAAE,EAAE,IAAI,EAAE,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE;QACvC,IAAI,EAAE,EAAE,IAAI,EAAE;KACf,CAAC,CACH,CAAA;IAED,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,SAAS,EAAE,CAAC;QACpD,MAAM,IAAI,KAAK,CAAC,sDAAsD,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;IACjG,CAAC;IAED,OAAO;QACL,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC,MAAM;QAC1B,SAAS,EAAE,MAAM,CAAC,IAAI,CAAC,SAAS;QAChC,QAAQ,EAAE,SAAS;KACpB,CAAA;AACH,CAAC"}
@@ -0,0 +1,6 @@
1
+ export interface ValidateGameResult {
2
+ valid: boolean;
3
+ issues: string[];
4
+ }
5
+ export declare function validateGame(filePath: string): Promise<ValidateGameResult>;
6
+ //# sourceMappingURL=validate-game.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-game.d.ts","sourceRoot":"","sources":["../../../src/core/tools/validate-game.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,kBAAkB;IACjC,KAAK,EAAE,OAAO,CAAA;IACd,MAAM,EAAE,MAAM,EAAE,CAAA;CACjB;AAED,wBAAsB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,CAAC,CAqDhF"}
@@ -0,0 +1,41 @@
1
+ import { readFile } from 'node:fs/promises';
2
+ export async function validateGame(filePath) {
3
+ const html = await readFile(filePath, 'utf-8');
4
+ const issues = [];
5
+ const remixSdkScriptRegex = /<script\s+(?:[^>]*?\s+)?src=["'][^"']*@remix-gg\/sdk[^"']*["'][^>]*><\/script>/i;
6
+ const legacySdkScriptRegex = /<script\s+(?:[^>]*?\s+)?src=["'][^"']*@farcade\/game-sdk[^"']*["'][^>]*><\/script>/i;
7
+ if (!html.includes('<!DOCTYPE html>') && !html.includes('<!doctype html>')) {
8
+ issues.push('Missing <!DOCTYPE html> declaration');
9
+ }
10
+ if (!html.includes('name="viewport"')) {
11
+ issues.push('Missing viewport meta tag — needed for mobile play');
12
+ }
13
+ if (/\blocalStorage\b/.test(html) || /\bsessionStorage\b/.test(html)) {
14
+ issues.push('localStorage/sessionStorage is not allowed — use RemixSDK.saveGameState() and RemixSDK.getGameState() instead for persistent storage');
15
+ }
16
+ if (legacySdkScriptRegex.test(html)) {
17
+ issues.push('Legacy @farcade/game-sdk script detected — replace it with <script src="https://cdn.jsdelivr.net/npm/@remix-gg/sdk@latest/dist/index.min.js"></script>');
18
+ }
19
+ else if (!remixSdkScriptRegex.test(html)) {
20
+ issues.push('Missing RemixSDK script tag in <head> — add: <script src="https://cdn.jsdelivr.net/npm/@remix-gg/sdk@latest/dist/index.min.js"></script>');
21
+ }
22
+ const hasSinglePlayerGameOver = /singlePlayer\.actions\.gameOver\s*\(/.test(html);
23
+ const hasMultiplayerGameOver = /multiplayer\.actions\.gameOver\s*\(/.test(html);
24
+ if (hasSinglePlayerGameOver && hasMultiplayerGameOver) {
25
+ issues.push('Both singlePlayer.actions.gameOver and multiplayer.actions.gameOver detected — use exactly one. Use singlePlayer for solo games, multiplayer for two-player games.');
26
+ }
27
+ else if (!hasSinglePlayerGameOver && !hasMultiplayerGameOver) {
28
+ issues.push('Missing gameOver call — use singlePlayer.actions.gameOver({ score }) for solo games or multiplayer.actions.gameOver({ scores }) for two-player games');
29
+ }
30
+ if (!/\.onToggleMute\s*\(/.test(html)) {
31
+ issues.push('Missing onToggleMute(callback) call — must register a callback to handle mute/unmute');
32
+ }
33
+ if (!/\.onPlayAgain\s*\(/.test(html)) {
34
+ issues.push('Missing onPlayAgain(callback) call — must register a callback to restart the game');
35
+ }
36
+ if (/\bonclick\s*=/.test(html) || /\bonload\s*=/.test(html)) {
37
+ issues.push('Inline event handlers detected — use addEventListener instead');
38
+ }
39
+ return { valid: issues.length === 0, issues };
40
+ }
41
+ //# sourceMappingURL=validate-game.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"validate-game.js","sourceRoot":"","sources":["../../../src/core/tools/validate-game.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAA;AAO3C,MAAM,CAAC,KAAK,UAAU,YAAY,CAAC,QAAgB;IACjD,MAAM,IAAI,GAAG,MAAM,QAAQ,CAAC,QAAQ,EAAE,OAAO,CAAC,CAAA;IAE9C,MAAM,MAAM,GAAa,EAAE,CAAA;IAC3B,MAAM,mBAAmB,GACvB,iFAAiF,CAAA;IACnF,MAAM,oBAAoB,GACxB,qFAAqF,CAAA;IAEvF,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE,CAAC;QAC3E,MAAM,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAA;IACpD,CAAC;IACD,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE,CAAC;QACtC,MAAM,CAAC,IAAI,CAAC,oDAAoD,CAAC,CAAA;IACnE,CAAC;IACD,IAAI,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACrE,MAAM,CAAC,IAAI,CACT,sIAAsI,CACvI,CAAA;IACH,CAAC;IACD,IAAI,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACpC,MAAM,CAAC,IAAI,CACT,wJAAwJ,CACzJ,CAAA;IACH,CAAC;SAAM,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC3C,MAAM,CAAC,IAAI,CACT,0IAA0I,CAC3I,CAAA;IACH,CAAC;IACD,MAAM,uBAAuB,GAAG,sCAAsC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IACjF,MAAM,sBAAsB,GAAG,qCAAqC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;IAC/E,IAAI,uBAAuB,IAAI,sBAAsB,EAAE,CAAC;QACtD,MAAM,CAAC,IAAI,CACT,oKAAoK,CACrK,CAAA;IACH,CAAC;SAAM,IAAI,CAAC,uBAAuB,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC/D,MAAM,CAAC,IAAI,CACT,sJAAsJ,CACvJ,CAAA;IACH,CAAC;IACD,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACtC,MAAM,CAAC,IAAI,CACT,sFAAsF,CACvF,CAAA;IACH,CAAC;IACD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QACrC,MAAM,CAAC,IAAI,CAAC,mFAAmF,CAAC,CAAA;IAClG,CAAC;IACD,IAAI,eAAe,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC;QAC5D,MAAM,CAAC,IAAI,CAAC,+DAA+D,CAAC,CAAA;IAC9E,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,MAAM,CAAC,MAAM,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;AAC/C,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=tools.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tools.test.d.ts","sourceRoot":"","sources":["../../src/core/tools.test.ts"],"names":[],"mappings":""}