aboutsummaryrefslogtreecommitdiffstats
path: root/packages/sra-spec/src/json-schemas.ts
diff options
context:
space:
mode:
authorFrancesco Agosti <francesco.agosti93@gmail.com>2018-08-25 03:00:39 +0800
committerGitHub <noreply@github.com>2018-08-25 03:00:39 +0800
commit7f36574a57ced8ead0059b90673fe01f97f04827 (patch)
tree2f1779253061ecba9392aebf708f98c4db67648d /packages/sra-spec/src/json-schemas.ts
parent7f585a15f526e0a61fd822cdefb7087fc6bb8934 (diff)
parentb637ca105a73f8fef6bd523615b852654ef6ab7e (diff)
downloaddexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.tar
dexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.tar.gz
dexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.tar.bz2
dexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.tar.lz
dexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.tar.xz
dexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.tar.zst
dexon-sol-tools-7f36574a57ced8ead0059b90673fe01f97f04827.zip
Merge pull request #1011 from 0xProject/sra-api/rename/sra-spec
[sra-spec] Rename the sra-api package to sra-spec
Diffstat (limited to 'packages/sra-spec/src/json-schemas.ts')
-rw-r--r--packages/sra-spec/src/json-schemas.ts63
1 files changed, 63 insertions, 0 deletions
diff --git a/packages/sra-spec/src/json-schemas.ts b/packages/sra-spec/src/json-schemas.ts
new file mode 100644
index 000000000..173a04bfb
--- /dev/null
+++ b/packages/sra-spec/src/json-schemas.ts
@@ -0,0 +1,63 @@
+import { schemas as jsonSchemas } from '@0xproject/json-schemas';
+
+// Only include schemas we actually need
+const {
+ numberSchema,
+ addressSchema,
+ hexSchema,
+ orderHashSchema,
+ orderSchema,
+ signedOrderSchema,
+ signedOrdersSchema,
+ ordersSchema,
+ paginatedCollectionSchema,
+ relayerApiErrorResponseSchema,
+ relayerApiFeeRecipientsResponseSchema,
+ relayerApiOrderSchema,
+ relayerApiOrdersSchema,
+ relayerApiOrderConfigPayloadSchema,
+ relayerApiOrderConfigResponseSchema,
+ relayerApiOrderbookResponseSchema,
+ relayerApiAssetDataPairsResponseSchema,
+ relayerApiAssetDataTradeInfoSchema,
+ relayerApiOrdersChannelSubscribeSchema,
+ relayerApiOrdersChannelSubscribePayload,
+ relayerApiOrdersChannelUpdateSchema,
+ relayerApiOrdersResponseSchema,
+ relayerApiAssetDataPairsSchema,
+} = jsonSchemas;
+
+const usedSchemas = {
+ numberSchema,
+ addressSchema,
+ hexSchema,
+ orderHashSchema,
+ orderSchema,
+ signedOrderSchema,
+ signedOrdersSchema,
+ ordersSchema,
+ paginatedCollectionSchema,
+ relayerApiErrorResponseSchema,
+ relayerApiFeeRecipientsResponseSchema,
+ relayerApiOrderSchema,
+ relayerApiOrdersSchema,
+ relayerApiOrderConfigPayloadSchema,
+ relayerApiOrderConfigResponseSchema,
+ relayerApiOrderbookResponseSchema,
+ relayerApiAssetDataPairsResponseSchema,
+ relayerApiAssetDataTradeInfoSchema,
+ relayerApiOrdersChannelSubscribeSchema,
+ relayerApiOrdersChannelSubscribePayload,
+ relayerApiOrdersChannelUpdateSchema,
+ relayerApiOrdersResponseSchema,
+ relayerApiAssetDataPairsSchema,
+};
+
+// We need to replace the `$ref`s to be OpenAPI compliant.
+const openApiSchemas = JSON.parse(
+ JSON.stringify(usedSchemas).replace(/(\/\w+)/g, match => `#/components/schemas${match}`),
+);
+// The json schema used by OpenAPI does not accept ids
+Object.keys(openApiSchemas).forEach(key => delete openApiSchemas[key].id);
+
+export const schemas = openApiSchemas;