Content Manager: Added Documentation, Implemented functional approach to the HTML table generation and refactored API codes, Using DOM purifier to prevent XSS
This commit is contained in:
106
src-manager/docs/manager/1.0.0/utils_asyncDatabase.js.html
Normal file
106
src-manager/docs/manager/1.0.0/utils_asyncDatabase.js.html
Normal file
@@ -0,0 +1,106 @@
|
||||
<!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<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<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>
|
||||
Reference in New Issue
Block a user