Status |
Coverage |
Docs |
Site Release |
Style |
DOI |
---|---|---|---|---|---|
TBA |
2024.05.xx |
frb-voe
is a telescope-agnostic server for publishing, broadcasting, and recording Virtual Observatory Events (VOEvents) for detections of Fast Radio Bursts (FRBs). Telescopes and observatories that are actively detecting or following up FRBs can establish a subscription-based FRB VOEvent service using frb-voe
. The core functionality of the code base is the following tasks:
- Publish VOEvents that follow an extension to the FRB VOEvent Standard originally prescribed in Petroff et al. 2017 using a Comet broker and/or an SMTP email server.
- Maintain and interact with a Mongo Database of VOEvent metadata and subscribers information.
- Submit FRBs to the Transient Name Server (TNS).
The following are instructions for installing the frb-voe package and running the TNS service.
First, cd
into your preferred path /my/path
and clone the repository.
git clone git@github.com:CHIMEFRB/voe.git
Now, move into the repo:
cd voe
And build the docker container and initialize the servers and database. If you do not have docker installed on your system, instructions can be found here: https://docs.docker.com/get-docker/.
docker compose build
Note: MongoDB is set to run at port 27017 by default. Ensure nothing is running at this port, or, choose another port by changing the SANIC_MONGODB_PORT variable in the docker-compose.yaml file (and the corresponding ports in the mongo configuration).
To ensure the interface between the frb-voe
server and the host observatory are as seemless as possible, HTTP requests are used. To initiate an FRB VOEvent, the host observatory must send a request to the frb-voe
server containing basic FRB metadata. An example of such a request as well as a template script to send the request can be found in the examples
directory.
The frb-voe
software operates using HTTP requests, in order to initiate the publication of a VOEvent from your observatory, a correctly formatted HTTP request must be sent to your frb-voe
server. This request is required to contain the burst metadata (for "detection" and "subsequent" type VOEvents, or an update message or internal ID for "update" and "retraction" type VOEvents, respectively). This can be accomplished manually, or from an automated request being sent from the host observatory to the frb-voe
server upon detection of a new event. An example script demonstrating this is provided in the examples
directory.
Certain aspects of the service (such as SMTP servers and interactions with the TNS) require sensitive information such as passwords and API keys. To use these services, it is recommended that you pass these secrets as environment variables. These must be added to your bash profile with the following naming convention.
- FRB_VOE_EMAIL_ADDRESS
- FRB_VOE_EMAIL_PASSWORD
- FRB_VOE_TNS_API_KEY
- FRB_VOE_TNS_BOT_NAME
- FRB_VOE_TNS_BOT_ID
To obtain a TNS API key, bot name, and bot ID, proceed to the next section.
The TNS is the official IAU-recognized distributor and maintainer of the naming scheme for FRBs. All programmatic requests to the TNS require authentication. This in turn requires registration on the TNS web portal. To complete the registration process and obtain required authorization, follow these steps:
- Request a User Account here. If you had additional team members who will manage your TNS data, they should also create a User Account.
- Log in here.
- Edit your TNS Group members here.
- Add a TNS bot here. This is required in order to obtain the credentials that are needed for making programmatic requests to the TNS via the API that is embedded in
frb-voe
. - Once your TNS bot has been created, it will appear in the table on this page. In the rightmost column you can click edit to view or change its properties. In particular, the Edit Bot page allows one to create a new API key for the bot at any time.
- From the Edit Bot page, one can obtain values for the environment variables that are required to use the TNS functionality of
frb-voe
.FRB_VOE_TNS_API_KEY
from the API alphanumeric key value.FRB_VOE_TNS_BOT_ID
from the"tns_id"
key in theUser-Agent
specification.FRB_VOE_TNS_BOT_NAME
from the"name"
key in theUser-Agent
specification.
Once the frb-voe backend is started, a dedicated CLI can be used for all interactions software.
poetry run frbvoe voe [COMMAND] [OPTIONS]
poetry run frbvoe voe send --help
poetry run frbvoe subscriber [COMMAND] [OPTIONS]
poetry run frbvoe subscriber add --help
poetry run frbvoe tns [COMMAND] [OPTIONS]
When you have the event number of a FRB Candidate that needs to be submitted to the TNS, use the following command to acquire the TNS name.
poetry run frbvoe tns submit --help
The help dialogue will explain what options are required and what data is needed from the user. These include:
- event number
- proprietary period length (in years)
Optionally, one can practice the submission by setting the --sandbox
flag in the call signature.
All motivated community members are welcomed and encouraged to contribute to the frb-voe Service. Contributions should be initiated with an issue and corresponding development branch. We encourage users to write tests for their contributed code, which can be run locally using:
poetry run pytest --cov-report=html --cov .
The repository is formatted according to pre-commit, to run pre-commit locally, use:
pre-commit run --all-files