• Recent
  • Tags
  • Unsolved
  • Solved
  • MagicMirror² Repository
  • Documentation
  • 3rd-Party-Modules
  • Donate
  • Discord
  • Register
  • Login
MagicMirror Forum
  • Recent
  • Tags
  • Unsolved
  • Solved
  • MagicMirror² Repository
  • Documentation
  • 3rd-Party-Modules
  • Donate
  • Discord
  • Register
  • Login
A New Chapter for MagicMirror: The Community Takes the Lead
Read the statement by Michael Teeuw here.

MMM-FRITZ-Box-Callmonitor-py3 and MMM-Callmonitor-Current-Call

Scheduled Pinned Locked Moved Utilities
47 Posts 3 Posters 7.1k Views 4 Watching
Loading More Posts
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • X Offline
    xIExodusIx @rkorell
    last edited by Mar 8, 2025, 8:27 PM

    @rkorell

    Hi Ralf,
    I’m glad to read this, I thoght it could only work for me.

    I will try to do what you said and edit the READ.ME file to put my changes in to it. I’m sadly could not code, what I did was only compare the different versions and merge the differences in a, for me, logical way together, and surprisingly, it worked.

    I personally own a FritzBox 7590AX that distinguishes between 4 types of calls, “incomming, outgoing, missed and blocked”. I would like to have the “blocked” calls also been handled and showed up in the module “MMM-FRITZ-Box-Callmonitor-py3” but I don’t know how to do this. I want these blocked calls handled by the module, because I have a large blocklist of callers that I don’t want to get in touch with. They try to cheat me for mony or peronal data. I got up to 15 calls a day of these unwanted calls.

    Do you have any Ideas?

    Regards
    Carsten

    R 1 Reply Last reply Mar 9, 2025, 6:54 PM Reply Quote 0
    • R Offline
      rkorell @xIExodusIx
      last edited by rkorell Mar 9, 2025, 6:56 PM Mar 9, 2025, 6:54 PM

      @xIExodusIx Dear Carsten,

      I’m not that good in object-oriented programming…
      The main problem for me in this module is the three-layer approach - so I’m not sure what happens when and where.
      In addition I’m not familiar with the used libraries…

      From my understanding the base layer “fritz_access.py” should handle your request.
      In this python program you can find the class FritzAccess which handles the queries to AVM Fritzbox.
      One of the calls used is “GetCallList” - in the second definition of the object:

          def download_recent_calls(self, directory = "data"):
              result = self.fc.call_action("X_AVM-DE_OnTel", "GetCallList")
              filename = os.path.join(directory, "calls.xml")
              self.forward_file(result["NewCallListURL"], filename)
      

      I can imagine (I don’t know!) that there is another call-function “GetBlockedCallList” or something similar.

      This has to be clarified.
      If such a call exists, you need an entry in the FritzAccess class for this and than a function which takes care about.

      In the second layer “node-helper.js” line 13ff

      const CALL_TYPE = Object.freeze({
      	INCOMING: "1",
      	MISSED: "2",
      	OUTGOING: "3"
      })
      

      Must be extended for fourth call_type - “BLOCKED”
      and the function setupMonitor() (line 73ff) must get an additional "monitor.on(“blocked” … "

      In the third layer (“MMM-FRITZ-Box-Callmonitor-py3.js”) you have to adopt the “socketNotificationReceived:” function (line 90ff) and handle the “BLOCKED” condition.

      This all from my very basic understanding, how theses modules are impelmented in general.

      Unfortunately my knowledge is currently not deep enough to be more concrete, sorry for this!

      May another user can step in here.
      Because you at least was able to reconfigure code out of three different repositories - may these little hints are enough for you…

      Warmest regards and good luck!
      Ralf

      X 1 Reply Last reply Mar 10, 2025, 11:13 AM Reply Quote 0
      • X Offline
        xIExodusIx @rkorell
        last edited by Mar 10, 2025, 11:13 AM

        @rkorell
        Hi Ralf,

        I did not touch the file “fritz_access.py” by now, but what I already did was edeting the files “MMM-FRITZ-Box-Callmonitor-py3.js” and “node-helper.js”.
        In the file “node-helper.js” I already added:
        const CALL_TYPE = Object.freeze({
        INCOMING: “1”,
        MISSED: “2”,
        OUTGOING: “3”,
        BLOCKED: “4”
        })
        and tried this (now comented out because it did not work):
        //Call blocked
        //monitor.on(“blocked”, function (call) {
        // var name = self.ownNumbers.includes(call.caller) ? self.getName(call.called) : self.getName(call.caller);
        // var direction = self.ownNumbers.includes(call.caller) ? “out” : “in”;
        // self.sendSocketNotification(“blocked”, { “caller”: name, “direction”: direction });
        //});
        and this (also now comented out):
        for (var index in callArray) {
        var call = callArray[index];
        var type = call.Type[0];
        //Try to handle blocked calls this is new from “if to else” delete all lines from “if to else” if it not works!
        //if var name = type == CALL_TYPE.BLOCKED || type == CALL_TYPE.INCOMING ? self.getName(call.Caller[0]) : self.getName(call.Called[0]);
        // var duration = call.Duration[0];
        // if (type == CALL_TYPE.INCOMING && self.config.deviceFilter && self.config.deviceFilter.indexOf(call.Device[0]) > -1) {
        // continue;
        //} else
        //From here the original script is ongoing
        var name = type == CALL_TYPE.MISSED || type == CALL_TYPE.INCOMING ? self.getName(call.Caller[0]) : self.getName(call.Called[0]);
        var duration = call.Duration[0];
        if (type == CALL_TYPE.INCOMING && self.config.deviceFilter && self.config.deviceFilter.indexOf(call.Device[0]) > -1) {
        continue;
        }
        In the file “MMM-FRITZ-Box-Callmonitor-py3” I did already this:
        const CALL_TYPE = Object.freeze({
        INCOMING: “1”,
        MISSED: “2”,
        OUTGOING: “3”,
        BLOCKED: “4” //New entry! to handle blocked calls
        })
        and tried this:
        //Handle blocked calls
        //if (notification === “blocked”) {
        //Send notification for currentCall module
        // this.sendNotification(“CALL_BLOCKED”, payload.caller);
        //Remove alert from UI when call is connected
        // this.sendNotification(“HIDE_ALERT”);
        // this.activeAlert = null;
        //}
        But that all does not work so I comented it out again.
        Thats my problem I can’t code and I dont really understand what I’m doing, all I can do is “Try and Error”!

        But thanks a lot for your help. :-)

        Carsten

        R 1 Reply Last reply Mar 10, 2025, 2:00 PM Reply Quote 0
        • R Offline
          rkorell @xIExodusIx
          last edited by rkorell Mar 10, 2025, 2:00 PM Mar 10, 2025, 2:00 PM

          @xIExodusIx Yeahh…
          You figured out the exact same idea and made more out of this than I’m able to do.
          But for sure you have to start at the python script - the python script “feeds” node-helper.
          And if node-helper don’t get info about “blocked” - your If-clause is never true so your new code couldn’t be reached.
          And for setting the python script correctly you have to identify how the AVM/Fritz interface works…

          Regards,
          Ralf

          X 1 Reply Last reply Mar 10, 2025, 3:17 PM Reply Quote 0
          • X Offline
            xIExodusIx @rkorell
            last edited by Mar 10, 2025, 3:17 PM

            @rkorell

            I have almost 2 hours googled for the right name of the function for the blocked calls, but did not find anythig about that.
            And I found some smaller errors in the funktion of the module. E.g. it should delete the alert (the big popup on the gui of the MM when a call comes in) when I answer this call. But that does not work.
            This should do the job in the "MMM-FRITZ-Box-Callmonitor-py3:
            if (notification === “connected”) {
            //Send notification for currentCall module
            this.sendNotification(“CALL_CONNECTED”, payload);

            		//Remove alert only on connect if it is the current alert shown
            		if (this.activeAlert === payload) {
            			//Remove alert from UI when call is connected
            			this.sendNotification("HIDE_ALERT");
            			this.activeAlert = null;
            		}
            	}
            

            but it dosn’t work.

            As I already said: I can’t code :-(

            Regards,
            Carsten

            R 1 Reply Last reply Mar 10, 2025, 4:41 PM Reply Quote 0
            • R Offline
              rkorell @xIExodusIx
              last edited by Mar 10, 2025, 4:41 PM

              @xIExodusIx Yes, I identified this “bug” as well and couldn’t find the mistake…
              As I mentioned - I couldn’t code (this) as well …

              Regards,
              Ralf

              X 1 Reply Last reply Mar 10, 2025, 8:24 PM Reply Quote 0
              • X Offline
                xIExodusIx @rkorell
                last edited by Mar 10, 2025, 8:24 PM

                @rkorell

                I think it is something with the syntax, maybe it has changed somehow in python3, or a wrong set “,” or “;” so the modulescript could not run correct, but it is enough to let the module almost run as expected.
                For that I have not enough experience to figure that out.

                Would be nice if there were the possebility of a testing enviroment for MS-Windows, so that I could test the scripts. For editing I could use VS-Code.

                R 1 Reply Last reply Mar 11, 2025, 12:34 PM Reply Quote 0
                • R Offline
                  rkorell @xIExodusIx
                  last edited by Mar 11, 2025, 12:34 PM

                  @xIExodusIx said in MMM-FRITZ-Box-Callmonitor-py3 and MMM-Callmonitor-Current-Call:

                  testing enviroment for MS-Windows,

                  For Python you can use this …

                  Regards,
                  Ralf

                  X 1 Reply Last reply Mar 12, 2025, 2:19 PM Reply Quote 0
                  • X Offline
                    xIExodusIx @rkorell
                    last edited by Mar 12, 2025, 2:19 PM

                    @rkorell

                    Hi Ralf,
                    I found out that the correct entry for handle “blocked calls” is “10”, not “4”, I found that on “https://fritzconnection.readthedocs.io/en/1.14.0/sources/library_modules.html”
                    Slowly I understand how the module works and what the entire entries do, but without understandig the syntax and how to code. I will not come further.

                    Regards
                    Carsten

                    R 1 Reply Last reply Mar 14, 2025, 9:05 AM Reply Quote 1
                    • R Offline
                      rkorell @xIExodusIx
                      last edited by Mar 14, 2025, 9:05 AM

                      @xIExodusIx
                      Dear Carsten,

                      quick question: For several reasons yesterday I had checked the log files during startup of my MagicMirror.

                      Unfortunately there is an error related to your pimped module:

                      [ERROR] ERROR! Could not find main module js file for MMM-FRITZ-Box-Callmonitor-py3_drtorchwood
                      

                      The module works (!?) but may there is something that don’t work?

                      Is there a submodule which is not loaded to git?

                      Thanks for any hint!

                      X 1 Reply Last reply Mar 14, 2025, 1:07 PM Reply Quote 0
                      • 1
                      • 2
                      • 3
                      • 4
                      • 5
                      • 3 / 5
                      3 / 5
                      • First post
                        29/47
                        Last post
                      Enjoying MagicMirror? Please consider a donation!
                      MagicMirror created by Michael Teeuw.
                      Forum managed by Sam, technical setup by Karsten.
                      This forum is using NodeBB as its core | Contributors
                      Contact | Privacy Policy