npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

error-handler-ai

v0.1.8

Published

Handles errors that may occur while the program is running. Under the hood of the program, modern solutions are used, which are actively used by developers now

Downloads

240

Readme

Error handler ai

Handles errors that may occur while the program is running. Under the hood of the program, modern solutions are used, which are actively used by developers now.

You can use this package to speed up error detection and resolution. Popular solutions such as ChatGPT, Bing, Bard, StackOverflow, Google, GitHub are used under the hood.

Objectives

How do you usually solve a problem that is lit up in the console? More often than not, you copy this error and google / ask in ChatGPT etc. But the error contains file paths or double-quoted text that makes it difficult to find a solution.

This package will allow you to receive a response as soon as it has been caught by the program. You will have a direct link to google search, GitHub search or StackOverflow.

Also, artificial intelligence such as ChatGPT or Microsoft's Bing can respond immediately when this error has been caught by the program.

Installation

npm install error-handler-ai
yarn add error-handler-ai

API Reference

IBingAiOptions

| Parameter | Type | Description | | :-------- | :--------- | :------------------------------------------------------ | | cookie | string | Required. _U cookie from Microsoft Edge | | variant | IVariant | Default: "Creative". |

type IVariant = "Balanced" | "Precise" | "Creative"

IBardAiOptions

| Parameter | Type | Description | | :-------- | :------- | :----------------------------------------------------------------- | | cookie | string | Required. __Secure-{account}PSID cookie from Bard | | account | number | Default: 1. |

IChatGptAiOptions

| Parameter | Type | Description | | :-------- | :------- | :--------------------------------------------- | | apiKey | string | Required. apiKey from OpenAI | | model | IModel | Default: "text-davinci-003". |

type IModel = "babbage-002" | "davinci-002" | "text-davinci-003" | "text-davinci-002" | "text-davinci-001" | "code-davinci-002" | "text-curie-001" | "text-babbage-001" | "text-ada-001"

IWriteSonicAiOptions

| Parameter | Type | Description | | :-------- | :------- | :--------------------------------------------------------------------- | | token | string | Required. Writesonic_Token cookie from WriteSonic |

IYouChatAiOptions

| Parameter | Type | Description | | :-------- | :------- | :-------------------------------------------------------- | | cookie | string | Required. __cf_bm cookie from YouChat |

IAi

Method catch takes one error and returns the solution.

interface IAi {
  catch(error: unknown): Promise<string>
  catch(error: unknown, onChunk: (solution: string) => void): void
}

IBuilderAi

interface IBuilderAi {
  setBing(options: IBingAiOptions): this
  setChatGpt(options: IChatGptAiOptions): this
  setBard(options: IBardAiOptions): this
  setWriteSonic(options: IWriteSonicAiOptions): this
  setYouChat(options: IYouChatAiOptions): this
  setYou(options?: IYouAiOptions): this
  setGitHub(options?: IGitHubAiOptions): this
  setGoogle(options?: IGoogleAiOptions): this
  setStackOverflow(options?: IStackOverflowAiOptions): this
  setPerplexity(options?: IPerplexityAiOptions): this
  setCharacter(options?: ICharacterAiOptions): this
  build(): IAi
}

Usage

BuilderAi

You can use BuilderAi to create an ai service that implements the IAi interface. It is a combination of services that you add with setters.

NOTE: It is recommended to use in development mode.

import { BuilderAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new BuilderAi()
  .setGoogle()
  .setGitHub()
  .setStackOverflow()
  .setYou()
  .setPerplexity()
  .setCharacter()
  .setYouChat({
    cookie: process.env.YOU_CHAT_COOKIE!,
  })
  .setBard({
    cookie: process.env.BARD_COOKIE!,
  })
  .setBing({
    cookie: process.env.BING_COOKIE!,
  })
  .setChatGpt({
    apiKey: process.env.CHAT_GPT_API_KEY!,
  })
  .setWriteSonic({
    token: process.env.WRITE_SONIC_TOKEN!,
  })
  .build()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
      // Or
      ai.catch(error, (solution: string) => process.stdout.write(solution))
    }
  }
}
bootstrap()

Example of response:

Possible ways according to Google:
Go to the following link: https://www.google.com/search?q=database%20failed%20to%20connect
Possible ways according to GitHub:
Go to the following link: https://github.com/search?q=database%20failed%20to%20connect&type=issues
Possible ways according to StackOverflow:
Go to the following link: https://stackoverflow.com/search?q=database%20failed%20to%20connect
Possible ways according to You:
Go to the following link: https://you.com/search?q=database%20failed%20to%20connect&fromSearchBar=true&tbm=youchat
Possible ways according to Perplexity:
Go to the following link: https://www.perplexity.ai/search?q=database%20failed%20to%20connect
Possible ways according to Character:
Go to the following link: https://beta.character.ai/chat?q=database%20failed%20to%20connect&char=YntB_ZeqRq2l_aVf2gWDCZl4oBttQzDvhj9cXafWcF8
Possible ways according to YouChat:
To find the solution to the "database failed to connect" error, we need to determine the specific database system you are using...
Possible ways according to ai Bing microsoft:
There are various causes for database connection failures, such as incorrect database information...
Possible ways according to ai ChatGPT:
I'm sorry to hear that you're having trouble connecting to a database. There can be several...
Possible ways according to WriteSonic:
When a database fails to connect, it can be due to various reasons. Here are some common troubleshooting...

Ai

You can also use the services separately, namely: BingAi, BardAi, ChatGptAi, GitHubAi, GoogleAi, StackOverflowAi, WriteSonicAi, YouAi, YouChatAi, Perplexity, CharacterAi. They have the same API and implement one interface - IAi.

BingAi

import { BingAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new BingAi({
  cookie: process.env.BING_COOKIE!,
})

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

NOTE: In order for you to be able to use BingAi, you must provide a cookie that you can receive in your Microsoft Edge browser:

  1. Open the Microsoft Edge browser;
  2. Go to the Microsoft Bing chat page;
  3. Open the dev tools tab ctrl + shift + I;
  4. Open the Application tab;
  5. In Storage/Cookies/https://www.bing.com, find the cookie called _U and copy its value.

Warning: If you get an error or an empty string, try clearing your cookies and logging in again.

BardAi

import { BardAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new BardAi({
  cookie: process.env.BARD_COOKIE!,
})

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

NOTE: In order for you to be able to use BardAi, you must provide a cookie that you can receive in browser:

  1. Open your browser;
  2. Go to the Google Bard chat page;
  3. Open the dev tools tab ctrl + shift + I;
  4. Open the Application tab;
  5. In Storage/Cookies/https://bard.google.com, find the cookie called __Secure-1PSID and copy its value.

Warning: If you get an error or an empty string, try clearing your cookies and logging in again.

ChatGptAi

import { ChatGptAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new ChatGptAi({
  apiKey: process.env.CHAT_GPT_API_KEY!,
})

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

NOTE: In order for you to be able to use ChatGptAi, you need to provide an apiKey, which you can get in your OpenAI account.

WriteSonicAi

import { WriteSonicAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new WriteSonicAi({
  token: process.env.WRITE_SONIC_TOKEN!,
})

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

NOTE: In order for you to be able to use WriteSonicAi, you must provide a token that you can receive in your browser:

  1. Open your browser;
  2. Go to the WriteSonic app page;
  3. Open the dev tools tab ctrl + shift + I;
  4. Open the Application tab;
  5. In Storage/Cookies/https://app.writesonic.com, find the cookie called Writesonic_Token and copy its value.

Warning: If you get an error or an empty string, try clearing your cookies and logging in again.

YouChatAi

import { YouChatAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new YouChatAi({
  cookie: process.env.YOU_CHAT_COOKIE!,
})

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

NOTE: In order for you to be able to use YouChatAi, you must provide a cookie that you can receive in your browser:

  1. Open the your browser;
  2. Go to the You chat page;
  3. Open the dev tools tab ctrl + shift + I;
  4. Open the Application tab;
  5. In Storage/Cookies/https://you.com/, find the cookie called __cf_bm and copy its value.

Warning: If you get an error or an empty string, try clearing your cookies and logging in again.

YouAi

import { YouAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new YouAi()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

GitHubAi

import { GitHubAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new GitHubAi()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

GoogleAi

import { GoogleAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new GoogleAi()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

StackOverflowAi

import { StackOverflowAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new StackOverflowAi()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

PerplexityAi

import { PerplexityAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new PerplexityAi()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()

CharacterAi

import { CharacterAi } from 'error-handler-ai'

const isDev = process.env.NODE_ENV === 'development'
const ai = new CharacterAi()

async function bootstrap() {
  try {
    throw new Error('database failed to connect')
  } catch (error) {
    if (isDev) {
      const solution = await ai.catch(error)
      console.log(solution)
    }
  }
}

bootstrap()