목차
| Table of Contents |
|---|
...
텍스트 AI
GPT 예제
- @waylaidwanderer/fetch-event-source를 활용한 Node Express server 예제입니다.
| Code Block | ||||||
|---|---|---|---|---|---|---|
| ||||||
const { fetch, Headers, Request, Response } = require('fetch-undici');
if (!globalThis.fetch) {
globalThis.fetch = fetch;
globalThis.Headers = Headers;
globalThis.Request = Request;
globalThis.Response = Response;
}
module.exports = require('@waylaidwanderer/fetch-event-source');
|
...
| Code Block | ||||||
|---|---|---|---|---|---|---|
| ||||||
const express = require('express');
const bodyParser = require('body-parser');
const { fetchEventSource } = require('./modules/FetchEventSource');
const GPT_API_URL = ''; // API URL ex) 'https://api.openai.com/v1/chat/completions'; // API URL
const GPT_API_KEY = ''; // API KEY
const app = express();
const router = express.Router();
router.post('/request', (request, response) => {
const bodyData = Object.assign({}, request.body, {
model: 'gpt-3.5-turbo',
stream: true
});
requestGPT(response, bodyData)
.then(() => response.end())
.catch((error) => response.status(error.status).json(error).end());
});
/**
* GPT 서버로 요청합니다.
* @param {Response} response
* @param {Object} bodyData
* @returns {Promise}
*/
function requestGPT(response, bodyData) {
const abortController = new AbortController();
return new Promise(async (resolve, reject) => {
try {
await fetchEventSource(GPT_API_URL, {
method: 'post',
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${GPT_API_KEY}` // OpenAI
// 'Api-Key': GPT_API_KEY` // Azure OpenAI
},
body: JSON.stringify(bodyData),
signal: abortController.signal,
onopen: async (openResponse) => {
if (openResponse.status === 200) {
response.on('close', () => {
abortController.abort();
resolve();
});
response.set({
'Cache-Control': 'no-cache',
'Connection': 'keep-alive',
'Content-Type': 'text/event-stream'
});
response.flushHeaders();
return;
}
let error;
try {
const json = await openResponse.json();
error = json;
} catch (e) {
error = e;
}
error.status = openResponse.status;
throw error;
},
onclose: () => resolve(),
onerror: (error) => {
reject(error);
throw error;
},
onmessage: (message) => {
if (!message.data || message.event === 'ping') {
return;
}
response.write('data:' + message.data + '\n\n');
},
});
} catch (e) {
reject(e);
}
});
}
app.use(bodyParser.json());
app.use('/', router);
app.listen(8080);
|
하이퍼클로바 X 예제
- axios를 활용한 Node Express server 예제입니다.
| Code Block | ||||||
|---|---|---|---|---|---|---|
| ||||||
const express = require('express');
const axios = require('axios');
const bodyParser = require('body-parser');
const HCX_API_URL = ''https://; // API URL - CLOVA Studio에서 url 확인 ex)https://clovastudio.apigw.ntruss.com/testapp/v1/chat-completions/HCX-002'; // API URL003
const HCX_API_KEY = ''; // API KEY
const HCX_GATEWAY_KEY = '';// GATEWAY KEY
const app = express();
const router = express.Router();
router.post('/request', (request, response) => {
const bodyData = request.body;
requestHCX(response, bodyData)
.then(() => response.end())
.catch(err => {
console.error('[ERROR] requestHCX chat completion failed: ' + err);
return resresponse.status(err.status || 500).json(err).end();
});
});
/**
* 하이퍼클로바 X 서버로 요청합니다.
* @param {Response} response
* @param {Object} body
* @returns {Promise}
*/
function requestHCX(response, bodyData) {
const source = axios.CancelToken.source();
const url = HCX_API_URL;
const headers= {
'Content-Type': 'application/json',
'Accept': 'text/event-stream',
'X-NCP-CLOVASTUDIO-API-KEY': HCX_API_KEY,
'X-NCP-APIGW-API-KEY': HCX_GATEWAY_KEY
}
return new Promise(async (resolve, reject) => {
try {
axios.post(url, bodyData, {
headers,
responseType: 'stream',
cancelToken: source.token
}).then(reshcxRes => {
reshcxRes.data.pipe(resresponse);
}).catch(reject);
response.on('close', () => {
source.cancel('요청을 취소합니다.');
resolve();
});
} catch (e) {
reject(e);
}
});
}
app.use(bodyParser.json());
app.use('/', router);
app.listen(8080); |
Gemini 예제
- axios를 활용한 Node Express server 예제입니다.
| Code Block | ||||||
|---|---|---|---|---|---|---|
| ||||||
const express = require('express');
const axios = require('axios');
const bodyParser = require('body-parser');
const GEMINI_URL = ''; // API URL ex) 'https://generativelanguage.googleapis.com/v1beta/models/gemini-1.5-flash:streamGenerateContent'
const GEMINI_PARAM = ''; // API PARAMETER ex) 'alt=sse&'
const GEMINI_KEY = ''; // API KEY
const app = express();
const router = express.Router();
router.post('/request', (request, response) => {
const bodyData = Object.assign({}, request.body);
requestGeminiServer(response, bodyData)
.then(() => response.end())
.catch((err) => response.status(err.status || 500).json(err).end());
});
/**
* Gemini 서버로 요청을 합니다.
* @param {Response} response
* @param {Object} bodyData
* @returns {Promise}
*/
function requestGeminiServer(response, bodyData) {
const url = GEMINI_URL;
const key = GEMINI_KEY;
const param = GEMINI_PARAM;
const urlWithParam = `${url}?${param}key=${key}`;
const source = axios.CancelToken.source();
return new Promise((resolve, reject) => {
try {
axios.post(urlWithParam, bodyData, {
headers: {
'Content-Type': 'application/json'
},
responseType: 'stream',
cancelToken: source.token
}).then(geminiRes => {
geminiRes.data.pipe(response);
}).catch(reject);
response.on('close', () => {
source.cancel('요청을 취소합니다.');
resolve();
});
} catch (e) {
reject(e);
}
});
}
app.use(bodyParser.json());
app.use('/', router);
app.listen(8080); |
...
이미지 생성 AI
DALL-E 예제
- axios를 활용한 Node Express server 예제입니다.
| Code Block | ||||||
|---|---|---|---|---|---|---|
| ||||||
const express = require('express');
const axios = require('axios');
const bodyParser = require('body-parser');
const DALLE_URL = ''; // API URL ex) 'https://api.openai.com/v1/images/generations'
const DALLE_API_KEY = ''; // API KEY
const app = express();
const router = express.Router();
router.post('/request', (request, response) => {
const bodyData = request.body;
requestDALLEServer(response, bodyData)
.then((data) => response.json(data))
.catch((error) => response.status(error.status).json(error).end());
});
/**
* DALL·E 서버로 요청을 합니다.
* @param {Response} response
* @param {Object} bodyData
* @returns {Promise}
*/
function requestDALLEServer(response, bodyData) {
const source = axios.CancelToken.source();
const url = DALLE_URL;
return new Promise((resolve, reject) => {
try {
axios.post(url, bodyData, {
headers: {
'Content-Type': 'application/json',
'Authorization': `Bearer ${DALLE_API_KEY}`
},
cancelToken: source.token
}).then(res => {
resolve(res.data);
}).catch(error => {
reject({
status: error.response ? error.response.status : 500,
message: error.message
});
});
response.on('close', () => {
source.cancel('요청을 취소합니다.');
resolve();
});
} catch (e) {
reject(e);
}
});
}
app.use(bodyParser.json());
app.use('/', router);
app.listen(8080); |
...