Skip to content
Snippets Groups Projects
  1. Sep 01, 2023
    • Rob Swindell's avatar
      Don't use scope argument value to js.exec() if it's null · 82d1ed4f
      Rob Swindell authored
      Fixes issue #611
      82d1ed4f
    • Rob Swindell's avatar
      node utility can now display one/some/all key/values from node*/client.ini · 5531de7b
      Rob Swindell authored
      <nelgin> Remind me why you can't show the ip address on node status? :)
      
      Using the new '-v[key]' option, a sysop can view one, some, or all of the
      key/value pairs from the nodes with a connected client. For nodes without
      a connected client, the client.ini file values aren't particularly useful, but
      if someone wants an option to show those values for non-client-connected nodes
      I can do that too.
      
      When using '-v', all the client.ini key/value pairs will be displayed for all
      the node records requested with currently connected clients. By specifying
      '-v[key]' the sysop can specify a key to display (rather than all of them)
      e.g. 'node list -vaddr' to list nodes with remote client IP addresses.
      This option can be used multiple times on the command-line to view multiple
      keys. See node*/client.ini for the list of supported keys.
      
      This feature only works for nodes whose directory paths are ../node#/
      relative to the ctrl directory. Since the node utility doesn't read any
      configuration files, this is a limitation. If you have different node
      directory names/parents and need to use this feature, let me know and I'll
      see about adding support for reading/parsing main.ini file to discover those
      non-standard/default node directory paths automatically.
      
      The version number displayed is now taken from the sbbs version (sbbsdefs.h).
      The maximum ctrl directory path is now extended from 40 chars to MAX_PATH.
      More readable help/usage output (using indentation).
      5531de7b
  2. Aug 31, 2023
    • Rob Swindell's avatar
      Remove MQTT message publishing from mqtt_connect_callback() · b4aaddb8
      Rob Swindell authored
      A follow-up to commit 81d4575e
      
      Although I was not able to successfully reproduce the problem that Ree
      reported with his commit (even when changing the SCFG->Networks->MQTT->Publish
      QOS to 1: At least once) on Windows, I do see how this problem could
      theoretically happen. And like Ree said in the follow-up comment on the MR
      "maybe these two lines should have stayed in mqtt_startup", they don't really
      belong in the connection callback.
      
      The "client" topics only needs to be cleared upon startup or recycle (by
      publishing a null message) and it would be bad to clear these topics whenever
      the broker was reconnected (the server's clients didn't magically disconnect).
      So these "client" topic-clearing publishes are now only done during startup
      (again).
      
      The "recycle" topics don't really need to be published to here at all. I
      think I only did this for cases where someone published a non-null message to
      the topic and its stale message would remain afterward, appearing in MQTT
      browsers (like MQTT explorer) long after the server had recycled. The real
      solution to this cosmetic issue is to only publish null (0-length) messages to
      the "recycle" topics in the first place.
      b4aaddb8
    • Rob Swindell's avatar
      Fix "Error writing /path/to/sbbs.ini" when using '-f' option. · 4147775c
      Rob Swindell authored
      Wasn't opening the sbbs.ini file for modify access.
      
      As reported via DOVE-Net by Accession (PHARCYDE)
      4147775c
  3. Aug 20, 2023
  4. Aug 17, 2023
  5. Aug 11, 2023
  6. Aug 10, 2023
  7. Aug 09, 2023
    • Rob Swindell's avatar
      Code indentation change only. · 2a85e911
      Rob Swindell authored
      2a85e911
    • Rob Swindell's avatar
      Insure the exec_dir is *always* prepped (fix for Windows upgrade to v3.20) · e5753faf
      Rob Swindell authored
      A "prepped" means directory means a relative path from the configuration files
      (or default settings) has been converted to a full/absolute path with proper
      slashes for the platform (i.e. backslashes instead of forward-slashes on
      Windows).
      
      JSexec doesn't require that the new v3.20 ctrl/*.ini files exist to run; this
      was necessary to be able to run 'jsexec update -> upgrade_to_v320.js' which
      does the ctrl/*.cnf to .ini file conversion (egg not required to build
      chicken). When JSexec failed to load ctrl/msgs.ini
      (e.g. "!ERROR loading configuration files: 2 (No such file or directory)
      opening /sbbs/ctrl\msgs.ini"), it would continue to run, but not "prep" any
      of the "path" settings (e.g. exec_dir).
      
      The first run of 'jsexec update.js' would fail to run upgrade_to_v320.exe
      (which does the v3.20 user base conversion) and a bunch of other (but not as
      important) update steps because Windows couldn't execute "../exec/*".
      
      Multiple errors would be displayed in this case, but the most important (as
      reported by Ree in #synchronet of irc.synchro.net) was:
        '..' is not recognized as an internal or external command
      
      right after the status output:
        No v3.20 user base found, running ../exec/upgrade_to_v320
      
      Notice the "../exec/" prefix, which is not support by Windows when specifying
      a file path to execute.
      
      A second run of 'jsexec update' would work fine because the new v3.20 .ini
      files would be successfully created after the first run (though the user base
      was not).
      
      This is likely the same issue that MRO reported recently when upgrading a
      Windows SBBS v3.19 install to v3.20 and not having the user base upgraded
      the first time.
      e5753faf
  8. Aug 04, 2023
    • Rob Swindell's avatar
      Don't leave socket open when dial() reports "NO CARRIER" · 948136d1
      Rob Swindell authored
      As reported by Deon on DOVE-net, when the call to socket_recvdone() returns
      true (socket is disconnected and all data has been recv()ed), dial() would
      report "NO CARRIER" but leave the open socket opened, thus preventing any
      subsequent dial attempt ("Can't dial: Already connected" and "ERROR").
      
      Also removed the source file path/name from the debug print statements - don't
      need that noise.
      
      Incremented the version to 0.4
      948136d1
  9. Aug 03, 2023
  10. Jul 30, 2023
  11. Jul 29, 2023
  12. Jul 25, 2023
  13. Jul 21, 2023
  14. Jul 20, 2023
    • Rob Swindell's avatar
      Always delete the AREASxxxxxx temp file · 722cd31c
      Rob Swindell authored
      When there are no changes (areas added or removed) via an areafix message, the
      data/AREASxxxxxx temp file would be left behind. The file was only removed if
      areas were added or removed from the area file via areafix message.
      
      The orphaned data/AREASxxxxxxx files were reported via DOVE-Net by Gamgee (PALANTIR)
      If you have these stale files, you can safely delete them.
      722cd31c
  15. Jul 15, 2023
  16. Jul 10, 2023
  17. Jul 09, 2023
  18. Jul 08, 2023
  19. Jul 04, 2023
Loading