From 0a01b7f3c13225aae20dfccde04de75c4720dacd Mon Sep 17 00:00:00 2001 From: Michelle Bergeron Date: Tue, 7 Oct 2025 13:56:17 -0400 Subject: [PATCH 1/5] wip --- components/accuranker/accuranker.app.mjs | 49 ++++++++++++- .../actions/list-domains/list-domains.mjs | 73 +++++++++++++++++++ components/accuranker/package.json | 4 +- 3 files changed, 121 insertions(+), 5 deletions(-) create mode 100644 components/accuranker/actions/list-domains/list-domains.mjs diff --git a/components/accuranker/accuranker.app.mjs b/components/accuranker/accuranker.app.mjs index 61c7679581a2c..f1f1ae8019f03 100644 --- a/components/accuranker/accuranker.app.mjs +++ b/components/accuranker/accuranker.app.mjs @@ -1,11 +1,54 @@ +import { axios } from "@pipedream/platform"; +const DEFAULT_LIMIT = 100; + export default { type: "app", app: "accuranker", propDefinitions: {}, methods: { - // this.$auth contains connected account data - authKeys() { - console.log(Object.keys(this.$auth)); + _baseUrl() { + return "https://app.accuranker.com/api/v4"; + }, + _makeRequest({ + $ = this, path, ...opts + }) { + return axios($, { + url: `${this._baseUrl()}/${path}`, + headers: { + Authorization: `Bearer ${this.$auth.oauth_access_token}`, + }, + ...opts, + }); + }, + listDomains(opts = {}) { + return this._makeRequest({ + path: "/domains/", + ...opts, + }); + }, + async *paginate({ + fn, args, max, + }) { + args = { + ...args, + params: { + ...args?.params, + limit: DEFAULT_LIMIT, + }, + }; + + let total, count = 0; + do { + const response = await fn(args); + for (const item of response) { + yield item; + if (max && ++count >= max) { + return count; + } + } + total = response?.length; + args.params.offset += DEFAULT_LIMIT; + } while (total === DEFAULT_LIMIT); }, }, }; diff --git a/components/accuranker/actions/list-domains/list-domains.mjs b/components/accuranker/actions/list-domains/list-domains.mjs new file mode 100644 index 0000000000000..8ee55930fa801 --- /dev/null +++ b/components/accuranker/actions/list-domains/list-domains.mjs @@ -0,0 +1,73 @@ +import accuranker from "../../accuranker.app.mjs"; + +export default { + key: "accuranker-list-domains", + name: "List Domains", + description: "List domains in Accuranker. [See the documentation](https://app.accuranker.com/api/read-docs#tag/Domains/operation/List%20Domains)", + version: "0.0.{{ts}}", + type: "action", + annotations: { + destructiveHint: false, + openWorldHint: true, + readOnlyHint: true, + }, + props: { + accuranker, + fields: { + type: "string[]", + label: "Fields", + description: "The fields to return", + optional: true, + default: [ + "id", + "display_name", + "domain", + "status", + "created_at", + "last_scraped", + ], + }, + periodFrom: { + type: "string", + label: "Period From", + description: "Date in format: YYYY-MM-DD", + optional: true, + }, + periodTo: { + type: "string", + label: "Period To", + description: "Date in format: YYYY-MM-DD", + optional: true, + }, + max: { + type: "integer", + label: "Max", + description: "Maximum number of domains to return", + optional: true, + default: 100, + }, + }, + async run({ $ }) { + const domains = this.accuranker.paginate({ + fn: this.accuranker.listDomains, + args: { + $, + params: { + fields: this.fields.join(","), + period_from: this.periodFrom, + period_to: this.periodTo, + }, + }, + max: this.max, + }); + + const results = []; + for await (const domain of domains) { + results.push(domain); + } + + $.export("$summary", `Found ${results.length} domain(s)`); + + return results; + }, +}; diff --git a/components/accuranker/package.json b/components/accuranker/package.json index 7f53f61fc491c..90be230b08c15 100644 --- a/components/accuranker/package.json +++ b/components/accuranker/package.json @@ -1,6 +1,6 @@ { "name": "@pipedream/accuranker", - "version": "0.6.0", + "version": "0.7.0", "description": "Pipedream accuranker Components", "main": "accuranker.app.mjs", "keywords": [ @@ -13,6 +13,6 @@ "access": "public" }, "dependencies": { - "@pipedream/platform": "^3.0.0" + "@pipedream/platform": "^3.1.0" } } From ae171246f0c1fe63eb48d0caa9ba32eaf6504d81 Mon Sep 17 00:00:00 2001 From: Michelle Bergeron Date: Tue, 7 Oct 2025 15:24:15 -0400 Subject: [PATCH 2/5] wip --- components/accuranker/accuranker.app.mjs | 71 ++++++++++++++- .../actions/create-domain/create-domain.mjs | 90 +++++++++++++++++++ .../create-keywords/create-keywords.mjs | 40 +++++++++ 3 files changed, 200 insertions(+), 1 deletion(-) create mode 100644 components/accuranker/actions/create-domain/create-domain.mjs create mode 100644 components/accuranker/actions/create-keywords/create-keywords.mjs diff --git a/components/accuranker/accuranker.app.mjs b/components/accuranker/accuranker.app.mjs index f1f1ae8019f03..2e12c31ad554e 100644 --- a/components/accuranker/accuranker.app.mjs +++ b/components/accuranker/accuranker.app.mjs @@ -4,7 +4,50 @@ const DEFAULT_LIMIT = 100; export default { type: "app", app: "accuranker", - propDefinitions: {}, + propDefinitions: { + accountId: { + type: "string", + label: "Account ID", + description: "The ID of the account", + async options() { + const { accounts } = await this.listAccounts(); + return accounts.map((account) => ({ + label: account.name, + value: account.id, + })); + }, + }, + groupId: { + type: "string", + label: "Group ID", + description: "The ID of the group", + async options({ accountId }) { + const { accounts } = await this.listGroups(); + const { groups } = accounts.find((account) => account.id === accountId); + return groups?.map((group) => ({ + label: group.group_name, + value: group.id, + })) || []; + }, + }, + domainId: { + type: "string", + label: "Domain ID", + description: "The ID of the domain", + async options({ page }) { + const domains = await this.listDomains({ + params: { + limit: DEFAULT_LIMIT, + offset: DEFAULT_LIMIT * page, + }, + }); + return domains?.map((domain) => ({ + label: domain.domain, + value: domain.id, + })) || []; + }, + }, + }, methods: { _baseUrl() { return "https://app.accuranker.com/api/v4"; @@ -20,12 +63,38 @@ export default { ...opts, }); }, + listAccounts(opts = {}) { + return this._makeRequest({ + path: "/accounts/", + ...opts, + }); + }, + listGroups(opts = {}) { + return this._makeRequest({ + path: "/overview/group_domains/", + ...opts, + }); + }, listDomains(opts = {}) { return this._makeRequest({ path: "/domains/", ...opts, }); }, + createDomain(opts = {}) { + return this._makeRequest({ + method: "POST", + path: "/domain/", + ...opts, + }); + }, + createKeywords(opts = {}) { + return this._makeRequest({ + method: "POST", + path: "/keyword/", + ...opts, + }); + }, async *paginate({ fn, args, max, }) { diff --git a/components/accuranker/actions/create-domain/create-domain.mjs b/components/accuranker/actions/create-domain/create-domain.mjs new file mode 100644 index 0000000000000..57eafd09848d8 --- /dev/null +++ b/components/accuranker/actions/create-domain/create-domain.mjs @@ -0,0 +1,90 @@ +import accuranker from "../../accuranker.app.mjs"; + +export default { + key: "accuranker-create-domain", + name: "Create Domain", + description: "Create a domain in Accuranker. [See the documentation](https://app.accuranker.com/api/write-docs#tag/Domains/operation/Create%20domain)", + version: "0.0.{{ts}}", + type: "action", + annotations: { + destructiveHint: false, + openWorldHint: true, + readOnlyHint: false, + }, + props: { + accuranker, + accountId: { + propDefinition: [ + accuranker, + "accountId", + ], + }, + groupId: { + propDefinition: [ + accuranker, + "groupId", + (c) => ({ + accountId: c.accountId, + }), + ], + }, + domain: { + type: "string", + label: "Domain", + description: "No http:// or www. You can enter a path that must be found. Eg. example.com/path. Search result must then begin with your path to match.", + }, + country: { + type: "string", + label: "Country", + description: "Two letters combination of country and language. Example: en-GB (for english in Great Britain)", + }, + searchEngine: { + type: "string", + label: "Search Engine", + description: "Search engine to use", + options: [ + "Google", + "Bing", + "Baidu", + "Youtube", + "Naver", + "ChatGPT", + "Perplexity", + "AI Overview", + "AI Mode", + ], + }, + searchTypes: { + type: "string", + label: "Search Types", + description: "Search types to use", + options: [ + "Desktop", + "Mobile", + ], + }, + }, + async run({ $ }) { + const response = await this.accuranker.createDomain({ + $, + data: { + domain: this.domain, + group_id: this.groupId, + default_searchsettings_names: [ + { + countrylocale: this.country, + search_engine_names: [ + { + search_engine: this.searchEngine, + search_type_names: this.searchTypes, + }, + ], + }, + ], + }, + }); + + $.export("$summary", `The domain ${this.domain} was successfully created!`); + return response; + }, +}; diff --git a/components/accuranker/actions/create-keywords/create-keywords.mjs b/components/accuranker/actions/create-keywords/create-keywords.mjs new file mode 100644 index 0000000000000..2461d0f1f097d --- /dev/null +++ b/components/accuranker/actions/create-keywords/create-keywords.mjs @@ -0,0 +1,40 @@ +import accuranker from "../../accuranker.app.mjs"; + +export default { + key: "accuranker-create-keywords", + name: "Create Keywords", + description: "Add keywords to a domain in Accuranker. [See the documentation](https://app.accuranker.com/api/write-docs#tag/Keywords/operation/Create%20keyword)", + version: "0.0.{{ts}}", + type: "action", + annotations: { + destructiveHint: false, + openWorldHint: true, + readOnlyHint: false, + }, + props: { + accuranker, + domainId: { + propDefinition: [ + accuranker, + "domainId", + ], + }, + keywords: { + type: "string[]", + label: "Keywords", + description: "List of keyword to add to the domain", + }, + }, + async run({ $ }) { + const response = await this.accuranker.createKeywords({ + $, + data: { + domain_id: this.domainId, + keywords: this.keywords, + }, + }); + + $.export("$summary", `Successfully added ${this.keywords.length} keyword(s) to the domain ${this.domainId}`); + return response; + }, +}; From 5f73f0dfc02ecbd2d6400025bb1e75bb129e1807 Mon Sep 17 00:00:00 2001 From: Michelle Bergeron Date: Wed, 8 Oct 2025 13:50:17 -0400 Subject: [PATCH 3/5] new actions --- components/accuranker/accuranker.app.mjs | 100 +++++++++--------- .../actions/create-domain/create-domain.mjs | 90 ---------------- .../create-keywords/create-keywords.mjs | 40 ------- .../actions/list-brands/list-brands.mjs | 75 +++++++++++++ .../actions/list-domains/list-domains.mjs | 27 +++-- .../actions/list-keywords/list-keywords.mjs | 79 ++++++++++++++ 6 files changed, 219 insertions(+), 192 deletions(-) delete mode 100644 components/accuranker/actions/create-domain/create-domain.mjs delete mode 100644 components/accuranker/actions/create-keywords/create-keywords.mjs create mode 100644 components/accuranker/actions/list-brands/list-brands.mjs create mode 100644 components/accuranker/actions/list-keywords/list-keywords.mjs diff --git a/components/accuranker/accuranker.app.mjs b/components/accuranker/accuranker.app.mjs index 2e12c31ad554e..24c50f8cbf9c1 100644 --- a/components/accuranker/accuranker.app.mjs +++ b/components/accuranker/accuranker.app.mjs @@ -5,40 +5,16 @@ export default { type: "app", app: "accuranker", propDefinitions: { - accountId: { - type: "string", - label: "Account ID", - description: "The ID of the account", - async options() { - const { accounts } = await this.listAccounts(); - return accounts.map((account) => ({ - label: account.name, - value: account.id, - })); - }, - }, - groupId: { - type: "string", - label: "Group ID", - description: "The ID of the group", - async options({ accountId }) { - const { accounts } = await this.listGroups(); - const { groups } = accounts.find((account) => account.id === accountId); - return groups?.map((group) => ({ - label: group.group_name, - value: group.id, - })) || []; - }, - }, domainId: { type: "string", label: "Domain ID", description: "The ID of the domain", async options({ page }) { - const domains = await this.listDomains({ + const { results: domains } = await this.listDomains({ params: { limit: DEFAULT_LIMIT, offset: DEFAULT_LIMIT * page, + fields: "id,domain", }, }); return domains?.map((domain) => ({ @@ -47,6 +23,46 @@ export default { })) || []; }, }, + keywordId: { + type: "string", + label: "Keyword ID", + description: "The ID of the keyword", + async options({ + domainId, page, + }) { + const { results: keywords } = await this.listKeywords({ + domainId, + params: { + limit: DEFAULT_LIMIT, + offset: DEFAULT_LIMIT * page, + fields: "id,keyword", + }, + }); + return keywords?.map((keyword) => ({ + label: keyword.keyword, + value: keyword.id, + })) || []; + }, + }, + periodFrom: { + type: "string", + label: "Period From", + description: "Date in format: YYYY-MM-DD", + optional: true, + }, + periodTo: { + type: "string", + label: "Period To", + description: "Date in format: YYYY-MM-DD", + optional: true, + }, + max: { + type: "integer", + label: "Max", + description: "Maximum number of results to return", + optional: true, + default: 100, + }, }, methods: { _baseUrl() { @@ -56,42 +72,30 @@ export default { $ = this, path, ...opts }) { return axios($, { - url: `${this._baseUrl()}/${path}`, + url: `${this._baseUrl()}${path}`, headers: { Authorization: `Bearer ${this.$auth.oauth_access_token}`, }, ...opts, }); }, - listAccounts(opts = {}) { - return this._makeRequest({ - path: "/accounts/", - ...opts, - }); - }, - listGroups(opts = {}) { - return this._makeRequest({ - path: "/overview/group_domains/", - ...opts, - }); - }, listDomains(opts = {}) { return this._makeRequest({ path: "/domains/", ...opts, }); }, - createDomain(opts = {}) { + listKeywords({ + domainId, ...opts + }) { return this._makeRequest({ - method: "POST", - path: "/domain/", + path: `/domains/${domainId}/keywords/`, ...opts, }); }, - createKeywords(opts = {}) { + listBrands(opts = {}) { return this._makeRequest({ - method: "POST", - path: "/keyword/", + path: "/brands/", ...opts, }); }, @@ -108,14 +112,14 @@ export default { let total, count = 0; do { - const response = await fn(args); - for (const item of response) { + const { results } = await fn(args); + for (const item of results) { yield item; if (max && ++count >= max) { return count; } } - total = response?.length; + total = results?.length; args.params.offset += DEFAULT_LIMIT; } while (total === DEFAULT_LIMIT); }, diff --git a/components/accuranker/actions/create-domain/create-domain.mjs b/components/accuranker/actions/create-domain/create-domain.mjs deleted file mode 100644 index 57eafd09848d8..0000000000000 --- a/components/accuranker/actions/create-domain/create-domain.mjs +++ /dev/null @@ -1,90 +0,0 @@ -import accuranker from "../../accuranker.app.mjs"; - -export default { - key: "accuranker-create-domain", - name: "Create Domain", - description: "Create a domain in Accuranker. [See the documentation](https://app.accuranker.com/api/write-docs#tag/Domains/operation/Create%20domain)", - version: "0.0.{{ts}}", - type: "action", - annotations: { - destructiveHint: false, - openWorldHint: true, - readOnlyHint: false, - }, - props: { - accuranker, - accountId: { - propDefinition: [ - accuranker, - "accountId", - ], - }, - groupId: { - propDefinition: [ - accuranker, - "groupId", - (c) => ({ - accountId: c.accountId, - }), - ], - }, - domain: { - type: "string", - label: "Domain", - description: "No http:// or www. You can enter a path that must be found. Eg. example.com/path. Search result must then begin with your path to match.", - }, - country: { - type: "string", - label: "Country", - description: "Two letters combination of country and language. Example: en-GB (for english in Great Britain)", - }, - searchEngine: { - type: "string", - label: "Search Engine", - description: "Search engine to use", - options: [ - "Google", - "Bing", - "Baidu", - "Youtube", - "Naver", - "ChatGPT", - "Perplexity", - "AI Overview", - "AI Mode", - ], - }, - searchTypes: { - type: "string", - label: "Search Types", - description: "Search types to use", - options: [ - "Desktop", - "Mobile", - ], - }, - }, - async run({ $ }) { - const response = await this.accuranker.createDomain({ - $, - data: { - domain: this.domain, - group_id: this.groupId, - default_searchsettings_names: [ - { - countrylocale: this.country, - search_engine_names: [ - { - search_engine: this.searchEngine, - search_type_names: this.searchTypes, - }, - ], - }, - ], - }, - }); - - $.export("$summary", `The domain ${this.domain} was successfully created!`); - return response; - }, -}; diff --git a/components/accuranker/actions/create-keywords/create-keywords.mjs b/components/accuranker/actions/create-keywords/create-keywords.mjs deleted file mode 100644 index 2461d0f1f097d..0000000000000 --- a/components/accuranker/actions/create-keywords/create-keywords.mjs +++ /dev/null @@ -1,40 +0,0 @@ -import accuranker from "../../accuranker.app.mjs"; - -export default { - key: "accuranker-create-keywords", - name: "Create Keywords", - description: "Add keywords to a domain in Accuranker. [See the documentation](https://app.accuranker.com/api/write-docs#tag/Keywords/operation/Create%20keyword)", - version: "0.0.{{ts}}", - type: "action", - annotations: { - destructiveHint: false, - openWorldHint: true, - readOnlyHint: false, - }, - props: { - accuranker, - domainId: { - propDefinition: [ - accuranker, - "domainId", - ], - }, - keywords: { - type: "string[]", - label: "Keywords", - description: "List of keyword to add to the domain", - }, - }, - async run({ $ }) { - const response = await this.accuranker.createKeywords({ - $, - data: { - domain_id: this.domainId, - keywords: this.keywords, - }, - }); - - $.export("$summary", `Successfully added ${this.keywords.length} keyword(s) to the domain ${this.domainId}`); - return response; - }, -}; diff --git a/components/accuranker/actions/list-brands/list-brands.mjs b/components/accuranker/actions/list-brands/list-brands.mjs new file mode 100644 index 0000000000000..64defbd91bf5f --- /dev/null +++ b/components/accuranker/actions/list-brands/list-brands.mjs @@ -0,0 +1,75 @@ +import accuranker from "../../accuranker.app.mjs"; + +export default { + key: "accuranker-list-brands", + name: "List Brands", + description: "List brands in Accuranker. [See the documentation](https://app.accuranker.com/api/read-docs#tag/Brands/operation/List%20Brands)", + version: "0.0.1", + type: "action", + annotations: { + destructiveHint: false, + openWorldHint: true, + readOnlyHint: true, + }, + props: { + accuranker, + fields: { + type: "string[]", + label: "Fields", + description: "The fields to return", + optional: true, + default: [ + "id", + "last_scraped", + "group", + "domain", + "display_name", + "brand_list", + "competitors", + "history", + "created_at", + ], + }, + periodFrom: { + propDefinition: [ + accuranker, + "periodFrom", + ], + }, + periodTo: { + propDefinition: [ + accuranker, + "periodTo", + ], + }, + max: { + propDefinition: [ + accuranker, + "max", + ], + }, + }, + async run({ $ }) { + const brands = this.accuranker.paginate({ + fn: this.accuranker.listBrands, + args: { + $, + params: { + fields: this.fields.join(","), + period_from: this.periodFrom, + period_to: this.periodTo, + }, + }, + max: this.max, + }); + + const results = []; + for await (const brand of brands) { + results.push(brand); + } + + $.export("$summary", `Found ${results.length} brand(s)`); + + return results; + }, +}; diff --git a/components/accuranker/actions/list-domains/list-domains.mjs b/components/accuranker/actions/list-domains/list-domains.mjs index 8ee55930fa801..0741767750568 100644 --- a/components/accuranker/actions/list-domains/list-domains.mjs +++ b/components/accuranker/actions/list-domains/list-domains.mjs @@ -4,7 +4,7 @@ export default { key: "accuranker-list-domains", name: "List Domains", description: "List domains in Accuranker. [See the documentation](https://app.accuranker.com/api/read-docs#tag/Domains/operation/List%20Domains)", - version: "0.0.{{ts}}", + version: "0.0.1", type: "action", annotations: { destructiveHint: false, @@ -28,23 +28,22 @@ export default { ], }, periodFrom: { - type: "string", - label: "Period From", - description: "Date in format: YYYY-MM-DD", - optional: true, + propDefinition: [ + accuranker, + "periodFrom", + ], }, periodTo: { - type: "string", - label: "Period To", - description: "Date in format: YYYY-MM-DD", - optional: true, + propDefinition: [ + accuranker, + "periodTo", + ], }, max: { - type: "integer", - label: "Max", - description: "Maximum number of domains to return", - optional: true, - default: 100, + propDefinition: [ + accuranker, + "max", + ], }, }, async run({ $ }) { diff --git a/components/accuranker/actions/list-keywords/list-keywords.mjs b/components/accuranker/actions/list-keywords/list-keywords.mjs new file mode 100644 index 0000000000000..d4b25512dc13c --- /dev/null +++ b/components/accuranker/actions/list-keywords/list-keywords.mjs @@ -0,0 +1,79 @@ +import accuranker from "../../accuranker.app.mjs"; + +export default { + key: "accuranker-list-keywords", + name: "List Keywords", + description: "List keywords for a domain in Accuranker. [See the documentation](https://app.accuranker.com/api/read-docs#tag/Keywords/operation/List%20Keywords)", + version: "0.0.1", + type: "action", + annotations: { + destructiveHint: false, + openWorldHint: true, + readOnlyHint: true, + }, + props: { + accuranker, + domainId: { + propDefinition: [ + accuranker, + "domainId", + ], + }, + fields: { + type: "string[]", + label: "Fields", + description: "The fields to return", + optional: true, + default: [ + "id", + "keyword", + "description", + "ranks", + "compenitor_ranks", + ], + }, + periodFrom: { + propDefinition: [ + accuranker, + "periodFrom", + ], + }, + periodTo: { + propDefinition: [ + accuranker, + "periodTo", + ], + }, + max: { + propDefinition: [ + accuranker, + "max", + ], + max: 100, + }, + }, + async run({ $ }) { + const keywords = this.accuranker.paginate({ + fn: this.accuranker.listKeywords, + args: { + $, + domainId: this.domainId, + params: { + fields: this.fields.join(","), + period_from: this.periodFrom, + period_to: this.periodTo, + }, + }, + max: this.max, + }); + + const results = []; + for await (const keyword of keywords) { + results.push(keyword); + } + + $.export("$summary", `Found ${results.length} keyword(s)`); + + return results; + }, +}; From f1f83c2f290085462861d1569dfd10e6eadf71ec Mon Sep 17 00:00:00 2001 From: Michelle Bergeron Date: Wed, 8 Oct 2025 13:51:23 -0400 Subject: [PATCH 4/5] pnpm-lock.yaml --- pnpm-lock.yaml | 15 +++++++-------- 1 file changed, 7 insertions(+), 8 deletions(-) diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 2af094a37cb1e..2b3e597849e28 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -238,8 +238,8 @@ importers: components/accuranker: dependencies: '@pipedream/platform': - specifier: ^3.0.0 - version: 3.0.3 + specifier: ^3.1.0 + version: 3.1.0 components/accuweather: dependencies: @@ -1924,8 +1924,7 @@ importers: components/braintree: {} - components/brandblast: - specifiers: {} + components/brandblast: {} components/brandfetch: {} @@ -31287,22 +31286,22 @@ packages: superagent@3.8.1: resolution: {integrity: sha512-VMBFLYgFuRdfeNQSMLbxGSLfmXL/xc+OO+BZp41Za/NRDBet/BNbkRJrYzCUu0u4GU0i/ml2dtT8b9qgkw9z6Q==} engines: {node: '>= 4.0'} - deprecated: Please upgrade to v9.0.0+ as we have fixed a public vulnerability with formidable dependency. Note that v9.0.0+ requires Node.js v14.18.0+. See https://github.com/ladjs/superagent/pull/1800 for insight. This project is supported and maintained by the team at Forward Email @ https://forwardemail.net + deprecated: Please upgrade to superagent v10.2.2+, see release notes at https://github.com/forwardemail/superagent/releases/tag/v10.2.2 - maintenance is supported by Forward Email @ https://forwardemail.net superagent@4.1.0: resolution: {integrity: sha512-FT3QLMasz0YyCd4uIi5HNe+3t/onxMyEho7C3PSqmti3Twgy2rXT4fmkTz6wRL6bTF4uzPcfkUCa8u4JWHw8Ag==} engines: {node: '>= 6.0'} - deprecated: Please upgrade to v9.0.0+ as we have fixed a public vulnerability with formidable dependency. Note that v9.0.0+ requires Node.js v14.18.0+. See https://github.com/ladjs/superagent/pull/1800 for insight. This project is supported and maintained by the team at Forward Email @ https://forwardemail.net + deprecated: Please upgrade to superagent v10.2.2+, see release notes at https://github.com/forwardemail/superagent/releases/tag/v10.2.2 - maintenance is supported by Forward Email @ https://forwardemail.net superagent@5.3.1: resolution: {integrity: sha512-wjJ/MoTid2/RuGCOFtlacyGNxN9QLMgcpYLDQlWFIhhdJ93kNscFonGvrpAHSCVjRVj++DGCglocF7Aej1KHvQ==} engines: {node: '>= 7.0.0'} - deprecated: Please upgrade to v9.0.0+ as we have fixed a public vulnerability with formidable dependency. Note that v9.0.0+ requires Node.js v14.18.0+. See https://github.com/ladjs/superagent/pull/1800 for insight. This project is supported and maintained by the team at Forward Email @ https://forwardemail.net + deprecated: Please upgrade to superagent v10.2.2+, see release notes at https://github.com/forwardemail/superagent/releases/tag/v10.2.2 - maintenance is supported by Forward Email @ https://forwardemail.net superagent@7.1.6: resolution: {integrity: sha512-gZkVCQR1gy/oUXr+kxJMLDjla434KmSOKbx5iGD30Ql+AkJQ/YlPKECJy2nhqOsHLjGHzoDTXNSjhnvWhzKk7g==} engines: {node: '>=6.4.0 <13 || >=14'} - deprecated: Please upgrade to v9.0.0+ as we have fixed a public vulnerability with formidable dependency. Note that v9.0.0+ requires Node.js v14.18.0+. See https://github.com/ladjs/superagent/pull/1800 for insight. This project is supported and maintained by the team at Forward Email @ https://forwardemail.net + deprecated: Please upgrade to superagent v10.2.2+, see release notes at https://github.com/forwardemail/superagent/releases/tag/v10.2.2 - maintenance is supported by Forward Email @ https://forwardemail.net supports-color@10.0.0: resolution: {integrity: sha512-HRVVSbCCMbj7/kdWF9Q+bbckjBHLtHMEoJWlkmYzzdwhYMkjkOwubLM6t7NbWKjgKamGDrWL1++KrjUO1t9oAQ==} From 617050b4abd449c5ae36b7cac979ca711ab5a7b7 Mon Sep 17 00:00:00 2001 From: Michelle Bergeron Date: Wed, 8 Oct 2025 14:02:47 -0400 Subject: [PATCH 5/5] fix typo --- components/accuranker/actions/list-keywords/list-keywords.mjs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/components/accuranker/actions/list-keywords/list-keywords.mjs b/components/accuranker/actions/list-keywords/list-keywords.mjs index d4b25512dc13c..722c88ab6bda1 100644 --- a/components/accuranker/actions/list-keywords/list-keywords.mjs +++ b/components/accuranker/actions/list-keywords/list-keywords.mjs @@ -29,7 +29,7 @@ export default { "keyword", "description", "ranks", - "compenitor_ranks", + "competitor_ranks", ], }, periodFrom: {