Classes
Methods
(inner) createApiParams(baseUrl, input, outputopt) → {Promise.<FetchParams>}
Build a URL call from a baseUrl and input; specify an OutputFormat (for fetchResults).
- Source:
Parameters:
Name | Type | Attributes | Default | Description |
---|---|---|---|---|
baseUrl |
string
|
base URL of API we are trying to call | ||
input |
string
|
Object
|
string of query, or object of parameters | ||
output |
OutputFormat
|
<optional> |
string | which OutputFormat we want |
Returns:
- Type:
-
Promise.<FetchParams>
Example
// resolves {url: 'https://api.wolframalpha.com/v1/result?appid=DEMO&i=2%2B2', output: 'string'}
createApiParams('https://api.wolframalpha.com/v1/result?appid=DEMO', '2+2', 'string')
// resolves {
// url: 'https://api.wolframalpha.com/v1/simple?appid=DEMO&i=nyc%20to%la&units=metric',
// output: 'image'
// }
createApiParams('https://api.wolframalpha.com/v1/simple?appid=DEMO',
{i: 'nyc to la', units: 'metric'}, 'image')
// rejects TypeError('method only receives string or object')
createApiParams('https://api.wolframalpha.com/v1/result?appid=DEMO')
(inner) fetchResults(params) → {Promise.<FormatParams>}
Return a Promise that downloads params.url, and resolves the results (for formatResults).
- Source:
Parameters:
Name | Type | Description |
---|---|---|
params |
FetchParams
|
Returns:
- Type:
-
Promise.<FormatParams>
Example
// resolves { data: '4', output: 'string', statusCode: 200,
// contentType: 'text/plain;charset=utf-8' }
fetchResults({
url: 'https://api.wolframalpha.com/v1/result?appid=DEMO&i=2%2B2',
output: 'string'
})
// resolves { output: 'json', statusCode: 200, contentType: 'text/plain;charset=utf-8',
// data: '{"queryresult" : {\n\t"success" : true, \n\t"error" : false, \n\t"nu...', }
fetchResults({
url: 'https://api.wolframalpha.com/v2/query?appid=DEMO&input=2%2B2&output=json',
output: 'json'
})
// resolves { output: 'image', statusCode: 200, contentType: 'image/gif',
// data: 'R0lGODlhHAJNBfcAAAAAAAAEAAgICAgMCBAQEBAUEBgYGBgcGCAgICAkICksKSkoKTEwMT...'}
fetchResults({
url: 'https://api.wolframalpha.com/v1/simple?appid=DEMO&i=nyc%20to%la&units=metric',
output: 'image'
})
// resolves { output: 'image', statusCode: 501, contentType: 'text/plain;charset=utf-8',
// data: 'Wolfram|Alpha did not understand your input' }
fetchResults({
url: 'https://api.wolframalpha.com/v1/result?appid=DEMO&i=F9TVlu5AmVzL'
output: 'string'
})
(inner) formatResults(params) → {Promise.<(Object|string)>}
Return a Promise that resolves a formatted form of params.data, as specified by
params.output, params.statusCode, and params.contentType
- Source:
Parameters:
Name | Type | Description |
---|---|---|
params |
FormatParams
|
Returns:
- Type:
-
Promise.<(Object|string)>
Example
// resolves "4"
formatResults({
data: '4', output: 'string', statusCode: 200,
contentType: 'text/plain;charset=utf-8'
})
// resolves {success: true, error: false, numpods: 6, datatypes: 'Math', timedout: '' ...}
formatResults({
data: '{"queryresult" : {\n\t"success" : true, \n\t"error" : false, \n\t"nu...',
output: 'json', statusCode: 200, contentType: 'text/plain;charset=utf-8'
})
// resolves '...
formatResults({
data: 'R0lGODlhHAJNBfcAAAAAAAAEAAgICAgMCBAQEBAUEBgYGBgcGCAgICAkICksKSkoKTEwMT...'
output: 'image', statusCode: 200, contentType: 'image/gif'
})
// rejects Error('Wolfram|Alpha did not understand your input')
formatResults({
data: 'Wolfram|Alpha did not understand your input'
output: 'image', statusCode: 501, contentType: 'text/plain;charset=utf-8'
})
(inner) initializeClass(appid)
You may get your 'appid' at https://developer.wolframalpha.com/portal/myapps/.
Remember, this appID must be kept secret.
- Source:
Parameters:
Name | Type | Description |
---|---|---|
appid |
string
|
the appid, must be non-empty string. |
Throws:
TypeError
Example
const WolframAlphaAPI = require('wolfram-alpha-api');
const waApi = WolframAlphaAPI('DEMO-APPID');
Type Definitions
FetchParams
Properties:
Name | Type | Description | ||||||
---|---|---|---|---|---|---|---|---|
params |
Object
|
|||||||
Name | Type | Description |
---|---|---|
url |
string
|
full URL of api call |
output |
OutputFormat
|
which OutputFormat do we want? |
- Source:
Example
{url: 'https://api.wolframalpha.com/v1/result?appid=DEMO&i=2%2B2', output: 'string'}
FormatParams
Properties:
Name | Type | Description | ||||||
---|---|---|---|---|---|---|---|---|
params |
Object
|
|||||||
Name | Type | Description |
---|---|---|
data |
string
|
data returned by fetchResults |
output |
OutputFormat
|
which OutputFormat do we want? |
statusCode
integer
contentType
string
- Source:
Example
{data: '4', output: 'string', statusCode: 200, contentType: 'text/plain;charset=utf-8'}
OutputFormat
We support four 'output' formats: 'string' and 'xml' are both strings, 'json' is an Object (a result of JSON.parse), and 'image' is a string of a "Data URI"
Properties:
Name | Type | Description |
---|---|---|
output |
'string' |'json' |'image' |'xml'
|
- Source: