2020-04-22 19:37:10 +01:00
<!DOCTYPE html>
< html >
< head >
< meta http-equiv = "Content-Type" content = "text/html; charset=utf-8" / >
< title > Handbook Troggle Architecture Speculations< / title >
< link rel = "stylesheet" type = "text/css" href = "../../css/main2.css" / >
< / head >
< body > < style > body { background : #fff url ( /images/style/bg-system.png ) repeat-x 0 0 } < / style >
< h2 id = "tophead" > CUCC Expedition Handbook< / h2 >
< h1 > Troggle Architecture Speculations< / h1 >
< pre >
From: Philip Sargent (Gmail) [mailto:philip.sargent@gmail.com]
2020-07-09 23:48:02 +01:00
Sent: 19 April 2020 01:28 [original - since edited with extra refs.]
2020-04-22 19:37:10 +01:00
To: expo-tech@lists.wookware.org
Subject: vague thoughts about future troggle architecture
< / pre >
< p >
At our last virtual pub Sam confirmed that using today's tools to
re-partition troggle with all the user interface in the user's browser would
be utterly horrible using current tools (javascript frameworks: react,
angular etc.).
< p >
2020-07-09 23:48:02 +01:00
These front-end frameworks get out of date in couple of years or so. So they don't
2020-04-22 19:37:10 +01:00
give us the decade-long stability we need to match available maintenance
2020-07-09 23:48:02 +01:00
effort. [ See < a href = "https://en.wikipedia.org/wiki/Comparison_of_JavaScript_frameworks" >
Wikipedia list of javascript frameworks< / a > .] With our deep historical perspective ("cough"),
we can expect this menagerie to sort itself out into a stable, standardised foundation
within the next 10 years.
2020-04-22 19:37:10 +01:00
< p >
A web API to expose the troggle database (read-only) would allow some keen
person to write a special-purpose app on a phone, e.g. an entrance-locator
app, talking directly to the database. But replacing the whole user
2020-07-09 23:48:02 +01:00
interface does not seem feasible yet. In 10 years: probably.
2020-04-22 19:37:10 +01:00
< p >
It did occur to me that we are missing a trick: 99+% of the database doesn't
change except for survey data updates which, apart from during expo, happen
only every week or so. And the database is only 10 MB so is entirely
feasible to copy absolutely everything into the browser except for scanned
images and photos.
< p >
So we could partition troggle so that all the user display bits run in the
browser (or a progressive web app) using a python interpreter running in
javascript. [yeah, expofiles would need some subset labelled as needing to
be forcibly downloaded, but the rest coming only on demand.] Some django
enthusiast must have done this already surely ? Ah yes, Brython.< br >
< a href = "https://github.com/brython-dev/brython" > github.com/brython-dev/brython< / a > < br >
< a href = "https://www.brython.info/" > www.brython.info< / a >
< p >
Which is fun, but not useful. And not just because it is immature. None of
2020-05-12 19:59:10 +01:00
this addresses < strong > our biggest problem: devising something that can be
2020-04-22 19:37:10 +01:00
maintained by fewer, less-expert people who can only devote short snippets
2020-05-12 19:59:10 +01:00
of time and not long-duration immersion< / strong > .
2020-05-14 22:28:13 +01:00
< h3 > Our biggest problem< / h3 >
We need:
< ul >
< li > something that can be maintained by fewer, less-expert people
< li > who can only devote short snippets of time
< li > without requiring weeks of long-duration deep immersion
< / ul >
< h3 > Federation of independent scripts< / h3 >
2020-04-22 19:37:10 +01:00
< p >
I know Wookey has been thinking of a loose federation of independent scripts
working on the same data, but the more I look at troggle and the tasks it
2020-05-12 19:59:10 +01:00
does the less I feel that would work. < strong > At the core there is a common data
model that everything must understand< / strong > - and the only unambiguous way of
2020-04-22 19:37:10 +01:00
presenting that data model is working code, e.g. see
< a href = "http://expo.survex.com/handbook/troggle/trogarch.html" > Troggle architecture< / a > and click on the image
to see a bigger copy. [It is out of date - if someone can quickly generate
an update that would be nice. It's on my < a href = "../computing/todo.html" > to-do list..< / a > ] Much of what
wallets.py does (originally by Martin Green) is in troggle already - but
better. [There is a many:many relationship between svx files and wallet
directories in reality, not 1:1]
< p >
2020-05-14 22:28:13 +01:00
< h3 > troggle now< / h3 >
2020-04-22 19:37:10 +01:00
Troggle is very nearly fully working (not with as many functions as
2020-07-09 23:48:02 +01:00
originally envisaged admittedly) but very nearly [it is now: 8 July 2020].
2020-05-14 22:28:13 +01:00
The QM data display needs writing; but other than that it's in pretty good
2020-04-22 19:37:10 +01:00
shape. [Ah, yes, we should really add "drawings" as a core concept as well
as "surveyscans". That will be a bit of work.]
< p >
2020-05-14 22:28:13 +01:00
< h3 > Need for separate data-import checking scripts< / h3 >
2020-04-22 19:37:10 +01:00
The one thing external scripts would be really useful for is syntax checking
and reference checking prior to import. I have found some weird and
wonderful filename paths inside the tunnel and therion drawings, and in
survex *ref paths.
2020-05-14 22:28:13 +01:00
< h3 > Non-django troggle< / h3 >
< p > Another possibility is ripping django out of troggle and leaving bare python
2020-07-09 23:48:02 +01:00
plus a SQL database [see < a href = "trog2030.html" > Trog2030 proposal< / a > ]. This means that programmers would need to understand more SQL but would not need to understand "django". Arguably this
2020-05-14 22:28:13 +01:00
could mean that we could gain.
< p > Writing our own multi-user code would not be sensible, hence the database.
But we could move to a read-only system where the only writing happens on data-import.
Then we could use python 'pickle()' or 'json()' read-only data structures, but we
would need to create all our own indexing and cross-referencing code.
< p > There would be more lower-level code, but the
different segments of the system could be in caving-sensible modules not
django-meaningful modules. And we would not have all the extra
language-like constructs that django introduces e.g. < var > X.objects.set_all()< / var > , which
modern editors complain about because it is a django idiom and
not a function within the python codebase.
(We could retain an HTML templating engine though.)
< h3 > < em > Addendum< / em > < / h3 >
2020-04-22 19:37:10 +01:00
< p > There is a templating engine < a href = "https://mozilla.github.io/nunjucks/" > Nunjucks< / a >
which is a port to JavaScript of the Django templating system we use
(via < a href = "https://palletsprojects.com/p/jinja/" > Jinja< / a > - these are the same people who do Flask). This would be an obvious thing to use if we needed to go in that direction.
2020-07-09 23:48:02 +01:00
< p > We need a templating engine because so much of the troggle coorindation output is in tables of data from diffrerent sources, e.g. see < a href = /survexfile/264" > all survey data for 264< / a > .
2020-04-22 19:37:10 +01:00
< p > Several organisations have moved their user-interface layer to the browser using
Nunjucks including < a href = "https://service-manual.nhs.uk/design-system/prototyping" >
the NHS digital service< / a > and Firefox.
< hr / >
2020-07-27 01:42:09 +01:00
Return to: < a href = "trogdesign.html" > Troggle design and future implementations< / a > < br / >
Return to: < a href = "trogintro.html" > Troggle intro< / a > < br / >
Troggle index:
< a href = "trogindex.html" > Index of all troggle documents< / a > < br / >
2020-04-22 19:37:10 +01:00
< hr / >
< / body >
< / html >