Menu

Tree [0305e0] master /
 History

HTTPS access


File Date Author Commit
 congruity 2024-10-03 Alexander Sulfrian Alexander Sulfrian [0305e0] mhgui: Make dialog box resizable
 girr_test_cases 2024-04-28 Ben Meister Ben Meister [df351f] GIRR test cases
 .gitattributes 2014-03-29 Scott Talbert Scott Talbert [c2ed05] Update .gitattributes
 .gitignore 2013-01-28 Scott Talbert Scott Talbert [425362] Add a .gitignore file.
 COPYING 2008-06-14 Stephen Warren Stephen Warren [b8dd09] Check in congruity release 7
 Changelog 2022-08-15 Scott Talbert Scott Talbert [4a8fc9] New release 21
 LICENSE.txt 2009-12-17 Stephen Warren Stephen Warren [ae04d3] Changes for congruity-14
 README.txt 2022-08-15 Scott Talbert Scott Talbert [da22af] Update README with latest tested versions
 congruity.1 2008-06-14 Stephen Warren Stephen Warren [b8dd09] Check in congruity release 7
 congruity.desktop 2009-08-05 Stephen Warren Stephen Warren [95445b] Modify MIME types to match Logitech website, an...
 icon-sources.txt 2009-02-23 Stephen Warren Stephen Warren [126d38] Add icon-sources.txt
 mhgui.1 2013-10-29 Scott Talbert Scott Talbert [27a4ce] Add a man page for mhgui. Fixes #16.
 mhgui.desktop 2013-10-29 Scott Talbert Scott Talbert [5c071d] Add a .desktop file for mhgui. Closes #11.
 mkrelease.sh 2014-03-29 Scott Talbert Scott Talbert [f1e391] Update mkrelease.sh script to use 'git archive'
 setup.py 2022-08-15 Scott Talbert Scott Talbert [4a8fc9] New release 21

Read Me

Requirements
==============================================================================

Python (tested with 3.10.6 on Fedora 36)
  See https://www.python.org/

wxPython (tested with wxPython-4.0.7 and wxPython-4.2.0 on Fedora 36)
  See https://www.wxpython.org/

libconcord (version 1.1 or newer is *required*; tested on Fedora 36)
  See https://www.phildev.net/concordance/
  Note that the python bindings are also required; see
  libconcord/bindings/python

python-six
  Six is used for enabling Python 3 support.

python-suds (tested with 1.1.2 on Fedora 36)
  Suds is required for mhgui.

libsecret and PyGObject (optional for mhgui)
  libsecret and PyGObject are used by mhgui to store usernames and passwords.
  mhgui will work just fine without them, however.
  See https://wiki.gnome.org/Projects/Libsecret
  And https://wiki.gnome.org/Projects/PyGObject

Python, wxPython, Six, and Suds are typically installed using your
distribution's package management system. If this is not the case, installation
instructions should be located in the documentation accompanying those packages.

libconcord may be available via your distribution's package management
system. If so, please ensure that you install any sub-packages required to
provide the libconcord Python bindings, e.g. both libconcord and
libconcord-python.

If installing libconcord from source, please follow the instructions
accompanying the source. Note that the Python bindings must be installed
separately; the bindings are found within the following sub-directory of the
libconcord source package:

    libconcord/bindings/python

Some versions of libconcord provide a README.txt detailing the installation
process. Otherwise, the basic instructions are to run the following command as
root:

    python setup.py install

Installation
==============================================================================

congruity may be installed by running the following command:

    python setup.py install

This command typically requires root access, since the default installation
location is /usr/local.

The setup.py uses Setuptools, so please see the Setuptools documentation for
additional information on available options:
https://setuptools.readthedocs.io/en/latest/index.html

The only non-standard option supported is --skip-update-desktop-db which will
skip running the 'update-desktop-database' command after installation.

Device Node Access Setup
==============================================================================

You may need to set up udev/similar rules so that the USB device nodes used
by the application are accessible without running congruity as root. Note that
distribution packages of libconcord typically provide these rules, so they may
already be set up for you.

If you need to manually set up udev rules, the following file should work:

----- /etc/udev/rules.d/custom-concordance.rules:
SYSFS{idVendor}=="046d", SYSFS{idProduct}=="c110", MODE="666"
-----

Note that your vendor and product ID may be different. Use lsusb to verify:

-----
[swarren@esk ~]$ lsusb
...
Bus 005 Device 011: ID 046d:c110 Logitech, Inc. 
...
-----

Remember to differentiate between the Harmony remote and any other Logitech
peripherals you may have! Note that not all Harmony-compatible remotes are
Logitech-branded in the USB listing.

Usage Model
==============================================================================

congruity aims to fit into the usage model implemented by the official
Logitech software. The primary differentiation is that congruity is both
open-source and more cross-platform than the official software.

Harmony remotes are configured using the Logitech website, based at the
following URL:

    http://members.harmonyremote.com/EasyZapper/

Note that other URLs may be used for remotes that are not branded as
"Harmony". However, the overall process is identical.

The website provides a database of devices, and a set of wizards to select
which of those are present in your setup. All decisions regarding how the
remote will be configured are made through this website. 

Please note that more recent versions of the Logitech software appear to be
an application that executes locally on the user's computer. However, they are
in fact a simple wrapping of a web-browser, simply hiding the web-based nature
of the configuration process.

Once the configuration is complete, the website will push various file
downloads to the web browser. These files contain the information required to
program the user's configuration into the remote. For each file downloaded,
the congruity application should be executed to process the instructions in
that file.

Web Browser Setup
==============================================================================

Configure your web browser to open files of type *.EZHex, *.EZUp, and *.EZTut
with the congruity application.

This is typically set up using the dialog box that appears when a file is
about to be downloaded. congruity should be executed once for each file
downloaded, and should be passed the name of the saved download as a command-
line parameter, for example:

    congruity /tmp/Connectivity.EZHex

If you're confused, the above behavior is most likely what your web browser
will do automatically when configured to open files using congruity.

Firefox Specific Notes
==============================================================================

You'll need to change a setting to see the download action prompt; Otherwise,
files will simply be saved to disk without you being asked. On Linux, this may
be achieved from the Edit menu -> Preferences menu item -> Main tab -> Select
"Always ask me where to save files". The exact menu location may vary slightly
on other operating systems.

When a file download commences, a dialog will appear with the option to "Open
With", or "Save" the file. Select "Open With", and browse for the congruity
executable as the application. You may also want to select "Do this
automatically for files like this from now on". You will need to select the
path to the congruity application once for each file type (*.EZHex, *.EZUp,
*.EZTut).

If the automatic option is not selected, the dialog will appear for every file
downloaded. Note that Firefox does remember the path to congruity for future
downloads, even though it is not displayed.

MHGUI
==============================================================================

MHGUI was developed as an alternative front-end to the myharmony.com website,
which requires Silverlight and is thus unsupported on Linux and other platforms.
Specifically, combined with congruity and libconcord, it enables users of the
Harmony 200 and 300 (which are only supported through myharmony.com and not
through members.harmonyremote.com) to configure and program their remotes under
Linux.  Simply run 'mhgui' and follow the on-screen prompts.