Allows fetching weather data using Apple WeatherKit API. Follows Apple WeatherKit object and query parameters.
import * as fs from 'fs'
import WeatherKit from 'node-apple-weatherkit'
import { WeatherKitAuth, DataSet, Err, isErr, WeatherKitResponse } from 'node-apple-weatherkit'
;(async () => {
// Read the key from file. Can be also assigned inline
const key = fs.readFileSync('key/AuthKey_APPLEKEYID.p8')
const defaultAuth: WeatherKitAuth = {
teamId: 'APPLETEAMID',
serviceId: 'com.example.weather',
keyId: 'APPLEKEYID',
key: key,
}
const location = {
lat: 29.42,
lon: -81.93
}
const wk = new WeatherKit(defaultAuth)
const availability: DataSet[] | Err = await wk.availability.get(location.lat, location.lon)
if (!isErr(availability)) {
const weather: WeatherKitResponse | Err = await wk.weather.get(location.lat, location.lon, { dataSets: availability })
if (!isErr(weather)) {
console.log(weather.forecastDaily?.days[0].temperatureMin)
}
} else {
console.log('Cannot get location available datasets')
}
})()
Query parameters can be added to WeatherKit.weather.get() by supplying a QueryParams object as parameter. Known parameters are:
countryCode?: string
currentAsOf?: Date
dailyEnd?: Date
dailyStart?: Date
hourlyEnd?: Date
hourlyStart?: Date
dataSets?: DataSet[]
timezone?: string | 'Etc/UTC'