-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathgenOpenAIImage.js
109 lines (82 loc) · 3.83 KB
/
genOpenAIImage.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
var generateOpenAIImage = require('./utility/generateOpenAIImage.js');
var genErrorPage = require('./utility/genErrorPage.js');
var downloadPhoto = require("./utility/downloadPhoto.js");
var genHTML = require('./utility/genHTML.js');
var tweetPhoto = require("./utility/twitterTool.js");
const { initializeApp, applicationDefault, cert } = require('firebase-admin/app');
const { getFirestore, Timestamp, FieldValue, Filter } = require('firebase-admin/firestore');
const serviceAccount = require('/Users/mikeland/WeatherWindow/config/' + process.env.SERVICE_FILE_NAME);
initializeApp({
credential: cert(serviceAccount)
});
const db = getFirestore();
var date = new Date();
var prettyDate = date.toLocaleDateString('en-US', {
year: "numeric",
month: 'long',
day: 'numeric',
hour: 'numeric',
minute: 'numeric'
});
console.log("========================\n\nStarting WeatherWindow genOpenAIAndTweet Process", prettyDate, "\n");
var unixTimeStamp = Date.now();
function genDBDoc(queryPkg) {
var dbDoc = {
query: queryPkg.query,
weather: queryPkg.weather,
imageSource: "OpenAI",
storageDriveID: "OpenAI",
spice: queryPkg.spice,
model: "Dall-E",
unixTimeStamp: unixTimeStamp.toString(),
city: queryPkg.city,
country: queryPkg.country,
twitterMediaID: "",
tweetID: ""
};
return dbDoc;
};
(async () => {
var queryPkg;
try {
var pendingQueries = await db.collection("WeatherWindowQueries").where("openAIImage", "==", "PENDING").limit(1).get();
pendingQueries.forEach(queryDoc => {
queryPkg = queryDoc.data();
queryPkg.id = queryDoc.id;
})
if (!queryPkg) {
console.log("No PENDING queries found");
process.exit(0);
}
console.log("Querying OpenAI For Photo of", queryPkg.query);
console.log("GENENERATING PHOTO NOW, THIS MAY TAKE A MOMENT");
var photoURL = await generateOpenAIImage.grab(queryPkg.query);
console.log("Successfully Generated OpenAI Image");
var dbDoc = genDBDoc(queryPkg);
dbDoc.originalURL = photoURL;
console.log("Downloading Photo");
var fileName = await downloadPhoto.go(photoURL, queryPkg.query, unixTimeStamp, "/Users/mikeland/Desktop/OpenAI/");
console.log("Photo Downloaded Successfully to", fileName);
console.log("Setting new Image Doc");
await db.collection("weatherwindow").doc(fileName).set(dbDoc);
console.log("Successfully Setting new Image Doc");
console.log("Setting new Query Doc");
await db.collection("WeatherWindowQueries").doc(queryPkg.id).update({openAIImage:fileName});
console.log("Successfully Setting OpenAIImage on Query Doc as filename");
console.log("\n\nEnding WeatherWindow genOpenAIAndTweet Process ========================");
process.exit(0);
} catch (err) {
if (queryPkg && queryPkg.id && err == "CleanError Error: Request failed with status code 400 Your request was rejected as a result of our safety system. Your prompt may contain text that is not allowed by our safety system.") {
var dbDoc = genDBDoc(queryPkg);
console.log("Setting new CENSORED Image Doc");
var fileName = await downloadPhoto.downloadCensoredPhoto("censored-saftey-system", unixTimeStamp, "/Users/mikeland/Desktop/OpenAI/");
await db.collection("weatherwindow").doc(fileName).set(dbDoc);
console.log("Successfully Set new CENSORED Image Doc");
console.log("Saving CENSORED openAIImage");
await db.collection("WeatherWindowQueries").doc(queryPkg.id).update({openAIImage:fileName});
console.log("Successfully Saved censorPkg");
};
console.log(err);
await genErrorPage.gen(err);
}
})();