Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Contribute to GitLab
Sign in
Toggle navigation
D
domotikad
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
Wiki
Wiki
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Commits
Issue Boards
Open sidebar
domotika
domotikad
Commits
2e6f0f46
Commit
2e6f0f46
authored
May 12, 2014
by
nextime
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Fix duplicated outputs in autodetection
parent
b15f9da5
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
7 additions
and
24 deletions
+7
-24
dmdb.py
domotika/db/dmdb.py
+1
-0
domotika.py
domotika/domotika.py
+6
-24
No files found.
domotika/db/dmdb.py
View file @
2e6f0f46
...
@@ -503,6 +503,7 @@ def resetDynAnalogs():
...
@@ -503,6 +503,7 @@ def resetDynAnalogs():
return
Registry
.
getConfig
()
.
delete
(
"analog"
,
where
=
[
"dynamic=1"
])
return
Registry
.
getConfig
()
.
delete
(
"analog"
,
where
=
[
"dynamic=1"
])
def
resetDynRelays
():
def
resetDynRelays
():
log
.
debug
(
'RESET DYN RELAYS'
)
return
Registry
.
getConfig
()
.
delete
(
"relay"
,
where
=
[
"dynamic=1"
])
return
Registry
.
getConfig
()
.
delete
(
"relay"
,
where
=
[
"dynamic=1"
])
def
resetDynInputs
():
def
resetDynInputs
():
...
...
domotika/domotika.py
View file @
2e6f0f46
...
@@ -642,27 +642,6 @@ class domotikaService(service.Service):
...
@@ -642,27 +642,6 @@ class domotikaService(service.Service):
self
.
sendCommand
(
"BOARDTYPE"
,
arg
=
ALLIP
,
act
=
C
.
IKAP_ACT_BOARD
,
ctx
=
C
.
IKAP_CTX_SYSTEM
,
msgtype
=
C
.
IKAP_MSG_REQUESTCONF
)
self
.
sendCommand
(
"BOARDTYPE"
,
arg
=
ALLIP
,
act
=
C
.
IKAP_ACT_BOARD
,
ctx
=
C
.
IKAP_CTX_SYSTEM
,
msgtype
=
C
.
IKAP_MSG_REQUESTCONF
)
self
.
timeconfstatus
=
reactor
.
callLater
(
15
,
self
.
endConfStatus
)
self
.
timeconfstatus
=
reactor
.
callLater
(
15
,
self
.
endConfStatus
)
def
checkDoubleRelDevice
(
self
,
dres
,
domain
):
dmdb
.
Relay
.
find
(
where
=
[
"domain=? AND active=1 AND outnum!=0"
,
domain
],
orderby
=
"board_ip,outnum"
)
.
addCallback
(
self
.
createDevice
,
domain
,
dres
,
'relay'
)
def
checkDoubleInpDevice
(
self
,
dres
,
domain
):
dmdb
.
Input
.
find
(
where
=
[
"inpname=? AND active=1 AND inpnum!=0"
,
domain
],
orderby
=
"board_ip,inpnum"
)
.
addCallback
(
self
.
createDevice
,
domain
,
dres
,
'input'
)
def
checkDoubleAnaDevice
(
self
,
dres
,
domain
):
dmdb
.
Analog
.
find
(
where
=
[
"ananame=? AND active=1 AND ananum!=0"
,
domain
],
orderby
=
"board_ip,ananum"
)
.
addCallback
(
self
.
createDevice
,
domain
,
dres
,
'analog'
)
def
retriveDeviceInputs
(
self
):
log
.
debug
(
"retriveDeviceInputs"
)
dmdb
.
runQuery
(
"SELECT DISTINCT(inpname) FROM input WHERE active=1 AND inpnum!=0"
)
.
addCallback
(
self
.
idomainRetrivied
)
def
retriveDeviceAnalogs
(
self
):
log
.
debug
(
"retriveDeviceAnalogs"
)
dmdb
.
runQuery
(
"SELECT DISTINCT(ananame) FROM analog WHERE active=1 AND ananum!=0"
)
.
addCallback
(
self
.
adomainRetrivied
)
def
startDevicePopulation
(
self
,
r
):
dmdb
.
runQuery
(
"SELECT DISTINCT(domain) FROM relay WHERE active=1 AND outnum!=0"
)
.
addCallback
(
self
.
odomainRetrivied
)
def
endConfStatus
(
self
):
def
endConfStatus
(
self
):
log
.
info
(
"finished building boardlist"
)
log
.
info
(
"finished building boardlist"
)
self
.
updateDaemonStatus
(
'normal'
)
self
.
updateDaemonStatus
(
'normal'
)
...
@@ -761,10 +740,10 @@ class domotikaService(service.Service):
...
@@ -761,10 +740,10 @@ class domotikaService(service.Service):
if
bplugin
.
hasOutputs
:
if
bplugin
.
hasOutputs
:
for
o
in
bplugin
.
getOutputsConfs
()
.
values
():
for
o
in
bplugin
.
getOutputsConfs
()
.
values
():
# OUTPUT NOTE: is based on output not on relay! an output can have more than 1 relay...
# OUTPUT NOTE: is based on output not on relay! an output can have more than 1 relay...
dmdb
.
Relay
.
find
(
where
=
[
"""outnum=? AND board_name=? """
,
i
,
name
])
.
addCallback
(
self
.
insertRelay
,
dmdb
.
Relay
.
find
(
where
=
[
"""outnum=? AND board_name=? """
,
o
.
num
,
name
])
.
addCallback
(
self
.
insertRelay
,
o
,
name
,
fwver
o
,
name
,
fwver
)
)
dmdb
.
Output
.
find
(
where
=
[
"""outnum=? AND board_name=? """
,
i
,
name
])
.
addCallback
(
self
.
insertOutput
,
dmdb
.
Output
.
find
(
where
=
[
"""outnum=? AND board_name=? """
,
o
.
num
,
name
])
.
addCallback
(
self
.
insertOutput
,
o
,
name
,
fwver
o
,
name
,
fwver
)
)
bplugin
.
syncOutputs
()
bplugin
.
syncOutputs
()
...
@@ -777,7 +756,10 @@ class domotikaService(service.Service):
...
@@ -777,7 +756,10 @@ class domotikaService(service.Service):
if
res
:
if
res
:
log
.
debug
(
"OUTPUT
%
s exists (
%
s,
%
s)"
%
(
out
.
dname
,
name
,
out
.
host
))
log
.
debug
(
"OUTPUT
%
s exists (
%
s,
%
s)"
%
(
out
.
dname
,
name
,
out
.
host
))
for
c
in
res
:
for
c
in
res
:
if
c
.
outtype
!=
int
(
out
.
otype
):
if
i
>
0
:
log
.
debug
(
"CANNOT EXIST MORE THAN ONE OUTPUT NUM PER BOARD"
)
c
.
delete
()
elif
c
.
outtype
!=
int
(
out
.
otype
)
and
i
==
0
:
log
.
debug
(
"OUTPUT type changed. Delete old entries"
)
log
.
debug
(
"OUTPUT type changed. Delete old entries"
)
c
.
delete
()
c
.
delete
()
del
res
[
i
]
del
res
[
i
]
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment