Page 1 of 1

ZoneMinder API NodeJS Project Help?

Posted: Tue Oct 15, 2019 7:39 pm
by trillobite
Hopefully there is a javaScript developer out there to help out, but I have been attempting to toggle my cameras "mode" between Modect and Mocord.

This project is running in NodeJS, I have successfully been able to change the camera's mode while using postman, however when I try to make the same POST request in NodeJS the new mode doesn't set. I am using "request" to simplify the request. Documentation on that is here: https://github.com/request/request#forms

Here's some code:

Code: Select all

            request.post({
                url: `${zmRoot}/monitors/${camera}.json`, 
                form: {
                    Monitor: {
                        Function: mode, //This holds a string value of either "Modect" or "Mocord."
                    }
                }
            }, (err, httpResponse, body) => {
                if (err) {
                    reject(err);
                } else {
                    resolve(JSON.parse(body));
                }
            });
Here's the response from zoneminder:

Code: Select all

{ message: 'Saved' }
However, whenever I check zoneminder's console, I do not see that any of the modes have changed on any of the cameras.

Re: ZoneMinder API NodeJS Project Help?

Posted: Tue Oct 15, 2019 7:44 pm
by trillobite
Here is the full project source, pushing my latest copy right now...
https://github.com/trillobite/zmScheduler

Re: ZoneMinder API NodeJS Project Help?

Posted: Wed Oct 16, 2019 1:53 am
by trillobite
I actually figured out the issue...
Zoneminder counts it's cameras starting with 1,
Node/JavaScript counts it's cameras starting with 0.

My index was off by -1 and it was setting the incorrect camera.

If anyone likes this project let me know, and I may continue to make updates on the side.

Re: ZoneMinder API NodeJS Project Help?

Posted: Thu Oct 17, 2019 8:39 pm
by iconnor
Let's be clear, we don't start the Id's at 1. mysql starts any sequence at 1. There can also be gaps.

Isaac