Skip to content

origo-map/origo-server

Repository files navigation

Origo server

Install Origo server

The minimum requirements are:

  • Git
  • Node.js (version 4 or higher is recommended)
  1. To get your own local copy of Origo server use git to clone the repository with the command below:

      git clone https://github.com/origo-map/origo-server.git
    
  2. To install the required node dependencies run the following command from the root directory of origo-server:

       npm install
    

    install without optional dependencies

    npm install --no-optional

  3. To start Origo server, run:

      node app.js
    

The server will be available at http://localhost:3001/origoserver.

The database dependencies in Origo server are optional and if any of the modules fails to install it will be skipped. Currently Origo server supports MS SQL Server, Oracle and PostgreSQL.

Install Origo server as a Windows service

Origo can be installed as a Windows service. Run the following command from tasks:

node create_windowsservice.js

Make sure the paths specified in create_windowsservice.js are correct.

To uninstall run the following command:

node uninstall_windowsservice.js

Current services provided

Basic configuration needed in conf/config.js and/or conf/dbconfig.js. More information about configuration can be found in the CONFIG.md file.

Configured services at:

  • Inskrivning Direkt - configuration of serviceparts at models/inskrivning.js

    /origoserver/estate/inskrivning?fnr={fastighetsnyckel}
    
    /origoserver/estate/inskrivning?objektid={objektidentitet}
    
  • Byggnad Direkt - set consumer_key and consumer_secret in conf/config.js

    /origoserver/lm/building?registerenhet={objektidentitet of estate}
    
    /origoserver/lm/building?uuid={objektidentitet of building}
    
  • Akt Direkt

    /origoserver/document/index.djvu?archive={archive/county-number}&id={akt-number}
    
    /origoserver/document/page_{vers}_{subdoc}_{page}_{archive}_{id}.djvu
    
  • Search

    /origoserver/addressestatesearch?q={defined in dbconfig.js}
    
    /origoserver/search?q={defined in dbconfig.js}
    
    /origoserver/singlesearch?q={defined in dbconfig.js}
    
  • Proxys

    /origoserver/proxy
    
    /origoserver/lmproxy-ver
    
    /origoserver/lmproxy
    
  • Höjd Direkt - set consumer_key and consumer_secret in conf/config.js

    /origoserver/lm/elevation/{EPSG code}/{longitude}/{latitude}
    
    Get ground height for coordinate
    
    /origoserver/lm/elevation/{EPSG code}
    
    POST a GeoJSON to get all coordinates set to elevation in response
    
  • Ortnamn Direkt - set consumer_key and consumer_secret in conf/config.js

    /origoserver/lm/placenames/?q={searchstring}&kommunkod={4-digit number for the municipality}&limit={number}&nametype={placename type}&lang={language name}&srid={EPSG code}
    
  • Registerbeteckning Direkt - set consumer_key and consumer_secret in conf/config.js

    /origoserver/lm/registerenheter?q={searchstring}&srid={EPSG code}&maxHits={number}
    
    The {searchstring} should start with one or multiple, seperated by commas, municipalities and then a space followed by the free text search for the address. For example "Sundsvall,Hudiksvall Nyland 99:1"
    
    /origoserver/lm/registerenheter?&fnr={UUID}
    
    /origoserver/lm/registerenheter/{UUID}/enhetsomraden
    
    /origoserver/lm/registerenheter?x={easting}&y={northing}&srid={EPSG code}
    
    /origoserver/lm/enhetsomraden?x={easting}&y={northing}&srid={EPSG code}&type={merged/full}
    
    Type can be merged or full, default is merged. Full will get the full response from Lantmäteriet and merged will give enhetsomraden polygon and only a subset of properties.
    
  • Belägenhetsadress Direkt - set consumer_key and consumer_secret in conf/config.js

    /origoserver/lm/addresses?q={searchstring}&srid={EPSG code}&maxHits={number}&municipalityCodes={codes}&statusAddress={status}
    
    The {searchstring} can start with one or multiple, seperated by commas, municipalities and then a space followed by the free text search for the address. For example "Sundsvall,Hudiksvall Storgatan". The {number} specifies total number of hits that should be returned, default is 30. If the search is done on multiple municipalities the total is multiplied as well. The {codes} should be one or more 'kommunkod' separated by comma. If  'municipalityCodes' is set there is no need to have municipalities in the {searchstring}. With {statusAddress} it's possible to limit the search to a specific status, default is 'Gällande'.
    
    /origoserver/lm/addresses?northing={northing}&easting={easting}&srid={EPSG code}&format={format}
    
    Supply coordinates and get the closest address to those coordinates. Default format is GeoJSON, but Origo can also be used.
    
  • IoTProxy - translates the IoT standard NGSI-LD to GeoJSON

    /origoserver/iotproxy/?q={service name}&srid={EPSG code}
    
    The {service name} specified in the config. Transforms coordinates to Sweref99 TM (EPSG:3006) if no srid is supplied.
    
  • Overpass - sends Overpass queries for OpenStreetMap and returns GeoJSON

    /origoserver/overpass/?q={query name}
    
    The {query name} specified in the config.
    
  • Trafikverket API - fetches data from Trafikverket API

    /origoserver/tvapi/?q={query name}&output={format}
    
    The {query name} specified in the config. The format of the output if not the standard from Trafikverket API, currently only supported GeoJSON.
    
  • ConvertToGeojson - translates a none standard json to GeoJSON FeatureCollection

    /origoserver/converttogeojson/?q={query name}
    
    The {query name} specified in the config.
    
  • Authorization - openid authorization and token refresh

    Configure auth in conf/config.js
    
    The {clients} contains the different clients which this origo server will support (which need authentication). Since the authentication is done externally, the clients need a way to get back to their urls, then the client has to have an defined identifier which is also defined here with a url, used for the redirect.
    
  • NGP Detaljplan - get documents from detailed plans

    Configure ngpDetaljplan in conf/config.js
    
    /origoserver/attachments/ngp/dpdocuments/something-like-the-layername/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/attachments
    
    /origoserver/attachments/ngp/dpdocuments/something-like-the-layername/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/attachments/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
    
  • Attachment - list, get, add and delete files to features

    Configure attachment in conf/config.js
    
    /origoserver/attachment/{something-like-the-layername}/{a unique identifier}/attachments
    
    A GET request to list all attachments for a specific object.
    
    /origoserver/attachment/{something-like-the-layername}/attachments
    
    A GET request to list all attachments for a specific layer/collection.
    
    /origoserver/attachment/{something-like-the-layername}/{a unique identifier}/attachments/{uuid}
    
    A GET request to get the url for the attachment with a specific uuid.
    
    /origoserver/attachment/{something-like-the-layername}/{a unique identifier}/addAttachment
    
    POST a file to store it in the configured folder under the sub-folder {something-like-the-layername}/{a unique identifier}/{group}. Requires "Content-Type: multipart/form-data" with the multipart fields "attachment" and "group".
    
    /origoserver/attachment/{something-like-the-layername}/{a unique identifier}/deleteAttachments
    
    POST a string of comma-separated attachment IDs as a JSON body, e g { attachmentIds: "id1,id2,etc" } to delete the specified attachments.
    
    /origoserver/attachment/{something-like-the-layername}/{a unique identifier}/deleteAttachments/
    
    A GET request to delete all attachments for a specific object.
    
  • Samfällighetsförening Direkt - Show information from Samfällighetsförening Direkt API from Lantmäteriet.

    Configure attachment in conf/config.js
    
    /origoserver/lm/communityassociation/{objektidentitet of the community association}
    
    A GET request to show the information on the community association.
    
    /origoserver/lm/communityassociation/beror/{objektidentitet of the object the association maintains}
    
    A GET request to show the information on the community association associated with this object.
    
    /origoserver/lm/communityassociation/filter?lanskod={two digit code}&sate={municipality name}&sateMatch={search method}&kommunkodForvaltningsobjekt={four digit code}&namn={association name}&namnMatch={search method}&foreningstyp={type of association}&andamal={purpose of maintaince object}&maxHits={number}&srid={EPSG code}
    
     A GET request to list community association based on search parameters. To get the response as a GeoJSON add header "Accept: application/geo+json" in the request, can be used to integrate as Origo layer although the response may take several seconds so shouldn't be used directly. Download the GeoJSON beforehand and publish on webserver or use a geospatial data server to serve the data.
    
     Filters parameters:
    
    - lanskod - the code of the county (two digit code)
    
    - sate - the name of the seat of municipalty the the association resides.
    
    - sateMatch - the way the search for seat is to be done. Valid values "equals", "startsWith", "contains", "endsWith".
    
    - kommunkodForvaltningsobjekt - the code of the municipality (four digit code)
    
    - namn - the name of the association.
    
    - namnMatch - the way the search for name is to be done. Valid values "equals", "startsWith", "contains", "endsWith".
    
    - foreningstyp - the type of the association. Valid values "LGA-samfällighet", "Vägsamfällighet", "Vägförening", "Samfällighetsförening".
    
    - andamal - the purpose of maintaince object. Valid values "Anläggning enligt vattenlagen", "Avloppsanläggning", "Bad och/eller båtanläggning", "Elledning och/eller belysning", "Garage och/eller parkering", "Grönområden", "Kvartersanläggning", "Radio- TV och/eller tele", "Skiftessamfälligheter", "Vattenförsörjning", "Vägar", "Värmeanläggning", "Övrigt".
    
    - maxHits - the maximum numbeers of hits returned. Default 100. Set a value of 0 or less to get unlimited hits.
    
    - srid - the EPSG code of the coordinate referens system. Limited to Sweref 99 codes.
    
  • lmservices - Helper to get information from Lantmäteriet services. Can be used like this:

        const lmservices = require('./lmservices.js');
        const getStuff = async (req, res) => {
          const typ = req.query.typ;
          const fastighet = req.query.fastighet;
          const id = req.query.id || [];
          const hasAccess = await checkAccess();
          if(hasAccess){
            console.log("Has access");
            const response = await lmservices({ typ, fastighet, id, includeData: 'total' })
            res.json(response);
          } else {
            console.log("No access");
            res.send();
          }
        }
        module.exports = getStuff;
    

About

Origo server

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 13