Files
sera-new-hp/src-manager/docs/manager/1.0.0/utils_asyncDatabase.js.html

107 lines
3.0 KiB
HTML

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>JSDoc: Source: utils/asyncDatabase.js</title>
<script src="scripts/prettify/prettify.js"> </script>
<script src="scripts/prettify/lang-css.js"> </script>
<!--[if lt IE 9]>
<script src="//html5shiv.googlecode.com/svn/trunk/html5.js"></script>
<![endif]-->
<link type="text/css" rel="stylesheet" href="styles/prettify-tomorrow.css">
<link type="text/css" rel="stylesheet" href="styles/jsdoc-default.css">
</head>
<body>
<div id="main">
<h1 class="page-title">Source: utils/asyncDatabase.js</h1>
<section>
<article>
<pre class="prettyprint source linenums"><code>/**
* @module utils/asyncDatabase
*/
import sqlite3 from 'sqlite3';
/**
* @param {sqlite3.Database} database
* @param {string} sqlQuery
* @param {function} callback - function (rows)
* @returns {Promise&lt;any>} Promise for database operation
* @example
* const result = await asyncDatabaseRead(userDatabase, `SELECT * FROM users`, (rows) => {
* return wrapInTable(rows);
* });
*/
const asyncDatabaseRead = (database, sqlQuery, callback) => {
return new Promise((resolve, reject) => {
database.serialize(() => {
database.all(sqlQuery, (err, rows) => {
if (err) {
reject(err);
} else {
resolve(callback(rows));
}
});
});
});
};
/**
* @param {sqlite3.Database} database
* @param {string} sqlQuery
* @param {function} callback - function ()
* @returns {Promise&lt;any>} Promise for database operation
* @example
* let sqlQuery = `INSERT INTO users (id, name, age) VALUES (${genID()}, "${userName}", "${userAge}");`;
* await asyncDatabaseWrite(userDatabase, sqlQuery, () => {
* console.log("Added User ", userName);
* });
*/
const asyncDatabaseWrite = (database, sqlQuery, callback) => {
return new Promise((resolve, reject) => {
database.serialize(() => {
database.run(sqlQuery, (err, rows) => {
if (err) {
reject(err);
} else {
resolve(callback(rows));
}
});
});
});
};
export { asyncDatabaseRead, asyncDatabaseWrite };
</code></pre>
</article>
</section>
</div>
<nav>
<h2><a href="index.html">Home</a></h2><h3>Modules</h3><ul><li><a href="module-api_gallery-image.html">api/gallery-image</a></li><li><a href="module-api_news.html">api/news</a></li><li><a href="module-utils_asyncDatabase.html">utils/asyncDatabase</a></li><li><a href="module-utils_tableWrapper.html">utils/tableWrapper</a></li></ul>
</nav>
<br class="clear">
<footer>
Documentation generated by <a href="https://github.com/jsdoc/jsdoc">JSDoc 4.0.4</a> on Tue Nov 26 2024 23:18:12 GMT+0900 (日本標準時)
</footer>
<script> prettyPrint(); </script>
<script src="scripts/linenumber.js"> </script>
</body>
</html>