- Common Options
- Modules
- Other Methods
- Util Methods
- Error Handling
- Validation
- Concurrency
- Upgrading from v1
Coming soon. Briefly:
const queryOpts = {}; // query options specific to the module
const moduleOpts = {
devel: boolean|string, // see the main README
fetchOptions: {}, // options to pass to fetch
validateResult:boolean, // READ SUPER NB VALIDATION DOC BEFORE TURNING THIS OFF
}
const result = await yahooFinance.module(query, queryOpts, moduleOpts);
- autoc - autocomplete, great for symbol lookup.
- historical - historical market prices.
- quote - essential symbol info.
- quoteSummary - comprehensive symbol info.
- search - symbol lookup, news and articles.
- recommendationsBySymbol - similar symbols.
- trendingSymbols - symbols trending in a country.
- options - options trading (call/put).
- insights - insights and scores.
- quoteCombine - debounce and combine multiple quote calls.
- setGlobalConfig - set global config options.
The modules rely on external services and things can go wrong. Therefore, it's important to wrap your use of this library in try..catch statements, e.g.:
let result;
try {
result = await yahooFinance.quote(symbol);
} catch (error) {
// Inspect error and decide what to do; often, you may want to just abort:
console.warn(`Skipping yf.quote("${symbol}"): [${error.name}] ${error.message})`);
return;
}
doSomethingWith(result); // safe to use in the way you expect
So what can go wrong?
- Network errors: request timeouts, no response, etc.
- HTTP errors: internal errors, etc.
- Missing resources, e.g. asking for fund data for a stock.
- Validation errors.
The library goes to great lengths to ensure that if there are no errors, the result you receive will be in an expected format and structure, that is safe to use, put in your database, perform calculations with, etc (but please do let us know if you come across any edge cases).
There is a list of specific errors at lib/errors.ts,
accessible via yahooFinance.errors
, but many of these will require further
inspection at runtime. For example:
-
FailedYahooValidationError
- see the Validation section on how to handle these correctly. -
HTTPError
- themessage
property will be the HTTP Response statusText. -
Error
- thrown after a "successful" HTTP request that returns JSON with an{ error: { name: "ErrorName", description: "string" } }
shape, and where we don't have an "ErrorName" class. Themessage
property will be thedescription
.
Example:
import yahooFinance from 'yahoo-finance2';
let result;
try {
result = await yahooFinance.quote(symbol);
} catch (error) {
if (error instanceof yahooFinance.errors.FailedYahooValidationError) {
// See the validation docs for examples of how to handle this
// error.result will be a partially validated / coerced result.
} else if (error instanceof yahooFinance.errors.HTTPError) {
// Probably you just want to log and skip these
console.warn(`Skipping yf.quote("${symbol}"): [${error.name}] ${error.message})`);
return;
} else {
// Same here
console.warn(`Skipping yf.quote("${symbol}"): [${error.name}] ${error.message})`);
return;
}
}
doSomethingWith(result); // safe to use in the way you expect
If you run into any problems with error handling, feel free to open an issue so we can make these docs clearer.
As per the previous section, if you do receive a result (i.e. if no error is thrown), it should reliably be in the format you expect. As such, every received result is validated against the schema we've developed for each module.
See the Validation docs for more info, including how to continue past validation errors or skip validation entirely, as long as you understand the risks.
See Concurrency Docs.
See Upgrading from v1.