Commit graph

187 commits

Author SHA1 Message Date
baldo dabc675aa9 New api endpoint for client config. 2022-07-07 11:08:35 +02:00
baldo 7ef13bc28c Extracted some types to shared module. 2022-07-07 11:08:15 +02:00
baldo 002ae4419f Implement custom logger to replace scribe.js.
* scribe.js is unmaintained and adds unnecessary complexity.
2022-02-09 18:02:59 +01:00
baldo 5edeea4573 Lots of package updates. 2021-10-14 17:18:30 +02:00
baldo 12a13f47bf Allow to completely disable logging. 2021-08-23 21:05:17 +02:00
baldo e2766e8402 Fix logging. 2021-08-09 22:03:27 +02:00
baldo 3a253ba72e Fix: Use seconds for unix timestamps to not compare seconds and milliseconds. 2021-08-09 21:54:13 +02:00
baldo 8cc9ee0908 Added logging when deleting nodes that were never online. 2021-08-09 21:36:41 +02:00
baldo f96113c1c5 [UNTESTED]: Also delete offline nodes that were never online. 2021-07-26 21:40:54 +02:00
baldo ada5d99128 Fix: Typo in field assignment. 2021-02-22 22:35:40 +01:00
baldo 93069806f6 Fix: Parsing node files did not prefill missing fields correctly.
* This lead to a HTTP 500 on dashboard as some nodes were missing
monitoring fields.
* Removed a problematic cast and added sane defaults.
2021-02-22 22:26:19 +01:00
baldo 9ad9ffabf7 Fix: Background-Jobs did not run automatically.
* Had to make sure `this` referred to `task` in `task.run()`.
2021-02-22 21:48:39 +01:00
baldo cc44bce95a Fix: Some calls returned not only the node but also nodeSecrets.
* Broke REST-calls.
* Also prevents leaking monitoring tokens.
2021-01-25 22:40:41 +01:00
baldo 84ac9bd256 Bump versions of server / dev dependencies. 2020-06-30 18:29:06 +02:00
baldo b6a67d6e74 Admin: Add message with failed / total nodes for nodes.json-task. 2020-06-30 17:08:24 +02:00
baldo fb87695b3e Migrate to version 2 of nodes.json and start adding tests 2020-06-30 13:47:30 +02:00
baldo 52822207a5 Typescript migration: Major refactoring. 2020-04-15 20:12:58 +02:00
baldo 31ecc0cf4f Typescript migration:
* resources/frontendResource.js
* resources/taskResource.js
* resources/versionResource.js

Also some refactoring towards using promises with async / await.
2020-04-09 20:18:13 +02:00
baldo b1755047af Typescript migration:
* utils/resources.js
* validation/constraints.js (only server side)
2020-04-09 01:41:45 +02:00
baldo 8b8835e4ac Typescript migration:
* Refactoring of scheduler and jobs to use promises.
* Add "failed" state for tasks.
2020-04-08 23:41:04 +02:00
baldo 5c0b5abf73 Typescript migration:
* validation/validator.js
2020-04-08 22:45:21 +02:00
baldo 9e29eb924e Typescript migration
* db/database.js
* utils/databaseUtil.js
2020-04-08 22:05:53 +02:00
baldo 7325cd4db6 Typescript migration
* utils/strings.js
* utils/urlBuilder.js
2020-04-08 21:25:33 +02:00
baldo 08249885a8 Typescript migration
* config.js
* Added typesafe validation of config.json.
2020-04-08 17:55:45 +02:00
baldo 9652519267 Typescript migration
* app.js
* main.js
* router.js
2020-04-08 03:19:55 +02:00
baldo 94d01310b9 Quick and dirty typescript setup to get going. 2020-04-08 01:55:48 +02:00
baldo 2e27e63f94 Fix: Start using sqlite module that actually uses promises.
For now export legacy sqlite3 module until other code is refactored.
2019-03-29 22:26:54 +01:00
baldo 8697d79ba5 Removing ng-di on the server. 2018-12-18 00:29:20 +01:00
baldo ddb2f47a9d Promisify and asyncify db initialization. 2018-12-17 22:08:38 +01:00
baldo 84b20b209e Splitting site field: Now we track site and domain. 2018-12-17 20:06:39 +01:00
baldo d23024241c Added links for imprint and privacy information. 2018-05-21 13:22:28 +02:00
baldo 8513ff0f3d Fix: During import skip nodes which cannot be parsed. 2018-01-05 20:34:57 +01:00
baldo 0dd170d755 Fix: Give unix timestamp to db when marking missing nodes as offline. 2017-08-13 19:39:40 +02:00
baldo 7d413a6f76 Added logging. 2017-08-13 19:36:16 +02:00
baldo 950daf6939 Simplify and improve marking missing nodes as offline. 2017-08-13 19:30:30 +02:00
baldo 8628bee9e9 Fix: Typo. 2017-08-13 19:29:50 +02:00
baldo 2b22926b2f Fix: Setting site for missing node was bogus. 2017-08-13 19:29:36 +02:00
baldo 2cb804f4b3 Fix for deletion job: Don't try to delete key files for gateways. 2017-08-13 18:55:56 +02:00
baldo 82a69769c3 If site is currently unknown keep previous site on update. 2017-08-13 18:37:58 +02:00
baldo 683937539b Allow to filter and sort by site. 2017-08-13 18:18:40 +02:00
baldo 7dd8d35139 Fix: Wrong object to store site from. 2017-08-13 17:47:37 +02:00
baldo 9774aa7e4f Fix: Site info wasn't stored correctly. 2017-08-13 17:44:12 +02:00
baldo 88dab5743f Add field "site" in admin panel. 2017-08-13 17:22:34 +02:00
baldo 05c6cdafb7 Show duration of previous task run in admin panel.
See: https://github.com/freifunkhamburg/ffffng/issues/29
2017-05-13 12:08:16 +02:00
baldo 8ec1b3e845 Add a nice error message if no nodes.json URL is set. 2017-05-13 11:38:51 +02:00
baldo 6214404b64 Fix: Allow proper logging of node.js Error objects.
See: https://github.com/bluejamesbond/Scribe.js/issues/70
2017-05-13 11:38:25 +02:00
baldo 8de06a0a8a Allow serving everything beneath a baseUrl with a path.
See: https://github.com/freifunkhamburg/ffffng/issues/44
2017-05-06 18:40:59 +02:00
baldo 3d6fb5feec Fixed or disabled warnings 2017-05-06 17:31:34 +02:00
baldo 94a51921fd Fix: Remove trailing slash from URLs in config.
Fixes: https://github.com/freifunkhamburg/ffffng/issues/33
2017-05-06 16:58:42 +02:00
baldo 231eec3544 Fix: Avoid duplicates from different nodes.json files. Use only newest. 2017-03-19 16:31:50 +01:00
baldo f12ef87567 Fix: Correct support for multiple nodes.json files. 2017-03-06 20:32:52 +01:00
baldo 5086d8c71f Allow to specify nodes.json-URLs for multiple communities / domains. 2017-03-03 22:02:26 +01:00
baldo 2343e95c94 Hack to ignore URL suffixes wrongly added by mail clients.
Fixes: https://github.com/freifunkhamburg/ffffng/issues/40
2016-10-24 19:54:13 +02:00
Andreas Baldeau 5435f95b86 Fix: Deleting offline node without node file won't fail anymore. 2016-09-09 21:58:50 +02:00
Alexander a9cf109992 Typo fix 2016-08-24 09:08:27 +02:00
Andreas Baldeau 769ca33495 Merge pull request #27 from rubo77/master
Documents the main structure, that sends out emails for offline nodes
2016-08-19 20:33:19 +02:00
Alexander d518f3c2b5 Typo fix 2016-08-15 09:58:15 +02:00
baldo 6aac4af80f Job to automatically delete nodes after 100 days. 2016-07-29 23:09:43 +02:00
baldo d63cf55abf Mark nodes not listed in nodes.json as offline. 2016-07-29 21:49:03 +02:00
baldo 7677aad10a Fix: Dramatic slowdown when running the NodeInformationRetrievalJob 2016-07-29 12:58:03 +02:00
baldo c2cea8626f Fixed indentation 2016-07-29 12:53:36 +02:00
baldo 7921178165 Added support for writing profiling logs.
For now it supports profiling database queries and
job execution time.
2016-07-29 12:53:20 +02:00
baldo bf1740a95d Fix: Limit max parallel node imports. 2016-07-27 22:02:07 +02:00
rubo77 0435df2ef3 Documents the main structure, that sends out emails for offline nodes 2016-07-24 13:49:37 +02:00
baldo cb4c659261 Less verbose logging. 2016-07-23 22:09:13 +02:00
baldo 8660553d0f Filtering of nodes in admin panel. 2016-07-23 11:30:41 +02:00
baldo 3c80be4d00 Added Statistics
See: https://github.com/freifunkhamburg/ffffng/issues/24
2016-07-19 13:24:43 +02:00
baldo 7c09523e53 Config option for tile layers.
See: https://github.com/freifunkhamburg/ffffng/issues/23
2016-07-14 16:28:17 +02:00
baldo eaaf659674 Fix: Update node data even when skipping.
Also prevents infinite loop as the SELECT to loads the batch
checks modified_at.
2016-06-29 12:02:46 +02:00
baldo 121468bec3 Fix: Added missing callback. 2016-06-29 11:40:11 +02:00
baldo 3df5509df0 Fix: Use correct callback to prevent monitoring sending job from hanging. 2016-06-29 11:28:39 +02:00
baldo fa2a047370 Footer for frontend and report errors link. 2016-06-26 22:00:58 +02:00
baldo 124f330895 Version information and extended header for admin panel. 2016-06-26 20:21:45 +02:00
baldo dd48bd9702 Fix: "SQLITE_ERROR: 6 values for 8 columns" when retrieving nodes.json 2016-06-26 19:38:11 +02:00
baldo 392e37ab05 Fix: "SQLITE_ERROR: too many SQL variables" when loading nodes 2016-06-26 19:27:09 +02:00
baldo cd746a41ea Display of online state for nodes and hostname for monitoring info in admin panel. 2016-06-26 19:09:12 +02:00
baldo ecc82e30c1 Fix: Correct total number of monitoring entries in admin panel.
See: https://github.com/freifunkhamburg/ffffng/issues/16
2016-06-26 13:06:58 +02:00
baldo f720c0e028 Less verbose logging on INFO.
See: https://github.com/freifunkhamburg/ffffng/issues/18
2016-06-26 12:58:40 +02:00
baldo 5ac54f2a0d Fixed mis-pasted code. 2016-06-25 20:45:19 +02:00
baldo 71bebb7c27 Fixed fix for sending mails in short time 2016-06-25 20:24:28 +02:00
baldo 0e5c5e4e1e Fix: Display Last Status Mail Sent for monitoring in admin panel correctly.
Naming of column is now also consistent.
2016-06-25 14:33:51 +02:00
baldo 9c7b2558f0 Fix: Don't send monitoring mails too soon after each other.
Fixes: https://github.com/freifunkhamburg/ffffng/issues/17
2016-06-25 14:18:43 +02:00
baldo c08f94abda Fix: Do not list nodes without tokens in admin panel.
See: https://github.com/freifunkhamburg/ffffng/issues/15
2016-06-22 00:06:32 +02:00
baldo b4dc9e37b2 More robust node filename generation.
Do not place "undefined" in parts of filenames even
if node files are missing entries like the token.
2016-06-21 23:47:24 +02:00
baldo 2dc7ad0c23 Fix: More asynchronous glob operations and graceful-fs.
Hope this fixes the "Error: EMFILE, too many open files" in
NodeInformationRetrievalJob.

See: https://github.com/freifunkhamburg/ffffng/issues/13
2016-06-21 22:59:37 +02:00
baldo 23cd31e064 Fix: More asynchronous operations to fix stack overflow. 2016-06-21 18:20:36 +02:00
baldo d24e6e6307 Replaced python script to fix filenames by internal background job. 2016-06-21 15:21:08 +02:00
baldo ce155951bf Show task description in admin panel. 2016-06-21 14:55:02 +02:00
baldo 8dbec7612b Texts and URL fixes 2016-06-20 22:28:01 +02:00
baldo 50e6175021 Made main.js executable. 2016-06-11 19:09:05 +02:00
baldo 2a2a2b72e9 Get config.json location from command line parameter. 2016-06-11 17:15:19 +02:00
baldo 8684c075ef shebang for main.js of server 2016-06-11 16:27:23 +02:00
baldo 4ea37d59cd Overview over monitoring states in admin panel. 2016-06-11 15:31:57 +02:00
baldo eb3e0d96be Mail templates for monitoring mails 2016-06-11 15:13:06 +02:00
baldo c038546ac2 Moved mail template rendering into own service. 2016-06-11 12:32:20 +02:00
baldo 26aaec385a Mail-Queue management in admin panel. 2016-06-11 12:08:50 +02:00
baldo 807f3f5fb2 Fix: No 'undefined' in filename for nodes without monitoring 2016-06-07 14:48:18 +02:00
baldo 03083b819b Open node in form and map. 2016-06-07 14:18:28 +02:00
baldo 5b9d2e615b Filtering for tasks 2016-06-07 12:45:23 +02:00
baldo 122eadc0de Filtering for nodes 2016-06-07 12:39:52 +02:00