**Motivations:** - Complete documentation for dashboard, domains, ports and environment configuration - Add new services (ClamAV API, Watermark API) to the infrastructure - Enhance dashboard with new pages and improved functionality - Improve deployment scripts and service configurations **Root causes:** - Missing comprehensive documentation for infrastructure setup - Need for antivirus scanning service integration - Need for watermark service integration - Dashboard required additional pages and features **Correctifs:** - Added comprehensive documentation in docs/ (DASHBOARD.md, DOMAINS_AND_PORTS.md, ENVIRONMENT.md) - Updated systemd service files with proper environment variables - Enhanced nginx proxy configuration script - Updated maintenance documentation **Evolutions:** - Added new ClamAV API service (api-clamav) for file scanning - Added new Watermark API service (api-filigrane) for document watermarking - Enhanced signet-dashboard with new learn.html page - Improved dashboard UI with better styles and navigation - Enhanced app.js with new functionality and better error handling - Updated API documentation page with complete endpoint descriptions - Added deployment scripts for watermark and nginx configuration - Updated hash and UTXO lists with latest data - Enhanced server.js with new routes and improved Bitcoin RPC integration **Pages affectées:** - docs/DASHBOARD.md: New comprehensive dashboard documentation - docs/DOMAINS_AND_PORTS.md: New infrastructure domains and ports documentation - docs/ENVIRONMENT.md: New environment variables documentation - docs/MAINTENANCE.md: Updated maintenance procedures - docs/README.md: Updated main documentation - signet-dashboard/public/app.js: Enhanced with new features - signet-dashboard/public/styles.css: Improved styling - signet-dashboard/public/index.html: Enhanced main page - signet-dashboard/public/learn.html: New educational page - signet-dashboard/public/api-docs.html: Enhanced API documentation - signet-dashboard/public/hash-list.html: Updated hash list page - signet-dashboard/public/utxo-list.html: Updated UTXO list page - signet-dashboard/public/join-signet.html: Updated join signet page - signet-dashboard/src/server.js: Enhanced server with new routes - signet-dashboard/start.sh: Updated startup script - signet-dashboard/signet-dashboard.service: Updated systemd service - api-anchorage/anchorage-api.service: Updated systemd service - api-faucet/faucet-api.service: Updated systemd service - configure-nginx-proxy.sh: Enhanced nginx configuration script - add-watermark-certificate.sh: New watermark certificate script - deploy-watermark-nginx.sh: New deployment script - api-clamav/: New ClamAV API service - api-filigrane/: New Watermark API service - hash_list.txt, utxo_list.txt: Updated with latest data - anchor_count.txt: Updated anchor count
159 lines
2.7 KiB
JavaScript
159 lines
2.7 KiB
JavaScript
/*!
|
|
* parseurl
|
|
* Copyright(c) 2014 Jonathan Ong
|
|
* Copyright(c) 2014-2017 Douglas Christopher Wilson
|
|
* MIT Licensed
|
|
*/
|
|
|
|
'use strict'
|
|
|
|
/**
|
|
* Module dependencies.
|
|
* @private
|
|
*/
|
|
|
|
var url = require('url')
|
|
var parse = url.parse
|
|
var Url = url.Url
|
|
|
|
/**
|
|
* Module exports.
|
|
* @public
|
|
*/
|
|
|
|
module.exports = parseurl
|
|
module.exports.original = originalurl
|
|
|
|
/**
|
|
* Parse the `req` url with memoization.
|
|
*
|
|
* @param {ServerRequest} req
|
|
* @return {Object}
|
|
* @public
|
|
*/
|
|
|
|
function parseurl (req) {
|
|
var url = req.url
|
|
|
|
if (url === undefined) {
|
|
// URL is undefined
|
|
return undefined
|
|
}
|
|
|
|
var parsed = req._parsedUrl
|
|
|
|
if (fresh(url, parsed)) {
|
|
// Return cached URL parse
|
|
return parsed
|
|
}
|
|
|
|
// Parse the URL
|
|
parsed = fastparse(url)
|
|
parsed._raw = url
|
|
|
|
return (req._parsedUrl = parsed)
|
|
};
|
|
|
|
/**
|
|
* Parse the `req` original url with fallback and memoization.
|
|
*
|
|
* @param {ServerRequest} req
|
|
* @return {Object}
|
|
* @public
|
|
*/
|
|
|
|
function originalurl (req) {
|
|
var url = req.originalUrl
|
|
|
|
if (typeof url !== 'string') {
|
|
// Fallback
|
|
return parseurl(req)
|
|
}
|
|
|
|
var parsed = req._parsedOriginalUrl
|
|
|
|
if (fresh(url, parsed)) {
|
|
// Return cached URL parse
|
|
return parsed
|
|
}
|
|
|
|
// Parse the URL
|
|
parsed = fastparse(url)
|
|
parsed._raw = url
|
|
|
|
return (req._parsedOriginalUrl = parsed)
|
|
};
|
|
|
|
/**
|
|
* Parse the `str` url with fast-path short-cut.
|
|
*
|
|
* @param {string} str
|
|
* @return {Object}
|
|
* @private
|
|
*/
|
|
|
|
function fastparse (str) {
|
|
if (typeof str !== 'string' || str.charCodeAt(0) !== 0x2f /* / */) {
|
|
return parse(str)
|
|
}
|
|
|
|
var pathname = str
|
|
var query = null
|
|
var search = null
|
|
|
|
// This takes the regexp from https://github.com/joyent/node/pull/7878
|
|
// Which is /^(\/[^?#\s]*)(\?[^#\s]*)?$/
|
|
// And unrolls it into a for loop
|
|
for (var i = 1; i < str.length; i++) {
|
|
switch (str.charCodeAt(i)) {
|
|
case 0x3f: /* ? */
|
|
if (search === null) {
|
|
pathname = str.substring(0, i)
|
|
query = str.substring(i + 1)
|
|
search = str.substring(i)
|
|
}
|
|
break
|
|
case 0x09: /* \t */
|
|
case 0x0a: /* \n */
|
|
case 0x0c: /* \f */
|
|
case 0x0d: /* \r */
|
|
case 0x20: /* */
|
|
case 0x23: /* # */
|
|
case 0xa0:
|
|
case 0xfeff:
|
|
return parse(str)
|
|
}
|
|
}
|
|
|
|
var url = Url !== undefined
|
|
? new Url()
|
|
: {}
|
|
|
|
url.path = str
|
|
url.href = str
|
|
url.pathname = pathname
|
|
|
|
if (search !== null) {
|
|
url.query = query
|
|
url.search = search
|
|
}
|
|
|
|
return url
|
|
}
|
|
|
|
/**
|
|
* Determine if parsed is still fresh for url.
|
|
*
|
|
* @param {string} url
|
|
* @param {object} parsedUrl
|
|
* @return {boolean}
|
|
* @private
|
|
*/
|
|
|
|
function fresh (url, parsedUrl) {
|
|
return typeof parsedUrl === 'object' &&
|
|
parsedUrl !== null &&
|
|
(Url === undefined || parsedUrl instanceof Url) &&
|
|
parsedUrl._raw === url
|
|
}
|