Give all your conference rooms a digital dashboard tied to your Google Apps account!
- Display a room's upcoming scheduled meetings
- Quickly join Hangouts for each meeting -- no login necessary
This project is a utility (powered by the Google Calendar API) that creates a website to display the schedules of each of your conference rooms, including links for upcoming hangouts.
- Users can browse room usage via an internal URL.
- Each conference room has its own landing page that can be used as a homepage for conference room computers/TVs. Employees and visitors can easily see who has resevered a given room and quickly access Hangouts via the app's account login.
To get the utility up and running you will have to do the following (detailed below):
- Add your conference rooms to your Google Apps account as resources
- Configure the app in Google Cloud Console and your Google Apps account
- Install this codeset on a Python-powered web server
- Configure URLs to point to web service and deploy within conference rooms.
This utility requires setting up each of your conference rooms as a resource within Google Apps. Add resources from the Google Apps admin panel under Apps -> Calendar -> Resources. See Google's documentation on resources to learn more.
(Note that as Google frequently changes their administration pages, this documentation may be out of date.)
- Go to the Google Developers Console and create a new project. You may use whatever information you desire on this screen.
- Go to the APIs & Auth > APIs and activate the Calendar API and the Google+ Hangouts API.
- Go to APIs & Auth > Credentials registered apps and register a new service account.
- Click on the application, select certificate, and click generate new key.
- Download the private key, taking note of the password.
- Put the key generated in the previous step on the server in a secure place.
- In the Google Apps Admin panel, go to Google Apps -> Calendar -> General Settings
- Under "External Sharing" select "Share all information, but outsiders cannot change calendars."
- Share the desired resource calendars with the generated service account. Be sure to select "See all event details" as the permission setting.
- Python
- flask
- pytz
- httplib2
- google-api-python-client
- python-dateutil
-
Clone this project
git clone [email protected]:thisisgrow/grow-conference-room-utility.git
-
Install pip
sudo easy_install pip
-
Install required packages
sudo pip install --upgrade flask pytz httplib2 google-api-python-client python-dateutil
-
On some platforms, you may also have to install Python headers and pyopenssl
sudo apt-get install python-dev sudo pip install pyopenssl
-
Edit the configuration file. See crweb/config.py for configuration options. To use a custom logo, replace the current logo located here: crweb/static/img/logo.png with another 60px square PNG. To use another size or format, edit the properties of the logo class in crweb/static/css/styles.css.
-
Test configuration and Google setup by running the calendar resource test. Fix any errors that will appear. A successful test will return a dump of all events for the room specified in the configuration variable
test_room_id
.python crweb/cal_resource.py
-
To test that the app is functioning and that configuration values are correct, run with the Flask test server. The rooms that were added in the configuration should be present. As the cron is not yet set, no data will appear. To force reload, click the reload link in the bottom right corner of the resource pane.
python crweb/crweb.py
-
A cron (scheduled task) will need to be setup to periodically update the data for each room. You can set this cron to repeat as often as you like, but you will need to be sure not to go over the daily Google Calendar API usage limit (currently 100,000.) To determine how often you can run the cron, use the following formula where
f
is the frequency in minutes andr
is the number of rooms in the configuration file.f = (60 * 24 * r) / 100,000
Be sure to leave some overhead for expansion and forced reloads. If you have frequent updates to the calendar, then quicker updates may be necessary. If the calendar is not frequently changed, than setting the utility to update once or twice a day will be sufficient. The following cron will run every five minutes. Replace the path to the utility with your own path.
*/5 * * * * cd <PATH-TO-UTILITY> && python crweb/reload.py
-
Run the app either manually or with WSGI middleware.
Point a domain at the web service you just installed. For instance, you could use rooms.YourDomain.com. We recommend either password-protecting this site, or hosting it on an internal network.
Now employees should be able to use this new URL to browse the status of all configured rooms.
For each conference room that is equipped with a computer and primary display (either TV or a monitor), do the following:
- Open the web browser and log into gmail with your resource's account. Close the window. (Note, by logging in this first time, clicking on Join Hangout links within the utility in the future will join the given Hangout as this resource account.)
- Navigate to TheDomainYouConfiguredAbove.com and click on the room that you are currently in. Make this page the browser's home screen.
Created by Grow
This project is licensed under the MIT License. (See LICENSE)