Download
There are two schema files available to download that are both needed to consume the API.
- portal.xsd contains the generic types.
- lightning_v1.xsd contains the versioned types.
Generic
There are a couple of generic types used by many resources. They use the namespace https://opendata.smhi.se/xsd/portal.xsd
and are not subject to the API versioning system.
linkType and linksType
A linkType
represents a link to another resource. It consist of:
rel
- the mediatype of the target resource ( application/xml )type
- the xsd type of the target resource ( parameter )href
- the url to the target resource ( https://opendata-download-lightning.smhi.se/api )
A linksType
represents a set of linkType
with additional information.
This information contains a title
to describe the resource, a summary
for extra description and updated
which represents the last time the target resource, or underlying subresources, was
updated.
This can be useful to deside if data is stale or not without traversing down to the actual data.
The linksType
is used to represent the next level.
For instance the Category type uses a list of linksType
to represent all the Versions available.
The linkType
in this case refers to the different Versions in different formats.
Besides links to the same resource or the next resource in different formats, linkType
are also used to refer to other useful resources. Here are some examples.
- Parent resources
- Metadata
rel="iso19139"
<?xml version="1.0" encoding="utf-8" ?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:portal="https://opendata.smhi.se/xsd/portal.xsd" targetNamespace="https://opendata.smhi.se/xsd/portal.xsd" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xs:complexType name="linkType"> <xs:attribute name="rel" type="xs:string" use="required" /> <xs:attribute name="type" type="xs:string" use="required" /> <xs:attribute name="href" type="xs:anyURI" use="required" /> </xs:complexType> <xs:complexType name="linksType"> <xs:sequence> <xs:element name="key" type="xs:string" minOccurs="0"/> <xs:element name="updated" type="xs:dateTime" /> <xs:element name="title" type="xs:string" /> <xs:element name="summary" type="xs:string" /> <xs:element name="link" type="portal:linkType" minOccurs="0" maxOccurs="unbounded"/> </xs:sequence> </xs:complexType> </xs:schema> Source
geoBox and geoLinksType
geoBox
represents an area of interest devided by minLatitude
, maxLatitude
, minLongitude
and maxLongitude
.
The geoLinksType
is a regular linksType
but with an additional geoBox
.
<?xml version="1.0" encoding="utf-8" ?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:portal="https://opendata.smhi.se/xsd/portal.xsd" targetNamespace="https://opendata.smhi.se/xsd/portal.xsd" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xs:complexType name="geoBox"> <xs:sequence> <xs:element name="minLatitude" type="xs:double"/> <xs:element name="minLongitude" type="xs:double"/> <xs:element name="maxLatitude" type="xs:double"/> <xs:element name="maxLongitude" type="xs:double"/> </xs:sequence> </xs:complexType> <xs:complexType name="geoLinksType"> <xs:complexContent> <xs:extension base="portal:linksType"> <xs:sequence> <xs:element name="geoBox" type="portal:geoBox"> </xs:element> </xs:sequence> </xs:extension> </xs:complexContent> </xs:complexType> </xs:schema> Source
category and version
The category
and version
types are used for versioning. The version
element in category
links to the different versions of the API that can be used. Versions are incremented when
changes are made to the API. There is one special version called latest
. This version is virtual and always points to the latest version of the API. It is not recomended to use this in any application as it might
be redirected without notice. Instead try to use the version with the highest number as these do not change. Older versions will be deprecated and only maintained for a couple of months.
The version
type contains links to all available years
published.
<?xml version="1.0" encoding="utf-8" ?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:portal="https://opendata.smhi.se/xsd/portal.xsd" targetNamespace="https://opendata.smhi.se/xsd/portal.xsd" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xs:element name="category"> <xs:complexType> <xs:sequence> <xs:element name="key" type="xs:string" /> <xs:element name="updated" type="xs:dateTime" /> <xs:element name="title" type="xs:string" /> <xs:element name="summary" type="xs:string" /> <xs:element name="link" type="portal:linkType" minOccurs="0" maxOccurs="unbounded" /> <xs:element name="version" type="portal:linksType" minOccurs="0" maxOccurs="unbounded" /> </xs:sequence> </xs:complexType> </xs:element> <xs:element name="version"> <xs:complexType> <xs:sequence> <xs:element name="key" type="xs:string" /> <xs:element name="updated" type="xs:dateTime" /> <xs:element name="title" type="xs:string" /> <xs:element name="summary" type="xs:string" /> <xs:element name="link" type="portal:linkType" minOccurs="0" maxOccurs="unbounded" /> <xs:element name="resource" type="portal:geoLinksType" minOccurs="0" maxOccurs="unbounded" /> </xs:sequence> </xs:complexType> </xs:element> </xs:schema> Source
Specific
The rest of the types are versioned and uses the namespace https://opendata.smhi.se/xsd/lightning_v1.xsd
. Common to these main types are
key
- resource identifierupdate
- timestamp of last modification timetitle
- the name of the resourcesummary
- description of the resource
They also contains link
to other resources such as to themself in other mediatypes and more specific links to the next level.
lightningYear, lightningMonth and lightningDay
lightningYear
represents a year. It contains linksType
to all months that produces data for the specific year.
lightningDay
represents a day. It contains linksType
to all datafiles for the specific day.
lightningMonth
represents a month. It contains linksType
to all days that produces data for the specific month.
<?xml version="1.0" encoding="utf-8" ?> <xs:schema xmlns:xs="http://www.w3.org/2001/XMLSchema" xmlns:lightning="https://opendata.smhi.se/xsd/lightning_v1.xsd" xmlns:portal="https://opendata.smhi.se/xsd/portal.xsd" targetNamespace="https://opendata.smhi.se/xsd/lightning_v1.xsd" elementFormDefault="qualified" attributeFormDefault="unqualified"> <xs:import namespace="https://opendata.smhi.se/xsd/portal.xsd" /> <!-- LIGHTNING YEAR --> <xs:element name="lightningYear"> <xs:complexType> <xs:sequence> <xs:element name="key" type="xs:string" /> <xs:element name="title" type="xs:string" /> <xs:element name="summary" type="xs:string" /> <xs:element name="link" type="portal:linkType" minOccurs="0" maxOccurs="unbounded" /> <xs:element name="month" type="portal:linksType" minOccurs="0" maxOccurs="unbounded" /> </xs:sequence> </xs:complexType> </xs:element> <!-- LIGHTNING MONTH --> <xs:element name="lightningMonth"> <xs:complexType> <xs:sequence> <xs:element name="key" type="xs:string" /> <xs:element name="title" type="xs:string" /> <xs:element name="summary" type="xs:string" /> <xs:element name="link" type="portal:linkType" minOccurs="0" maxOccurs="unbounded" /> <xs:element name="day" type="portal:linksType" minOccurs="0" maxOccurs="unbounded" /> </xs:sequence> </xs:complexType> </xs:element> <!-- LIGHTNING DAY --> <xs:element name="lightningDay"> <xs:complexType> <xs:sequence> <xs:element name="key" type="xs:string" /> <xs:element name="title" type="xs:string" /> <xs:element name="summary" type="xs:string" /> <xs:element name="link" type="portal:linkType" minOccurs="0" maxOccurs="unbounded" /> <xs:element name="data" type="portal:linksType" minOccurs="0" maxOccurs="unbounded" /> </xs:sequence> </xs:complexType> </xs:element> <xs:element name="lightningData"> <xs:complexType> <xs:sequence> <xs:element name="values" type="lightning:lightningValueType" maxOccurs="unbounded" minOccurs="1"/> </xs:sequence> </xs:complexType> </xs:element> <xs:complexType name="lightningValueType"> <xs:sequence> <xs:element name="timeTick" type="xs:dateTime" maxOccurs="1" minOccurs="1"/> <xs:element name="offsetFromTimeTickNs" type="xs:int" maxOccurs="1" minOccurs="1"/> <xs:element name="lat" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="lon" type="xs:double" maxOccurs="1" minOccurs="1" /> <xs:element name="altitude" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="peakCurrent" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="vhfRnp" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="multiplicityForFlashData" type="xs:int" maxOccurs="1" minOccurs="1"/> <xs:element name="numberOfSensors" type="xs:int" maxOccurs="1" minOccurs="1"/> <xs:element name="degreesOfFreedom" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="ellipseAngle" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="lengthOfSemiMajorAxis" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="lengthOfSemiMinorAxis" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="chiSquareValue" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="risetimeOfWaveform" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="peakToZeroTime" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="maxRateOfRise" type="xs:double" maxOccurs="1" minOccurs="1"/> <xs:element name="cloudIndicator" type="xs:boolean" maxOccurs="1" minOccurs="1"/> <xs:element name="angleIndicator" type="xs:boolean" maxOccurs="1" minOccurs="1"/> <xs:element name="signalIndicator" type="xs:boolean" maxOccurs="1" minOccurs="1"/> <xs:element name="timingIndicator" type="xs:boolean" maxOccurs="1" minOccurs="1"/> </xs:sequence> </xs:complexType> </xs:schema> Source
It is notable that the links to data points to zip-archives with rel
set to data
and type
set to application/zip