openwebrx-clone/config_webrx.py

294 lines
12 KiB
Python
Raw Normal View History

2016-04-11 14:48:59 +02:00
# -*- coding: utf-8 -*-
2014-11-29 01:07:10 +01:00
"""
config_webrx: configuration options for OpenWebRX
2017-05-02 15:17:50 +02:00
This file is part of OpenWebRX,
an open-source SDR receiver software with a web UI.
Copyright (c) 2013-2015 by Andras Retzler <randras@sdr.hu>
2019-11-12 13:43:39 +01:00
Copyright (c) 2019 by Jakob Ketterl <dd5jfk@darc.de>
2014-11-29 01:07:10 +01:00
This program is free software: you can redistribute it and/or modify
it under the terms of the GNU Affero General Public License as
published by the Free Software Foundation, either version 3 of the
License, or (at your option) any later version.
2014-11-29 01:07:10 +01:00
This program is distributed in the hope that it will be useful,
2014-11-29 01:07:10 +01:00
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License
along with this program. If not, see <http://www.gnu.org/licenses/>.
2014-11-29 01:07:10 +01:00
2017-05-02 15:17:50 +02:00
++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
2014-11-29 01:07:10 +01:00
2017-05-02 15:17:50 +02:00
In addition, as a special exception, the copyright holders
state that config_rtl.py and config_webrx.py are not part of the
Corresponding Source defined in GNU AGPL version 3 section 1.
2016-04-11 14:48:59 +02:00
2017-05-02 15:17:50 +02:00
(It means that you do not have to redistribute config_rtl.py and
config_webrx.py if you make any changes to these two configuration files,
and use them for running your web service with OpenWebRX.)
2014-11-29 01:07:10 +01:00
"""
2016-04-23 11:20:35 +02:00
# NOTE: you can find additional information about configuring OpenWebRX in the Wiki:
# https://github.com/simonyiszk/openwebrx/wiki
# ==== Server settings ====
web_port = 8073
max_clients = 20
2014-11-29 01:07:10 +01:00
# ==== Web GUI configuration ====
receiver_name = "[Callsign]"
receiver_location = "Budapest, Hungary"
receiver_asl = 200
receiver_admin = "example@example.com"
receiver_gps = (47.000000, 19.000000)
photo_title = "Panorama of Budapest from Schönherz Zoltán Dormitory"
photo_desc = """
2014-11-29 01:07:10 +01:00
You can add your own background photo and receiver information.<br />
Receiver is operated by: <a href="mailto:%[RX_ADMIN]">%[RX_ADMIN]</a><br/>
Device: %[RX_DEVICE]<br />
Antenna: %[RX_ANT]<br />
Website: <a href="http://localhost" target="_blank">http://localhost</a>
"""
# ==== sdr.hu listing ====
# If you want your ham receiver to be listed publicly on sdr.hu, then take the following steps:
# 1. Register at: http://sdr.hu/register
# 2. You will get an unique key by email. Copy it and paste here:
sdrhu_key = ""
# 3. Set this setting to True to enable listing:
sdrhu_public_listing = False
server_hostname = "localhost"
# ==== DSP/RX settings ====
fft_fps = 9
fft_size = 4096 # Should be power of 2
fft_voverlap_factor = (
2019-11-23 01:13:16 +01:00
0.3 # If fft_voverlap_factor is above 0, multiple FFTs will be used for creating a line on the diagram.
)
2017-01-28 15:19:16 +01:00
audio_compression = "adpcm" # valid values: "adpcm", "none"
fft_compression = "adpcm" # valid values: "adpcm", "none"
digimodes_enable = True # Decoding digimodes come with higher CPU usage.
digimodes_fft_size = 1024
2017-05-04 20:35:40 +02:00
# determines the quality, and thus the cpu usage, for the ambe codec used by digital voice modes
# if you're running on a Raspi (up to 3B+) you'll want to leave this on 1
digital_voice_unvoiced_quality = 1
2019-05-30 17:19:46 +02:00
# enables lookup of DMR ids using the radioid api
digital_voice_dmr_id_lookup = True
2017-01-28 15:19:16 +01:00
"""
Note: if you experience audio underruns while CPU usage is 100%, you can:
- decrease `samp_rate`,
- set `fft_voverlap_factor` to 0,
- decrease `fft_fps` and `fft_size`,
- limit the number of users by decreasing `max_clients`.
"""
# ==== I/Q sources ====
# (Uncomment the appropriate by removing # characters at the beginning of the corresponding lines.)
2017-04-05 08:34:00 +02:00
#################################################################################################
# Is my SDR hardware supported? #
# Check here: https://github.com/simonyiszk/openwebrx/wiki#guides-for-receiver-hardware-support #
#################################################################################################
2019-06-07 15:44:11 +02:00
# Currently supported types of sdr receivers: "rtl_sdr", "sdrplay", "hackrf", "airspy"
2019-11-22 23:34:27 +01:00
#
# NEW: There is now custom connector software available, that is tailored for the use with
# openwebrx. The connectors allow the SDR to be reprogrammed while running, which allows for
# quicker profile changes. It also reduces the risk of a USB disconnect that can happen when the
# SDR software is restarted, since the connector will run continuously.
# Check out the connector repository here: https://github.com/jketterl/owrx_connector
#
# The following connectors are available (simply use them as the "type" in the config below):
# "rtl_sdr_connector", "sdrplay_connector", "airspy_connector"
#
# NOTE: These connectors will become the default as soon as they have become mature; the existing
# receiver types will then automatically be migrated to connectors. At that point, the old "nmux"
# method will start to be phased out.
2019-05-09 22:44:29 +02:00
sdrs = {
"rtlsdr": {
"name": "RTL-SDR USB Stick",
"type": "rtl_sdr_connector",
2019-05-09 22:44:29 +02:00
"ppm": 0,
2019-05-11 13:25:48 +02:00
# you can change this if you use an upconverter. formula is:
2019-11-21 15:31:37 +01:00
# center_freq + lfo_offset = actual frequency on the sdr
2019-05-11 13:25:48 +02:00
# "lfo_offset": 0,
2019-05-10 16:14:16 +02:00
"profiles": {
"70cm": {
"name": "70cm Relais",
"center_freq": 438800000,
"rf_gain": 30,
"samp_rate": 2400000,
"start_freq": 439275000,
"start_mod": "nfm",
2019-05-10 16:14:16 +02:00
},
"2m": {
"name": "2m komplett",
"center_freq": 145000000,
"rf_gain": 30,
"samp_rate": 2400000,
"start_freq": 145725000,
"start_mod": "nfm",
},
},
2019-05-09 22:44:29 +02:00
},
"sdrplay": {
"name": "SDRPlay RSP2",
"type": "sdrplay_connector",
2019-05-09 22:44:29 +02:00
"ppm": 0,
2019-05-10 16:14:16 +02:00
"profiles": {
"20m": {
"name": "20m",
2019-05-10 16:14:16 +02:00
"center_freq": 14150000,
"rf_gain": 0,
2019-05-10 16:14:16 +02:00
"samp_rate": 500000,
"start_freq": 14070000,
"start_mod": "usb",
"antenna": "Antenna A",
2019-05-10 16:14:16 +02:00
},
2019-05-16 21:44:05 +02:00
"30m": {
"name": "30m",
2019-05-16 21:44:05 +02:00
"center_freq": 10125000,
"rf_gain": 0,
2019-05-16 21:44:05 +02:00
"samp_rate": 250000,
"start_freq": 10142000,
"start_mod": "usb",
2019-05-16 21:44:05 +02:00
},
2019-05-10 16:14:16 +02:00
"40m": {
"name": "40m",
2019-05-10 16:14:16 +02:00
"center_freq": 7100000,
"rf_gain": 0,
2019-05-10 16:14:16 +02:00
"samp_rate": 500000,
"start_freq": 7070000,
"start_mod": "usb",
"antenna": "Antenna A",
2019-05-10 16:14:16 +02:00
},
"80m": {
"name": "80m",
2019-05-10 16:14:16 +02:00
"center_freq": 3650000,
"rf_gain": 0,
2019-05-10 16:14:16 +02:00
"samp_rate": 500000,
"start_freq": 3570000,
"start_mod": "usb",
"antenna": "Antenna A",
2019-05-11 00:38:03 +02:00
},
"49m": {
"name": "49m Broadcast",
"center_freq": 6000000,
"rf_gain": 0,
2019-05-11 00:38:03 +02:00
"samp_rate": 500000,
"start_freq": 6070000,
"start_mod": "am",
"antenna": "Antenna A",
},
},
2019-05-10 16:14:16 +02:00
},
2019-05-09 22:44:29 +02:00
}
# ==== Misc settings ====
2016-04-11 14:48:59 +02:00
iq_port_range = [
4950,
4960,
] # TCP port for range ncat to listen on. It will send I/Q data over its connections, for internal use in OpenWebRX. It is only accessible from the localhost by default.
2016-02-10 17:33:48 +01:00
# ==== Color themes ====
# A guide is available to help you set these values: https://github.com/simonyiszk/openwebrx/wiki/Calibrating-waterfall-display-levels
### default theme by teejez:
waterfall_colors = [0x000000FF, 0x0000FFFF, 0x00FFFFFF, 0x00FF00FF, 0xFFFF00FF, 0xFF0000FF, 0xFF00FFFF, 0xFFFFFFFF]
waterfall_min_level = -88 # in dB
waterfall_max_level = -20
waterfall_auto_level_margin = (5, 40)
### old theme by HA7ILM:
# waterfall_colors = "[0x000000ff,0x2e6893ff, 0x69a5d0ff, 0x214b69ff, 0x9dc4e0ff, 0xfff775ff, 0xff8a8aff, 0xb20000ff]"
# waterfall_min_level = -115 #in dB
# waterfall_max_level = 0
# waterfall_auto_level_margin = (20, 30)
2016-10-30 10:23:12 +01:00
##For the old colors, you might also want to set [fft_voverlap_factor] to 0.
# Note: When the auto waterfall level button is clicked, the following happens:
2017-05-02 15:17:50 +02:00
# [waterfall_min_level] = [current_min_power_level] - [waterfall_auto_level_margin[0]]
# [waterfall_max_level] = [current_max_power_level] + [waterfall_auto_level_margin[1]]
#
# ___|____________________________________|____________________________________|____________________________________|___> signal power
# \_waterfall_auto_level_margin[0]_/ |__ current_min_power_level | \_waterfall_auto_level_margin[1]_/
# current_max_power_level __|
2017-05-30 17:12:19 +02:00
# 3D view settings
mathbox_waterfall_frequency_resolution = 128 # bins
mathbox_waterfall_history_length = 10 # seconds
mathbox_waterfall_colors = [
0x000000FF,
0x2E6893FF,
0x69A5D0FF,
0x214B69FF,
0x9DC4E0FF,
0xFFF775FF,
0xFF8A8AFF,
0xB20000FF,
]
2017-05-30 17:12:19 +02:00
# === Experimental settings ===
# Warning! The settings below are very experimental.
csdr_dynamic_bufsize = False # This allows you to change the buffering mode of csdr.
csdr_print_bufsizes = False # This prints the buffer sizes used for csdr processes.
csdr_through = False # Setting this True will print out how much data is going into the DSP chains.
nmux_memory = 50 # in megabytes. This sets the approximate size of the circular buffer used by nmux.
2019-07-07 15:52:24 +02:00
google_maps_api_key = ""
# how long should positions be visible on the map?
# they will start fading out after half of that
# in seconds; default: 2 hours
map_position_retention_time = 2 * 60 * 60
2019-09-12 15:32:54 +02:00
# wsjt decoder queue configuration
# due to the nature of the wsjt operating modes (ft8, ft8, jt9, jt65 and wspr), the data is recorded for a given amount
# of time (6.5 seconds up to 2 minutes) and decoded at the end. this can lead to very high peak loads.
# to mitigate this, the recordings will be queued and processed in sequence.
# the number of workers will limit the total amount of work (one worker will losely occupy one cpu / thread)
wsjt_queue_workers = 2
# the maximum queue length will cause decodes to be dumped if the workers cannot keep up
# if you are running background services, make sure this number is high enough to accept the task influx during peaks
# i.e. this should be higher than the number of wsjt services running at the same time
wsjt_queue_length = 10
2019-09-15 16:37:12 +02:00
# wsjt decoding depth will allow more results, but will also consume more cpu
wsjt_decoding_depth = 3
# can also be set for each mode separately
# jt65 seems to be somewhat prone to erroneous decodes, this setting handles that to some extent
2019-09-25 23:12:30 +02:00
wsjt_decoding_depths = {"jt65": 1}
2019-09-12 15:32:54 +02:00
temporary_directory = "/tmp"
2019-07-28 13:29:45 +02:00
2019-08-11 11:39:35 +02:00
services_enabled = False
2019-08-12 00:02:39 +02:00
services_decoders = ["ft8", "ft4", "wspr", "packet"]
2019-08-18 00:15:07 +02:00
# === aprs igate settings ===
# if you want to share your APRS decodes with the aprs network, configure these settings accordingly
aprs_callsign = "N0CALL"
aprs_igate_enabled = False
aprs_igate_server = "euro.aprs2.net"
aprs_igate_password = ""
# beacon uses the receiver_gps setting, so if you enable this, make sure the location is correct there
aprs_igate_beacon = False
2019-09-18 17:22:35 +02:00
# path to the aprs symbols repository (get it here: https://github.com/hessu/aprs-symbols)
aprs_symbols_path = "/opt/aprs-symbols/png"
2019-09-24 21:44:14 +02:00
# === PSK Reporter setting ===
# enable this if you want to upload all ft8, ft4 etc spots to pskreporter.info
2019-09-25 00:35:57 +02:00
# this also uses the receiver_gps setting from above, so make sure it contains a correct locator
2019-09-24 21:44:14 +02:00
pskreporter_enabled = False
pskreporter_callsign = "N0CALL"