Ejemplo n.º 1
0
 def syncdb(args):
     print "syncing database"
     eal = EAlGIS()
     db = eal.db
     db.create_all()
     db.session.commit()
     eal.create_extensions()
Ejemplo n.º 2
0
    def query(args):
        eal = EAlGIS()
        from dataexpr import DataExpression
        iters = []
        data = {}
        for expr in args.equation:
            ti = eal.get_table_info(args.geometry)
            geometry_source = ti.geometry_source
            it = iter(
                DataExpression("CLI",
                               geometry_source,
                               expr,
                               "",
                               3112,
                               include_geometry=False,
                               order_by_gid=True).get_query().yield_per(1))
            data[expr] = {}
            for gid, v in it:
                data[expr][gid] = v
        all_gids = set()
        for expr in data:
            all_gids = all_gids.union(set(data[expr].keys()))
        w = csv.writer(sys.stdout)
        w.writerow(['gid'] + args.equation)

        for gid in sorted(all_gids):
            row = [gid] + [data[t].get(gid) for t in args.equation]
            w.writerow(row)
Ejemplo n.º 3
0
 def build_layer(geo_query):
     layer = mapscript.layerObj()
     layer.type = mapscript.MS_LAYER_POLYGON
     layer.status = mapscript.MS_DEFAULT
     layer.name = self.name = name
     layer.connectiontype = mapscript.MS_POSTGIS
     eal = EAlGIS()
     layer.connection = "host=%s port=%s dbname=%s user=%s password=%s" % (eal.dbhost(), eal.dbport(), eal.dbname(), eal.dbuser(), eal.dbpassword())
     layer.data = geo_query
     # layer.label = "[sa1_7digit]"
     layer.processing = "CLOSE_CONNECTION=DEFER"
     layer.labelitem = None
     return layer
Ejemplo n.º 4
0
 def add_user(args):
     eal = EAlGIS()
     db = eal.db
     addresses = []
     for s in args.email_address:
         parts = [t.strip() for t in s.split(',')]
         for part in parts:
             name, email_address = email.utils.parseaddr(part)
             addresses.append((name, email_address))
     for (name, email_address) in addresses:
         if eal.get_user_by_email(email_address) is not None:
             print "User %s / %s already has access, skipped." % (name, email_address)
             continue
         db.session.add(User(email_address=email_address, name=name))
         db.session.commit()
         print "User %s / %s added." % (name, email_address)
Ejemplo n.º 5
0
 def add_user(args):
     eal = EAlGIS()
     db = eal.db
     addresses = []
     for s in args.email_address:
         parts = [t.strip() for t in s.split(',')]
         for part in parts:
             name, email_address = email.utils.parseaddr(part)
             addresses.append((name, email_address))
     for (name, email_address) in addresses:
         if eal.get_user_by_email(email_address) is not None:
             print "User %s / %s already has access, skipped." % (name, email_address)
             continue
         db.session.add(User(email_address=email_address, name=name))
         db.session.commit()
         print "User %s / %s added." % (name, email_address)
Ejemplo n.º 6
0
def api_datainfo_table(table_name):
    table_info = EAlGIS().get_table_info(table_name)
    if table_info is None:
        abort(404)
    info = {}
    info['columns'] = columns = {}
    for column in table_info.column_info.all():
        columns[column.name] = json.loads(column.metadata_json)
    return jsonify(info)
Ejemplo n.º 7
0
 def __init__(self, rev, defn):
     self.instance = mapscript.mapObj(
         os.path.expanduser('/app/backend/mapserver/template.map'))
     self.instance.imagetype = 'png'
     self.instance.setProjection('init=epsg:%s' %
                                 (EAlGIS().get_setting('map_srid')))
     self.rev = rev
     self.layers = []
     self.layers.append(self.make_base_layer(defn))
Ejemplo n.º 8
0
 def build_layer(geo_query):
     layer = mapscript.layerObj()
     layer.type = mapscript.MS_LAYER_POLYGON
     layer.status = mapscript.MS_DEFAULT
     layer.name = self.name = name
     layer.connectiontype = mapscript.MS_POSTGIS
     eal = EAlGIS()
     layer.connection = "host=%s port=%s dbname=%s user=%s password=%s" % (
         eal.dbhost(), eal.dbport(), eal.dbname(), eal.dbuser(),
         eal.dbpassword())
     layer.data = geo_query
     # layer.label = "[sa1_7digit]"
     layer.processing = "CLOSE_CONNECTION=DEFER"
     layer.labelitem = None
     return layer
Ejemplo n.º 9
0
 def run(args):
     eal = EAlGIS()
     opts = []
     if args.opts is not None:
         opts = [t.split(':', 2) for t in args.opts.split(',')]
     for module in args.module:
         module_name = os.path.splitext(os.path.basename(module))[0]
         opts_module = dict([tuple(t[1:3]) for t in opts if t[0] == module_name])
         print "running loader:", module, repr(opts_module)
         loader = imp.load_source('_plugin', module)
         tmpdir = '/data/tmp'
         try:
             os.mkdir(tmpdir)
         except OSError:
             pass
         loader.go(eal, tmpdir, **opts_module)
         del loader
Ejemplo n.º 10
0
def api_map(map_name):
    eal = EAlGIS()
    defn = MapDefinition.get_by_name(map_name)
    if request.method == 'POST':
        if (defn is not None) and (not is_administrator(defn)):
            abort(403)
        try:
            if 'json' not in request.form:
                abort(400)
            if defn is None:
                defn = MapDefinition(name=map_name)
                eal.db.session.add(defn)
                eal.db.session.commit()
            try:
                rev = defn.set(json.loads(request.form['json']))
                eal.db.session.commit()
            except ValueError:
                abort(400)
            return jsonify(status="OK", updated=defn.get(), rev=rev)
        except CompilationError as e:
            return jsonify(status="ERROR",
                           title="Expression compilation failed",
                           mesg=e.message)
        except NoMatches as e:
            return jsonify(status="ERROR",
                           title="Attribute could not be resolved",
                           mesg=e.message)
        except TooManyMatches as e:
            return jsonify(status="ERROR",
                           title="Attribube reference is ambiguous",
                           mesg=e.message)
    elif request.method == 'DELETE':
        if defn is None:
            abort(404)
        if not is_administrator(defn):
            abort(403)
        eal.db.session.delete(defn)
        eal.db.session.commit()
        return jsonify(status="OK")
    else:
        if defn is None:
            abort(404)
        return jsonify(defn=defn.get(), administrator=is_administrator(defn))
Ejemplo n.º 11
0
 def unload(args):
     eal = EAlGIS()
     eal.unload(args.table_name)
Ejemplo n.º 12
0
# top-level for flask CLI
from db import EAlGIS

eal = EAlGIS()
app = eal.app
Ejemplo n.º 13
0
 def syncdb(args):
     print "syncing database"
     db = EAlGIS().db
     db.create_all()
     db.session.commit()
Ejemplo n.º 14
0
 def fn_set(args):
     eal = EAlGIS()
     eal.set_setting(args.key, args.value)
     print("`%s' now set to `%s'" % (args.key, args.value))
Ejemplo n.º 15
0
def api_datainfo():
    eal = EAlGIS()
    return jsonify(eal.get_datainfo())
Ejemplo n.º 16
0
try:
    import simplejson as json
except ImportError:
    import json
import urllib
from flask import request, jsonify, abort, Response
from flask.ext.login import current_user, login_required
from db import EAlGIS, MapDefinition, Setting, NoMatches, TooManyMatches, CompilationError
from colour_scale import colour_for_layer, definitions
app = EAlGIS().app

# handler broken out due to complexity of surrounding code
from mapserver import mapserver_wms  # noqa


@app.route("/api/0.1/maps", methods=['POST', 'GET'])
@login_required
def api_maps():
    r = {}
    for m in MapDefinition.query.all():
        r[m.name] = {"description": m.description}
    return jsonify(r)


def is_administrator(map_defn):
    email = current_user.get_email()
    administrators = map_defn.get().get('administrators')
    # for now it's more sane to not lock anyone out if there are no admins
    # eg. treat as public
    if administrators is None:
        return True
Ejemplo n.º 17
0
def settings():
    settings_obj = {}
    eal = EAlGIS()
    for setting in eal.db.session.query(Setting).all():
        settings_obj[setting.key] = setting.value
    return jsonify(settings_obj)
Ejemplo n.º 18
0
#!/usr/bin/env python

# top-level for uwsgi
from db import EAlGIS

eal = EAlGIS()
app = eal.serve()

# load in URL handlers
import handlers
Ejemplo n.º 19
0
 def fn_clear(args):
     eal = EAlGIS()
     eal.clear_setting(args.key)
     print("`%s' cleared." % (args.key))
Ejemplo n.º 20
0
 def fn_clear(args):
     eal = EAlGIS()
     eal.clear_setting(args.key)
     print("`%s' cleared." % (args.key))
Ejemplo n.º 21
0
 def georelate(args):
     eal = EAlGIS()
     left_source = eal.get_table_info(args.geom_left).geometry_source
     right_source = eal.get_table_info(args.geom_right).geometry_source
     from .georelate import build_relations
     build_relations(left_source, right_source)
Ejemplo n.º 22
0
 def list_users(args):
     db = EAlGIS().db
     w = csv.writer(sys.stdout)
     for user in db.session.query(User).order_by(User.email_address):
         w.writerow([user.email_address, user.name])
Ejemplo n.º 23
0
 def recompile(args):
     eal = EAlGIS()
     eal.recompile_all()
     eal.db.session.commit()
Ejemplo n.º 24
0
def main():
    import argparse
    parser = argparse.ArgumentParser()
    parser.add_argument('--verbose',
                        '-v',
                        action='store_const',
                        const=True,
                        help='verbose mode')
    subparsers = parser.add_subparsers(help='sub-command help')

    def syncdb(args):
        print "syncing database"
        eal = EAlGIS()
        db = eal.db
        db.create_all()
        db.session.commit()
        eal.create_extensions()

    def list_users(args):
        db = EAlGIS().db
        w = csv.writer(sys.stdout)
        for user in db.session.query(User).order_by(User.email_address):
            w.writerow([user.email_address, user.name])

    def add_user(args):
        eal = EAlGIS()
        db = eal.db
        addresses = []
        for s in args.email_address:
            parts = [t.strip() for t in s.split(',')]
            for part in parts:
                name, email_address = email.utils.parseaddr(part)
                addresses.append((name, email_address))
        for (name, email_address) in addresses:
            if eal.get_user_by_email(email_address) is not None:
                print "User %s / %s already has access, skipped." % (
                    name, email_address)
                continue
            db.session.add(User(email_address=email_address, name=name))
            db.session.commit()
            print "User %s / %s added." % (name, email_address)

    def query(args):
        eal = EAlGIS()
        from dataexpr import DataExpression
        iters = []
        data = {}
        for expr in args.equation:
            ti = eal.get_table_info(args.geometry)
            geometry_source = ti.geometry_source
            it = iter(
                DataExpression("CLI",
                               geometry_source,
                               expr,
                               "",
                               3112,
                               include_geometry=False,
                               order_by_gid=True).get_query().yield_per(1))
            data[expr] = {}
            for gid, v in it:
                data[expr][gid] = v
        all_gids = set()
        for expr in data:
            all_gids = all_gids.union(set(data[expr].keys()))
        w = csv.writer(sys.stdout)
        w.writerow(['gid'] + args.equation)

        for gid in sorted(all_gids):
            row = [gid] + [data[t].get(gid) for t in args.equation]
            w.writerow(row)

    def delete_user(args):
        db = EAlGIS().db
        u = User.query.filter(User.email_address == args.email_address).one()
        db.session.delete(u)
        db.session.commit()

    def unload(args):
        eal = EAlGIS()
        eal.unload(args.table_name)

    def georelate(args):
        eal = EAlGIS()
        left_source = eal.get_table_info(args.geom_left).geometry_source
        right_source = eal.get_table_info(args.geom_right).geometry_source
        from .georelate import build_relations
        build_relations(left_source, right_source)

    def fn_set(args):
        eal = EAlGIS()
        eal.set_setting(args.key, args.value)
        print("`%s' now set to `%s'" % (args.key, args.value))

    def fn_clear(args):
        eal = EAlGIS()
        eal.clear_setting(args.key)
        print("`%s' cleared." % (args.key))

    def run(args):
        eal = EAlGIS()
        opts = []
        if args.opts is not None:
            opts = [t.split(':', 2) for t in args.opts.split(',')]
        for module in args.module:
            module_name = os.path.splitext(os.path.basename(module))[0]
            opts_module = dict(
                [tuple(t[1:3]) for t in opts if t[0] == module_name])
            print "running loader:", module, repr(opts_module)
            loader = imp.load_source('_plugin', module)
            tmpdir = '/data/tmp'
            try:
                os.mkdir(tmpdir)
            except OSError:
                pass
            loader.go(eal, tmpdir, **opts_module)
            del loader

    def recompile(args):
        eal = EAlGIS()
        eal.recompile_all()
        eal.db.session.commit()

    # parse command line options, then hand off to the appropriate
    # function listed above
    parser_syncdb = subparsers.add_parser('syncdb', help='Sync Database')
    parser_syncdb.set_defaults(func=syncdb)

    parser_set = subparsers.add_parser('set', help='Configure EAlGIS')
    parser_set.add_argument('key', type=str)
    parser_set.add_argument('value', type=str)
    parser_set.set_defaults(func=fn_set)

    parser_clear = subparsers.add_parser('clear', help='Configure EAlGIS')
    parser_clear.add_argument('key', type=str)
    parser_clear.set_defaults(func=fn_clear)

    parser_run = subparsers.add_parser('run', help='Run data loader')
    parser_run.add_argument('module',
                            type=str,
                            nargs='+',
                            help='Path to loader module')
    parser_run.add_argument('--opts', '-o', help='loader options')
    parser_run.set_defaults(func=run)

    parser_listusers = subparsers.add_parser('listusers', help="List users")
    parser_listusers.set_defaults(func=list_users)

    parser_adduser = subparsers.add_parser('adduser', help="Add user(s)")
    parser_adduser.add_argument('email_address',
                                type=str,
                                nargs='+',
                                help="email address")
    parser_adduser.set_defaults(func=add_user)

    parser_query = subparsers.add_parser(
        'query', help="Evaluate equations on a geometry")
    parser_query.add_argument('geometry', type=str)
    parser_query.add_argument('equation',
                              type=str,
                              nargs='+',
                              help="equations to evaluate (eg. \"b3+b4\")")
    parser_query.set_defaults(func=query)

    parser_deleteuser = subparsers.add_parser('deleteuser', help="Add a user")
    parser_deleteuser.add_argument('email_address',
                                   type=str,
                                   help="email address")
    parser_deleteuser.set_defaults(func=delete_user)

    parser_unload = subparsers.add_parser('unload', help="Remove table")
    parser_unload.add_argument('table_name', type=str, help="Table to unload")
    parser_unload.set_defaults(func=unload)

    parser_georelate = subparsers.add_parser('georelate',
                                             help="Relate geometries")
    parser_georelate.add_argument('geom_left', type=str, help="Left geometry")
    parser_georelate.add_argument('geom_right',
                                  type=str,
                                  help="Right geometry")
    parser_georelate.set_defaults(func=georelate)

    parser_recompile = subparsers.add_parser(
        'recompile', help="Recompile cached SQL queries")
    parser_recompile.set_defaults(func=recompile)

    args = parser.parse_args()
    if args.verbose:
        EAlGIS().db.engine.echo = True
    args.func(args)
Ejemplo n.º 25
0
 def fn_set(args):
     eal = EAlGIS()
     eal.set_setting(args.key, args.value)
     print("`%s' now set to `%s'" % (args.key, args.value))
Ejemplo n.º 26
0
 def delete_user(args):
     db = EAlGIS().db
     u = User.query.filter(User.email_address == args.email_address).one()
     db.session.delete(u)
     db.session.commit()
Ejemplo n.º 27
0
 def recompile(args):
     eal = EAlGIS()
     eal.recompile_all()
     eal.db.session.commit()
Ejemplo n.º 28
0
 def unload(args):
     eal = EAlGIS()
     eal.unload(args.table_name)
Ejemplo n.º 29
0
#!/usr/bin/env python

# top-level for uwsgi
from db import EAlGIS

eal = EAlGIS()
app = eal.serve().wsgi_app

# load in URL handlers
import handlers  # noqa
Ejemplo n.º 30
0
 def georelate(args):
     eal = EAlGIS()
     left_source = eal.get_table_info(args.geom_left).geometry_source
     right_source = eal.get_table_info(args.geom_right).geometry_source
     from .georelate import build_relations
     build_relations(left_source, right_source)