Skip to content

Commit

Permalink
FAQ extension
Browse files Browse the repository at this point in the history
  • Loading branch information
mbaudis committed Aug 8, 2024
1 parent 1219290 commit 6eaef01
Show file tree
Hide file tree
Showing 3 changed files with 212 additions and 28 deletions.
167 changes: 161 additions & 6 deletions docs/FAQ.md
Original file line number Diff line number Diff line change
@@ -1,11 +1,12 @@
# Frequently Asked Questions

!!! Note "Citation"
!!! info "Citation"

**Beacon v2 and Beacon Networks: a "lingua franca" for federated data discovery in biomedical genomics, and beyond.**
Jordi Rambla, Michael Baudis, Tim Beck, Lauren A. Fromont, Arcadi Navarro, Manuel Rueda, Gary Saunders, Babita Singh, J.Dylan Spalding, Juha Tornroos, Claudia Vasallo, Colin D.Veal, Anthony J.Brookes. _Human Mutation_ (2022) [DOI](https://doi.org/10.1002/humu.24369).

??? faq "Is it `Beacon` or `beacon`?"

??? question "Is it `Beacon` or `beacon`?"

The uppercase `Beacon` is used to label API, framework or protocol and their
components - while lower case `beacons` are instances of these, _i.e._ individual
Expand All @@ -14,7 +15,77 @@
##### last change 2023-03-13 by Michael Baudis [:fontawesome-brands-github:](https://github.com/mbaudis)


??? faq "Security: What are the general security principles for Beacon?"
??? faq "How do I emulate Beacon v1 while supporting the v2 protocol?<a id="v1-emulation"> </a>"

The [Beacon Framework](/framework) describes the overall structure of the API
requests, responses, parameters etc. One can implement e.g. a Boolean beacon (_cf._ the
original protocol) without any use of the model, just by providing a well-formed
JSON response upon a request [very similar to the (pre-)v1 allele request](/variant-queries/#beacon-sequence-queries).


##### Minimal Example Request

This example is for a minimal SNV-type variant query.

```
/beacon/g_variants/?referenceName=refseq:NC_000017.11&start=7577120&referenceBases=G&alternateBases=A
```

##### Example Boolean Response

In this minimal response to the query above the beacon indicates that its default
response is Boolean and that it could interpreted it against the `genomicVariant` entity and in the context of the same Beacon version.

In principle one could launch a Beacon instance using the example response document as a template
in whatever server environment one has at hand. However, a proper Beacon v2
installation also has to provide informational endpoints (`/info`, `/map` ...)
to allow it's integration through [aggregators](/networks/).

```json
{
"meta": {
"apiVersion": "v2.0.0",
"beaconId": "org.progenetix.beacon",
"receivedRequestSummary": {
"apiVersion": "v2.0.0",
"pagination": {
"limit": 2000,
"skip": 0
},
"requestedGranularity": "boolean",
"requestedSchemas": [
{
"entityType": "genomicVariant",
"schema": "https://progenetix.org/services/schemas/genomicVariant/"
}
],
"requestParameters": {
"alternateBases": "A",
"referenceBases": "G",
"referenceName": "refseq:NC_000017.11",
"start": [
7577120
]
}
},
"returnedGranularity": "boolean",
"returnedSchemas": [
{
"entityType": "genomicVariant",
"schema": "https://progenetix.org/services/schemas/genomicVariant/"
}
]
},
"responseSummary": {
"exists": true
}
}
```

###### last change 2023-02-17 @mbaudis


??? security "What are the general security principles for Beacon?"

An implementation of a Beacon must implement the Global Alliance for Genomics and Health ([GA4GH](https://www.ga4gh.org)) Beacon standard. The V2 standard has been approved by both the Regulatory and Ethics, and Data Security foundational workstreams.

Expand All @@ -28,12 +99,96 @@

As part of the ELIXIR 2019-21 Beacon Network Implementation Study deliverable [D3.3](https://docs.google.com/document/d/1q7XuUB-Z4A_DogWT1AVrvkp_qHWWtbbICxokHup_tts/edit) a document has been written to describe security best practice for users interested in deploying or running a Beacon or users who govern data hosted within a Beacon, and the requirements for adding the Beacon to the ELIXIR Beacon network. As the Beacon standard extends in V2 towards supporting phenotype and range queries, the tiered access model becomes more important to ensure the Beacon response is appropriate to the underlying data.

??? faq "Security: How is security actually implemented when I deploy a Beacon?"

??? security "How is security actually implemented when I deploy a Beacon?"

Security attributes are part of the Beacon v2 [Framework](https://github.com/ga4gh-beacon/beacon-v2/tree/main/framework). The file [`beaconConfiguration.json`](https://github.com/ga4gh-beacon/beacon-v2/blob/main/framework/json/configuration/beaconConfigurationSchema.json) defines the schema of the JSON file that includes core aspects of a Beacon instance configuration. Its third section, called **securityAttributes**, defines the security.

Check out the **securityAttributes** section on the [Beacon Documentation website](http://docs.genomebeacons.org/framework/#the-beacon-configuration-file).

??? faq "Security: How do I test a Beacon without having to go through complex security matters (yet)?"

As a Beacon is designed to support data discoverability of controlled access datasets, it is recommended that synthetic or artificial data is used for testing and initial deployment of Beacon instances. The use of synthetic data for testing is important in that it ensures that the full functionality of a Beacon can be tested and / or demonstrated without risk of exposing data from individuals. In addition to testing or demonstrating a deployment, synthetic data should be used for development, for example adding new features. Additionally, these data can also be used to demonstrate the access levels and data governance procedures for loading data to a Beacon to build trust with data controllers or data access committees who may be considering loading data to a Beacon. An example dataset that contains chromosome specific vcf files is hosted at EGA under dataset accession EGAD00001006673. While this dataset requires a user to log in to get access, the EGA test user can access this dataset.
??? security "How do I test a Beacon without having to go through complex security matters (yet)?"

As a Beacon is designed to support data discoverability of controlled access datasets, it is recommended that synthetic or artificial data is used for testing and initial deployment of Beacon instances. The use of synthetic data for testing is important in that it ensures that the full functionality of a Beacon can be tested and / or demonstrated without risk of exposing data from individuals. In addition to testing or demonstrating a deployment, synthetic data should be used for development, for example adding new features. Additionally, these data can also be used to demonstrate the access levels and data governance procedures for loading data to a Beacon to build trust with data controllers or data access committees who may be considering loading data to a Beacon. An example dataset that contains chromosome specific vcf files is hosted at EGA under dataset accession EGAD00001006673. While this dataset requires a user to log in to get access, the EGA test user can access this dataset.

??? faq "What types of genomic variants are supported in Beacon queries?"

Beacon v2.0 does not provide a mechanism to detect what types of genomic variant
queries are supported by a given instance.

Beacon had been originally designed to handle the "simplest" type of genomic
variant queries in which a `position`, `alternateBases` (_i.e._ one or more base
sequence of the variant at the position) and - sometimes optional - the reference
sequence at this position (necessary e.g. for small deletions).

Beacon v1.1 in principle supported "bracketed" queries and a `variantType` parameter
(pointing to the VCF use) - see the [current documentation](https://docs.genomebeacons.org/variant-queries/#beacon-bracket-queries) for details. However, the support & interpretation was - and still is (2022-12-13) -
left to implementers. Similar for [Beacon Range Queries](https://docs.genomebeacons.org/variant-queries/#beacon-range-queries).

However, the [Beacon documentation](https://docs.genomebeacons.org/variant-queries/#varianttype-parameter-interpretation)
provides information about use and expected interpretation of `variantType` values, specifically
for copy number variations.

###### last change 2022-12-14 @mbaudis


?? faq "How can I add e.g. an age limit to a query for a disease?"

Ages are queried as [ISO8601 durations](https://genomestandards.org/standards/dates-times/#durations)
such as `P65Y` (_i.e._ 65 years) with a comparator (`=`, `<=`, `>` ...). However,
the value needs an indication of _what_ the duration refers to and resources
may provide different ways to indicate this (as then shown in their `/filtering_terms`)
endpoint).

We recommend that all Beacon instances that support age queries support at
minimum the syntax of `age:<=P65Y` and map such values to the internal datapoint
most relevant for the resource's context (in most cases probably corresponding
to "age at diagniosis").

However, different scenarios may be supported (e.g. `EFO_0005056:<=P1Y6M` for
an "age at death" scenario).

###### last change 2023-05-31 by @mbaudis

??? faq "How can I handle haplotype queries & representation in Beacon v2?<a id="haplotypes"> </a>"

#### Queries

The Beacon framework currently (_v2.0_ and earlier) considers genomic
variants to be _allelic_ and does not support the query for multiple alleles
or "haplotype shorthand expressions" (e.g. `C,T`).

**Workarounds** In case of a specific need for haplotype queries implementers
of a given beacon with control of its data content in principle can extend their
query model to support shorthand haploype expressions, as long as they support
the standard format, too. However, such an approach may be superseeded or in conflict
with future direct protocol support.

An approach in line with the current protocol would be to query for one allelic
variant with a record-level `genomicVariation` response, and then query the
retrieved variants individually by their `id` in combination with the second
allele.

#### Variant representation

As with queries the Beacon "legacy" format does not support haplotype representation
but would represent each allelic variation separately. The same is true for the
VRSified variant representation which for v2.0 corresponds to VRS v1.2.
However, draft versions of the VRS standard (will) address haplotype and genotype
representations and will be adopted by Beacon v2.n after reaching a release state.


??? faq "Does the Beacon protocol support Boolean expressions?<a id="boolean-logic"> </a>"

No (...but). Beacon queries as of v2 always assume a logical **AND** between query parameters
and individual filters, _i.e._ all conditions have to be met. There is currently
no support for Boolean expressions.
However, a logical exception is the use of multiple filters for the same parameter which
a Beacon implementation should treat as a logical **OR** since they otherwise
would fail in most instances. E.g. the query using `NCIT:C3493` and `NCIT:C2926`
(mapped against `biosample.histological_diagnosis.id`) would match both
_Lung Non-Small Cell Carcinoma_ (NCIT:C2926) and _Lung Squamous Cell Carcinoma_
(NCIT:C3493) which are exclusive diagnoses.



17 changes: 17 additions & 0 deletions docs/css/theme_overrides.css
Original file line number Diff line number Diff line change
@@ -1,5 +1,7 @@
:root {
--md-accent-fg-color: #076d63;
--md-admonition-icon--pied-piper: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 576 512"><path d="M244 246c-3.2-2-6.3-2.9-10.1-2.9-6.6 0-12.6 3.2-19.3 3.7l1.7 4.9zm135.9 197.9c-19 0-64.1 9.5-79.9 19.8l6.9 45.1c35.7 6.1 70.1 3.6 106-9.8-4.8-10-23.5-55.1-33-55.1zM340.8 177c6.6 2.8 11.5 9.2 22.7 22.1 2-1.4 7.5-5.2 7.5-8.6 0-4.9-11.8-13.2-13.2-23 11.2-5.7 25.2-6 37.6-8.9 68.1-16.4 116.3-52.9 146.8-116.7C548.3 29.3 554 16.1 554.6 2l-2 2.6c-28.4 50-33 63.2-81.3 100-31.9 24.4-69.2 40.2-106.6 54.6l-6.3-.3v-21.8c-19.6 1.6-19.7-14.6-31.6-23-18.7 20.6-31.6 40.8-58.9 51.1-12.7 4.8-19.6 10-25.9 21.8 34.9-16.4 91.2-13.5 98.8-10zM555.5 0l-.6 1.1-.3.9.6-.6zm-59.2 382.1c-33.9-56.9-75.3-118.4-150-115.5l-.3-6c-1.1-13.5 32.8 3.2 35.1-31l-14.4 7.2c-19.8-45.7-8.6-54.3-65.5-54.3-14.7 0-26.7 1.7-41.4 4.6 2.9 18.6 2.2 36.7-10.9 50.3l19.5 5.5c-1.7 3.2-2.9 6.3-2.9 9.8 0 21 42.8 2.9 42.8 33.6 0 18.4-36.8 60.1-54.9 60.1-8 0-53.7-50-53.4-60.1l.3-4.6 52.3-11.5c13-2.6 12.3-22.7-2.9-22.7-3.7 0-43.1 9.2-49.4 10.6-2-5.2-7.5-14.1-13.8-14.1-3.2 0-6.3 3.2-9.5 4-9.2 2.6-31 2.9-21.5 20.1L15.9 298.5c-5.5 1.1-8.9 6.3-8.9 11.8 0 6 5.5 10.9 11.5 10.9 8 0 131.3-28.4 147.4-32.2 2.6 3.2 4.6 6.3 7.8 8.6 20.1 14.4 59.8 85.9 76.4 85.9 24.1 0 58-22.4 71.3-41.9 3.2-4.3 6.9-7.5 12.4-6.9.6 13.8-31.6 34.2-33 43.7-1.4 10.2-1 35.2-.3 41.1 26.7 8.1 52-3.6 77.9-2.9 4.3-21 10.6-41.9 9.8-63.5l-.3-9.5c-1.4-34.2-10.9-38.5-34.8-58.6-1.1-1.1-2.6-2.6-3.7-4 2.2-1.4 1.1-1 4.6-1.7 88.5 0 56.3 183.6 111.5 229.9 33.1-15 72.5-27.9 103.5-47.2-29-25.6-52.6-45.7-72.7-79.9zm-196.2 46.1v27.2l11.8-3.4-2.9-23.8zm-68.7-150.4l24.1 61.2 21-13.8-31.3-50.9zm84.4 154.9l2 12.4c9-1.5 58.4-6.6 58.4-14.1 0-1.4-.6-3.2-.9-4.6-26.8 0-36.9 3.8-59.5 6.3z"/></svg>');
--md-admonition-icon--lock: url('data:image/svg+xml;charset=utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="16" height="16" fill="currentColor" class="bi bi-lock" viewBox="0 0 16 16"><path d="M8 1a2 2 0 0 1 2 2v4H6V3a2 2 0 0 1 2-2m3 6V3a3 3 0 0 0-6 0v4a2 2 0 0 0-2 2v5a2 2 0 0 0 2 2h6a2 2 0 0 0 2-2V9a2 2 0 0 0-2-2M5 8h6a1 1 0 0 1 1 1v5a1 1 0 0 1-1 1H5a1 1 0 0 1-1-1V9a1 1 0 0 1 1-1"/></svg>')
}

.md-grid {
Expand Down Expand Up @@ -39,3 +41,18 @@ li li li {
display: flex;
justify-content: center;
}

.md-typeset .admonition.security,
.md-typeset details.security {
border-color: rgb(222, 2, 12);
}
.md-typeset .security > .admonition-title,
.md-typeset .security > summary {
background-color: rgba(222, 2, 12, 0.1);
}
.md-typeset .security > .admonition-title::before,
.md-typeset .security > summary::before {
background-color: rgb(222, 2, 12);
-webkit-mask-image: var(--md-admonition-icon--lock);
mask-image: var(--md-admonition-icon--lock);
}
56 changes: 34 additions & 22 deletions mkdocs.yaml
Original file line number Diff line number Diff line change
@@ -1,12 +1,36 @@
# ------------------------ Navigation Menu ----------------------------------- #

nav:
- Introduction: /
- News: news
- FAQ: FAQ
- Publications: publications
- People: people
- Protocols & Minutes: minutes
- External Links:
- Beacon API Documentation &#8599;: http://docs.genomebeacons.org
- Github Repositories &#8599;: https://github.com/ga4gh-beacon/
- Beacon v2 service registry &#8599;: https://ga4gh-approval-service-registry.ega-archive.org
- ELIXIR BeaconNetwork &#8599;: https://beacon-network.elixir-europe.org
- Beacon @ ELIXIR &#8599;: http://www.elixir-europe.org/about-us/implementation-studies/beacons
- '<div>Progenetix&nbsp;Beacon<span style="color: red; font-weight: 800;">+</span> &#8599;</div>': https://progenetix.org/search/
- GA4GH &#8599;: http://ga4gh.org
- GA4GH::SchemaBlocks &#8599;: http://schemablocks.org
- GA4GH::Discovery &#8599;: http://ga4gh-discovery.github.io

# ------------------------- Repository Settings ------------------------------ #

site_name: Beacon v2 Project Website
site_description: 'Website for Beacon v2'
site_author: 'Michael Baudis, Laureen Fromont & Beacon Developers'
copyright: '&copy; Copyright 2021-2023, Beacon v2 Documentation Contributors'
copyright: '&copy; Copyright 2021-2024, Beacon v2 Documentation Contributors'
repo_name: 'ga4gh-beacon.github.io'
repo_url: https://github.com/ga4gh-beacon/ga4gh-beacon.github.io
repo_url: https://github.com/ga4gh-beacon/ga4gh-beacon-legacy-website
edit_uri: edit/main/docs/

repo_icon: " [:fontawesome-brands-github:](https://github.com/ga4gh-beacon/ga4gh-beacon.github.io/tree/main/docs)"

# ------------------- Mkdocs Configurattion and Extensions-------------------- #

extra_css: [css/theme_overrides.css]

plugins:
Expand Down Expand Up @@ -43,30 +67,15 @@ markdown_extensions:
- pymdownx.emoji:
emoji_index: !!python/name:materialx.emoji.twemoji
emoji_generator: !!python/name:materialx.emoji.to_svg
options:
custom_icons:
- extras/.icons
- pymdownx.superfences:
custom_fences:
- name: mermaid
class: mermaid
format: !!python/name:mermaid2.fence_mermaid

nav:
- Introduction: /
- News: news
- FAQ: FAQ
- Publications: publications
- People: people
- Protocols & Minutes: minutes
- External Links:
- Beacon API Documentation &#8599;: http://docs.genomebeacons.org
- Github Repositories &#8599;: https://github.com/ga4gh-beacon/
- Beacon v2 service registry &#8599;: https://ga4gh-approval-service-registry.ega-archive.org
- ELIXIR BeaconNetwork &#8599;: https://beacon-network.elixir-europe.org
- Beacon @ ELIXIR &#8599;: http://www.elixir-europe.org/about-us/implementation-studies/beacons
- '<div>Progenetix&nbsp;Beacon<span style="color: red; font-weight: 800;">+</span> &#8599;</div>': https://progenetix.org/search/
- GA4GH &#8599;: http://ga4gh.org
- GA4GH::SchemaBlocks &#8599;: http://schemablocks.org
- GA4GH::Discovery &#8599;: http://ga4gh-discovery.github.io

theme:
custom_dir: extras
name: material
Expand All @@ -75,7 +84,10 @@ theme:
logo: img/GA-logo.png
favicon: img/ga4gh_circle.ico
icon:
repo: fontawesome/brands/github-alt
repo: fontawesome/brands/github-alt
admonition:
warning: lock
security: lock
features:
- content.tabs.link
- search.highlight
Expand Down

0 comments on commit 6eaef01

Please sign in to comment.