This is a Mac OSX compatible bash script which is used to synchronize sleep data to your mac via an Ezshare Wifi SD card. It can also be used to automate the upload of your data to Sleep HQ.
The script connects to the EZ Share WiFi SD card and synchronizes the data to a folder on your desktop called SD_Card.
If all you're looking to do is synchronize the contents of the SD card with your mac (for review in Oscar etc), then the script will work for both the Airsense 10 and 11 machines as the directory structure on both machines are the same.
For uploading of data to Sleep HQ however, the script has only been tested against the Airsense 10. It has not been confirmed whether it works with the Resmed Airsense 11 but the Identification.json and JOURNAL.JNL files are automatically included in the upload.zip file if they're present in the SD_Card directory.
The script doesn't store any WiFi credentials in the script itself or on the filesystem. Instead, it will store them in your Login Keychain. When you first run the script, it will prompt you for the WiFi SSID and Password for both the Ez Share SD card, and your home WiFi network. Once these details are saved in your Keychain, you don't have to enter them again.
The script can be configured to automatically upload your data to Sleep HQ for review. The script will perform the upload provided that there is new sleep data since the last time the script was run.
The script is configured to automatically update itself so you don't have to. When new features are implemented or bugs are fixed, the script will automatically download the latest version, and execute it.
The script is designed to perform operations against the SD card in parallel. This includes:
- Determining which directories on the SD card need to be checked
- Determining which files need to be downloaded
- Downloading files from the SD card
The SD card that was used for testing contained 283 days worth of sleep data. Using the previous incarnation of the script which used the Python 3 ezshare module, the script took 260 seconds to check 283 days worth of sleep data, download 1 days worth of sleep data and upload that data to Sleep HQ.
That same operation using the new script took 88 seconds to perform the same operations. The new script also provides timings for most of the stages so we can break that down as follows:
- Determining which directories on the SD card need to be checked: 13 seconds (285 directories)
- Determining which files need to be downloaded: 18 seconds
- Downloading files from the SD card: 7 seconds (17 files(1 days worth of sleep data))
- Creating a zip file to upload to Sleep HQ: 1 second
- Uploading the zip file to Sleep HQ: 34 seconds
- Misc operations (like connecting to different wifi networks, checking connectivity etc): 15 seconds
The script will automatically send any csv files in the SD_Card directory to Sleep HQ. This allows you to view Sp02, Movement, and pulse rate data alongside your CPAP therapy data charts. Simply download your data from the ViHealth app or via a tool such as o2r and save it as a CSV file, and place the files in the SD_Card directory on your Desktop. When you next run the script, it will automatically upload them to Sleep HQ.
As of version 17, the script can be configured to use a different directory to store the contents of your SD Card. When the script finds that the default SD card directory doesn't exist (/Users/YOUR_USERNAME/Desktop/SD_Card), a setup process is initiated. The script will ask for the correct location to store files and keep a record of that location in your keychain.
If you have existing data in your SD_Card directory and would like to move it, simply rename and/or move your existing SD card directory. The next time the script executes, it will ask for the new directory location and store the location in your keychain.
If you have more than one wifi adapter, the script will assume that you're using one of them to connect to the ezshare wifi SD card. It will no longer switch wifi networks. Should you disconnect the USB wifi adapter, normal functionality is restored and wifi switching is re-enabled automatically.
This means it's now possible to turn a mac into a magic uploader! Simply run the script every 10 to 15 minutes and it'll upload new sleep data to Sleep HQ!
If you want to know how to enable it, see the FAQ section for more information.
- An EZ Share Wifi SD Card. You can purchase them from Ali Express. I recommend purchasing more than one just in case they die.
- Your sleep data on the SD Card.
- The wifi details for the EZ Share Wifi SD card.
- The wifi details for your home Wifi network.
Open a terminal window and perform the following actions.
curl -o sync.sh https://raw.githubusercontent.com/iitggithub/ezshare_cpap/main/sync.sh
chmod 755 sync.sh
That's it. The script is ready to use. The script will collect your WiFi details and Sleep HQ credentials when you first run it.
./sync.sh
If you've got a lot of data on your SD card already, it's significantly quicker to connect your SD card directly to your mac and copy the contents of the SD Card into the SD_Card folder on your desktop. Once an initial sync has been performed subsequent executions will be much faster.
- Remove the SD Card from your CPAP device
- Connect it to your computer
- Create a folder on your desktop called SD_Card (The name is case sensitive!)
- Copy the contents of your SD Card into the newly created folder
- Place the SD card back into your CPAP device
The next time you execute the script, it will search for any files that have been added since the last time the folder was synchronized.
Once you've synchronized your O2 data to your phone in the ViHealth Android app, you need to perform the following steps for each entry you would like to export in your History.
- Under History, choose the entry you'd like to export to bring up your Oxygen Level, Pulse Rate and Motion information for that session.
- In the top-right corner of the app, tap the button to share the data.
- For Format, choose CSV.
- Choose Share.
- Save the file somewhere and download it to your computer.
- Move the file into the SD_Card directory on the Desktop of your mac. If this folder does not exist, create it.
- Repeat steps 1 - 6 until all of your O2 Ring CSV files are in the SD_Card directory on your mac.
- Run the sync.sh script. If you want to skip synchronizing your sleep data and upload only the O2 Ring data, execute the following instead:
./sync.sh --skip-sync
The O2 ring CSV files will be zipped and uploaded to Sleep HQ using your Sleep HQ API Credentials.
If you've got an older version of the script, you need to update to at least version 9 when the functionality was first implemented. Running the script should trigger an automatic update to the latest version. You'll need your Client UID and Client Secret in order to begin. These are generated in the Account Settings page of Sleep HQ.
If you choose not to enable Sleep HQ uploads, it won't ask you again nor will it create an upload.zip file containing the files that have changed.
Either there's no update available or you're probably running the original version of the script which didn't include the automatic update feature. Simply re-install the script to obtain the latest version which includes this feature.
I don't know... does it? Some notable changes have been made to accommodate the Airsense 11 such as the inclusion of the Identification.json and JOURNAL.JNL in the upload.zip file but it still needs testing by an Airsense 11 user for confirmation.
The only machine I've tested it with is the Airsense 10.
You can run the commands below to remove specific entries in the keychain. When you next run the script, it will prompt you for that information again.
./sync.sh --remove-ezshare
./sync.sh --remove-home
./sync.sh --remove-sleephq
./sync.sh --remove-all
./sync.sh --skip-sync
./sync.sh --skip-upload
./sync.sh --skip-o2sync
./sync.sh --version
./sync.sh --max-streams=X
Note that X should be a number equal to the number of parallel checks you'd like to run. Default is 15 files/directories checked in parallel.
./sync.sh --max-downloads=X
Note that X should be a number equal to the number of parallel downloads you'd like to run. Default is 5 downloads in parallel.
The script keeps track of the contents of the SD card locally on the mac. In each directory there is a hidden html file (such as .SETTINGS.html in the SETTINGS directory). You will need to remove the file to force the directory to be checked.
rm -f /path/to/hidden/file
OR you can simply run the script with the --full-sync option which checks each file in every directory rather than just checking the directory itself.
./sync.sh --full-sync
Firstly, at the time of writing there aren't any wifi adapters that are supported on Apple Silicon. Getting multiple wifi adapters working in Mac OS requires a compatible wifi adapter such as the TP-Link Archer T3U Plus AC1300 Wireless USB Adapter which can be purchased on Amazon for less than $20 USD. You can get a list of working adapters and download the latest release from Github.
You then need to disable System Integrity Protection (SIP) which can only be performed in Mac OS Recovery mode. Instructions for this as well as driver installation can be found here.
Once the driver is installed and you've rebooted, there will be an icon for the Wireless Network Utility in your notification bar.
You MUST use the USB wifi adapter to connect to your HOME Wifi. DNS and routing priorities are higher for the USB wifi adapter so if you connect the wifi the other way around, you won't be able to connect to the internet or your local network and the only website you'll be able to resolve will be the ezshare.card website.
Next, connect your built-in wifi adapter to your ezshare wifi SD card wifi network.
Now you've got your secondary wifi adapter connected, you can run the sync.sh script whenever you want without interrupting your connection to the internet.
Finally, you'll need to configure the script to perform a sync periodically. The easiest way to do this is using the commands below:
- Open a new terminal window
- Download the EzshareSync.plist file to ~/Library/LaunchAgents
curl -o ~/Library/LaunchAgents/EzshareSync.plist https://raw.githubusercontent.com/iitggithub/ezshare_cpap/main/EzshareSync.plist
- Modify the file and update the path to the sync.sh script. By default the script contains the following which you will most likely need to change:
<key>ProgramArguments</key>
<array>
<string>/usr/local/bin/sync.sh</string>
<string>--dedicated</string>
</array>
If your script is in the Downloads folder for example, you would update it to the following:
<key>ProgramArguments</key>
<array>
<string>/Users/MYUSER/Downloads/sync.sh</string>
<string>--dedicated</string>
</array>
Note that you will have to change MYUSER to the user you run the script as.
- Tell launchd about it
launchctl load ~/Library/LaunchAgents/EzshareSync.plist
- (Optional) Add ezshare.card to the /etc/hosts file
This will allow the web interface to be accessed via http://ezshare.card/
sudo cat | tee -a /etc/hosts <<EOF
192.168.4.1\tezshare.card
EOF
Note this isn't needed for the script to function since the directory listing can be directly accessed via http://192.168.4.1/dir?dir=A: but if you want to access the web interface for any other reason, you'll need to perform step 5.
- Try it out!
Using this method will result in a sync being performed every 15 minutes as long as the user is logged into the mac.