/poligrok

A Lens on Climate Policy

Primary LanguageJupyter NotebookMIT LicenseMIT

PoliGrok

A Lens on Climate Policy

Inspiration

Laws are the software of society. They enable it to function. Laws are code, written by programmers (aka lawyers and legislators).

On a global level there’s a lot of duplication in legal texts across countries. There’s also a lot of embedded knowledge. That can be useful, especially in emerging legal branches like climate policy.

We want citizens to be able to reuse work that has already been created and proven. In order to do that we need to extract the knowledge from legal policies and render it in human readable form. We want to provide the evidence “for evidence-based policy making”.

What it does

PoliGrok is a tool to analyze a collection of policy documents. As material we were provided with a couple thousand polices, from countries around the world, in various languages. A team of editors had laboriously created summaries and added metadata. Our task is to dig deeper into the full text of the documents and find answers to researchers’ questions.

Instructions for Azure Cloud & Amber

Ambar github page

Setting up an Azure VM

Create a new VM. Ensure resources are registered to the subscription bound to the resource group

az vm create \
  --resource-group <RESOURCE_NAME> \
  --name <NAME>\
  --image UbuntuLTS \
  --admin-username azureuser \
  --generate-ssh-keys

Open port 80, 443, 22 for nginx / webservers, ssh

az vm open-port --port 80 --resource-group <RESOURCE_NAME> --name <NAME> -- priority 110
az vm open-port --port 443 --resource-group <RESOURCE_NAME> --name <NAME> --priority 120
az vm open-port --port 22 --resource-group <RESOURCE_NAME> --name <NAME> --priority 105
az vm open-port --port 8080 --resource-group PoliGrok --name laurence_vm --priority 130
az vm open-port --port 8081 --resource-group PoliGrok --name laurence_vm --priority 131
az vm open-port --port 8082 --resource-group PoliGrok --name laurence_vm --priority 133

scp documents

scp "/Users/laurence/Downloads/Afghanistan Energy Sector Strategy 1387-1391 (2007:8-2012:3).pdf" azureuser@51.137.93.137:/tmp/documents

Connect to VM

ssh azureuser@<PUBLIC_IP>

Docker and Docker-compose

Install docker and docker-compose using standard instructions.

Private repo for Ambar images

docker login http://repo.ambar.cloud:443

usernamee: USERNAME password: PASSWORD

Edit the docker-compose.yml file, with the Public ip of the vm, only for the frontend service

frontend:
    depends_on:
      webapi:
        condition: service_healthy
    image: repo.ambar.cloud:443/ambar-frontend:2.1
    restart: always
    networks:
      - internal_network
    ports:
      - "80:80"
    expose:
      - "80"
    environment:
      - api=http://__PUBLIC IP__:8080

Resize VM

az vm resize --resource-group <RESOURCE_NAME> --name <NAME> --size Standard_E2s_v3

Troubleshooting

Logging in to the private docker repo - try removing docker login tools.
sudo apt remove golang-docker-credential-helpers