Skip to content
This repository has been archived by the owner on Oct 9, 2024. It is now read-only.

Commit

Permalink
fix!: removed ajv usage and replaced with typebox-validators
Browse files Browse the repository at this point in the history
  • Loading branch information
gentlementlegen committed May 3, 2024
1 parent 5948b95 commit f7fd336
Show file tree
Hide file tree
Showing 11 changed files with 125 additions and 111 deletions.
21 changes: 6 additions & 15 deletions .github/.ubiquibot-config.yml
Original file line number Diff line number Diff line change
@@ -1,13 +1,3 @@
price-multiplier: 1.5
command-settings:
- name: start
enabled: false
# newContributorGreeting:
# enabled: true
# header: "Thank you for contributing to UbiquiBot! Please be sure to set your wallet address before completing your first bounty so that the automatic payout upon task completion will work for you."
# helpMenu: true
# footer: "###### Also please star this repository and [@ubiquity/devpool-directory](https://github.com/ubiquity/devpool-directory/) to show your support. It helps a lot!"

incentives:
enabled: true
contentEvaluator:
Expand Down Expand Up @@ -77,8 +67,9 @@ incentives:

plugins:
'issues.closed':
- uses:
- plugin: ubiquity/conversation-rewards@testing/ubiquibot-v2-testing
type: github
with:
evmNetworkId: 100
- skipBotEvents: true
uses:
- plugin: ubiquibot/conversation-rewards@testing/ubiquibot-v2-testing
type: github
with:
evmNetworkId: 100
11 changes: 5 additions & 6 deletions package.json
Original file line number Diff line number Diff line change
Expand Up @@ -25,15 +25,15 @@
"ubiquibot",
"open-source"
],
"dependencies": {},
"dependencies": {
},
"peerDependencies": {
"@octokit/webhooks": "12.2.0",
"@sinclair/typebox": "0.32.23",
"ajv": "8.13.0",
"ajv-formats": "3.0.1",
"dotenv": "16.4.5",
"lodash": "4.17.21",
"ms": "2.1.3"
"ms": "2.1.3",
"typebox-validators": "0.3.5"
},
"devDependencies": {
"@commitlint/cli": "18.6.1",
Expand All @@ -55,8 +55,6 @@
"@types/node": "20.11.19",
"@typescript-eslint/eslint-plugin": "7.0.1",
"@typescript-eslint/parser": "7.0.1",
"ajv": "8.12.0",
"ajv-formats": "3.0.1",
"cspell": "8.3.2",
"dotenv": "16.4.5",
"esbuild": "0.20.0",
Expand All @@ -82,6 +80,7 @@
"ts-jest": "29.1.2",
"tslib": "2.6.2",
"tsx": "4.7.1",
"typebox-validators": "0.3.5",
"typescript": "5.3.3"
},
"lint-staged": {
Expand Down
8 changes: 4 additions & 4 deletions src/types/configuration-types.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { ObjectOptions, Static, StaticDecode, StringOptions, TProperties, Type as T } from "@sinclair/typebox";
import ms from "ms";
import { ajv } from "../utils";
import { StandardValidator } from "typebox-validators";
import { contentEvaluatorConfigurationType } from "./configuration/content-evaluator-config";
import { dataPurgeConfigurationType } from "./configuration/data-purge-config";
import { formattingEvaluatorConfigurationType } from "./configuration/formatting-evaluator-config";
Expand Down Expand Up @@ -59,10 +59,10 @@ export const envConfigSchema = T.Object({
APP_ID: T.Number(),
});

export const validateEnvConfig = ajv.compile(envConfigSchema);
export const validateEnvConfig = new StandardValidator(envConfigSchema);
export type EnvConfigType = Static<typeof envConfigSchema>;

const botConfigSchema = strictObject(
export const botConfigSchema = strictObject(
{
keys: strictObject({
evmPrivateEncrypted: T.Optional(T.String()),
Expand Down Expand Up @@ -119,6 +119,6 @@ const botConfigSchema = strictObject(
},
{ default: undefined } // top level object can't have default!
);
export const validateBotConfig = ajv.compile(botConfigSchema);
export const validateBotConfig = new StandardValidator(botConfigSchema);

export type BotConfig = StaticDecode<typeof botConfigSchema>;
2 changes: 1 addition & 1 deletion src/types/configuration/plugin-configuration.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ type GithubPlugin = {
ref?: string;
};

function githubPluginType() {
export function githubPluginType() {
return T.Transform(T.String())
.Decode((value) => {
const matches = value.match(pluginNameRegex);
Expand Down
38 changes: 0 additions & 38 deletions src/utils/ajv.ts

This file was deleted.

40 changes: 28 additions & 12 deletions src/utils/generate-configuration.ts
Original file line number Diff line number Diff line change
@@ -1,13 +1,15 @@
import { Value } from "@sinclair/typebox/value";
import { DefinedError } from "ajv";
import mergeWith from "lodash/merge";
import YAML from "yaml";
import { BotConfig, stringDuration, validateBotConfig } from "../types";
import { BotConfig, botConfigSchema, stringDuration, validateBotConfig } from "../types";
// @ts-expect-error gets transformed by rollup
import orgConfig from "../../.github/.ubiquibot-config.yml";
import { githubPluginType } from "../types/configuration/plugin-configuration";

export function generateConfiguration(repoConfig?: BotConfig): BotConfig {
const merged = mergeWith({}, orgConfig, repoConfig, (objValue: unknown, srcValue: unknown) => {
const defaultConfig = Value.Default(botConfigSchema, {}) as BotConfig;

const merged = mergeWith(defaultConfig, orgConfig, repoConfig, (objValue: unknown, srcValue: unknown) => {
if (Array.isArray(objValue) && Array.isArray(srcValue)) {
// if it's string array, concat and remove duplicates
if (objValue.every((value) => typeof value === "string")) {
Expand All @@ -18,12 +20,12 @@ export function generateConfiguration(repoConfig?: BotConfig): BotConfig {
}
});

const isValid = validateBotConfig(merged);
if (!isValid) {
const errorMessage = getErrorMsg(validateBotConfig.errors as DefinedError[]);
if (errorMessage) {
throw new Error(`Invalid merged configuration: ${errorMessage}`);
if (!validateBotConfig.test(merged)) {
const errors = validateBotConfig.errors(merged);
for (const error of errors) {
console.error(error);
}
throw new Error("Invalid configuration.");
}

// this will run transform functions
Expand All @@ -33,7 +35,6 @@ export function generateConfiguration(repoConfig?: BotConfig): BotConfig {
console.error(`Could not transform the configuration: ${err}`);
throw err;
}

return merged as BotConfig;
}

Expand Down Expand Up @@ -74,12 +75,27 @@ export function transformConfig(config: BotConfig) {
errorMsg += `Invalid taskDisqualifyDuration value: ${decodeError.value}\n`;
}
}
errorMsg += transformUseReferences(config);
if (errorMsg) throw new Error(errorMsg);
}

function getErrorMsg(errors: DefinedError[]) {
const errorsWithoutStrict = errors.filter((error) => error.keyword !== "additionalProperties");
return errorsWithoutStrict.length === 0 ? null : errorsWithoutStrict.map((error) => error.instancePath.replaceAll("/", ".") + " " + error.message).join("\n");
function transformUseReferences(config: BotConfig) {
let errorMsg = "";
try {
for (const plugins of Object.values(config.plugins)) {
for (const plugin of plugins) {
for (const use of plugin.uses) {
use.plugin = Value.Decode(githubPluginType(), use.plugin);
}
}
}
} catch (err: unknown) {
const decodeError = err as DecodeError;
if (decodeError.value) {
errorMsg += `Invalid plugin use value: ${decodeError.value}\n`;
}
}
return errorMsg;
}

/**
Expand Down
1 change: 0 additions & 1 deletion src/utils/index.ts
Original file line number Diff line number Diff line change
@@ -1,2 +1 @@
export * from "./ajv";
export * from "./generate-configuration";
8 changes: 1 addition & 7 deletions tests/__mocks__/test-default-conf-obj.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,4 @@
const defaultConfig = {
"price-multiplier": 1.5,
"command-settings": [
{
name: "start",
enabled: false,
},
],
incentives: {
enabled: true,
contentEvaluator: {
Expand Down Expand Up @@ -104,6 +97,7 @@ const defaultConfig = {
plugins: {
"issues.closed": [
{
skipBotEvents: true,
uses: [
{
plugin: "ubiquity/conversation-rewards@testing/ubiquibot-v2-testing",
Expand Down
7 changes: 0 additions & 7 deletions tests/__mocks__/test-valid-conf-obj.ts
Original file line number Diff line number Diff line change
@@ -1,11 +1,4 @@
const validConfig = {
"price-multiplier": 1.5,
"command-settings": [
{
name: "start",
enabled: false,
},
],
keys: {},
features: {
assistivePricing: false,
Expand Down
70 changes: 66 additions & 4 deletions tests/__mocks__/test-valid-config.yml
Original file line number Diff line number Diff line change
@@ -1,4 +1,66 @@
price-multiplier: 1.5
command-settings:
- name: start
enabled: false
incentives:
enabled: true
contentEvaluator:
enabled: true
userExtractor:
enabled: true
redeemTask: true
dataPurge:
enabled: true
formattingEvaluator:
enabled: true
scores:
br: 0
code: 1
p: 1
em: 0
img: 0
strong: 0
blockquote: 0
h1: 1
h2: 1
h3: 1
h4: 1
h5: 1
h6: 1
a: 1
li: 1
td: 1
hr: 0
multipliers:
- type: [ ISSUE, ISSUER, SPECIFICATION ]
formattingMultiplier: 1
wordValue: 0.1
- type: [ ISSUE, ISSUER, COMMENTED ]
formattingMultiplier: 1
wordValue: 0.2
- type: [ ISSUE, ASSIGNEE, COMMENTED ]
formattingMultiplier: 0
wordValue: 0
- type: [ ISSUE, COLLABORATOR, COMMENTED ]
formattingMultiplier: 1
wordValue: 0.1
- type: [ ISSUE, CONTRIBUTOR, COMMENTED ]
formattingMultiplier: 0.25
wordValue: 0.1
- type: [ REVIEW, ISSUER, TASK ]
formattingMultiplier: 0
wordValue: 0
- type: [ REVIEW, ISSUER, COMMENTED ]
formattingMultiplier: 2
wordValue: 0.2
- type: [ REVIEW, ASSIGNEE, COMMENTED ]
formattingMultiplier: 1
wordValue: 0.1
- type: [ REVIEW, COLLABORATOR, COMMENTED ]
formattingMultiplier: 1
wordValue: 0.1
- type: [ REVIEW, CONTRIBUTOR, COMMENTED ]
formattingMultiplier: 0.25
wordValue: 0.1
permitGeneration:
enabled: true
githubComment:
enabled: true
post: true
debug: false
30 changes: 14 additions & 16 deletions yarn.lock
Original file line number Diff line number Diff line change
Expand Up @@ -2073,14 +2073,17 @@ aggregate-error@^3.0.0, aggregate-error@^3.1.0:
clean-stack "^2.0.0"
indent-string "^4.0.0"

ajv-formats@3.0.1:
version "3.0.1"
resolved "https://registry.yarnpkg.com/ajv-formats/-/ajv-formats-3.0.1.tgz#3d5dc762bca17679c3c2ea7e90ad6b7532309578"
integrity sha512-8iUql50EUR+uUcdRQ3HDqa6EVyo3docL8g5WJ3FNcWmu62IbkGUue/pEyLBW8VGKKucTPgqeks4fIU1DA4yowQ==
ajv@^6.12.4:
version "6.12.6"
resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4"
integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==
dependencies:
ajv "^8.0.0"
fast-deep-equal "^3.1.1"
fast-json-stable-stringify "^2.0.0"
json-schema-traverse "^0.4.1"
uri-js "^4.2.2"

ajv@8.12.0, ajv@^8.0.0, ajv@^8.11.0:
ajv@^8.11.0:
version "8.12.0"
resolved "https://registry.yarnpkg.com/ajv/-/ajv-8.12.0.tgz#d1a0527323e22f53562c567c00991577dfbe19d1"
integrity sha512-sRu1kpcO9yLtYxBKvqfTeh9KzZEwO3STyX1HT+4CaDzC6HpTGYhIhPIzj9XuKU7KYDwnaeh5hcOwjy1QuJzBPA==
Expand All @@ -2090,16 +2093,6 @@ ajv@8.12.0, ajv@^8.0.0, ajv@^8.11.0:
require-from-string "^2.0.2"
uri-js "^4.2.2"

ajv@^6.12.4:
version "6.12.6"
resolved "https://registry.yarnpkg.com/ajv/-/ajv-6.12.6.tgz#baf5a62e802b07d977034586f8c3baf5adf26df4"
integrity sha512-j3fVLgvTo527anyYyJOGTYJbG+vnnQYvE0m5mmkc1TK+nxAppkCLMIL0aZ4dblVCNoGShhm+kzE4ZUykBoMg4g==
dependencies:
fast-deep-equal "^3.1.1"
fast-json-stable-stringify "^2.0.0"
json-schema-traverse "^0.4.1"
uri-js "^4.2.2"

ansi-escapes@^4.2.1:
version "4.3.2"
resolved "https://registry.yarnpkg.com/ansi-escapes/-/ansi-escapes-4.3.2.tgz#6b2291d1db7d98b6521d5f1efa42d0f3a9feb65e"
Expand Down Expand Up @@ -6451,6 +6444,11 @@ type-fest@^1.0.1:
resolved "https://registry.yarnpkg.com/type-fest/-/type-fest-1.4.0.tgz#e9fb813fe3bf1744ec359d55d1affefa76f14be1"
integrity sha512-yGSza74xk0UG8k+pLh5oeoYirvIiWo5t0/o3zHHAO2tRDiZcxWP7fywNlXhqb6/r6sWvwi+RsyQMWhVLe4BVuA==

typebox-validators@0.3.5:
version "0.3.5"
resolved "https://registry.yarnpkg.com/typebox-validators/-/typebox-validators-0.3.5.tgz#b913bad0a87571ffe0edd01d2b6090a268e1ecc9"
integrity sha512-FXrmSUAN6bSGxDANResNCZQ8VRRLr5bSyy73/HyqSXGdiVuogppGAoRocy7NTVZY4Wc2sWUofmWwwIXE6OxS6Q==

typed-array-buffer@^1.0.2:
version "1.0.2"
resolved "https://registry.yarnpkg.com/typed-array-buffer/-/typed-array-buffer-1.0.2.tgz#1867c5d83b20fcb5ccf32649e5e2fc7424474ff3"
Expand Down

0 comments on commit f7fd336

Please sign in to comment.