Wweather forecasts and historical weather data
Create a new document in a collection of your choice. See the docs here
Execute an aggregation pipeline on a MongoDB collection. See the documentation
The DarkSky API offers detailed weather information that includes minute-by-minute forecasts, hourly forecasts, and daily summaries. By harnessing this API on Pipedream, you can automate tasks like sending alerts, integrating weather data into event planning platforms, or tailoring content based on weather conditions. With Pipedream’s serverless platform, these use cases become straightforward to implement, and you can trigger workflows with new weather data, schedule checks at regular intervals, or even react to changes in forecasted conditions.
import { axios } from "@pipedream/platform"
export default defineComponent({
props: {
darksky_api: {
type: "app",
app: "darksky_api",
}
},
async run({steps, $}) {
return await axios($, {
url: `https://api.darksky.net/forecast/${this.darksky_api.$auth.secret_key}/37.8267,-122.4233`,
})
},
})
The MongoDB API provides powerful capabilities to interact with a MongoDB database, allowing you to perform CRUD (Create, Read, Update, Delete) operations, manage databases, and execute sophisticated queries. With Pipedream, you can harness these abilities to automate tasks, sync data across various apps, and react to events in real-time. It’s a combo that’s particularly potent for managing data workflows, syncing application states, or triggering actions based on changes to your data.
import mongodb from 'mongodb'
export default defineComponent({
props: {
mongodb: {
type: "app",
app: "mongodb",
},
collection: {
type: "string"
},
filter: {
type: "object"
}
},
async run({steps, $}) {
const MongoClient = mongodb.MongoClient
const {
database,
hostname,
username,
password,
} = this.mongodb.$auth
const url = `mongodb+srv://${username}:${password}@${hostname}/test?retryWrites=true&w=majority`
const client = await MongoClient.connect(url, {
useNewUrlParser: true,
useUnifiedTopology: true
})
const db = client.db(database)
const results = await db.collection(this.collection).find(this.filter).toArray();
$.export('results', results);
await client.close()
},
})