From b1228a681e74db2c56d97e5489fa01c4f649ade4 Mon Sep 17 00:00:00 2001
From: James Meyer <james.meyer@operamail.com>
Date: Thu, 20 Dec 2012 11:54:57 -0600
Subject: LinHES-system: add be_check.py and modify LinHES-session to use it.
 This will stop mythfrontend/mythwelcome from starting if be_check can't
 connect to the master backend. Mostly this was done to stop mythfronted from
 complaining about not being able to contact the MBE and in the worst case
 displaying  the DB connection configuration screen.

refs #886
---
 abs/core/LinHES-system/LinHES-session | 15 +++++++++++++--
 abs/core/LinHES-system/PKGBUILD       | 10 ++++++----
 abs/core/LinHES-system/be_check.py    | 29 +++++++++++++++++++++++++++++
 abs/core/LinHES-system/myth_status.py |  2 +-
 4 files changed, 49 insertions(+), 7 deletions(-)
 create mode 100644 abs/core/LinHES-system/be_check.py

diff --git a/abs/core/LinHES-system/LinHES-session b/abs/core/LinHES-system/LinHES-session
index a5632fd..d55b900 100755
--- a/abs/core/LinHES-system/LinHES-session
+++ b/abs/core/LinHES-system/LinHES-session
@@ -317,10 +317,21 @@ function start_myth() {
 
     echo "====================================================================="
     echo "Starting $STARTCMD"
-    #firstboot.sh &
+    if [ "x$bewait" = "x1" ]
+    then
+        #do init check
+        /usr/LH/bin/be_check.py
+        rc=$?
+        while [ $rc -ne 0 ]
+        do
+            msg "Waiting for connection to MythBackend"
+            /usr/LH/bin/be_check.py
+            rc=$?
+            sleep 6
+        done
+    fi
 
     #continue on with starting mythtv
-
     if [ x$STARTUP_STYLE = xenhanced ]
     then
         start_myth_mv
diff --git a/abs/core/LinHES-system/PKGBUILD b/abs/core/LinHES-system/PKGBUILD
index 61ea2f2..e4e26d4 100755
--- a/abs/core/LinHES-system/PKGBUILD
+++ b/abs/core/LinHES-system/PKGBUILD
@@ -1,6 +1,6 @@
 pkgname=LinHES-system
 pkgver=2
-pkgrel=129
+pkgrel=131
 arch=('i686' 'x86_64')
 MVDIR=$startdir/pkg/usr/LH
 BINDIR=$startdir/pkg/usr/bin
@@ -30,7 +30,8 @@ binfiles="LinHES-start optimize_mythdb.py
  misc_status_info.sh
  misc_upcoming_recordings.pl
  misc_which_recorder.pl
- change_channel.sh change_channel_wrapper.sh"
+ change_channel.sh change_channel_wrapper.sh
+ be_check.py"
 
 source=(LinHES-session
     LinHES-profile.sh $binfiles
@@ -79,7 +80,7 @@ build() {
 
 
 }
-md5sums=('d35912d6b6b267bc6616205fa4776833'
+md5sums=('d275db0a946087671e0c2014dac9ed22'
          '5881bdb43d578ec3a79d1f77ea58a3db'
          'a875ee97f86e46f34a741c2bc455f894'
          '76b2637cac0452b3acdbeeb4e8a5474b'
@@ -91,7 +92,7 @@ md5sums=('d35912d6b6b267bc6616205fa4776833'
          '542e670e78d117657f93141e9689f54d'
          '41951459ea9d2b0567be521b67e6285a'
          '659c0a55b0b375c48fcd751252dd2102'
-         '309638acf596ce3c790aa2bf5c7c9880'
+         '692563448cca1d49f45e7d1c8abcaa0c'
          '962a3e9eaba2d1466251b7ab0956705d'
          '1758aed160de64abfafb28a3a8f3390e'
          '2200f08381370f6ae553e13a9f376377'
@@ -117,6 +118,7 @@ md5sums=('d35912d6b6b267bc6616205fa4776833'
          '116b0f62ed4e8dd6e437930deeb6e49e'
          '17f678d37187be0f12d67f64e40429c6'
          'bacc813b48bafcc6fe906e5969930501'
+         'd6d11865317d13f3e2a313980108736b'
          'eb879fee9603a05d5420d4ce8ed9e450'
          '6782771960c495aeb597893f37d1e5ee'
          '84492954db16740f949d795b74383189'
diff --git a/abs/core/LinHES-system/be_check.py b/abs/core/LinHES-system/be_check.py
new file mode 100644
index 0000000..91c39dc
--- /dev/null
+++ b/abs/core/LinHES-system/be_check.py
@@ -0,0 +1,29 @@
+#!/usr/bin/python2
+#simple program to check if mythbackend is up and running
+#exit code of 0 is success, anything else means it can't connect
+import sys
+class Logger(object):
+    def __init__(self, filename="/tmp/Default.log"):
+        #self.terminal = sys.stdout
+        self.log = open(filename, "a")
+
+    def write(self, message):
+        #self.terminal.write(message)
+        self.log.write(message)
+
+sys.stdout = Logger("/tmp/be_check.log")
+
+
+from MythTV import MythBE,MythDB
+#import datetime,time,sys,subprocess
+
+
+
+
+
+try:
+    be=MythBE()
+    db = MythDB()
+except:
+    sys.exit(1)
+sys.exit(0)
\ No newline at end of file
diff --git a/abs/core/LinHES-system/myth_status.py b/abs/core/LinHES-system/myth_status.py
index da43679..2e48024 100644
--- a/abs/core/LinHES-system/myth_status.py
+++ b/abs/core/LinHES-system/myth_status.py
@@ -5,7 +5,7 @@ try:
     be=MythBE()
     db = MythDB()
 except:
-    print "Couldn't connect to MythTV service for status"
+    print "\nCouldn't connect to MythTV service for status"
     sys.exit(1)
 
 cursor = db.cursor()
-- 
cgit v0.12