**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
92 lines
2.4 KiB
JavaScript
92 lines
2.4 KiB
JavaScript
'use strict';
|
|
|
|
var INITIAL_STATE = 1;
|
|
var FAIL_STATE = 0;
|
|
/**
|
|
* A StateMachine represents a deterministic finite automaton.
|
|
* It can perform matches over a sequence of values, similar to a regular expression.
|
|
*/
|
|
|
|
class StateMachine {
|
|
constructor(dfa) {
|
|
this.stateTable = dfa.stateTable;
|
|
this.accepting = dfa.accepting;
|
|
this.tags = dfa.tags;
|
|
}
|
|
/**
|
|
* Returns an iterable object that yields pattern matches over the input sequence.
|
|
* Matches are of the form [startIndex, endIndex, tags].
|
|
*/
|
|
|
|
|
|
match(str) {
|
|
var self = this;
|
|
return {
|
|
*[Symbol.iterator]() {
|
|
var state = INITIAL_STATE;
|
|
var startRun = null;
|
|
var lastAccepting = null;
|
|
var lastState = null;
|
|
|
|
for (var p = 0; p < str.length; p++) {
|
|
var c = str[p];
|
|
lastState = state;
|
|
state = self.stateTable[state][c];
|
|
|
|
if (state === FAIL_STATE) {
|
|
// yield the last match if any
|
|
if (startRun != null && lastAccepting != null && lastAccepting >= startRun) {
|
|
yield [startRun, lastAccepting, self.tags[lastState]];
|
|
} // reset the state as if we started over from the initial state
|
|
|
|
|
|
state = self.stateTable[INITIAL_STATE][c];
|
|
startRun = null;
|
|
} // start a run if not in the failure state
|
|
|
|
|
|
if (state !== FAIL_STATE && startRun == null) {
|
|
startRun = p;
|
|
} // if accepting, mark the potential match end
|
|
|
|
|
|
if (self.accepting[state]) {
|
|
lastAccepting = p;
|
|
} // reset the state to the initial state if we get into the failure state
|
|
|
|
|
|
if (state === FAIL_STATE) {
|
|
state = INITIAL_STATE;
|
|
}
|
|
} // yield the last match if any
|
|
|
|
|
|
if (startRun != null && lastAccepting != null && lastAccepting >= startRun) {
|
|
yield [startRun, lastAccepting, self.tags[state]];
|
|
}
|
|
}
|
|
|
|
};
|
|
}
|
|
/**
|
|
* For each match over the input sequence, action functions matching
|
|
* the tag definitions in the input pattern are called with the startIndex,
|
|
* endIndex, and sub-match sequence.
|
|
*/
|
|
|
|
|
|
apply(str, actions) {
|
|
for (var [start, end, tags] of this.match(str)) {
|
|
for (var tag of tags) {
|
|
if (typeof actions[tag] === 'function') {
|
|
actions[tag](start, end, str.slice(start, end + 1));
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
module.exports = StateMachine;
|
|
//# sourceMappingURL=index.js.map
|