Setting Up Geoweb

Guide to installing VertiGIS Studio Web and Studio Reporting.

Projects: c2platform/rws/ansible-gis, c2platform.wincore, c2platform.gis


Overview

This guide provides a step-by-step process to set up Geoweb, which includes VertiGIS Studio Web and Reporting.

  1. Vagrant creates a VirtualBox VM named gsd-geoweb and performs Sysprep on it.

  2. Vagrant runs the Ansible provisioner to prepare the VM for manual installation of the MSI:

    1. Open firewall ports for Web and Reporting.
    2. Create an SSL/TLS certificate.
    3. Install IIS.
    4. Create a service account sa_geoweb.
    5. Configure IIS: create websites, bindings, application pools, etc.
    6. Download the MSI and license file to the node gsd-geoweb.
  3. Connect to gsd-geoweb via RDP and manually run the installers1.

  4. Run the provisioner again to update the IIS configuration created by the VertiGIS installers to use the service account sa_geoweb.

NodeOSProviderPurpose
gsd-geowebWindows 2022 ServerVirtualBoxWeb and Reporting

Prerequisites

Setup

Run the following command:

vagrant up gsd-geoweb

Create App in ArcGIS Portal

  1. Navigate to https://gsd-agportal1.internal.c2platform.org/portal/home  and log in as portaladmin2.
    UsernamePassword
    portaladminportaladmin123
  2. Choose ContentNew ItemApplication
    PropertyValueComment
    Application TypeOther Application
    TitleGeoweb Modules registratie
    FolderKeep default portaldmin
    TagsGeoweb Vertigis Studio Modules
    SummaryApp for VertiGIS Studio modules registration
  3. Via SettingsApplicationUpdate:
    1. add the URL https://geoweb.c2platform.org/  ;
    2. add the Redirect URI
      • https://geoweb.c2platform.org/
      • https://geoweb.c2platform.org/ModuleViewer
      • https://geoweb.c2platform.org/ModuleReporting/designer
    3. Click Save.
  4. Copy the App ID / Client ID to your clipboard (e.g., 3a01FOjRkQJD2dCv).

Install Studio Web

  1. Connect to gsd-geoweb via RDP.
  2. Right-click on the Software shortcut on the Desktop and select Run as Administrator.
  3. Run VertiGIS-Studio-Web-5.31.0.msi.
    ModuleDestination Folder
    VertiGIS Studio WebD:\Apps\VertiGIS\Web
  4. Start post-installation configuration:
    PropertyValue
    IIS WebsiteModuleViewer
    Virtual Directory/ModuleViewer/
    Portal TypePortal for ArcGIS
    Portal URLhttps://gsd-agportal1.internal.c2platform.org/portal/home2
    App ID( value from previous step )
    Redirect URLhttps geoweb.c2platform.org

Install Studio Reporting

  1. Run as Administrator VertiGIS-Studio-Reporting-5.22.0.msi.
    ModuleDestination Folder
    VertiGIS Studio ReportingD:\Apps\VertiGIS\Reporting
  2. Post-installation configuration:
    PropertyValue
    Data DirectoryD:\ProgramData\Geocortex\Reporting
    IIS WebsiteModuleReporting
    Virtual Directory/ModuleReporting/
    Portal TypePortal for ArcGIS
    Portal URLhttps://gsd-agportal1.internal.c2platform.org/portal/home2
    App ID( value from previous step )
    Redirect URLhttps geoweb.c2platform.org /ModuleReporting/designer/

Verify

  1. Connect to gsd-geoweb as user vagrant, start IIS Manager, and review site settings:

    Site nameApplication PoolPhysical pathConnect as3
    ModuleViewerDefaultAppPoolD:\inetpub\StudioWebPass-through authentication
    ModuleReportingDefaultAppPoolD:\inetpub\ModuleReportingPass-through authentication

    Review site bindings:

    Site nameTypeIP addressPortHost nameSSL certificate
    ModuleViewerhttpAll Unassigned8080(empty)
    ModuleViewerhttpsAll Unassigned4443(empty)gsd-geoweb.internal.c2platform.org
    ModuleReportinghttpAll Unassigned8081(empty)
  2. Review applications:

    ApplicationApplication PoolPhysical PathConnect as
    ModuleViewerDefaultAppPoolD:\inetpub\ModuleReportingsa_geoweb
    ModuleReportingVertiGISStudioReportingD:\inetpub\ModuleReportingsa_geoweb
  3. Review application pools:

    Application PoolIdentity
    DefaultAppPoolsa_geoweb
    VertiGISStudioReportingsa_geoweb
  4. Navigate to https://geoweb.c2platform.org/ModuleViewer/  and https://geoweb.c2platform.org/ModuleReporting/  and login as portaladmin.

Review

In the inventory project c2platform/rws/ansible-gis:

  • The Geoweb play is located at plays/gis/geoweb.
  • The Geoweb configuration is in group_vars/geoweb.

The cplatform.gis.vertigis_studio Ansible role currently has minimal code. Downloads of MSI installers and the license file are handled by the c2platform.wincore.download role, while most configuration work is done by the c2platform.wincore.win role.

Certificates

The c2platform.gis.vertigis_studio Ansible role, part of the Ansible GIS Collection c2platform.gis, uses the Ansible role c2platform.core.cacerts2 to create and deploy certificates trusted on all nodes (including gsd-geoweb). On gsd-geoweb, the deployed certificate is used to create IIS HTTPS bindings.

  1. The trust relationship for certificates created with the cacerts2 role is configured in the file group_vars/windows/main.yml, applying to all Windows hosts:
    win_resources:
       0-bootstrap:
          - name: Download c2.crt
            type: win_get_url
            url: https://gitlab.com/c2platform/rws/ansible-gis/-/raw/master/.ca/c2/c2.crt?ref_type=heads
            dest: C:\tmp\c2.crt
          - name: C2 CA Server Trust Relationship
            type: win_certificate_store
            path: C:\tmp\c2.crt
            store_name: Root
            store_location: LocalMachine
    
  2. The file group_vars/geoweb/certs.yml contains the configuration for the certificate as part of the vertigis_studio_cacerts2_certificates variable, deploying it to C:\ProgramData\Certs\geoweb-GSD-GEOWEB.p12.
  3. The file group_vars/geoweb/win.yml contains the configuration to import the certificate into the Windows certificate store using the variable vertigis_studio_win_resources, which includes:
     - name: Import Geoweb Certificate
       type: win_certificate_store
       path: "{{ vertigis_studio_cacerts2_certificates[0]['deploy']['p12']['dest'] }}"
       key_exportable: true
       store_name: My
       key_storage: machine
       store_location: LocalMachine
       state: present
    
  4. Finally, the variable vertigis_studio_win_resources is used to manage IIS HTTPS bindings with an item similar to:
     - name: Add IIS HTTPS bindings
       type: win_iis_webbinding
       defaults:
         ssl_flags: 0  # sni disabled
         protocol: https
         certificate_friendly_name: "{{ gs_geoweb_certificate_friendly_name }}"
         state: present
       resources:
         - name: ModuleViewer
           port: "{{ gs_vertigis_studio_web_port_ssl }}"
         - name: ModuleReporting
           port: "{{ gs_vertigis_studio_reporting_port_ssl }}"
    

Additional Information

Footnotes


  1. Automating the MSI might be possible using a script similar to install-vsw.ps1  , but it does not seem supported to use a different virtual directory. The parameter VirtualPath appears to be ignored. ↩︎

  2. The reverse proxy URL https://age.c2platform.org/portal/home/ is currently not working. Instead, use https://gsd-agportal1.internal.c2platform.org/portal/home↩︎ ↩︎ ↩︎

  3. The win_iis_website module does not allow configuring a different “connect as” user. If this needs to be changed, it must be done manually. ↩︎



Last modified November 20, 2024: ansibe concept C2-572 (dd7007e)