otomato-sdk 2.0.179 → 2.0.180

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.
@@ -5112,7 +5112,7 @@ export const TRIGGERS = {
5112
5112
  "name": "Market Outcome Price",
5113
5113
  "description": "Monitor the price of a specific outcome in a Polymarket prediction market",
5114
5114
  "type": 3,
5115
- "blockData": "\n async (env) => {\n const { parameters, page, limit, offset, fieldFunctionName } = env;\n\n let renderEnumData = [];\n\n if (fieldFunctionName === 'renderEnumData') {\n const response = await fetch(`https://gamma-api.polymarket.com/events?offset=${offset}&limit=${limit}&active=true&ascending=false&order=startDate`, {\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n }\n });\n\n if (!response.ok) {\n console.error('Failed to fetch Polymarket markets');\n return [];\n }\n\n const markets = await response.json();\n\n const availableMarkets = markets\n .filter(market => !market.closed && market.active)\n .map(market => ({\n id: market.id,\n title: market.title, \n image: market.image || '',\n markets: market.markets\n .filter(mkt => !mkt.closed && mkt.active)\n .map(mkt => ({\n id: mkt.id,\n question: mkt.groupItemTitle,\n condition_id: mkt.conditionId,\n question_id: mkt.questionID,\n outcomes: mkt.outcomes ? JSON.parse(mkt.outcomes) : [],\n outcome_prices: mkt.outcomePrices ? JSON.parse(mkt.outcomePrices) : [],\n clobTokenIds: mkt.clobTokenIds ? JSON.parse(mkt.clobTokenIds) : []\n }))\n }));\n renderEnumData = availableMarkets;\n }\n\n return {\n renderEnumData\n };\n }",
5115
+ "blockData": "\n async (env) => {\n const {\n parameters,\n page = 1,\n limit = 10,\n fieldFunctionName,\n } = env;\n const offset = env.offset ?? (page - 1) * limit;\n\n let renderEnumData = [];\n\n if (fieldFunctionName === 'renderEnumData') {\n const response = await fetch(`https://gamma-api.polymarket.com/events?offset=${offset}&limit=${limit}&active=true&ascending=false&order=startDate`, {\n headers: {\n 'Accept': 'application/json',\n 'Content-Type': 'application/json'\n }\n });\n\n if (!response.ok) {\n console.error('Failed to fetch Polymarket markets');\n return [];\n }\n\n const markets = await response.json();\n\n const availableMarkets = markets\n .filter(market => !market.closed && market.active)\n .map(market => ({\n id: market.id,\n title: market.title, \n image: market.image || '',\n markets: market.markets\n .filter(mkt => !mkt.closed && mkt.active)\n .map(mkt => ({\n id: mkt.id,\n question: mkt.groupItemTitle,\n condition_id: mkt.conditionId,\n question_id: mkt.questionID,\n outcomes: mkt.outcomes ? JSON.parse(mkt.outcomes) : [],\n outcome_prices: mkt.outcomePrices ? JSON.parse(mkt.outcomePrices) : [],\n clobTokenIds: mkt.clobTokenIds ? JSON.parse(mkt.clobTokenIds) : []\n }))\n }));\n renderEnumData = availableMarkets;\n }\n\n return {\n renderEnumData\n };\n }",
5116
5116
  "output": {
5117
5117
  "price": "float",
5118
5118
  "outcome": "string",
@@ -5477,6 +5477,7 @@ export const TRIGGERS = {
5477
5477
  "name": "NFT Listing",
5478
5478
  "description": "Subscribe to live NFT listing events based on filters.",
5479
5479
  "type": 5,
5480
+ "blockData": "\n async (env) => {\n const { parameters, fieldFunctionName, contract } = env;\n\n const PARAMETERS_TYPE = {\"BOOLEAN\":\"boolean\",\"INTEGER\":\"integer\",\"INT8\":\"int8\",\"INT16\":\"int16\",\"INT32\":\"int32\",\"INT64\":\"int64\",\"INT128\":\"int128\",\"INT256\":\"int256\",\"UINT8\":\"uint8\",\"UINT16\":\"uint16\",\"UINT32\":\"uint32\",\"UINT64\":\"uint64\",\"UINT128\":\"uint128\",\"UINT256\":\"uint256\",\"FLOAT\":\"float\",\"PERCENTAGE\":\"percentage\",\"FIXED\":\"fixed\",\"UFIXED\":\"ufixed\",\"ERC20\":\"erc20\",\"NFT_COLLECTION\":\"nftCollection\",\"ADDRESS\":\"address\",\"STRING\":\"string\",\"URL\":\"url\",\"PHONE_NUMBER\":\"phone_number\",\"EMAIL\":\"email\",\"PARAGRAPH\":\"paragraph\",\"ARRAY_OF_ADDRESSES\":\"addresses_array\",\"ARRAY_OF_STRINGS\":\"string_array\",\"ARRAY_OF_ARRAYS\":\"arrays_array\",\"RENDER_ENUM\":\"render_enum\",\"RENDER_JSON\":\"render_json\",\"CHAIN_ID\":\"chainId\",\"LOGIC_OPERATOR\":\"logic_operator\",\"AND_OR\":\"and_or\",\"CONDITION_GROUPS\":\"condition_groups\",\"MATH_OPERATORS\":\"string\",\"ANY\":\"any\"};\n \n if (fieldFunctionName === 'renderJSONData') {\n try {\n const response = await fetch(`https://api.reservoir.tools/collections/${contract}/attributes/all/v1`);\n\n if (!response.ok) {\n console.error('Failed to fetch Blur traits');\n return [];\n }\n\n const data = await response.json();\n\n if (!data.attributes) {\n throw new Error('Invalid response from Blur API');\n }\n const traits = data.attributes;\n const traitJSONData = [];\n\n for (const trait of traits) {\n const traitValues = trait.values.map(value => value.value);\n traitJSONData.push({\n key: trait.key,\n type: PARAMETERS_TYPE.STRING,\n description: `The ${trait.key.toLowerCase()} of the NFT.`,\n enum: traitValues\n });\n }\n\n return {\n renderJSONData: {\n traits: traitJSONData,\n },\n };\n } catch (error) {\n throw new Error('Error fetching Blur traits: ' + error);\n }\n }\n\n return null;\n }",
5480
5481
  "parameters": [
5481
5482
  {
5482
5483
  "key": "contract",
@@ -5508,6 +5509,10 @@ export const TRIGGERS = {
5508
5509
  },
5509
5510
  {
5510
5511
  "key": "traits",
5512
+ "type": "render_json",
5513
+ "dependOn": [
5514
+ "contract"
5515
+ ],
5511
5516
  "description": "Trait-based filters. For example, you can only monitor punks with specific traits you are interested in.",
5512
5517
  "mandatory": false,
5513
5518
  "category": 1
@@ -1,4 +1,4 @@
1
- export const SDK_VERSION = '2.0.179';
1
+ export const SDK_VERSION = '2.0.180';
2
2
  export function compareVersions(v1, v2) {
3
3
  // Split the version strings into parts
4
4
  const v1Parts = v1.split('.').map(Number);
@@ -2171,6 +2171,7 @@ export declare const TRIGGERS: {
2171
2171
  name: string;
2172
2172
  description: string;
2173
2173
  type: number;
2174
+ blockData: string;
2174
2175
  parameters: Parameter[];
2175
2176
  output: {
2176
2177
  listingId: string;
@@ -1,2 +1,2 @@
1
- export declare const SDK_VERSION = "2.0.179";
1
+ export declare const SDK_VERSION = "2.0.180";
2
2
  export declare function compareVersions(v1: string, v2: string): number;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "otomato-sdk",
3
- "version": "2.0.179",
3
+ "version": "2.0.180",
4
4
  "description": "An SDK for building and managing automations on Otomato",
5
5
  "main": "dist/src/index.js",
6
6
  "types": "dist/types/src/index.d.ts",