Download

There are two schema files available to download that are both needed to consume the API.

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 identifier
  • update - timestamp of last modification time
  • title - the name of the resource
  • summary - 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