mirror of
https://gitlab.silvrtree.co.uk/martind2000/censis-archive.git
synced 2025-01-10 21:55:08 +00:00
”2016-06-06”
This commit is contained in:
commit
68e54bc7d3
BIN
obrand/.DS_Store
vendored
Normal file
BIN
obrand/.DS_Store
vendored
Normal file
Binary file not shown.
26
obrand/obrand-admin-server/O-BrandServer/.editorconfig
Normal file
26
obrand/obrand-admin-server/O-BrandServer/.editorconfig
Normal file
@ -0,0 +1,26 @@
|
||||
# EditorConfig helps developers define and maintain consistent
|
||||
# coding styles between different editors and IDEs
|
||||
# editorconfig.org
|
||||
|
||||
root = true
|
||||
|
||||
|
||||
[*]
|
||||
end_of_line = lf
|
||||
charset = utf-8
|
||||
trim_trailing_whitespace = true
|
||||
insert_final_newline = true
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
|
||||
[*.{js,json,hbs,html,css}]
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
|
||||
[*.hbs]
|
||||
insert_final_newline = false
|
||||
|
||||
[*.{diff,md}]
|
||||
indent_size = 2
|
||||
trim_trailing_whitespace = false
|
||||
|
194
obrand/obrand-admin-server/O-BrandServer/.gitignore
vendored
Normal file
194
obrand/obrand-admin-server/O-BrandServer/.gitignore
vendored
Normal file
@ -0,0 +1,194 @@
|
||||
### Archives template
|
||||
# It's better to unpack these files and commit the raw source because
|
||||
# git has its own built in compression methods.
|
||||
*.7z
|
||||
*.jar
|
||||
*.rar
|
||||
*.zip
|
||||
*.gz
|
||||
*.bzip
|
||||
*.bz2
|
||||
*.xz
|
||||
*.lzma
|
||||
*.cab
|
||||
|
||||
#packing-only formats
|
||||
*.iso
|
||||
*.tar
|
||||
|
||||
#package management formats
|
||||
*.dmg
|
||||
*.xpi
|
||||
*.gem
|
||||
*.egg
|
||||
*.deb
|
||||
*.rpm
|
||||
*.msi
|
||||
*.msm
|
||||
*.msp
|
||||
### Windows template
|
||||
# Windows image file caches
|
||||
Thumbs.db
|
||||
ehthumbs.db
|
||||
|
||||
# Folder config file
|
||||
Desktop.ini
|
||||
|
||||
# Recycle Bin used on file shares
|
||||
$RECYCLE.BIN/
|
||||
|
||||
# Windows Installer files
|
||||
*.cab
|
||||
*.msi
|
||||
*.msm
|
||||
*.msp
|
||||
|
||||
# Windows shortcuts
|
||||
*.lnk
|
||||
### JetBrains template
|
||||
# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio
|
||||
|
||||
*.iml
|
||||
|
||||
## Directory-based project format:
|
||||
.idea/
|
||||
# if you remove the above rule, at least ignore the following:
|
||||
|
||||
# User-specific stuff:
|
||||
# .idea/workspace.xml
|
||||
# .idea/tasks.xml
|
||||
# .idea/dictionaries
|
||||
|
||||
# Sensitive or high-churn files:
|
||||
# .idea/dataSources.ids
|
||||
# .idea/dataSources.xml
|
||||
# .idea/sqlDataSources.xml
|
||||
# .idea/dynamic.xml
|
||||
# .idea/uiDesigner.xml
|
||||
|
||||
# Gradle:
|
||||
# .idea/gradle.xml
|
||||
# .idea/libraries
|
||||
|
||||
# Mongo Explorer plugin:
|
||||
# .idea/mongoSettings.xml
|
||||
|
||||
## File-based project format:
|
||||
*.ipr
|
||||
*.iws
|
||||
|
||||
## Plugin-specific files:
|
||||
|
||||
# IntelliJ
|
||||
/out/
|
||||
|
||||
# mpeltonen/sbt-idea plugin
|
||||
.idea_modules/
|
||||
|
||||
# JIRA plugin
|
||||
atlassian-ide-plugin.xml
|
||||
|
||||
# Crashlytics plugin (for Android Studio and IntelliJ)
|
||||
com_crashlytics_export_strings.xml
|
||||
crashlytics.properties
|
||||
crashlytics-build.properties
|
||||
### Xcode template
|
||||
# Xcode
|
||||
#
|
||||
# gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore
|
||||
|
||||
## Build generated
|
||||
build/
|
||||
DerivedData
|
||||
|
||||
## Various settings
|
||||
*.pbxuser
|
||||
!default.pbxuser
|
||||
*.mode1v3
|
||||
!default.mode1v3
|
||||
*.mode2v3
|
||||
!default.mode2v3
|
||||
*.perspectivev3
|
||||
!default.perspectivev3
|
||||
xcuserdata
|
||||
|
||||
## Other
|
||||
*.xccheckout
|
||||
*.moved-aside
|
||||
*.xcuserstate
|
||||
### OSX template
|
||||
.DS_Store
|
||||
.AppleDouble
|
||||
.LSOverride
|
||||
|
||||
# Icon must end with two \r
|
||||
Icon
|
||||
|
||||
# Thumbnails
|
||||
._*
|
||||
|
||||
# Files that might appear in the root of a volume
|
||||
.DocumentRevisions-V100
|
||||
.fseventsd
|
||||
.Spotlight-V100
|
||||
.TemporaryItems
|
||||
.Trashes
|
||||
.VolumeIcon.icns
|
||||
|
||||
# Directories potentially created on remote AFP share
|
||||
.AppleDB
|
||||
.AppleDesktop
|
||||
Network Trash Folder
|
||||
Temporary Items
|
||||
.apdisk
|
||||
### Node template
|
||||
# Logs
|
||||
logs
|
||||
*.log
|
||||
npm-debug.log*
|
||||
|
||||
# Runtime data
|
||||
pids
|
||||
*.pid
|
||||
*.seed
|
||||
|
||||
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||
lib-cov
|
||||
|
||||
# Coverage directory used by tools like istanbul
|
||||
coverage
|
||||
|
||||
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
|
||||
.grunt
|
||||
|
||||
# node-waf configuration
|
||||
.lock-wscript
|
||||
|
||||
# Compiled binary addons (http://nodejs.org/api/addons.html)
|
||||
build/Release
|
||||
|
||||
# Dependency directory
|
||||
# https://docs.npmjs.com/misc/faq#should-i-check-my-node-modules-folder-into-git
|
||||
node_modules
|
||||
|
||||
# See http://help.github.com/ignore-files/ for more about ignoring files.
|
||||
|
||||
# compiled output
|
||||
/dist
|
||||
/tmp
|
||||
|
||||
# dependencies
|
||||
/node_modules
|
||||
/bower_components
|
||||
|
||||
# misc
|
||||
/.sass-cache
|
||||
/connect.lock
|
||||
/coverage/*
|
||||
/libpeerconnection.log
|
||||
npm-debug.log
|
||||
testem.log
|
||||
/.cache
|
||||
/.gradle
|
||||
/server/static/*
|
||||
/wwwroot/assets
|
46
obrand/obrand-admin-server/O-BrandServer/.jscsrc
Normal file
46
obrand/obrand-admin-server/O-BrandServer/.jscsrc
Normal file
@ -0,0 +1,46 @@
|
||||
{
|
||||
"disallowKeywords": ["with"],
|
||||
"disallowKeywordsOnNewLine": ["else"],
|
||||
"disallowMixedSpacesAndTabs": true,
|
||||
"disallowMultipleVarDecl": "exceptUndefined",
|
||||
"disallowNewlineBeforeBlockStatements": true,
|
||||
"disallowQuotedKeysInObjects": true,
|
||||
"disallowSpaceAfterObjectKeys": true,
|
||||
"disallowSpaceAfterPrefixUnaryOperators": true,
|
||||
"disallowSpacesInFunction": {
|
||||
"beforeOpeningRoundBrace": true
|
||||
},
|
||||
"disallowSpacesInsideParentheses": true,
|
||||
"disallowTrailingWhitespace": true,
|
||||
"maximumLineLength": 120,
|
||||
"requireCamelCaseOrUpperCaseIdentifiers": false,
|
||||
"requireCapitalizedComments": true,
|
||||
"requireCapitalizedConstructors": true,
|
||||
"requireCurlyBraces": true,
|
||||
"requireSpaceAfterKeywords": [
|
||||
"if",
|
||||
"else",
|
||||
"for",
|
||||
"while",
|
||||
"do",
|
||||
"switch",
|
||||
"case",
|
||||
"return",
|
||||
"try",
|
||||
"catch",
|
||||
"typeof"
|
||||
],
|
||||
"requireSpaceAfterLineComment": true,
|
||||
"requireSpaceAfterBinaryOperators": true,
|
||||
"requireSpaceBeforeBinaryOperators": true,
|
||||
"requireSpaceBeforeBlockStatements": true,
|
||||
"requireSpaceBeforeObjectValues": true,
|
||||
"requireSpacesInFunction": {
|
||||
"beforeOpeningCurlyBrace": true
|
||||
},
|
||||
"requireTrailingComma": false,
|
||||
"requireEarlyReturn": true,
|
||||
"validateIndentation": 2,
|
||||
"validateLineBreaks": "LF",
|
||||
"validateQuoteMarks": "'"
|
||||
}
|
34
obrand/obrand-admin-server/O-BrandServer/.jshintrc
Normal file
34
obrand/obrand-admin-server/O-BrandServer/.jshintrc
Normal file
@ -0,0 +1,34 @@
|
||||
{
|
||||
"predef": [
|
||||
"server",
|
||||
"document",
|
||||
"window",
|
||||
"-Promise"
|
||||
],
|
||||
"node": true,
|
||||
"browser": false,
|
||||
"boss": true,
|
||||
"curly": true,
|
||||
"debug": false,
|
||||
"devel": true,
|
||||
"eqeqeq": true,
|
||||
"evil": true,
|
||||
"forin": false,
|
||||
"immed": false,
|
||||
"laxbreak": false,
|
||||
"newcap": true,
|
||||
"noarg": true,
|
||||
"noempty": false,
|
||||
"nonew": false,
|
||||
"nomen": false,
|
||||
"onevar": false,
|
||||
"plusplus": false,
|
||||
"regexp": false,
|
||||
"undef": true,
|
||||
"sub": true,
|
||||
"strict": false,
|
||||
"white": false,
|
||||
"eqnull": true,
|
||||
"esnext": true,
|
||||
"unused": true
|
||||
}
|
1
obrand/obrand-admin-server/O-BrandServer/.pgpass
Normal file
1
obrand/obrand-admin-server/O-BrandServer/.pgpass
Normal file
@ -0,0 +1 @@
|
||||
localhost:5432:oBrand:obrand:obrand
|
59
obrand/obrand-admin-server/O-BrandServer/dbconfig.js
Normal file
59
obrand/obrand-admin-server/O-BrandServer/dbconfig.js
Normal file
@ -0,0 +1,59 @@
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-04-04
|
||||
* Time: 14:46
|
||||
*
|
||||
*/
|
||||
var db = require('./server/units/db-connector').dbConnection;
|
||||
var dbAccount = require('./server/units/db-accounts')(db);
|
||||
var exec = require('child_process').exec;
|
||||
|
||||
|
||||
function addUsers() {
|
||||
'use strict';
|
||||
dbAccount.addNewAccount({
|
||||
username: 'Default', password: 'password', email: 'm@g.com'
|
||||
})
|
||||
.then(function(data) {
|
||||
console.log(data);
|
||||
|
||||
return 'DONE';
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
return -1;
|
||||
});
|
||||
|
||||
|
||||
}
|
||||
|
||||
|
||||
function prepare_db() {
|
||||
exec('psql -Upostgres -d oBrand -h localhost -f ./obrand.sql', function(err) {
|
||||
if (err !== null) {
|
||||
console.log('exec error: ' + err);
|
||||
return -1;
|
||||
} else {
|
||||
addUsers();
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
function createDB() {
|
||||
'use strict';
|
||||
exec('createdb -Upostgres -h localhost oBrand', function(err) {
|
||||
if (err !== null) {
|
||||
console.log('exec error: ' + err);
|
||||
return -1;
|
||||
} else {
|
||||
prepare_db();
|
||||
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
createDB();
|
12
obrand/obrand-admin-server/O-BrandServer/dbrebuild.sh
Executable file
12
obrand/obrand-admin-server/O-BrandServer/dbrebuild.sh
Executable file
@ -0,0 +1,12 @@
|
||||
#!/bin/bash
|
||||
echo Database rebuilder...
|
||||
SQLFILE="obrand.sql"
|
||||
|
||||
createdb oBrand
|
||||
|
||||
if [[ ! -f "$SQLFILE" ]]; then
|
||||
wget https://dl.dropboxusercontent.com/u/233909/obrand/obrand.sql -O obrand.sql
|
||||
fi
|
||||
|
||||
|
||||
psql -f obrand.sql oBrand
|
29
obrand/obrand-admin-server/O-BrandServer/ecosystem.json
Normal file
29
obrand/obrand-admin-server/O-BrandServer/ecosystem.json
Normal file
@ -0,0 +1,29 @@
|
||||
{
|
||||
/**
|
||||
* Application configuration section
|
||||
* http://pm2.keymetrics.io/docs/usage/application-declaration/
|
||||
*/
|
||||
apps : [
|
||||
|
||||
// First application
|
||||
{
|
||||
name : "Obrand-Admin-Server",
|
||||
script : "obrand-server.js",
|
||||
"cwd": "/home/ubuntu/live",
|
||||
"watch": true,
|
||||
"max_restarts": 64,
|
||||
"merge_logs" : true,
|
||||
"autorestart" : true,
|
||||
"restart_delay" : 3500,
|
||||
"max_memory_restart" : "300M",
|
||||
|
||||
env: {
|
||||
COMMON_VARIABLE: "true"
|
||||
},
|
||||
env_production : {
|
||||
NODE_ENV: "production"
|
||||
}
|
||||
}
|
||||
]
|
||||
|
||||
}
|
69
obrand/obrand-admin-server/O-BrandServer/obrand-server.js
Normal file
69
obrand/obrand-admin-server/O-BrandServer/obrand-server.js
Normal file
@ -0,0 +1,69 @@
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-03-31
|
||||
* Time: 09:44
|
||||
*
|
||||
*/
|
||||
var express = require('express'), path = require('path'), http = require('http');
|
||||
var session = require('session');
|
||||
var morgan = require('morgan');
|
||||
var cookieParser = require('cookie-parser');
|
||||
var bodyParser = require('body-parser');
|
||||
|
||||
var globSync = require('glob').sync;
|
||||
var colors = require('colors/safe');
|
||||
|
||||
|
||||
var app = express();
|
||||
|
||||
app.set('port', process.env.PORT || 8086);
|
||||
app.set('views', path.join(__dirname, 'views'));
|
||||
app.set('view engine', 'jade');
|
||||
app.use(morgan('dev'));
|
||||
app.use(bodyParser.json());
|
||||
app.use(bodyParser.json({type: 'application/vnd.api+json'}));
|
||||
app.use(cookieParser('!n87klqX39cB:7ayiRzEL5yRy5y938'));
|
||||
/*app.use(session({
|
||||
secret: 'G)+W&2W5C3V6gXJ.8mSD!l/-n3D]EV', resave: false,
|
||||
saveUninitialized: false
|
||||
}));*/
|
||||
app.use('/export',express.static(path.join(__dirname,'server/static')));
|
||||
app.use('/css',express.static(path.join(__dirname,'server/css')));
|
||||
app.use('/',express.static(path.join(__dirname,'wwwroot')));
|
||||
|
||||
/* These next app.get's deal with ember's routing and when the user refreshes
|
||||
the page. It forces the page back into the app.
|
||||
*/
|
||||
app.get('/about', function(request, response) {
|
||||
response.redirect('/#/about');
|
||||
});
|
||||
|
||||
app.get('/profile', function(request, response) {
|
||||
response.redirect('/#/profile');
|
||||
});
|
||||
|
||||
app.get('/company', function(request, response) {
|
||||
response.redirect('/#/company');
|
||||
});
|
||||
|
||||
app.get('/venue', function(request, response) {
|
||||
response.redirect('/#/venue');
|
||||
});
|
||||
|
||||
app.get('/pages', function(request, response) {
|
||||
response.redirect('/#/pages');
|
||||
});
|
||||
|
||||
|
||||
console.log(path.join(__dirname,'server/static'));
|
||||
|
||||
var backend = globSync('./server/app/**/*.js', { cwd: __dirname }).map(require);
|
||||
|
||||
backend.forEach(function(route) { route(app); });
|
||||
|
||||
|
||||
app.listen(app.get('port'), function() {
|
||||
'use strict';
|
||||
console.log(colors.magenta('Obrand Server listening on ' + app.get('port')));
|
||||
});
|
668
obrand/obrand-admin-server/O-BrandServer/obrand.sql
Normal file
668
obrand/obrand-admin-server/O-BrandServer/obrand.sql
Normal file
@ -0,0 +1,668 @@
|
||||
-- Database: "oBrand"
|
||||
|
||||
DROP DATABASE "oBrand";
|
||||
|
||||
-- Role: obrand
|
||||
|
||||
DROP ROLE obrand;
|
||||
|
||||
CREATE ROLE obrand LOGIN
|
||||
ENCRYPTED PASSWORD 'md51e16472d06fb312d14e3001f44e9460e'
|
||||
NOSUPERUSER INHERIT NOCREATEDB NOCREATEROLE NOREPLICATION;
|
||||
|
||||
CREATE DATABASE "oBrand"
|
||||
WITH OWNER = postgres
|
||||
ENCODING = 'UTF8'
|
||||
TABLESPACE = pg_default
|
||||
LC_COLLATE = 'C'
|
||||
LC_CTYPE = 'C'
|
||||
CONNECTION LIMIT = -1;
|
||||
GRANT ALL ON DATABASE "oBrand" TO postgres;
|
||||
|
||||
|
||||
GRANT CONNECT ON DATABASE "oBrand" TO obrand;
|
||||
REVOKE ALL ON DATABASE "oBrand" FROM public;
|
||||
|
||||
ALTER DEFAULT PRIVILEGES
|
||||
GRANT INSERT, SELECT, UPDATE ON TABLES
|
||||
TO public;
|
||||
|
||||
ALTER DEFAULT PRIVILEGES
|
||||
GRANT INSERT, SELECT, UPDATE, DELETE, TRUNCATE, REFERENCES, TRIGGER ON TABLES
|
||||
TO postgres;
|
||||
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
|
||||
|
||||
ALTER TABLE "profile" DROP CONSTRAINT IF EXISTS "profile_fk0";
|
||||
|
||||
ALTER TABLE "profile" DROP CONSTRAINT IF EXISTS "profile_fk1";
|
||||
|
||||
ALTER TABLE "venue" DROP CONSTRAINT IF EXISTS "venue_fk0";
|
||||
|
||||
ALTER TABLE "billing" DROP CONSTRAINT IF EXISTS "billing_fk0";
|
||||
|
||||
DROP TABLE IF EXISTS "logins";
|
||||
|
||||
DROP TABLE IF EXISTS "profile";
|
||||
|
||||
DROP TABLE IF EXISTS "company";
|
||||
|
||||
DROP TABLE IF EXISTS "venue";
|
||||
|
||||
DROP TABLE IF EXISTS "billing";
|
||||
|
||||
DROP TABLE IF EXISTS "master_beacons";
|
||||
|
||||
DROP TABLE IF EXISTS "pages";
|
||||
|
||||
|
||||
-- SEQUENCES
|
||||
|
||||
|
||||
-- Sequence: public.billing_id_seq
|
||||
|
||||
-- DROP SEQUENCE public.billing_id_seq;
|
||||
|
||||
CREATE SEQUENCE public.billing_id_seq
|
||||
INCREMENT 1
|
||||
MINVALUE 1
|
||||
MAXVALUE 9223372036854775807
|
||||
START 1
|
||||
CACHE 1;
|
||||
ALTER TABLE public.billing_id_seq
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
|
||||
-- Sequence: public.company_id_seq
|
||||
|
||||
-- DROP SEQUENCE public.company_id_seq;
|
||||
|
||||
CREATE SEQUENCE public.company_id_seq
|
||||
INCREMENT 1
|
||||
MINVALUE 1
|
||||
MAXVALUE 9223372036854775807
|
||||
START 2
|
||||
CACHE 1;
|
||||
ALTER TABLE public.company_id_seq
|
||||
OWNER TO postgres;
|
||||
GRANT ALL ON SEQUENCE public.company_id_seq TO postgres;
|
||||
GRANT SELECT, UPDATE ON SEQUENCE public.company_id_seq TO obrand;
|
||||
|
||||
|
||||
|
||||
|
||||
-- Sequence: public.logins_id_seq
|
||||
|
||||
-- DROP SEQUENCE public.logins_id_seq;
|
||||
|
||||
CREATE SEQUENCE public.logins_id_seq
|
||||
INCREMENT 1
|
||||
MINVALUE 1
|
||||
MAXVALUE 9223372036854775807
|
||||
START 4
|
||||
CACHE 1;
|
||||
ALTER TABLE public.logins_id_seq
|
||||
OWNER TO postgres;
|
||||
GRANT ALL ON SEQUENCE public.logins_id_seq TO postgres;
|
||||
GRANT SELECT, UPDATE ON SEQUENCE public.logins_id_seq TO obrand;
|
||||
|
||||
|
||||
|
||||
|
||||
-- Sequence: public.pages_id_seq
|
||||
|
||||
-- DROP SEQUENCE public.pages_id_seq;
|
||||
|
||||
CREATE SEQUENCE public.pages_id_seq
|
||||
INCREMENT 1
|
||||
MINVALUE 1
|
||||
MAXVALUE 9223372036854775807
|
||||
START 35
|
||||
CACHE 1;
|
||||
ALTER TABLE public.pages_id_seq
|
||||
OWNER TO postgres;
|
||||
GRANT ALL ON SEQUENCE public.pages_id_seq TO postgres;
|
||||
GRANT SELECT, UPDATE ON SEQUENCE public.pages_id_seq TO obrand;
|
||||
|
||||
|
||||
|
||||
|
||||
-- Sequence: public.profile_id_seq
|
||||
|
||||
-- DROP SEQUENCE public.profile_id_seq;
|
||||
|
||||
CREATE SEQUENCE public.profile_id_seq
|
||||
INCREMENT 1
|
||||
MINVALUE 1
|
||||
MAXVALUE 9223372036854775807
|
||||
START 2
|
||||
CACHE 1;
|
||||
ALTER TABLE public.profile_id_seq
|
||||
OWNER TO postgres;
|
||||
GRANT ALL ON SEQUENCE public.profile_id_seq TO postgres;
|
||||
GRANT SELECT, UPDATE ON SEQUENCE public.profile_id_seq TO obrand;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- Sequence: public.venue_id_seq
|
||||
|
||||
-- DROP SEQUENCE public.venue_id_seq;
|
||||
|
||||
CREATE SEQUENCE public.venue_id_seq
|
||||
INCREMENT 1
|
||||
MINVALUE 1
|
||||
MAXVALUE 9223372036854775807
|
||||
START 1
|
||||
CACHE 1;
|
||||
ALTER TABLE public.venue_id_seq
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
-- ----
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- Table: public.company
|
||||
|
||||
-- DROP TABLE public.company;
|
||||
|
||||
CREATE TABLE public.company
|
||||
(
|
||||
id integer NOT NULL DEFAULT nextval('company_id_seq'::regclass),
|
||||
cid character varying(22) NOT NULL,
|
||||
company_name character varying(100) NOT NULL,
|
||||
address1 character varying(150) NOT NULL,
|
||||
address2 character varying(150),
|
||||
address3 character varying(150),
|
||||
town character varying(150) NOT NULL,
|
||||
county character varying(150),
|
||||
postcode character varying(12) NOT NULL,
|
||||
country integer,
|
||||
pcontact character varying(20) NOT NULL,
|
||||
ocontact character varying(20),
|
||||
mobile character varying(20),
|
||||
email character varying(150) NOT NULL,
|
||||
CONSTRAINT company_pk PRIMARY KEY (id)
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.company
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.company TO public;
|
||||
GRANT ALL ON TABLE public.company TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- Table: public.billing
|
||||
|
||||
-- DROP TABLE public.billing;
|
||||
|
||||
CREATE TABLE public.billing
|
||||
(
|
||||
id integer NOT NULL DEFAULT nextval('billing_id_seq'::regclass),
|
||||
company_id integer NOT NULL,
|
||||
CONSTRAINT billing_pk PRIMARY KEY (id),
|
||||
CONSTRAINT billing_fk0 FOREIGN KEY (company_id)
|
||||
REFERENCES public.company (id) MATCH SIMPLE
|
||||
ON UPDATE NO ACTION ON DELETE NO ACTION
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.billing
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.billing TO public;
|
||||
GRANT ALL ON TABLE public.billing TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- Table: public.logins
|
||||
|
||||
-- DROP TABLE public.logins;
|
||||
|
||||
CREATE TABLE public.logins
|
||||
(
|
||||
id integer NOT NULL DEFAULT nextval('logins_id_seq'::regclass),
|
||||
username character varying(100) NOT NULL,
|
||||
email character varying(150) NOT NULL,
|
||||
password_hash character varying(78) NOT NULL,
|
||||
password_reset_token character varying(128),
|
||||
uid character varying(22),
|
||||
CONSTRAINT logins_pk PRIMARY KEY (id),
|
||||
CONSTRAINT logins_email_key UNIQUE (email),
|
||||
CONSTRAINT logins_password_reset_token_key UNIQUE (password_reset_token),
|
||||
CONSTRAINT logins_uid_key UNIQUE (uid),
|
||||
CONSTRAINT logins_username_key UNIQUE (username)
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.logins
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.logins TO public;
|
||||
GRANT ALL ON TABLE public.logins TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT, DELETE, TRIGGER ON TABLE public.logins TO obrand;
|
||||
|
||||
|
||||
|
||||
|
||||
-- Table: public.master_beacons
|
||||
|
||||
-- DROP TABLE public.master_beacons;
|
||||
|
||||
CREATE TABLE public.master_beacons
|
||||
(
|
||||
id bigint NOT NULL,
|
||||
uid uuid NOT NULL,
|
||||
CONSTRAINT master_beacons_pk PRIMARY KEY (id)
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.master_beacons
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.master_beacons TO public;
|
||||
GRANT ALL ON TABLE public.master_beacons TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- Table: public.pages
|
||||
|
||||
-- DROP TABLE public.pages;
|
||||
|
||||
CREATE TABLE public.pages
|
||||
(
|
||||
id integer NOT NULL DEFAULT nextval('pages_id_seq'::regclass),
|
||||
cid character varying(22),
|
||||
vid character varying(22),
|
||||
pid character varying(22),
|
||||
content integer,
|
||||
title character varying(100) NOT NULL,
|
||||
data json NOT NULL,
|
||||
CONSTRAINT pages_pk PRIMARY KEY (id)
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.pages
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.pages TO public;
|
||||
GRANT ALL ON TABLE public.pages TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
-- Table: public.profile
|
||||
|
||||
-- DROP TABLE public.profile;
|
||||
|
||||
CREATE TABLE public.profile
|
||||
(
|
||||
id integer NOT NULL DEFAULT nextval('profile_id_seq'::regclass),
|
||||
uid character varying(22) NOT NULL,
|
||||
forename character varying(75) NOT NULL,
|
||||
surname character varying(75) NOT NULL,
|
||||
gender integer NOT NULL,
|
||||
dob date NOT NULL,
|
||||
bio text NOT NULL,
|
||||
member_of character varying(22),
|
||||
CONSTRAINT profile_pk PRIMARY KEY (id),
|
||||
CONSTRAINT profile_fk0 FOREIGN KEY (uid)
|
||||
REFERENCES public.logins (uid) MATCH SIMPLE
|
||||
ON UPDATE NO ACTION ON DELETE NO ACTION
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.profile
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.profile TO public;
|
||||
GRANT ALL ON TABLE public.profile TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
|
||||
-- Table: public.venue
|
||||
|
||||
-- DROP TABLE public.venue;
|
||||
|
||||
CREATE TABLE public.venue
|
||||
(
|
||||
id integer NOT NULL DEFAULT nextval('venue_id_seq'::regclass),
|
||||
venue_name character varying(100) NOT NULL,
|
||||
address1 character varying(150) NOT NULL,
|
||||
address2 character varying(150),
|
||||
address3 character varying(150),
|
||||
town character varying(150) NOT NULL,
|
||||
county character varying(150),
|
||||
postcode character varying(12) NOT NULL,
|
||||
country integer,
|
||||
pcontact character varying(20) NOT NULL,
|
||||
ocontact character varying(20),
|
||||
mobile character varying(20),
|
||||
email character varying(150) NOT NULL,
|
||||
company_id integer NOT NULL,
|
||||
CONSTRAINT venue_pk PRIMARY KEY (id),
|
||||
CONSTRAINT venue_fk0 FOREIGN KEY (company_id)
|
||||
REFERENCES public.company (id) MATCH SIMPLE
|
||||
ON UPDATE NO ACTION ON DELETE NO ACTION
|
||||
)
|
||||
WITH (
|
||||
OIDS=FALSE
|
||||
);
|
||||
ALTER TABLE public.venue
|
||||
OWNER TO postgres;
|
||||
GRANT SELECT, UPDATE, INSERT ON TABLE public.venue TO public;
|
||||
GRANT ALL ON TABLE public.venue TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
|
||||
|
||||
--ALTER TABLE "profile" ADD CONSTRAINT "profile_fk0" FOREIGN KEY ("uid") REFERENCES "logins"("uid");
|
||||
--ALTER TABLE "profile" ADD CONSTRAINT "profile_fk1" FOREIGN KEY ("member_of") REFERENCES "company"("cid");
|
||||
|
||||
--ALTER TABLE "venue" ADD CONSTRAINT "venue_fk0" FOREIGN KEY ("company_id") REFERENCES "company"("id");
|
||||
|
||||
--ALTER TABLE "billing" ADD CONSTRAINT "billing_fk0" FOREIGN KEY ("company_id") REFERENCES "company"("id");
|
||||
|
||||
grant connect on database "oBrand" to obrand;
|
||||
|
||||
GRANT SELECT, UPDATE, INSERT, DELETE, TRIGGER ON TABLE public.logins TO obrand;
|
||||
|
||||
grant select, update on logins_id_seq to obrand;
|
||||
grant select, update on profile_id_seq to obrand;
|
||||
grant select, update on company_id_seq to obrand;
|
||||
grant select, update on pages_pk to obrand;
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- functions
|
||||
|
||||
|
||||
-- Function: public.getaccountdetails(character varying)
|
||||
|
||||
-- DROP FUNCTION public.getaccountdetails(character varying);
|
||||
|
||||
CREATE OR REPLACE FUNCTION public.getaccountdetails(IN _uid character varying)
|
||||
RETURNS TABLE(id integer, email character varying, uid character varying, forename character varying, surname character varying, member_of character varying) AS
|
||||
$BODY$
|
||||
|
||||
BEGIN
|
||||
|
||||
|
||||
RETURN QUERY
|
||||
SELECT
|
||||
|
||||
logins.id,
|
||||
logins.email,
|
||||
logins.uid,
|
||||
profile.forename,
|
||||
profile.surname,
|
||||
profile.member_of
|
||||
FROM logins
|
||||
LEFT JOIN profile ON profile.uid = logins.uid
|
||||
WHERE logins.uid = _uid;
|
||||
|
||||
|
||||
END;
|
||||
$BODY$
|
||||
LANGUAGE plpgsql VOLATILE
|
||||
COST 100
|
||||
ROWS 1000;
|
||||
ALTER FUNCTION public.getaccountdetails(character varying)
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
-- Function: public.insert_user(character varying, character varying, character varying, character varying)
|
||||
|
||||
-- DROP FUNCTION public.insert_user(character varying, character varying, character varying, character varying);
|
||||
|
||||
CREATE OR REPLACE FUNCTION public.insert_user(
|
||||
_username character varying,
|
||||
_email character varying,
|
||||
_passwordhash character varying,
|
||||
_uid character varying)
|
||||
RETURNS void AS
|
||||
$BODY$
|
||||
|
||||
BEGIN
|
||||
INSERT into logins(username, email, password_hash, uid) Values(_username,_email,_passwordHash,_uid);
|
||||
END;
|
||||
$BODY$
|
||||
LANGUAGE plpgsql VOLATILE
|
||||
COST 100;
|
||||
ALTER FUNCTION public.insert_user(character varying, character varying, character varying, character varying)
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
|
||||
--
|
||||
|
||||
-- Function: public.makememberof(character varying, character varying)
|
||||
|
||||
-- DROP FUNCTION public.makememberof(character varying, character varying);
|
||||
|
||||
CREATE OR REPLACE FUNCTION public.makememberof(
|
||||
_uid character varying,
|
||||
_cid character varying)
|
||||
RETURNS void AS
|
||||
$BODY$
|
||||
|
||||
BEGIN
|
||||
UPDATE profile SET member_of = _cid WHERE uid = _uid;
|
||||
|
||||
|
||||
END;
|
||||
$BODY$
|
||||
LANGUAGE plpgsql VOLATILE
|
||||
COST 100;
|
||||
ALTER FUNCTION public.makememberof(character varying, character varying)
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
-- Function: public.upsert_company(character varying, character varying, character varying, character varying, character varying, character varying, character varying, character varying, integer, character varying, character varying, character varying, character varying)
|
||||
|
||||
-- DROP FUNCTION public.upsert_company(character varying, character varying, character varying, character varying, character varying, character varying, character varying, character varying, integer, character varying, character varying, character varying, character varying);
|
||||
|
||||
CREATE OR REPLACE FUNCTION public.upsert_company(
|
||||
_cid character varying,
|
||||
_company_name character varying,
|
||||
_address1 character varying,
|
||||
_address2 character varying,
|
||||
_address3 character varying,
|
||||
_town character varying,
|
||||
_county character varying,
|
||||
_postcode character varying,
|
||||
_country integer,
|
||||
_pcontact character varying,
|
||||
_ocontact character varying,
|
||||
_mobile character varying,
|
||||
_email character varying)
|
||||
RETURNS void AS
|
||||
$BODY$
|
||||
|
||||
BEGIN
|
||||
WITH upsert AS (UPDATE company
|
||||
SET cid = _cid,
|
||||
company_name = _company_name,
|
||||
address1 = _address1,
|
||||
address2 = _address2,
|
||||
address3 = _address3,
|
||||
town = _town,
|
||||
county = _county,
|
||||
postcode = _postcode,
|
||||
country = _country,
|
||||
pcontact = _pcontact,
|
||||
ocontact = _ocontact,
|
||||
mobile = _mobile,
|
||||
email = _email
|
||||
|
||||
WHERE cid = _cid
|
||||
RETURNING *)
|
||||
INSERT INTO company (
|
||||
cid,
|
||||
company_name,
|
||||
address1,
|
||||
address2,
|
||||
address3,
|
||||
town,
|
||||
county,
|
||||
postcode,
|
||||
country,
|
||||
pcontact,
|
||||
ocontact,
|
||||
mobile,
|
||||
email
|
||||
) SELECT
|
||||
_cid,
|
||||
_company_name,
|
||||
_address1,
|
||||
_address2,
|
||||
_address3,
|
||||
_town,
|
||||
_county,
|
||||
_postcode,
|
||||
_country,
|
||||
_pcontact,
|
||||
_ocontact,
|
||||
_mobile,
|
||||
_email
|
||||
WHERE NOT EXISTS(SELECT *
|
||||
FROM upsert);
|
||||
|
||||
|
||||
END;
|
||||
$BODY$
|
||||
LANGUAGE plpgsql VOLATILE
|
||||
COST 100;
|
||||
ALTER FUNCTION public.upsert_company(character varying, character varying, character varying, character varying, character varying, character varying, character varying, character varying, integer, character varying, character varying, character varying, character varying)
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
|
||||
-- Function: public.upsert_page(character varying, character varying, character varying, integer, character varying, json)
|
||||
|
||||
-- DROP FUNCTION public.upsert_page(character varying, character varying, character varying, integer, character varying, json);
|
||||
|
||||
CREATE OR REPLACE FUNCTION public.upsert_page(
|
||||
_cid character varying,
|
||||
_vid character varying,
|
||||
_pid character varying,
|
||||
_content integer,
|
||||
_title character varying,
|
||||
_data json)
|
||||
RETURNS void AS
|
||||
$BODY$
|
||||
|
||||
BEGIN
|
||||
WITH upsert AS (UPDATE pages
|
||||
SET cid = _cid, vid = _vid, content = _content, title = _title, data = _data
|
||||
WHERE pid = _pid
|
||||
RETURNING *)
|
||||
INSERT INTO pages (cid, vid, pid, content, title, data) SELECT
|
||||
_cid,
|
||||
_vid,
|
||||
_pid,
|
||||
_content,
|
||||
_title,
|
||||
_data
|
||||
WHERE NOT EXISTS(SELECT *
|
||||
FROM upsert);
|
||||
|
||||
|
||||
END;
|
||||
$BODY$
|
||||
LANGUAGE plpgsql VOLATILE
|
||||
COST 100;
|
||||
ALTER FUNCTION public.upsert_page(character varying, character varying, character varying, integer, character varying, json)
|
||||
OWNER TO postgres;
|
||||
|
||||
|
||||
|
||||
|
||||
--
|
||||
|
||||
|
||||
-- Function: public.upsert_profile(character varying, character varying, character varying, integer, date, text)
|
||||
|
||||
-- DROP FUNCTION public.upsert_profile(character varying, character varying, character varying, integer, date, text);
|
||||
|
||||
CREATE OR REPLACE FUNCTION public.upsert_profile(
|
||||
_uid character varying,
|
||||
_forename character varying,
|
||||
_surname character varying,
|
||||
_gender integer,
|
||||
_dob date,
|
||||
_bio text)
|
||||
RETURNS void AS
|
||||
$BODY$
|
||||
|
||||
BEGIN
|
||||
WITH upsert AS (UPDATE profile
|
||||
SET forename = _forename, surname = _surname, gender = _gender, dob = _dob, bio = _bio
|
||||
WHERE uid = _uid
|
||||
RETURNING *)
|
||||
INSERT INTO profile (uid, forename, surname, gender, dob, bio) SELECT
|
||||
_uid,
|
||||
_forename,
|
||||
_surname,
|
||||
_gender,
|
||||
_dob,
|
||||
_bio
|
||||
WHERE NOT EXISTS(SELECT *
|
||||
FROM upsert);
|
||||
|
||||
|
||||
END;
|
||||
$BODY$
|
||||
LANGUAGE plpgsql VOLATILE
|
||||
COST 100;
|
||||
ALTER FUNCTION public.upsert_profile(character varying, character varying, character varying, integer, date, text)
|
||||
OWNER TO postgres;
|
37
obrand/obrand-admin-server/O-BrandServer/package.json
Normal file
37
obrand/obrand-admin-server/O-BrandServer/package.json
Normal file
@ -0,0 +1,37 @@
|
||||
{
|
||||
"name": "obrand-admin-server",
|
||||
"version": "1.0.0",
|
||||
"description": "Obrand Administration backend server",
|
||||
"main": "obrand-server.js",
|
||||
"scripts": {
|
||||
"test": "echo \"Error: no test specified\" && exit 1"
|
||||
},
|
||||
"repository": {
|
||||
"type": "git",
|
||||
"url": "git+http://gitlab.silvrtree.co.uk/martind2000/obrand-admin-server.git"
|
||||
},
|
||||
"author": "Martin Donnelly <martind2000@gmail.com>",
|
||||
"license": "ISC",
|
||||
"dependencies": {
|
||||
"bcrypt": "^0.8.5",
|
||||
"bcrypt-as-promised": "^1.1.0",
|
||||
"body-parser": "^1.15.0",
|
||||
"colors": "^1.1.2",
|
||||
"cookie-parser": "^1.4.1",
|
||||
"express": "^4.13.4",
|
||||
"glob": "^7.0.3",
|
||||
"md-utils": "git+http://gitlab.silvrtree.co.uk/martind2000/md-utils.git",
|
||||
"moment": "^2.12.0",
|
||||
"morgan": "^1.7.0",
|
||||
"node-validator": "git+http://gitlab.silvrtree.co.uk/martind2000/node-validator.git",
|
||||
"oauth2-server": "^2.4.1",
|
||||
"pg-promise": "^3.4.3",
|
||||
"pug": "^2.0.0-alpha3",
|
||||
"uuid-pure": "^1.0.10"
|
||||
},
|
||||
"devDependencies": {
|
||||
"log4js": "^0.6.33",
|
||||
"session": "^0.1.0",
|
||||
"util": "^0.10.3"
|
||||
}
|
||||
}
|
26
obrand/obrand-admin-server/O-BrandServer/pg_hba.conf
Normal file
26
obrand/obrand-admin-server/O-BrandServer/pg_hba.conf
Normal file
@ -0,0 +1,26 @@
|
||||
# Allow any user on the local system to connect to any database with
|
||||
# any database user name using Unix-domain sockets (the default for local
|
||||
# connections).
|
||||
#
|
||||
# TYPE DATABASE USER ADDRESS METHOD
|
||||
local all all trust
|
||||
|
||||
# The same using local loopback TCP/IP connections.
|
||||
#
|
||||
# TYPE DATABASE USER ADDRESS METHOD
|
||||
host all all 127.0.0.1/32 trust
|
||||
|
||||
# The same as the previous line, but using a separate netmask column
|
||||
#
|
||||
# TYPE DATABASE USER IP-ADDRESS IP-MASK METHOD
|
||||
host all all 127.0.0.1 255.255.255.255 trust
|
||||
|
||||
# The same over IPv6.
|
||||
#
|
||||
# TYPE DATABASE USER ADDRESS METHOD
|
||||
host all all ::1/128 trust
|
||||
|
||||
# The same using a host name (would typically cover both IPv4 and IPv6).
|
||||
#
|
||||
# TYPE DATABASE USER ADDRESS METHOD
|
||||
host all all localhost trust
|
13
obrand/obrand-admin-server/O-BrandServer/process.json
Normal file
13
obrand/obrand-admin-server/O-BrandServer/process.json
Normal file
@ -0,0 +1,13 @@
|
||||
{
|
||||
"apps" : [{
|
||||
"name" : "OBrand-Server",
|
||||
"watch" : true,
|
||||
"script" : "obrand-server.js",
|
||||
"instances" : 1,
|
||||
"exec_mode" : "cluster",
|
||||
"combine_logs" : true,
|
||||
"max_memory_restart" : "150M",
|
||||
"restart_delay" : 5000,
|
||||
"ignore_watch" : ["[\\/\\\\]\\./", "node_modules", "server/static"]
|
||||
}]
|
||||
}
|
20
obrand/obrand-admin-server/O-BrandServer/rebuild.sh
Normal file
20
obrand/obrand-admin-server/O-BrandServer/rebuild.sh
Normal file
@ -0,0 +1,20 @@
|
||||
#!/bin/bash
|
||||
NVM="$HOME/.nvm"
|
||||
NVM_VERSION="5.7.0"
|
||||
DEV="$HOME/dev"
|
||||
LIVE="$HOME/live"
|
||||
SWAP="/swapfile"
|
||||
DBSETUP="obrand-admin-server/dbrebuild.sh"
|
||||
PKG_MANAGER=$( command -v yum || command -v apt-get ) || echo "Neither yum nor apt-get found"
|
||||
PKG_DEVICE=$(basename $PKG_MANAGER)
|
||||
|
||||
echo Copying...
|
||||
|
||||
cd $DEV/O-Brand/dist
|
||||
cp -ra . $DEV/obrand-admin-server/wwwroot
|
||||
|
||||
cd $DEV/obrand-admin-server
|
||||
|
||||
|
||||
rsync -uav --exclude .git $DEV/obrand-admin-server/ $LIVE
|
||||
|
@ -0,0 +1,36 @@
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbAccounts = require('../units/db-accounts')(db);
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var accountsRouter = express.Router();
|
||||
|
||||
accountsRouter.get('/:uid', function(req, res) {
|
||||
console.log(req.headers);
|
||||
if (/Bearer .+/.test(req.headers.authorization)) {
|
||||
|
||||
dbAccounts.sqlGetAccountDetails(req.params.uid)
|
||||
.then(function(data) {
|
||||
'use strict';
|
||||
const response = {
|
||||
data: {
|
||||
type: 'accounts', id: data.uid, attributes: {
|
||||
uid: data.uid, login: data.email, forename: data.forename,
|
||||
surname: data.surname, memberof: data.member_of
|
||||
}
|
||||
}
|
||||
};
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
res.status(400).end();
|
||||
});
|
||||
} else {
|
||||
console.log(req.headers);
|
||||
res.status(401).end();
|
||||
}
|
||||
});
|
||||
|
||||
app.use('/accounts', accountsRouter);
|
||||
};
|
||||
|
@ -0,0 +1,46 @@
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-04-05
|
||||
* Time: 11:48
|
||||
*
|
||||
*/
|
||||
/*jshint node:true*/
|
||||
|
||||
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbPages = require('../units/db-pages')(db);
|
||||
var logger = require('log4js').getLogger();
|
||||
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var beaconRouter = express.Router();
|
||||
|
||||
beaconRouter.get('/', function(req, res) {
|
||||
'use strict';
|
||||
var beacon = {};
|
||||
|
||||
logger.debug(req.headers);
|
||||
console.error(req.headers);
|
||||
if (req.headers.hasOwnProperty('beacon')) {
|
||||
beacon = JSON.parse(req.headers.beacon);
|
||||
logger.debug(beacon);
|
||||
}
|
||||
|
||||
logger.info('gettingLatestAddedPage');
|
||||
dbPages.getLatestAddedPage()
|
||||
.then((d) => {
|
||||
res.redirect(301, d.fullpath);
|
||||
}).catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
app.use('/beacon', require('body-parser').json());
|
||||
app.use('/beacon', require('body-parser').text());
|
||||
app.use('/beacon', require('body-parser').urlencoded());
|
||||
|
||||
app.use('/beacon', beaconRouter);
|
||||
};
|
@ -0,0 +1,60 @@
|
||||
/*jshint node:true*/
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbCompany = require('../units/db-company')(db);
|
||||
var $U = require('md-utils');
|
||||
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var companiesRouter = express.Router();
|
||||
|
||||
companiesRouter.get('/:id', function(req, res) {
|
||||
'use strict';
|
||||
var id = req.params.id;
|
||||
dbCompany.sqlGetSimpleCompany(id)
|
||||
.then(function(data) {
|
||||
|
||||
const response = {
|
||||
data: {
|
||||
type: 'company', id: id, attributes: $U.reDashObject(data)
|
||||
}
|
||||
};
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
});
|
||||
|
||||
companiesRouter.patch('/:id', function(req, res) {
|
||||
'use strict';
|
||||
if (/Bearer .+/.test(req.headers.authorization)) {
|
||||
var updateData = $U.unDashObject(req.body.data.attributes);
|
||||
dbCompany.addNewCompany(updateData)
|
||||
.then(function(d) {
|
||||
|
||||
let response = {
|
||||
data: {
|
||||
type: 'company', id: d.cid, attributes: d
|
||||
}
|
||||
|
||||
};
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch(function(e) {
|
||||
console.error(e);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
|
||||
companiesRouter.delete('/:id', function(req, res) {
|
||||
res.status(204).end();
|
||||
});
|
||||
|
||||
app.use('/api/companies', require('body-parser').json({type: 'application/vnd.api+json'}));
|
||||
|
||||
app.use('/api/companies', companiesRouter);
|
||||
};
|
@ -0,0 +1,32 @@
|
||||
doctype html
|
||||
html(lang="en")
|
||||
head
|
||||
meta(name='viewport', content='width=device-width, initial-scale=1.0')
|
||||
link(rel='stylesheet', href='/css/pure.min.css')
|
||||
link(rel='stylesheet', href='/css/obrand.css')
|
||||
title= title
|
||||
|
||||
body
|
||||
.pure-g
|
||||
.pure-u-1
|
||||
h1.textcenter= title
|
||||
#image.pure-u-1
|
||||
if image_url
|
||||
img.centerblock(src=image_url)
|
||||
#links.pure-u-1.pure-menu
|
||||
ul.pure-menu-list
|
||||
if link1_text
|
||||
li.pure-menu-item
|
||||
a.pure-menu-link.textcenter(href=link1_url)=link1_text
|
||||
|
||||
if link2_text
|
||||
li.pure-menu-item
|
||||
a.pure-menu-link.textcenter(href=link2_url)=link2_text
|
||||
|
||||
if link3_text
|
||||
li.pure-menu-item
|
||||
a.pure-menu-link.textcenter(href=link3_url)=link3_text
|
||||
|
||||
if link4_text
|
||||
li.pure-menu-item
|
||||
a.pure-menu-link.textcenter(href=link4_url)=link4_text
|
@ -0,0 +1,57 @@
|
||||
/*jshint node:true*/
|
||||
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbCompany = require('../units/db-company')(db);
|
||||
var dbAccounts = require('../units/db-accounts')(db);
|
||||
var $U = require('md-utils');
|
||||
var events = require('events');
|
||||
|
||||
// Create an eventEmitter object
|
||||
var eventEmitter = new events.EventEmitter();
|
||||
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var newcompaniesRouter = express.Router();
|
||||
|
||||
eventEmitter.on('makeMemberOf', (uid, cid) => {
|
||||
'use strict';
|
||||
dbAccounts.makeMemberOf(uid, cid)
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
});
|
||||
});
|
||||
|
||||
newcompaniesRouter.get('/', function(req, res) {
|
||||
res.send({
|
||||
newcompanies: []
|
||||
});
|
||||
});
|
||||
|
||||
newcompaniesRouter.post('/', function(req, res) {
|
||||
'use strict';
|
||||
var updateData = $U.unDashObject(req.body.data.attributes);
|
||||
if (/Bearer .+/.test(req.headers.authorization)) {
|
||||
dbCompany.addNewCompany(updateData)
|
||||
.then(function(d) {
|
||||
updateData.cid = d.cid;
|
||||
let response = {
|
||||
data: {
|
||||
type: 'newcompany', id: d.cid, attributes: updateData
|
||||
}
|
||||
|
||||
};
|
||||
eventEmitter.emit('makeMemberOf', updateData.uid, d.cid);
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch(function(e) {
|
||||
console.error(e);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
}
|
||||
});
|
||||
|
||||
app.use('/api/newcompanies', require('body-parser').json({type: 'application/vnd.api+json'}));
|
||||
|
||||
app.use('/api/newcompanies', newcompaniesRouter);
|
||||
};
|
163
obrand/obrand-admin-server/O-BrandServer/server/app/pages.js
Normal file
163
obrand/obrand-admin-server/O-BrandServer/server/app/pages.js
Normal file
@ -0,0 +1,163 @@
|
||||
/*jshint node:true*/
|
||||
'use strict';
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbPages = require('../units/db-pages')(db);
|
||||
var $U = require('md-utils');
|
||||
var Events = require('events');
|
||||
var jade = require('pug');
|
||||
var fs = require('fs');
|
||||
var logger = require('log4js').getLogger();
|
||||
|
||||
var eventHandler = new Events();
|
||||
|
||||
var util = require('util');
|
||||
|
||||
var templates = {
|
||||
basic: {path: __dirname + '/jade/type0.jade', compiled: null}
|
||||
};
|
||||
|
||||
var exportPath = __dirname + '/../static/';
|
||||
|
||||
var doRenderPage = (page) => {
|
||||
|
||||
var compiledhtml;
|
||||
var _page = $U.unDashObject(page);
|
||||
var htmlfile = exportPath + _page.pid + '.html';
|
||||
|
||||
if (templates.basic.compiled === null) {
|
||||
templates.basic.compiled = jade.compileFile(templates.basic.path);
|
||||
}
|
||||
|
||||
compiledhtml = templates.basic.compiled(_page);
|
||||
|
||||
fs.writeFileSync(htmlfile, compiledhtml);
|
||||
|
||||
};
|
||||
|
||||
var eventRenderPage = (page) => {
|
||||
doRenderPage(page);
|
||||
};
|
||||
|
||||
eventHandler.on('renderPage', eventRenderPage);
|
||||
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var pagesRouter = express.Router();
|
||||
|
||||
pagesRouter.get('/', function(req, res) {
|
||||
|
||||
dbPages.getFullPageList()
|
||||
.then(function(data) {
|
||||
const response = {
|
||||
data: data
|
||||
};
|
||||
|
||||
res.status(200).send(response);
|
||||
|
||||
}).catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
});
|
||||
|
||||
pagesRouter.get('/list', function(req, res) {
|
||||
dbPages.getPageList()
|
||||
.then(function(data) {
|
||||
res.render('pages', {data: data});
|
||||
|
||||
}).catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
});
|
||||
|
||||
pagesRouter.post('/', function(req, res) {
|
||||
dbPages.addNewPage(req.body.data)
|
||||
.then(function(data) {
|
||||
|
||||
dbPages.getPage(data.attributes.pid)
|
||||
.then(function(data) {
|
||||
let response = {
|
||||
data: data
|
||||
};
|
||||
logger.debug(response);
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
eventHandler.emit('renderPage', data.attributes);
|
||||
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
});
|
||||
|
||||
pagesRouter.patch('/:id', function(req, res) {
|
||||
dbPages.addNewPage(req.body.data)
|
||||
.then(function(data) {
|
||||
|
||||
let response = {
|
||||
data: data
|
||||
};
|
||||
res.status(200).send(response);
|
||||
eventHandler.emit('renderPage', data.attributes);
|
||||
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
});
|
||||
|
||||
|
||||
pagesRouter.delete('/:id', function(req, res) {
|
||||
logger.debug('Delete...');
|
||||
if (/Bearer .+/.test(req.headers.authorization)) {
|
||||
logger.debug(req.params.id);
|
||||
dbPages.deletePage(req.params.id)
|
||||
.then(function(data) {
|
||||
|
||||
let response = {
|
||||
data: data
|
||||
};
|
||||
res.status(200).send(response);
|
||||
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
} else {
|
||||
res.status(401).end();
|
||||
}
|
||||
});
|
||||
|
||||
pagesRouter.get('/:id', function(req, res) {
|
||||
logger.debug('Page to edit:', req.params.id);
|
||||
|
||||
dbPages.getPage(req.params.id)
|
||||
.then(function(data) {
|
||||
let response = {
|
||||
data: data
|
||||
};
|
||||
logger.debug(response);
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
app.use('/api/pages',
|
||||
require('body-parser').json({type: 'application/vnd.api+json'}));
|
||||
|
||||
app.use('/api/pages', pagesRouter);
|
||||
};
|
@ -0,0 +1,82 @@
|
||||
/*jshint node:true*/
|
||||
'use strict';
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbAccounts = require('../units/db-accounts')(db);
|
||||
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var profilesRouter = express.Router();
|
||||
var moment = require('moment');
|
||||
|
||||
profilesRouter.get('/:uid', function(req, res) {
|
||||
if (/Bearer .+/.test(req.headers.authorization)) {
|
||||
|
||||
dbAccounts.sqlGetProfile(req.params.uid)
|
||||
.then(function(data) {
|
||||
let response = {data: {}};
|
||||
if (data === null) {
|
||||
// No record yet, return an empty one.
|
||||
response.data = {
|
||||
type: 'profile', id: req.params.uid, attributes: {
|
||||
forename: '', surname: '', gender: 0, dob: '', bio: ''
|
||||
|
||||
}};
|
||||
} else {
|
||||
response.data = {
|
||||
type: 'profile', id: data.uid, attributes: {
|
||||
forename: data.forename,
|
||||
surname: data.surname,
|
||||
gender: data.gender,
|
||||
dob: moment(data.dob).format('YYYY-MM-DD'),
|
||||
bio: data.bio
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch(function(e) {
|
||||
console.error(e);
|
||||
res.status(401).end();
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
profilesRouter.patch('/:id', function(req, res) {
|
||||
var data = req.body.data;
|
||||
var attr = data.attributes;
|
||||
var updateData = {
|
||||
uid: data.id,
|
||||
forename: attr.forename,
|
||||
surname: attr.surname,
|
||||
gender: attr.gender,
|
||||
dob: attr.dob,
|
||||
bio: attr.bio
|
||||
};
|
||||
dbAccounts.addInsertProfile(updateData)
|
||||
.then(function() {
|
||||
let response = {
|
||||
data: {
|
||||
type: 'profile', id: req.params.id, attributes: data.attributes
|
||||
}
|
||||
};
|
||||
|
||||
res.status(200).send(response);
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
res.status(401).end();
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
profilesRouter.delete('/:id', function(req, res) {
|
||||
res.status(204).end();
|
||||
});
|
||||
|
||||
app.use('/api/profiles', require('body-parser').json());
|
||||
app.use('/api/profiles',
|
||||
require('body-parser').json({type: 'application/vnd.api+json'}));
|
||||
|
||||
app.use('/api/profiles', profilesRouter);
|
||||
};
|
58
obrand/obrand-admin-server/O-BrandServer/server/app/token.js
Normal file
58
obrand/obrand-admin-server/O-BrandServer/server/app/token.js
Normal file
@ -0,0 +1,58 @@
|
||||
/*jshint node:true*/
|
||||
'use strict';
|
||||
|
||||
var db = require('../units/db-connector').dbConnection;
|
||||
var dbAccounts = require('../units/db-accounts')(db);
|
||||
var logger = require('log4js').getLogger();
|
||||
|
||||
module.exports = function(app) {
|
||||
var express = require('express');
|
||||
var tokenRouter = express.Router();
|
||||
|
||||
tokenRouter.get('/', function(req, res) {
|
||||
res.send({
|
||||
token: []
|
||||
});
|
||||
});
|
||||
|
||||
tokenRouter.post('/', function(req, res) {
|
||||
if (req.body.hasOwnProperty('grant_type')) {
|
||||
if (req.body.grant_type === 'password') {
|
||||
dbAccounts.findAccount({
|
||||
email: req.body.username,
|
||||
password: req.body.password
|
||||
})
|
||||
.then(function(d) {
|
||||
let loginObj = {
|
||||
access_token: 'secret token!',
|
||||
account_id: d.uid,
|
||||
username: d.username,
|
||||
account: d.email
|
||||
};
|
||||
// Res.status(200).send('{ "access_token": "secret token!", "account_id": d.id }');
|
||||
res.status(200).send(loginObj);
|
||||
})
|
||||
.catch(function(err) {
|
||||
logger.error(err);
|
||||
res.status(400).send(
|
||||
'{ "error": "No account could be found with those details" }');
|
||||
});
|
||||
} else {
|
||||
logger.error('A');
|
||||
res.status(400).send(
|
||||
'{ "error": "No account could be found with those details" }');
|
||||
}
|
||||
|
||||
} else {
|
||||
logger.error('B');
|
||||
logger.warn(req.body.hasOwnProperty('grant_type'));
|
||||
res.status(400).send(
|
||||
'{ "error": "No account could be found with those details" }');
|
||||
}
|
||||
|
||||
});
|
||||
|
||||
app.use('/token', require('body-parser').urlencoded());
|
||||
|
||||
app.use('/token', tokenRouter);
|
||||
};
|
@ -0,0 +1,13 @@
|
||||
<?xml version="1.0"?>
|
||||
<!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd">
|
||||
<cross-domain-policy>
|
||||
<!-- Read this: www.adobe.com/devnet/articles/crossdomain_policy_file_spec.html -->
|
||||
|
||||
<!-- Most restrictive policy: -->
|
||||
<!-- <site-control permitted-cross-domain-policies="none"/>-->
|
||||
|
||||
<!-- Least restrictive policy: -->
|
||||
<site-control permitted-cross-domain-policies="all"/>
|
||||
<allow-access-from domain="*" to-ports="*" secure="false"/>
|
||||
<allow-http-request-headers-from domain="*" headers="*" secure="false"/>
|
||||
</cross-domain-policy>
|
1
obrand/obrand-admin-server/O-BrandServer/server/css/mui.min.css
vendored
Normal file
1
obrand/obrand-admin-server/O-BrandServer/server/css/mui.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
@ -0,0 +1,15 @@
|
||||
.textcenter {
|
||||
text-align: center !important;
|
||||
}
|
||||
|
||||
.centerblock {
|
||||
display: block;
|
||||
margin-left: auto;
|
||||
margin-right: auto;
|
||||
}
|
||||
|
||||
#image.img {
|
||||
max-width: 300px;
|
||||
max-height: 300px;
|
||||
|
||||
}
|
11
obrand/obrand-admin-server/O-BrandServer/server/css/pure.min.css
vendored
Normal file
11
obrand/obrand-admin-server/O-BrandServer/server/css/pure.min.css
vendored
Normal file
File diff suppressed because one or more lines are too long
25
obrand/obrand-admin-server/O-BrandServer/server/index.js
Normal file
25
obrand/obrand-admin-server/O-BrandServer/server/index.js
Normal file
@ -0,0 +1,25 @@
|
||||
/*jshint node:true*/
|
||||
|
||||
// To use it create some files under `mocks/`
|
||||
// e.g. `server/mocks/ember-hamsters.js`
|
||||
//
|
||||
// module.exports = function(app) {
|
||||
// app.get('/ember-hamsters', function(req, res) {
|
||||
// res.send('hello');
|
||||
// });
|
||||
// };
|
||||
|
||||
module.exports = function(app) {
|
||||
var globSync = require('glob').sync;
|
||||
var mocks = globSync('./mocks/**/*.js', { cwd: __dirname }).map(require);
|
||||
var proxies = globSync('./proxies/**/*.js', { cwd: __dirname }).map(require);
|
||||
|
||||
|
||||
// Log proxy requests
|
||||
var morgan = require('morgan');
|
||||
app.use(morgan('dev'));
|
||||
|
||||
mocks.forEach(function(route) { route(app); });
|
||||
proxies.forEach(function(route) { route(app); });
|
||||
|
||||
};
|
@ -0,0 +1,202 @@
|
||||
'use strict';
|
||||
|
||||
var mdValidator = require('node-validator');
|
||||
var mdErrors = require('./md-errors');
|
||||
var bcrypt = require('bcrypt-as-promised');
|
||||
var newId = require('uuid-pure').newId;
|
||||
|
||||
module.exports = function(db) {
|
||||
var module = {};
|
||||
|
||||
module.connectPGP = function() {
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.query('select $1::int as number', [1])
|
||||
.then((data)=> {
|
||||
resolve(data);
|
||||
})
|
||||
.catch((error)=> {
|
||||
reject(error);
|
||||
});
|
||||
});
|
||||
};
|
||||
module.sqlInsertAccount = function(data) {
|
||||
let _data = data;
|
||||
_data.uid = newId();
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.func('insert_user',
|
||||
[_data.username, _data.email, _data.hash, _data.uid])
|
||||
.then(()=> {
|
||||
return resolve('ok');
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
module.sqlGetAccount = function(email) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.oneOrNone('select * from logins where email=$1;', [email])
|
||||
.then(function(d) {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
module.sqlGetAccountDetails = function(uid) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.one('select * from getAccountDetails($1);',[uid])
|
||||
.then(function(d) {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
module.sqlUpsertProfile = function(data) {
|
||||
var propArray = [
|
||||
data.uid,
|
||||
data.forename,
|
||||
data.surname,
|
||||
data.gender,
|
||||
data.dob,
|
||||
data.bio
|
||||
];
|
||||
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.func('upsert_profile', propArray)
|
||||
.then(()=> {
|
||||
return resolve(true);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.sqlMakeMemberOf = function(cid, uid) {
|
||||
var propArray = [cid,uid];
|
||||
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.func('makeMemberOf', propArray)
|
||||
.then(()=> {
|
||||
return resolve(true);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.sqlGetProfile = function(uid) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.oneOrNone('select * from profile where uid=$1;', [uid])
|
||||
.then(function(d) {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.addNewAccount = function(data) {
|
||||
var self = this;
|
||||
return new Promise((resolve, reject) => {
|
||||
|
||||
let _data = {};
|
||||
_data.username = data.username.trim();
|
||||
_data.password = data.password.trim();
|
||||
_data.email = data.email.trim();
|
||||
|
||||
if (Object.keys(data).length === 3) {
|
||||
|
||||
if (_data.username.length === 0 || _data.password.length === 0 || _data.email.length === 0) {
|
||||
return reject(mdErrors.error(1000));
|
||||
}
|
||||
|
||||
if (mdValidator.Email(data.email) === false) {
|
||||
return reject(mdErrors.error(1001));
|
||||
} else {
|
||||
// It should be possible to insert the user now.
|
||||
bcrypt.hash(data.password,10).then((d) => {
|
||||
_data.hash = d;
|
||||
self.sqlInsertAccount(_data)
|
||||
.then(()=> {
|
||||
return resolve({reply: 'user added'});
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
|
||||
}
|
||||
} else {
|
||||
// Error - required details missing
|
||||
return reject(mdErrors.error(1002));
|
||||
|
||||
}
|
||||
});
|
||||
};
|
||||
module.findAccount = function(data) {
|
||||
|
||||
var _data = data;
|
||||
return new Promise((resolve, reject) => {
|
||||
this.sqlGetAccount(_data.email)
|
||||
.then((row) => {
|
||||
if (row === null) {
|
||||
return reject(mdErrors.error(1004));
|
||||
}
|
||||
// Check password against hash held in db
|
||||
// noinspection JSUnresolvedVariable
|
||||
bcrypt.compare(_data.password, row.password_hash)
|
||||
.then(function() {
|
||||
let loginDetails = {
|
||||
id: row.id,
|
||||
username: row.username,
|
||||
email: row.email,
|
||||
uid: row.uid
|
||||
};
|
||||
return resolve(loginDetails);
|
||||
})
|
||||
// Failure, reject
|
||||
.catch(function() {
|
||||
return reject(mdErrors.error(1004));
|
||||
});
|
||||
|
||||
})
|
||||
.catch(function(err) {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
module.addInsertProfile = function(data) {
|
||||
return new Promise((resolve, reject) => {
|
||||
this.sqlUpsertProfile(data)
|
||||
.then((d)=> {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
//MakeMemberOf(cid, uid)
|
||||
module.makeMemberOf = function(cid, uid) {
|
||||
return new Promise((resolve, reject) => {
|
||||
this.sqlMakeMemberOf(cid, uid)
|
||||
.then((d)=> {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
return module;
|
||||
};
|
||||
|
@ -0,0 +1,115 @@
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-03-15
|
||||
* Time: 14:04
|
||||
*
|
||||
*/
|
||||
'use strict';
|
||||
var $V = require('node-validator');
|
||||
var mdErrors = require('./md-errors');
|
||||
var newId = require('uuid-pure').newId;
|
||||
var $U = require('md-utils');
|
||||
|
||||
module.exports = function(db) {
|
||||
var module = {};
|
||||
|
||||
module.sqlInsertCompany = function(data) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.proc('upsert_company',data)
|
||||
.then(()=> {
|
||||
console.log('+sqlInsertCompany OK');
|
||||
return resolve('ok');
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.log('+sqlInsertCompany failed');
|
||||
console.log(err);
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
module.sqlGetSimpleCompany = function(id) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
//db.oneOrNone('select *, company_name company-name from company where cid=$1;', [id])
|
||||
|
||||
db.oneOrNone('select company.* from company where cid=$1;', [id])
|
||||
|
||||
.then(function(d) {
|
||||
console.log(d);
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
console.log(err);
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.addNewCompany = function(data) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let _data;
|
||||
_data = $U.cloneTrim(data);
|
||||
|
||||
_data = $U.sanitiseObj(_data,
|
||||
{company_name: true, address1: true, address2: true, address3: true,
|
||||
town: false, county: false, pcontact: true, ocontact: true,mobile: true});
|
||||
|
||||
if (_data.hasOwnProperty('company_name') && (_data.company_name.length === 0)) {
|
||||
return reject(mdErrors.error(1100));
|
||||
}
|
||||
|
||||
if ([
|
||||
_data.address1, _data.address2, _data.address3
|
||||
].join('').trim().length === 0) {
|
||||
return reject(mdErrors.error(1101));
|
||||
}
|
||||
|
||||
if ([_data.town, _data.county].join('').trim().length === 0) {
|
||||
return reject(mdErrors.error(1102));
|
||||
}
|
||||
|
||||
var pcv = $V.checkPostCode(_data.postcode);
|
||||
|
||||
if (pcv === '') {
|
||||
return reject(mdErrors.error(1103));
|
||||
} else {
|
||||
_data.postcode = pcv;
|
||||
}
|
||||
|
||||
_data.pcontact = $V.validatePhone(_data.pcontact);
|
||||
_data.ocontact = $V.validatePhone(_data.ocontact);
|
||||
_data.mobile = $V.validatePhone(_data.mobile);
|
||||
|
||||
if ([
|
||||
_data.pcontact, _data.ocontact, _data.mobile
|
||||
].join('').trim().length === 0) {
|
||||
return reject(mdErrors.error(1104));
|
||||
}
|
||||
|
||||
if (_data.email.length === 0 || !$V.Email(_data.email)) {
|
||||
return reject(mdErrors.error(1105));
|
||||
}
|
||||
|
||||
if (typeof _data.cid === 'undefined' || _data.cid === null) {
|
||||
_data.cid = newId();
|
||||
}
|
||||
|
||||
const sqlData = [_data.cid, _data.company_name, _data.address1, _data.address2,
|
||||
_data.address3, _data.town, _data.county, _data.postcode, _data.country, _data.pcontact,
|
||||
_data.ocontact, _data.mobile, _data.email];
|
||||
|
||||
this.sqlInsertCompany(sqlData)
|
||||
.then(function(d) {
|
||||
console.log('Inserted');
|
||||
console.log(d);
|
||||
return resolve({cid: _data.cid});
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.log('Failed to insert');
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
return module;
|
||||
};
|
@ -0,0 +1,21 @@
|
||||
'uses strict';
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-03-11
|
||||
* Time: 10:22
|
||||
*
|
||||
*/
|
||||
|
||||
var pgp = require('pg-promise')();
|
||||
|
||||
var cn = {
|
||||
host: 'localhost',
|
||||
port: 5432,
|
||||
database: 'oBrand',
|
||||
user: 'obrand',
|
||||
password: 'obrand'
|
||||
};
|
||||
|
||||
exports.dbConnection = pgp(cn);
|
||||
|
@ -0,0 +1,175 @@
|
||||
'use strict';
|
||||
|
||||
var mdErrors = require('./md-errors');
|
||||
var newId = require('uuid-pure').newId;
|
||||
var $U = require('md-utils');
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-03-24
|
||||
* Time: 11:10
|
||||
*
|
||||
*/
|
||||
|
||||
|
||||
module.exports = function(db) {
|
||||
|
||||
var module = {};
|
||||
|
||||
module.deletePage = function(id) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
|
||||
db.oneOrNone(
|
||||
'delete from pages where id=${id}',{id:id})
|
||||
.then((d) => {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
|
||||
module.getLatestAddedPage = function() {
|
||||
return new Promise(function(resolve, reject) {
|
||||
|
||||
db.oneOrNone(
|
||||
"select 'export/' || pages.pid::text || '.html' as fullpath from pages order by id desc limit 1;")
|
||||
.then((d) => {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
module.getPageList = function() {
|
||||
return new Promise(function(resolve, reject) {
|
||||
|
||||
db.any(
|
||||
"select pages.cid, pages.pid, pages.title, company.company_name, '/export/' || pages.pid::text || '.html' as fullpath from pages join company on company.cid = pages.cid;")
|
||||
.then((d) => {
|
||||
return resolve(d);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.getPage = function(pid) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
|
||||
db.oneOrNone(
|
||||
'select * from pages where pid=${pid}',{pid:pid})
|
||||
.then((d) => {
|
||||
let attributeObj = $U.newObjectFrom(d,
|
||||
['id', 'cid', 'vid', 'pid', 'content', 'title']);
|
||||
attributeObj = $U.populateObject(d.data, attributeObj);
|
||||
|
||||
let newObj = {
|
||||
"id": attributeObj.id,
|
||||
"type": "page",
|
||||
"attributes": attributeObj
|
||||
};
|
||||
|
||||
return resolve(newObj);
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.getFullPageList = function() {
|
||||
return new Promise(function(resolve, reject) {
|
||||
|
||||
db.any("select * from pages;")
|
||||
.then((d) => {
|
||||
let rArray = [];
|
||||
for (var l = 0; l < d.length; l++) {
|
||||
let attributeObj = $U.newObjectFrom(d[l],
|
||||
['id', 'cid', 'vid', 'pid', 'content', 'title']);
|
||||
attributeObj = $U.populateObject(d[l].data, attributeObj);
|
||||
|
||||
let newObj = {
|
||||
"id": attributeObj.id,
|
||||
"type": "page",
|
||||
"attributes": attributeObj
|
||||
};
|
||||
rArray.push(newObj);
|
||||
}
|
||||
return resolve(rArray);
|
||||
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
};
|
||||
|
||||
module.sqlInsertPage = function(data) {
|
||||
return new Promise(function(resolve, reject) {
|
||||
db.func('upsert_page', data)
|
||||
.then(()=> {
|
||||
return resolve('ok');
|
||||
})
|
||||
.catch((err)=> {
|
||||
return reject(err);
|
||||
});
|
||||
});
|
||||
|
||||
};
|
||||
|
||||
module.addNewPage = function(data) {
|
||||
return new Promise((resolve, reject) => {
|
||||
let _data, _jsonData;
|
||||
|
||||
_data = $U.cloneTrim(data.attributes);
|
||||
|
||||
if (typeof _data.pid === 'undefined' || _data.pid === null) {
|
||||
_data.pid = newId();
|
||||
}
|
||||
|
||||
_jsonData = $U.newObjectFrom(_data,
|
||||
[
|
||||
'title',
|
||||
'image-url',
|
||||
'link1-text',
|
||||
'link1-url',
|
||||
'link2-text',
|
||||
'link2-url',
|
||||
'link3-text',
|
||||
'link3-url',
|
||||
'link4-text',
|
||||
'link4-url'
|
||||
]);
|
||||
|
||||
const sqlData = [
|
||||
_data.cid,
|
||||
_data.vid,
|
||||
_data.pid,
|
||||
_data.content,
|
||||
_data.title,
|
||||
JSON.stringify(_jsonData)
|
||||
];
|
||||
|
||||
this.sqlInsertPage(sqlData)
|
||||
.then(function() {
|
||||
data.attributes = _data;
|
||||
return resolve(data);
|
||||
})
|
||||
.catch(function(err) {
|
||||
return reject(err);
|
||||
});
|
||||
|
||||
});
|
||||
};
|
||||
|
||||
return module;
|
||||
|
||||
};
|
@ -0,0 +1,37 @@
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-03-10
|
||||
* Time: 11:31
|
||||
*
|
||||
*/
|
||||
var logger = require('log4js').getLogger();
|
||||
|
||||
var MDERRORS = new function() {
|
||||
'use strict';
|
||||
|
||||
var errors = {
|
||||
1000: {name: 'Account error', title: 'Signup data missing'},
|
||||
1001: {name: 'Account error', title: 'Email address is not in the correct format'},
|
||||
1002: {name: 'Account error', title: 'Required details missing'},
|
||||
1003: {name: 'Account error', title: 'Email does not exist in login table'},
|
||||
1004: {name: 'Account error', title: 'Email address or password are incorrect'},
|
||||
1100: {name: 'Company Error', title: 'Company name is missing'},
|
||||
1101: {name: 'Company Error', title: 'Address details are missing'},
|
||||
1102: {name: 'Company Error', title: 'Town/County details are missing'},
|
||||
1103: {name: 'Company Error', title: 'Postcode is missing / incorrect'},
|
||||
1104: {name: 'Company Error', title: 'Contact phone number is missing'},
|
||||
1105: {name: 'Company Error', title: 'Email is missing / invalid'}
|
||||
|
||||
};
|
||||
|
||||
this.error = function(code) {
|
||||
var estring = errors[code].name + ': ' + errors[code].title + '\nCode: ' + code + '\n';
|
||||
|
||||
logger.error(estring);
|
||||
|
||||
return ({code: code, name: errors[code].name, title: errors[code].title, string: estring});
|
||||
};
|
||||
}();
|
||||
|
||||
module.exports = MDERRORS;
|
25
obrand/obrand-admin-server/O-BrandServer/views/pages.jade
Normal file
25
obrand/obrand-admin-server/O-BrandServer/views/pages.jade
Normal file
@ -0,0 +1,25 @@
|
||||
doctype html
|
||||
html(lang="en")
|
||||
head
|
||||
meta(name='viewport', content='width=device-width, initial-scale=1.0')
|
||||
link(rel='stylesheet', href='/css/mui.min.css')
|
||||
|
||||
title Generated Page List
|
||||
|
||||
body
|
||||
.mui-container
|
||||
.mui-panel
|
||||
.mui--text-headline.mui-text-accent Generated Page List
|
||||
|
||||
#list.mui-panel
|
||||
table.mui-table.mui-table--bordered
|
||||
thead
|
||||
tr
|
||||
th Company
|
||||
th Page Title
|
||||
|
||||
each item in data
|
||||
tr
|
||||
td= item.company_name
|
||||
td
|
||||
a.mui-btn.mui-btn--flat.mui-btn--primary(href=item.fullpath, target='_blank')=item.title
|
@ -0,0 +1,15 @@
|
||||
<?xml version="1.0"?>
|
||||
<!DOCTYPE cross-domain-policy SYSTEM "http://www.adobe.com/xml/dtds/cross-domain-policy.dtd">
|
||||
<cross-domain-policy>
|
||||
<!-- Read this: www.adobe.com/devnet/articles/crossdomain_policy_file_spec.html -->
|
||||
|
||||
<!-- Most restrictive policy: -->
|
||||
<site-control permitted-cross-domain-policies="none"/>
|
||||
|
||||
<!-- Least restrictive policy: -->
|
||||
<!--
|
||||
<site-control permitted-cross-domain-policies="all"/>
|
||||
<allow-access-from domain="*" to-ports="*" secure="false"/>
|
||||
<allow-http-request-headers-from domain="*" headers="*" secure="false"/>
|
||||
-->
|
||||
</cross-domain-policy>
|
11
obrand/obrand-admin-server/O-BrandServer/wwwroot/css.css
Normal file
11
obrand/obrand-admin-server/O-BrandServer/wwwroot/css.css
Normal file
File diff suppressed because one or more lines are too long
Binary file not shown.
@ -0,0 +1,229 @@
|
||||
<?xml version="1.0" standalone="no"?>
|
||||
<!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.1//EN" "http://www.w3.org/Graphics/SVG/1.1/DTD/svg11.dtd" >
|
||||
<svg xmlns="http://www.w3.org/2000/svg">
|
||||
<metadata></metadata>
|
||||
<defs>
|
||||
<font id="glyphicons_halflingsregular" horiz-adv-x="1200" >
|
||||
<font-face units-per-em="1200" ascent="960" descent="-240" />
|
||||
<missing-glyph horiz-adv-x="500" />
|
||||
<glyph />
|
||||
<glyph />
|
||||
<glyph unicode="
" />
|
||||
<glyph unicode=" " />
|
||||
<glyph unicode="*" d="M100 500v200h259l-183 183l141 141l183 -183v259h200v-259l183 183l141 -141l-183 -183h259v-200h-259l183 -183l-141 -141l-183 183v-259h-200v259l-183 -183l-141 141l183 183h-259z" />
|
||||
<glyph unicode="+" d="M0 400v300h400v400h300v-400h400v-300h-400v-400h-300v400h-400z" />
|
||||
<glyph unicode=" " />
|
||||
<glyph unicode=" " horiz-adv-x="652" />
|
||||
<glyph unicode=" " horiz-adv-x="1304" />
|
||||
<glyph unicode=" " horiz-adv-x="652" />
|
||||
<glyph unicode=" " horiz-adv-x="1304" />
|
||||
<glyph unicode=" " horiz-adv-x="434" />
|
||||
<glyph unicode=" " horiz-adv-x="326" />
|
||||
<glyph unicode=" " horiz-adv-x="217" />
|
||||
<glyph unicode=" " horiz-adv-x="217" />
|
||||
<glyph unicode=" " horiz-adv-x="163" />
|
||||
<glyph unicode=" " horiz-adv-x="260" />
|
||||
<glyph unicode=" " horiz-adv-x="72" />
|
||||
<glyph unicode=" " horiz-adv-x="260" />
|
||||
<glyph unicode=" " horiz-adv-x="326" />
|
||||
<glyph unicode="€" d="M100 500l100 100h113q0 47 5 100h-218l100 100h135q37 167 112 257q117 141 297 141q242 0 354 -189q60 -103 66 -209h-181q0 55 -25.5 99t-63.5 68t-75 36.5t-67 12.5q-24 0 -52.5 -10t-62.5 -32t-65.5 -67t-50.5 -107h379l-100 -100h-300q-6 -46 -6 -100h406l-100 -100 h-300q9 -74 33 -132t52.5 -91t62 -54.5t59 -29t46.5 -7.5q29 0 66 13t75 37t63.5 67.5t25.5 96.5h174q-31 -172 -128 -278q-107 -117 -274 -117q-205 0 -324 158q-36 46 -69 131.5t-45 205.5h-217z" />
|
||||
<glyph unicode="−" d="M200 400h900v300h-900v-300z" />
|
||||
<glyph unicode="◼" horiz-adv-x="500" d="M0 0z" />
|
||||
<glyph unicode="☁" d="M-14 494q0 -80 56.5 -137t135.5 -57h750q120 0 205 86.5t85 207.5t-85 207t-205 86q-46 0 -90 -14q-44 97 -134.5 156.5t-200.5 59.5q-152 0 -260 -107.5t-108 -260.5q0 -25 2 -37q-66 -14 -108.5 -67.5t-42.5 -122.5z" />
|
||||
<glyph unicode="✉" d="M0 100l400 400l200 -200l200 200l400 -400h-1200zM0 300v600l300 -300zM0 1100l600 -603l600 603h-1200zM900 600l300 300v-600z" />
|
||||
<glyph unicode="✏" d="M-13 -13l333 112l-223 223zM187 403l214 -214l614 614l-214 214zM887 1103l214 -214l99 92q13 13 13 32.5t-13 33.5l-153 153q-15 13 -33 13t-33 -13z" />
|
||||
<glyph unicode="" d="M0 1200h1200l-500 -550v-550h300v-100h-800v100h300v550z" />
|
||||
<glyph unicode="" d="M14 84q18 -55 86 -75.5t147 5.5q65 21 109 69t44 90v606l600 155v-521q-64 16 -138 -7q-79 -26 -122.5 -83t-25.5 -111q18 -55 86 -75.5t147 4.5q70 23 111.5 63.5t41.5 95.5v881q0 10 -7 15.5t-17 2.5l-752 -193q-10 -3 -17 -12.5t-7 -19.5v-689q-64 17 -138 -7 q-79 -25 -122.5 -82t-25.5 -112z" />
|
||||
<glyph unicode="" d="M23 693q0 200 142 342t342 142t342 -142t142 -342q0 -142 -78 -261l300 -300q7 -8 7 -18t-7 -18l-109 -109q-8 -7 -18 -7t-18 7l-300 300q-119 -78 -261 -78q-200 0 -342 142t-142 342zM176 693q0 -136 97 -233t234 -97t233.5 96.5t96.5 233.5t-96.5 233.5t-233.5 96.5 t-234 -97t-97 -233z" />
|
||||
<glyph unicode="" d="M100 784q0 64 28 123t73 100.5t104.5 64t119 20.5t120 -38.5t104.5 -104.5q48 69 109.5 105t121.5 38t118.5 -20.5t102.5 -64t71 -100.5t27 -123q0 -57 -33.5 -117.5t-94 -124.5t-126.5 -127.5t-150 -152.5t-146 -174q-62 85 -145.5 174t-149.5 152.5t-126.5 127.5 t-94 124.5t-33.5 117.5z" />
|
||||
<glyph unicode="" d="M-72 800h479l146 400h2l146 -400h472l-382 -278l145 -449l-384 275l-382 -275l146 447zM168 71l2 1z" />
|
||||
<glyph unicode="" d="M-72 800h479l146 400h2l146 -400h472l-382 -278l145 -449l-384 275l-382 -275l146 447zM168 71l2 1zM237 700l196 -142l-73 -226l192 140l195 -141l-74 229l193 140h-235l-77 211l-78 -211h-239z" />
|
||||
<glyph unicode="" d="M0 0v143l400 257v100q-37 0 -68.5 74.5t-31.5 125.5v200q0 124 88 212t212 88t212 -88t88 -212v-200q0 -51 -31.5 -125.5t-68.5 -74.5v-100l400 -257v-143h-1200z" />
|
||||
<glyph unicode="" d="M0 0v1100h1200v-1100h-1200zM100 100h100v100h-100v-100zM100 300h100v100h-100v-100zM100 500h100v100h-100v-100zM100 700h100v100h-100v-100zM100 900h100v100h-100v-100zM300 100h600v400h-600v-400zM300 600h600v400h-600v-400zM1000 100h100v100h-100v-100z M1000 300h100v100h-100v-100zM1000 500h100v100h-100v-100zM1000 700h100v100h-100v-100zM1000 900h100v100h-100v-100z" />
|
||||
<glyph unicode="" d="M0 50v400q0 21 14.5 35.5t35.5 14.5h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5zM0 650v400q0 21 14.5 35.5t35.5 14.5h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400 q-21 0 -35.5 14.5t-14.5 35.5zM600 50v400q0 21 14.5 35.5t35.5 14.5h400q21 0 35.5 -14.5t14.5 -35.5v-400q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5zM600 650v400q0 21 14.5 35.5t35.5 14.5h400q21 0 35.5 -14.5t14.5 -35.5v-400 q0 -21 -14.5 -35.5t-35.5 -14.5h-400q-21 0 -35.5 14.5t-14.5 35.5z" />
|
||||
<glyph unicode="" d="M0 50v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM0 450v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200 q-21 0 -35.5 14.5t-14.5 35.5zM0 850v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM400 50v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5 t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM400 450v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM400 850v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5 v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM800 50v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM800 450v200q0 21 14.5 35.5t35.5 14.5h200 q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM800 850v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5z" />
|
||||
<glyph unicode="" d="M0 50v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM0 450q0 -21 14.5 -35.5t35.5 -14.5h200q21 0 35.5 14.5t14.5 35.5v200q0 21 -14.5 35.5t-35.5 14.5h-200q-21 0 -35.5 -14.5 t-14.5 -35.5v-200zM0 850v200q0 21 14.5 35.5t35.5 14.5h200q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5zM400 50v200q0 21 14.5 35.5t35.5 14.5h700q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5 t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5zM400 450v200q0 21 14.5 35.5t35.5 14.5h700q21 0 35.5 -14.5t14.5 -35.5v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5zM400 850v200q0 21 14.5 35.5t35.5 14.5h700q21 0 35.5 -14.5t14.5 -35.5 v-200q0 -21 -14.5 -35.5t-35.5 -14.5h-700q-21 0 -35.5 14.5t-14.5 35.5z" />
|
||||
<glyph unicode="" d="M29 454l419 -420l818 820l-212 212l-607 -607l-206 207z" />
|
||||
<glyph unicode="" d="M106 318l282 282l-282 282l212 212l282 -282l282 282l212 -212l-282 -282l282 -282l-212 -212l-282 282l-282 -282z" />
|
||||
<glyph unicode="" d="M23 693q0 200 142 342t342 142t342 -142t142 -342q0 -142 -78 -261l300 -300q7 -8 7 -18t-7 -18l-109 -109q-8 -7 -18 -7t-18 7l-300 300q-119 -78 -261 -78q-200 0 -342 142t-142 342zM176 693q0 -136 97 -233t234 -97t233.5 96.5t96.5 233.5t-96.5 233.5t-233.5 96.5 t-234 -97t-97 -233zM300 600v200h100v100h200v-100h100v-200h-100v-100h-200v100h-100z" />
|
||||
<glyph unicode="" d="M23 694q0 200 142 342t342 142t342 -142t142 -342q0 -141 -78 -262l300 -299q7 -7 7 -18t-7 -18l-109 -109q-8 -8 -18 -8t-18 8l-300 300q-119 -78 -261 -78q-200 0 -342 142t-142 342zM176 694q0 -136 97 -233t234 -97t233.5 97t96.5 233t-96.5 233t-233.5 97t-234 -97 t-97 -233zM300 601h400v200h-400v-200z" />
|
||||
<glyph unicode="" d="M23 600q0 183 105 331t272 210v-166q-103 -55 -165 -155t-62 -220q0 -177 125 -302t302 -125t302 125t125 302q0 120 -62 220t-165 155v166q167 -62 272 -210t105 -331q0 -118 -45.5 -224.5t-123 -184t-184 -123t-224.5 -45.5t-224.5 45.5t-184 123t-123 184t-45.5 224.5 zM500 750q0 -21 14.5 -35.5t35.5 -14.5h100q21 0 35.5 14.5t14.5 35.5v400q0 21 -14.5 35.5t-35.5 14.5h-100q-21 0 -35.5 -14.5t-14.5 -35.5v-400z" />
|
||||
<glyph unicode="" d="M100 1h200v300h-200v-300zM400 1v500h200v-500h-200zM700 1v800h200v-800h-200zM1000 1v1200h200v-1200h-200z" />
|
||||
<glyph unicode="" d="M26 601q0 -33 6 -74l151 -38l2 -6q14 -49 38 -93l3 -5l-80 -134q45 -59 105 -105l133 81l5 -3q45 -26 94 -39l5 -2l38 -151q40 -5 74 -5q27 0 74 5l38 151l6 2q46 13 93 39l5 3l134 -81q56 44 104 105l-80 134l3 5q24 44 39 93l1 6l152 38q5 40 5 74q0 28 -5 73l-152 38 l-1 6q-16 51 -39 93l-3 5l80 134q-44 58 -104 105l-134 -81l-5 3q-45 25 -93 39l-6 1l-38 152q-40 5 -74 5q-27 0 -74 -5l-38 -152l-5 -1q-50 -14 -94 -39l-5 -3l-133 81q-59 -47 -105 -105l80 -134l-3 -5q-25 -47 -38 -93l-2 -6l-151 -38q-6 -48 -6 -73zM385 601 q0 88 63 151t152 63t152 -63t63 -151q0 -89 -63 -152t-152 -63t-152 63t-63 152z" />
|
||||
<glyph unicode="" d="M100 1025v50q0 10 7.5 17.5t17.5 7.5h275v100q0 41 29.5 70.5t70.5 29.5h300q41 0 70.5 -29.5t29.5 -70.5v-100h275q10 0 17.5 -7.5t7.5 -17.5v-50q0 -11 -7 -18t-18 -7h-1050q-11 0 -18 7t-7 18zM200 100v800h900v-800q0 -41 -29.5 -71t-70.5 -30h-700q-41 0 -70.5 30 t-29.5 71zM300 100h100v700h-100v-700zM500 100h100v700h-100v-700zM500 1100h300v100h-300v-100zM700 100h100v700h-100v-700zM900 100h100v700h-100v-700z" />
|
||||
<glyph unicode="" d="M1 601l656 644l644 -644h-200v-600h-300v400h-300v-400h-300v600h-200z" />
|
||||
<glyph unicode="" d="M100 25v1150q0 11 7 18t18 7h475v-500h400v-675q0 -11 -7 -18t-18 -7h-850q-11 0 -18 7t-7 18zM700 800v300l300 -300h-300z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM500 500v400h100 v-300h200v-100h-300z" />
|
||||
<glyph unicode="" d="M-100 0l431 1200h209l-21 -300h162l-20 300h208l431 -1200h-538l-41 400h-242l-40 -400h-539zM488 500h224l-27 300h-170z" />
|
||||
<glyph unicode="" d="M0 0v400h490l-290 300h200v500h300v-500h200l-290 -300h490v-400h-1100zM813 200h175v100h-175v-100z" />
|
||||
<glyph unicode="" d="M1 600q0 122 47.5 233t127.5 191t191 127.5t233 47.5t233 -47.5t191 -127.5t127.5 -191t47.5 -233t-47.5 -233t-127.5 -191t-191 -127.5t-233 -47.5t-233 47.5t-191 127.5t-127.5 191t-47.5 233zM188 600q0 -170 121 -291t291 -121t291 121t121 291t-121 291t-291 121 t-291 -121t-121 -291zM350 600h150v300h200v-300h150l-250 -300z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM350 600l250 300 l250 -300h-150v-300h-200v300h-150z" />
|
||||
<glyph unicode="" d="M0 25v475l200 700h800l199 -700l1 -475q0 -11 -7 -18t-18 -7h-1150q-11 0 -18 7t-7 18zM200 500h200l50 -200h300l50 200h200l-97 500h-606z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -172 121.5 -293t292.5 -121t292.5 121t121.5 293q0 171 -121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM500 397v401 l297 -200z" />
|
||||
<glyph unicode="" d="M23 600q0 -118 45.5 -224.5t123 -184t184 -123t224.5 -45.5t224.5 45.5t184 123t123 184t45.5 224.5h-150q0 -177 -125 -302t-302 -125t-302 125t-125 302t125 302t302 125q136 0 246 -81l-146 -146h400v400l-145 -145q-157 122 -355 122q-118 0 -224.5 -45.5t-184 -123 t-123 -184t-45.5 -224.5z" />
|
||||
<glyph unicode="" d="M23 600q0 118 45.5 224.5t123 184t184 123t224.5 45.5q198 0 355 -122l145 145v-400h-400l147 147q-112 80 -247 80q-177 0 -302 -125t-125 -302h-150zM100 0v400h400l-147 -147q112 -80 247 -80q177 0 302 125t125 302h150q0 -118 -45.5 -224.5t-123 -184t-184 -123 t-224.5 -45.5q-198 0 -355 122z" />
|
||||
<glyph unicode="" d="M100 0h1100v1200h-1100v-1200zM200 100v900h900v-900h-900zM300 200v100h100v-100h-100zM300 400v100h100v-100h-100zM300 600v100h100v-100h-100zM300 800v100h100v-100h-100zM500 200h500v100h-500v-100zM500 400v100h500v-100h-500zM500 600v100h500v-100h-500z M500 800v100h500v-100h-500z" />
|
||||
<glyph unicode="" d="M0 100v600q0 41 29.5 70.5t70.5 29.5h100v200q0 82 59 141t141 59h300q82 0 141 -59t59 -141v-200h100q41 0 70.5 -29.5t29.5 -70.5v-600q0 -41 -29.5 -70.5t-70.5 -29.5h-900q-41 0 -70.5 29.5t-29.5 70.5zM400 800h300v150q0 21 -14.5 35.5t-35.5 14.5h-200 q-21 0 -35.5 -14.5t-14.5 -35.5v-150z" />
|
||||
<glyph unicode="" d="M100 0v1100h100v-1100h-100zM300 400q60 60 127.5 84t127.5 17.5t122 -23t119 -30t110 -11t103 42t91 120.5v500q-40 -81 -101.5 -115.5t-127.5 -29.5t-138 25t-139.5 40t-125.5 25t-103 -29.5t-65 -115.5v-500z" />
|
||||
<glyph unicode="" d="M0 275q0 -11 7 -18t18 -7h50q11 0 18 7t7 18v300q0 127 70.5 231.5t184.5 161.5t245 57t245 -57t184.5 -161.5t70.5 -231.5v-300q0 -11 7 -18t18 -7h50q11 0 18 7t7 18v300q0 116 -49.5 227t-131 192.5t-192.5 131t-227 49.5t-227 -49.5t-192.5 -131t-131 -192.5 t-49.5 -227v-300zM200 20v460q0 8 6 14t14 6h160q8 0 14 -6t6 -14v-460q0 -8 -6 -14t-14 -6h-160q-8 0 -14 6t-6 14zM800 20v460q0 8 6 14t14 6h160q8 0 14 -6t6 -14v-460q0 -8 -6 -14t-14 -6h-160q-8 0 -14 6t-6 14z" />
|
||||
<glyph unicode="" d="M0 400h300l300 -200v800l-300 -200h-300v-400zM688 459l141 141l-141 141l71 71l141 -141l141 141l71 -71l-141 -141l141 -141l-71 -71l-141 141l-141 -141z" />
|
||||
<glyph unicode="" d="M0 400h300l300 -200v800l-300 -200h-300v-400zM700 857l69 53q111 -135 111 -310q0 -169 -106 -302l-67 54q86 110 86 248q0 146 -93 257z" />
|
||||
<glyph unicode="" d="M0 401v400h300l300 200v-800l-300 200h-300zM702 858l69 53q111 -135 111 -310q0 -170 -106 -303l-67 55q86 110 86 248q0 145 -93 257zM889 951l7 -8q123 -151 123 -344q0 -189 -119 -339l-7 -8l81 -66l6 8q142 178 142 405q0 230 -144 408l-6 8z" />
|
||||
<glyph unicode="" d="M0 0h500v500h-200v100h-100v-100h-200v-500zM0 600h100v100h400v100h100v100h-100v300h-500v-600zM100 100v300h300v-300h-300zM100 800v300h300v-300h-300zM200 200v100h100v-100h-100zM200 900h100v100h-100v-100zM500 500v100h300v-300h200v-100h-100v-100h-200v100 h-100v100h100v200h-200zM600 0v100h100v-100h-100zM600 1000h100v-300h200v-300h300v200h-200v100h200v500h-600v-200zM800 800v300h300v-300h-300zM900 0v100h300v-100h-300zM900 900v100h100v-100h-100zM1100 200v100h100v-100h-100z" />
|
||||
<glyph unicode="" d="M0 200h100v1000h-100v-1000zM100 0v100h300v-100h-300zM200 200v1000h100v-1000h-100zM500 0v91h100v-91h-100zM500 200v1000h200v-1000h-200zM700 0v91h100v-91h-100zM800 200v1000h100v-1000h-100zM900 0v91h200v-91h-200zM1000 200v1000h200v-1000h-200z" />
|
||||
<glyph unicode="" d="M0 700l1 475q0 10 7.5 17.5t17.5 7.5h474l700 -700l-500 -500zM148 953q0 -42 29 -71q30 -30 71.5 -30t71.5 30q29 29 29 71t-29 71q-30 30 -71.5 30t-71.5 -30q-29 -29 -29 -71z" />
|
||||
<glyph unicode="" d="M1 700l1 475q0 11 7 18t18 7h474l700 -700l-500 -500zM148 953q0 -42 30 -71q29 -30 71 -30t71 30q30 29 30 71t-30 71q-29 30 -71 30t-71 -30q-30 -29 -30 -71zM701 1200h100l700 -700l-500 -500l-50 50l450 450z" />
|
||||
<glyph unicode="" d="M100 0v1025l175 175h925v-1000l-100 -100v1000h-750l-100 -100h750v-1000h-900z" />
|
||||
<glyph unicode="" d="M200 0l450 444l450 -443v1150q0 20 -14.5 35t-35.5 15h-800q-21 0 -35.5 -15t-14.5 -35v-1151z" />
|
||||
<glyph unicode="" d="M0 100v700h200l100 -200h600l100 200h200v-700h-200v200h-800v-200h-200zM253 829l40 -124h592l62 124l-94 346q-2 11 -10 18t-18 7h-450q-10 0 -18 -7t-10 -18zM281 24l38 152q2 10 11.5 17t19.5 7h500q10 0 19.5 -7t11.5 -17l38 -152q2 -10 -3.5 -17t-15.5 -7h-600 q-10 0 -15.5 7t-3.5 17z" />
|
||||
<glyph unicode="" d="M0 200q0 -41 29.5 -70.5t70.5 -29.5h1000q41 0 70.5 29.5t29.5 70.5v600q0 41 -29.5 70.5t-70.5 29.5h-150q-4 8 -11.5 21.5t-33 48t-53 61t-69 48t-83.5 21.5h-200q-41 0 -82 -20.5t-70 -50t-52 -59t-34 -50.5l-12 -20h-150q-41 0 -70.5 -29.5t-29.5 -70.5v-600z M356 500q0 100 72 172t172 72t172 -72t72 -172t-72 -172t-172 -72t-172 72t-72 172zM494 500q0 -44 31 -75t75 -31t75 31t31 75t-31 75t-75 31t-75 -31t-31 -75zM900 700v100h100v-100h-100z" />
|
||||
<glyph unicode="" d="M53 0h365v66q-41 0 -72 11t-49 38t1 71l92 234h391l82 -222q16 -45 -5.5 -88.5t-74.5 -43.5v-66h417v66q-34 1 -74 43q-18 19 -33 42t-21 37l-6 13l-385 998h-93l-399 -1006q-24 -48 -52 -75q-12 -12 -33 -25t-36 -20l-15 -7v-66zM416 521l178 457l46 -140l116 -317h-340 z" />
|
||||
<glyph unicode="" d="M100 0v89q41 7 70.5 32.5t29.5 65.5v827q0 28 -1 39.5t-5.5 26t-15.5 21t-29 14t-49 14.5v71l471 -1q120 0 213 -88t93 -228q0 -55 -11.5 -101.5t-28 -74t-33.5 -47.5t-28 -28l-12 -7q8 -3 21.5 -9t48 -31.5t60.5 -58t47.5 -91.5t21.5 -129q0 -84 -59 -156.5t-142 -111 t-162 -38.5h-500zM400 200h161q89 0 153 48.5t64 132.5q0 90 -62.5 154.5t-156.5 64.5h-159v-400zM400 700h139q76 0 130 61.5t54 138.5q0 82 -84 130.5t-239 48.5v-379z" />
|
||||
<glyph unicode="" d="M200 0v57q77 7 134.5 40.5t65.5 80.5l173 849q10 56 -10 74t-91 37q-6 1 -10.5 2.5t-9.5 2.5v57h425l2 -57q-33 -8 -62 -25.5t-46 -37t-29.5 -38t-17.5 -30.5l-5 -12l-128 -825q-10 -52 14 -82t95 -36v-57h-500z" />
|
||||
<glyph unicode="" d="M-75 200h75v800h-75l125 167l125 -167h-75v-800h75l-125 -167zM300 900v300h150h700h150v-300h-50q0 29 -8 48.5t-18.5 30t-33.5 15t-39.5 5.5t-50.5 1h-200v-850l100 -50v-100h-400v100l100 50v850h-200q-34 0 -50.5 -1t-40 -5.5t-33.5 -15t-18.5 -30t-8.5 -48.5h-49z " />
|
||||
<glyph unicode="" d="M33 51l167 125v-75h800v75l167 -125l-167 -125v75h-800v-75zM100 901v300h150h700h150v-300h-50q0 29 -8 48.5t-18 30t-33.5 15t-40 5.5t-50.5 1h-200v-650l100 -50v-100h-400v100l100 50v650h-200q-34 0 -50.5 -1t-39.5 -5.5t-33.5 -15t-18.5 -30t-8 -48.5h-50z" />
|
||||
<glyph unicode="" d="M0 50q0 -20 14.5 -35t35.5 -15h1100q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-1100q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM0 350q0 -20 14.5 -35t35.5 -15h800q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-800q-21 0 -35.5 -14.5t-14.5 -35.5 v-100zM0 650q0 -20 14.5 -35t35.5 -15h1000q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-1000q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM0 950q0 -20 14.5 -35t35.5 -15h600q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-600q-21 0 -35.5 -14.5 t-14.5 -35.5v-100z" />
|
||||
<glyph unicode="" d="M0 50q0 -20 14.5 -35t35.5 -15h1100q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-1100q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM0 650q0 -20 14.5 -35t35.5 -15h1100q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-1100q-21 0 -35.5 -14.5t-14.5 -35.5 v-100zM200 350q0 -20 14.5 -35t35.5 -15h700q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-700q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM200 950q0 -20 14.5 -35t35.5 -15h700q21 0 35.5 15t14.5 35v100q0 21 -14.5 35.5t-35.5 14.5h-700q-21 0 -35.5 -14.5 t-14.5 -35.5v-100z" />
|
||||
<glyph unicode="" d="M0 50v100q0 21 14.5 35.5t35.5 14.5h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-1100q-21 0 -35.5 15t-14.5 35zM100 650v100q0 21 14.5 35.5t35.5 14.5h1000q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-1000q-21 0 -35.5 15 t-14.5 35zM300 350v100q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-800q-21 0 -35.5 15t-14.5 35zM500 950v100q0 21 14.5 35.5t35.5 14.5h600q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-600 q-21 0 -35.5 15t-14.5 35z" />
|
||||
<glyph unicode="" d="M0 50v100q0 21 14.5 35.5t35.5 14.5h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-1100q-21 0 -35.5 15t-14.5 35zM0 350v100q0 21 14.5 35.5t35.5 14.5h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-1100q-21 0 -35.5 15 t-14.5 35zM0 650v100q0 21 14.5 35.5t35.5 14.5h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-1100q-21 0 -35.5 15t-14.5 35zM0 950v100q0 21 14.5 35.5t35.5 14.5h1100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-1100 q-21 0 -35.5 15t-14.5 35z" />
|
||||
<glyph unicode="" d="M0 50v100q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-100q-21 0 -35.5 15t-14.5 35zM0 350v100q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-100q-21 0 -35.5 15 t-14.5 35zM0 650v100q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-100q-21 0 -35.5 15t-14.5 35zM0 950v100q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-100q-21 0 -35.5 15 t-14.5 35zM300 50v100q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-800q-21 0 -35.5 15t-14.5 35zM300 350v100q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-800 q-21 0 -35.5 15t-14.5 35zM300 650v100q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15h-800q-21 0 -35.5 15t-14.5 35zM300 950v100q0 21 14.5 35.5t35.5 14.5h800q21 0 35.5 -14.5t14.5 -35.5v-100q0 -20 -14.5 -35t-35.5 -15 h-800q-21 0 -35.5 15t-14.5 35z" />
|
||||
<glyph unicode="" d="M-101 500v100h201v75l166 -125l-166 -125v75h-201zM300 0h100v1100h-100v-1100zM500 50q0 -20 14.5 -35t35.5 -15h600q20 0 35 15t15 35v100q0 21 -15 35.5t-35 14.5h-600q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM500 350q0 -20 14.5 -35t35.5 -15h300q20 0 35 15t15 35 v100q0 21 -15 35.5t-35 14.5h-300q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM500 650q0 -20 14.5 -35t35.5 -15h500q20 0 35 15t15 35v100q0 21 -15 35.5t-35 14.5h-500q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM500 950q0 -20 14.5 -35t35.5 -15h100q20 0 35 15t15 35v100 q0 21 -15 35.5t-35 14.5h-100q-21 0 -35.5 -14.5t-14.5 -35.5v-100z" />
|
||||
<glyph unicode="" d="M1 50q0 -20 14.5 -35t35.5 -15h600q20 0 35 15t15 35v100q0 21 -15 35.5t-35 14.5h-600q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM1 350q0 -20 14.5 -35t35.5 -15h300q20 0 35 15t15 35v100q0 21 -15 35.5t-35 14.5h-300q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM1 650 q0 -20 14.5 -35t35.5 -15h500q20 0 35 15t15 35v100q0 21 -15 35.5t-35 14.5h-500q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM1 950q0 -20 14.5 -35t35.5 -15h100q20 0 35 15t15 35v100q0 21 -15 35.5t-35 14.5h-100q-21 0 -35.5 -14.5t-14.5 -35.5v-100zM801 0v1100h100v-1100 h-100zM934 550l167 -125v75h200v100h-200v75z" />
|
||||
<glyph unicode="" d="M0 275v650q0 31 22 53t53 22h750q31 0 53 -22t22 -53v-650q0 -31 -22 -53t-53 -22h-750q-31 0 -53 22t-22 53zM900 600l300 300v-600z" />
|
||||
<glyph unicode="" d="M0 44v1012q0 18 13 31t31 13h1112q19 0 31.5 -13t12.5 -31v-1012q0 -18 -12.5 -31t-31.5 -13h-1112q-18 0 -31 13t-13 31zM100 263l247 182l298 -131l-74 156l293 318l236 -288v500h-1000v-737zM208 750q0 56 39 95t95 39t95 -39t39 -95t-39 -95t-95 -39t-95 39t-39 95z " />
|
||||
<glyph unicode="" d="M148 745q0 124 60.5 231.5t165 172t226.5 64.5q123 0 227 -63t164.5 -169.5t60.5 -229.5t-73 -272q-73 -114 -166.5 -237t-150.5 -189l-57 -66q-10 9 -27 26t-66.5 70.5t-96 109t-104 135.5t-100.5 155q-63 139 -63 262zM342 772q0 -107 75.5 -182.5t181.5 -75.5 q107 0 182.5 75.5t75.5 182.5t-75.5 182t-182.5 75t-182 -75.5t-75 -181.5z" />
|
||||
<glyph unicode="" d="M1 600q0 122 47.5 233t127.5 191t191 127.5t233 47.5t233 -47.5t191 -127.5t127.5 -191t47.5 -233t-47.5 -233t-127.5 -191t-191 -127.5t-233 -47.5t-233 47.5t-191 127.5t-127.5 191t-47.5 233zM173 600q0 -177 125.5 -302t301.5 -125v854q-176 0 -301.5 -125 t-125.5 -302z" />
|
||||
<glyph unicode="" d="M117 406q0 94 34 186t88.5 172.5t112 159t115 177t87.5 194.5q21 -71 57.5 -142.5t76 -130.5t83 -118.5t82 -117t70 -116t50 -125.5t18.5 -136q0 -89 -39 -165.5t-102 -126.5t-140 -79.5t-156 -33.5q-114 6 -211.5 53t-161.5 139t-64 210zM243 414q14 -82 59.5 -136 t136.5 -80l16 98q-7 6 -18 17t-34 48t-33 77q-15 73 -14 143.5t10 122.5l9 51q-92 -110 -119.5 -185t-12.5 -156z" />
|
||||
<glyph unicode="" d="M0 400v300q0 165 117.5 282.5t282.5 117.5q366 -6 397 -14l-186 -186h-311q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v125l200 200v-225q0 -165 -117.5 -282.5t-282.5 -117.5h-300q-165 0 -282.5 117.5 t-117.5 282.5zM436 341l161 50l412 412l-114 113l-405 -405zM995 1015l113 -113l113 113l-21 85l-92 28z" />
|
||||
<glyph unicode="" d="M0 400v300q0 165 117.5 282.5t282.5 117.5h261l2 -80q-133 -32 -218 -120h-145q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5l200 153v-53q0 -165 -117.5 -282.5t-282.5 -117.5h-300q-165 0 -282.5 117.5t-117.5 282.5 zM423 524q30 38 81.5 64t103 35.5t99 14t77.5 3.5l29 -1v-209l360 324l-359 318v-216q-7 0 -19 -1t-48 -8t-69.5 -18.5t-76.5 -37t-76.5 -59t-62 -88t-39.5 -121.5z" />
|
||||
<glyph unicode="" d="M0 400v300q0 165 117.5 282.5t282.5 117.5h300q61 0 127 -23l-178 -177h-349q-41 0 -70.5 -29.5t-29.5 -70.5v-500q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v69l200 200v-169q0 -165 -117.5 -282.5t-282.5 -117.5h-300q-165 0 -282.5 117.5 t-117.5 282.5zM342 632l283 -284l567 567l-137 137l-430 -431l-146 147z" />
|
||||
<glyph unicode="" d="M0 603l300 296v-198h200v200h-200l300 300l295 -300h-195v-200h200v198l300 -296l-300 -300v198h-200v-200h195l-295 -300l-300 300h200v200h-200v-198z" />
|
||||
<glyph unicode="" d="M200 50v1000q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-437l500 487v-1100l-500 488v-438q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5z" />
|
||||
<glyph unicode="" d="M0 50v1000q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-437l500 487v-487l500 487v-1100l-500 488v-488l-500 488v-438q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5z" />
|
||||
<glyph unicode="" d="M136 550l564 550v-487l500 487v-1100l-500 488v-488z" />
|
||||
<glyph unicode="" d="M200 0l900 550l-900 550v-1100z" />
|
||||
<glyph unicode="" d="M200 150q0 -21 14.5 -35.5t35.5 -14.5h200q21 0 35.5 14.5t14.5 35.5v800q0 21 -14.5 35.5t-35.5 14.5h-200q-21 0 -35.5 -14.5t-14.5 -35.5v-800zM600 150q0 -21 14.5 -35.5t35.5 -14.5h200q21 0 35.5 14.5t14.5 35.5v800q0 21 -14.5 35.5t-35.5 14.5h-200 q-21 0 -35.5 -14.5t-14.5 -35.5v-800z" />
|
||||
<glyph unicode="" d="M200 150q0 -20 14.5 -35t35.5 -15h800q21 0 35.5 15t14.5 35v800q0 21 -14.5 35.5t-35.5 14.5h-800q-21 0 -35.5 -14.5t-14.5 -35.5v-800z" />
|
||||
<glyph unicode="" d="M0 0v1100l500 -487v487l564 -550l-564 -550v488z" />
|
||||
<glyph unicode="" d="M0 0v1100l500 -487v487l500 -487v437q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-1000q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v438l-500 -488v488z" />
|
||||
<glyph unicode="" d="M300 0v1100l500 -487v437q0 21 14.5 35.5t35.5 14.5h100q21 0 35.5 -14.5t14.5 -35.5v-1000q0 -21 -14.5 -35.5t-35.5 -14.5h-100q-21 0 -35.5 14.5t-14.5 35.5v438z" />
|
||||
<glyph unicode="" d="M100 250v100q0 21 14.5 35.5t35.5 14.5h1000q21 0 35.5 -14.5t14.5 -35.5v-100q0 -21 -14.5 -35.5t-35.5 -14.5h-1000q-21 0 -35.5 14.5t-14.5 35.5zM100 500h1100l-550 564z" />
|
||||
<glyph unicode="" d="M185 599l592 -592l240 240l-353 353l353 353l-240 240z" />
|
||||
<glyph unicode="" d="M272 194l353 353l-353 353l241 240l572 -571l21 -22l-1 -1v-1l-592 -591z" />
|
||||
<glyph unicode="" d="M3 600q0 162 80 299.5t217.5 217.5t299.5 80t299.5 -80t217.5 -217.5t80 -299.5t-80 -299.5t-217.5 -217.5t-299.5 -80t-299.5 80t-217.5 217.5t-80 299.5zM300 500h200v-200h200v200h200v200h-200v200h-200v-200h-200v-200z" />
|
||||
<glyph unicode="" d="M3 600q0 162 80 299.5t217.5 217.5t299.5 80t299.5 -80t217.5 -217.5t80 -299.5t-80 -299.5t-217.5 -217.5t-299.5 -80t-299.5 80t-217.5 217.5t-80 299.5zM300 500h600v200h-600v-200z" />
|
||||
<glyph unicode="" d="M3 600q0 162 80 299.5t217.5 217.5t299.5 80t299.5 -80t217.5 -217.5t80 -299.5t-80 -299.5t-217.5 -217.5t-299.5 -80t-299.5 80t-217.5 217.5t-80 299.5zM246 459l213 -213l141 142l141 -142l213 213l-142 141l142 141l-213 212l-141 -141l-141 142l-212 -213l141 -141 z" />
|
||||
<glyph unicode="" d="M3 600q0 162 80 299.5t217.5 217.5t299.5 80t299.5 -80t217.5 -217.5t80 -299.5t-80 -299.5t-217.5 -217.5t-299.5 -80t-299.5 80t-217.5 217.5t-80 299.5zM270 551l276 -277l411 411l-175 174l-236 -236l-102 102z" />
|
||||
<glyph unicode="" d="M3 600q0 162 80 299.5t217.5 217.5t299.5 80t299.5 -80t217.5 -217.5t80 -299.5t-80 -299.5t-217.5 -217.5t-299.5 -80t-299.5 80t-217.5 217.5t-80 299.5zM364 700h143q4 0 11.5 -1t11 -1t6.5 3t3 9t1 11t3.5 8.5t3.5 6t5.5 4t6.5 2.5t9 1.5t9 0.5h11.5h12.5 q19 0 30 -10t11 -26q0 -22 -4 -28t-27 -22q-5 -1 -12.5 -3t-27 -13.5t-34 -27t-26.5 -46t-11 -68.5h200q5 3 14 8t31.5 25.5t39.5 45.5t31 69t14 94q0 51 -17.5 89t-42 58t-58.5 32t-58.5 15t-51.5 3q-50 0 -90.5 -12t-75 -38.5t-53.5 -74.5t-19 -114zM500 300h200v100h-200 v-100z" />
|
||||
<glyph unicode="" d="M3 600q0 162 80 299.5t217.5 217.5t299.5 80t299.5 -80t217.5 -217.5t80 -299.5t-80 -299.5t-217.5 -217.5t-299.5 -80t-299.5 80t-217.5 217.5t-80 299.5zM400 300h400v100h-100v300h-300v-100h100v-200h-100v-100zM500 800h200v100h-200v-100z" />
|
||||
<glyph unicode="" d="M0 500v200h195q31 125 98.5 199.5t206.5 100.5v200h200v-200q54 -20 113 -60t112.5 -105.5t71.5 -134.5h203v-200h-203q-25 -102 -116.5 -186t-180.5 -117v-197h-200v197q-140 27 -208 102.5t-98 200.5h-194zM290 500q24 -73 79.5 -127.5t130.5 -78.5v206h200v-206 q149 48 201 206h-201v200h200q-25 74 -75.5 127t-124.5 77v-204h-200v203q-75 -23 -130 -77t-79 -126h209v-200h-210z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM356 465l135 135 l-135 135l109 109l135 -135l135 135l109 -109l-135 -135l135 -135l-109 -109l-135 135l-135 -135z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM322 537l141 141 l87 -87l204 205l142 -142l-346 -345z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -115 62 -215l568 567q-100 62 -216 62q-171 0 -292.5 -121.5t-121.5 -292.5zM391 245q97 -59 209 -59q171 0 292.5 121.5t121.5 292.5 q0 112 -59 209z" />
|
||||
<glyph unicode="" d="M0 547l600 453v-300h600v-300h-600v-301z" />
|
||||
<glyph unicode="" d="M0 400v300h600v300l600 -453l-600 -448v301h-600z" />
|
||||
<glyph unicode="" d="M204 600l450 600l444 -600h-298v-600h-300v600h-296z" />
|
||||
<glyph unicode="" d="M104 600h296v600h300v-600h298l-449 -600z" />
|
||||
<glyph unicode="" d="M0 200q6 132 41 238.5t103.5 193t184 138t271.5 59.5v271l600 -453l-600 -448v301q-95 -2 -183 -20t-170 -52t-147 -92.5t-100 -135.5z" />
|
||||
<glyph unicode="" d="M0 0v400l129 -129l294 294l142 -142l-294 -294l129 -129h-400zM635 777l142 -142l294 294l129 -129v400h-400l129 -129z" />
|
||||
<glyph unicode="" d="M34 176l295 295l-129 129h400v-400l-129 130l-295 -295zM600 600v400l129 -129l295 295l142 -141l-295 -295l129 -130h-400z" />
|
||||
<glyph unicode="" d="M23 600q0 118 45.5 224.5t123 184t184 123t224.5 45.5t224.5 -45.5t184 -123t123 -184t45.5 -224.5t-45.5 -224.5t-123 -184t-184 -123t-224.5 -45.5t-224.5 45.5t-184 123t-123 184t-45.5 224.5zM456 851l58 -302q4 -20 21.5 -34.5t37.5 -14.5h54q20 0 37.5 14.5 t21.5 34.5l58 302q4 20 -8 34.5t-32 14.5h-207q-21 0 -33 -14.5t-8 -34.5zM500 300h200v100h-200v-100z" />
|
||||
<glyph unicode="" d="M0 800h100v-200h400v300h200v-300h400v200h100v100h-111q1 1 1 6.5t-1.5 15t-3.5 17.5l-34 172q-11 39 -41.5 63t-69.5 24q-32 0 -61 -17l-239 -144q-22 -13 -40 -35q-19 24 -40 36l-238 144q-33 18 -62 18q-39 0 -69.5 -23t-40.5 -61l-35 -177q-2 -8 -3 -18t-1 -15v-6 h-111v-100zM100 0h400v400h-400v-400zM200 900q-3 0 14 48t36 96l18 47l213 -191h-281zM700 0v400h400v-400h-400zM731 900l202 197q5 -12 12 -32.5t23 -64t25 -72t7 -28.5h-269z" />
|
||||
<glyph unicode="" d="M0 -22v143l216 193q-9 53 -13 83t-5.5 94t9 113t38.5 114t74 124q47 60 99.5 102.5t103 68t127.5 48t145.5 37.5t184.5 43.5t220 58.5q0 -189 -22 -343t-59 -258t-89 -181.5t-108.5 -120t-122 -68t-125.5 -30t-121.5 -1.5t-107.5 12.5t-87.5 17t-56.5 7.5l-99 -55z M238.5 300.5q19.5 -6.5 86.5 76.5q55 66 367 234q70 38 118.5 69.5t102 79t99 111.5t86.5 148q22 50 24 60t-6 19q-7 5 -17 5t-26.5 -14.5t-33.5 -39.5q-35 -51 -113.5 -108.5t-139.5 -89.5l-61 -32q-369 -197 -458 -401q-48 -111 -28.5 -117.5z" />
|
||||
<glyph unicode="" d="M111 408q0 -33 5 -63q9 -56 44 -119.5t105 -108.5q31 -21 64 -16t62 23.5t57 49.5t48 61.5t35 60.5q32 66 39 184.5t-13 157.5q79 -80 122 -164t26 -184q-5 -33 -20.5 -69.5t-37.5 -80.5q-10 -19 -14.5 -29t-12 -26t-9 -23.5t-3 -19t2.5 -15.5t11 -9.5t19.5 -5t30.5 2.5 t42 8q57 20 91 34t87.5 44.5t87 64t65.5 88.5t47 122q38 172 -44.5 341.5t-246.5 278.5q22 -44 43 -129q39 -159 -32 -154q-15 2 -33 9q-79 33 -120.5 100t-44 175.5t48.5 257.5q-13 -8 -34 -23.5t-72.5 -66.5t-88.5 -105.5t-60 -138t-8 -166.5q2 -12 8 -41.5t8 -43t6 -39.5 t3.5 -39.5t-1 -33.5t-6 -31.5t-13.5 -24t-21 -20.5t-31 -12q-38 -10 -67 13t-40.5 61.5t-15 81.5t10.5 75q-52 -46 -83.5 -101t-39 -107t-7.5 -85z" />
|
||||
<glyph unicode="" d="M-61 600l26 40q6 10 20 30t49 63.5t74.5 85.5t97 90t116.5 83.5t132.5 59t145.5 23.5t145.5 -23.5t132.5 -59t116.5 -83.5t97 -90t74.5 -85.5t49 -63.5t20 -30l26 -40l-26 -40q-6 -10 -20 -30t-49 -63.5t-74.5 -85.5t-97 -90t-116.5 -83.5t-132.5 -59t-145.5 -23.5 t-145.5 23.5t-132.5 59t-116.5 83.5t-97 90t-74.5 85.5t-49 63.5t-20 30zM120 600q7 -10 40.5 -58t56 -78.5t68 -77.5t87.5 -75t103 -49.5t125 -21.5t123.5 20t100.5 45.5t85.5 71.5t66.5 75.5t58 81.5t47 66q-1 1 -28.5 37.5t-42 55t-43.5 53t-57.5 63.5t-58.5 54 q49 -74 49 -163q0 -124 -88 -212t-212 -88t-212 88t-88 212q0 85 46 158q-102 -87 -226 -258zM377 656q49 -124 154 -191l105 105q-37 24 -75 72t-57 84l-20 36z" />
|
||||
<glyph unicode="" d="M-61 600l26 40q6 10 20 30t49 63.5t74.5 85.5t97 90t116.5 83.5t132.5 59t145.5 23.5q61 0 121 -17l37 142h148l-314 -1200h-148l37 143q-82 21 -165 71.5t-140 102t-109.5 112t-72 88.5t-29.5 43zM120 600q210 -282 393 -336l37 141q-107 18 -178.5 101.5t-71.5 193.5 q0 85 46 158q-102 -87 -226 -258zM377 656q49 -124 154 -191l47 47l23 87q-30 28 -59 69t-44 68l-14 26zM780 161l38 145q22 15 44.5 34t46 44t40.5 44t41 50.5t33.5 43.5t33 44t24.5 34q-97 127 -140 175l39 146q67 -54 131.5 -125.5t87.5 -103.5t36 -52l26 -40l-26 -40 q-7 -12 -25.5 -38t-63.5 -79.5t-95.5 -102.5t-124 -100t-146.5 -79z" />
|
||||
<glyph unicode="" d="M-97.5 34q13.5 -34 50.5 -34h1294q37 0 50.5 35.5t-7.5 67.5l-642 1056q-20 34 -48 36.5t-48 -29.5l-642 -1066q-21 -32 -7.5 -66zM155 200l445 723l445 -723h-345v100h-200v-100h-345zM500 600l100 -300l100 300v100h-200v-100z" />
|
||||
<glyph unicode="" d="M100 262v41q0 20 11 44.5t26 38.5l363 325v339q0 62 44 106t106 44t106 -44t44 -106v-339l363 -325q15 -14 26 -38.5t11 -44.5v-41q0 -20 -12 -26.5t-29 5.5l-359 249v-263q100 -91 100 -113v-64q0 -20 -13 -28.5t-32 0.5l-94 78h-222l-94 -78q-19 -9 -32 -0.5t-13 28.5 v64q0 22 100 113v263l-359 -249q-17 -12 -29 -5.5t-12 26.5z" />
|
||||
<glyph unicode="" d="M0 50q0 -20 14.5 -35t35.5 -15h1000q21 0 35.5 15t14.5 35v750h-1100v-750zM0 900h1100v150q0 21 -14.5 35.5t-35.5 14.5h-150v100h-100v-100h-500v100h-100v-100h-150q-21 0 -35.5 -14.5t-14.5 -35.5v-150zM100 100v100h100v-100h-100zM100 300v100h100v-100h-100z M100 500v100h100v-100h-100zM300 100v100h100v-100h-100zM300 300v100h100v-100h-100zM300 500v100h100v-100h-100zM500 100v100h100v-100h-100zM500 300v100h100v-100h-100zM500 500v100h100v-100h-100zM700 100v100h100v-100h-100zM700 300v100h100v-100h-100zM700 500 v100h100v-100h-100zM900 100v100h100v-100h-100zM900 300v100h100v-100h-100zM900 500v100h100v-100h-100z" />
|
||||
<glyph unicode="" d="M0 200v200h259l600 600h241v198l300 -295l-300 -300v197h-159l-600 -600h-341zM0 800h259l122 -122l141 142l-181 180h-341v-200zM678 381l141 142l122 -123h159v198l300 -295l-300 -300v197h-241z" />
|
||||
<glyph unicode="" d="M0 400v600q0 41 29.5 70.5t70.5 29.5h1000q41 0 70.5 -29.5t29.5 -70.5v-600q0 -41 -29.5 -70.5t-70.5 -29.5h-596l-304 -300v300h-100q-41 0 -70.5 29.5t-29.5 70.5z" />
|
||||
<glyph unicode="" d="M100 600v200h300v-250q0 -113 6 -145q17 -92 102 -117q39 -11 92 -11q37 0 66.5 5.5t50 15.5t36 24t24 31.5t14 37.5t7 42t2.5 45t0 47v25v250h300v-200q0 -42 -3 -83t-15 -104t-31.5 -116t-58 -109.5t-89 -96.5t-129 -65.5t-174.5 -25.5t-174.5 25.5t-129 65.5t-89 96.5 t-58 109.5t-31.5 116t-15 104t-3 83zM100 900v300h300v-300h-300zM800 900v300h300v-300h-300z" />
|
||||
<glyph unicode="" d="M-30 411l227 -227l352 353l353 -353l226 227l-578 579z" />
|
||||
<glyph unicode="" d="M70 797l580 -579l578 579l-226 227l-353 -353l-352 353z" />
|
||||
<glyph unicode="" d="M-198 700l299 283l300 -283h-203v-400h385l215 -200h-800v600h-196zM402 1000l215 -200h381v-400h-198l299 -283l299 283h-200v600h-796z" />
|
||||
<glyph unicode="" d="M18 939q-5 24 10 42q14 19 39 19h896l38 162q5 17 18.5 27.5t30.5 10.5h94q20 0 35 -14.5t15 -35.5t-15 -35.5t-35 -14.5h-54l-201 -961q-2 -4 -6 -10.5t-19 -17.5t-33 -11h-31v-50q0 -20 -14.5 -35t-35.5 -15t-35.5 15t-14.5 35v50h-300v-50q0 -20 -14.5 -35t-35.5 -15 t-35.5 15t-14.5 35v50h-50q-21 0 -35.5 15t-14.5 35q0 21 14.5 35.5t35.5 14.5h535l48 200h-633q-32 0 -54.5 21t-27.5 43z" />
|
||||
<glyph unicode="" d="M0 0v800h1200v-800h-1200zM0 900v100h200q0 41 29.5 70.5t70.5 29.5h300q41 0 70.5 -29.5t29.5 -70.5h500v-100h-1200z" />
|
||||
<glyph unicode="" d="M1 0l300 700h1200l-300 -700h-1200zM1 400v600h200q0 41 29.5 70.5t70.5 29.5h300q41 0 70.5 -29.5t29.5 -70.5h500v-200h-1000z" />
|
||||
<glyph unicode="" d="M302 300h198v600h-198l298 300l298 -300h-198v-600h198l-298 -300z" />
|
||||
<glyph unicode="" d="M0 600l300 298v-198h600v198l300 -298l-300 -297v197h-600v-197z" />
|
||||
<glyph unicode="" d="M0 100v100q0 41 29.5 70.5t70.5 29.5h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5zM31 400l172 739q5 22 23 41.5t38 19.5h672q19 0 37.5 -22.5t23.5 -45.5l172 -732h-1138zM800 100h100v100h-100v-100z M1000 100h100v100h-100v-100z" />
|
||||
<glyph unicode="" d="M-101 600v50q0 24 25 49t50 38l25 13v-250l-11 5.5t-24 14t-30 21.5t-24 27.5t-11 31.5zM100 500v250v8v8v7t0.5 7t1.5 5.5t2 5t3 4t4.5 3.5t6 1.5t7.5 0.5h200l675 250v-850l-675 200h-38l47 -276q2 -12 -3 -17.5t-11 -6t-21 -0.5h-8h-83q-20 0 -34.5 14t-18.5 35 q-55 337 -55 351zM1100 200v850q0 21 14.5 35.5t35.5 14.5q20 0 35 -14.5t15 -35.5v-850q0 -20 -15 -35t-35 -15q-21 0 -35.5 15t-14.5 35z" />
|
||||
<glyph unicode="" d="M74 350q0 21 13.5 35.5t33.5 14.5h18l117 173l63 327q15 77 76 140t144 83l-18 32q-6 19 3 32t29 13h94q20 0 29 -10.5t3 -29.5q-18 -36 -18 -37q83 -19 144 -82.5t76 -140.5l63 -327l118 -173h17q20 0 33.5 -14.5t13.5 -35.5q0 -20 -13 -40t-31 -27q-8 -3 -23 -8.5 t-65 -20t-103 -25t-132.5 -19.5t-158.5 -9q-125 0 -245.5 20.5t-178.5 40.5l-58 20q-18 7 -31 27.5t-13 40.5zM497 110q12 -49 40 -79.5t63 -30.5t63 30.5t39 79.5q-48 -6 -102 -6t-103 6z" />
|
||||
<glyph unicode="" d="M21 445l233 -45l-78 -224l224 78l45 -233l155 179l155 -179l45 233l224 -78l-78 224l234 45l-180 155l180 156l-234 44l78 225l-224 -78l-45 233l-155 -180l-155 180l-45 -233l-224 78l78 -225l-233 -44l179 -156z" />
|
||||
<glyph unicode="" d="M0 200h200v600h-200v-600zM300 275q0 -75 100 -75h61q124 -100 139 -100h250q46 0 83 57l238 344q29 31 29 74v100q0 44 -30.5 84.5t-69.5 40.5h-328q28 118 28 125v150q0 44 -30.5 84.5t-69.5 40.5h-50q-27 0 -51 -20t-38 -48l-96 -198l-145 -196q-20 -26 -20 -63v-400z M400 300v375l150 213l100 212h50v-175l-50 -225h450v-125l-250 -375h-214l-136 100h-100z" />
|
||||
<glyph unicode="" d="M0 400v600h200v-600h-200zM300 525v400q0 75 100 75h61q124 100 139 100h250q46 0 83 -57l238 -344q29 -31 29 -74v-100q0 -44 -30.5 -84.5t-69.5 -40.5h-328q28 -118 28 -125v-150q0 -44 -30.5 -84.5t-69.5 -40.5h-50q-27 0 -51 20t-38 48l-96 198l-145 196 q-20 26 -20 63zM400 525l150 -212l100 -213h50v175l-50 225h450v125l-250 375h-214l-136 -100h-100v-375z" />
|
||||
<glyph unicode="" d="M8 200v600h200v-600h-200zM308 275v525q0 17 14 35.5t28 28.5l14 9l362 230q14 6 25 6q17 0 29 -12l109 -112q14 -14 14 -34q0 -18 -11 -32l-85 -121h302q85 0 138.5 -38t53.5 -110t-54.5 -111t-138.5 -39h-107l-130 -339q-7 -22 -20.5 -41.5t-28.5 -19.5h-341 q-7 0 -90 81t-83 94zM408 289l100 -89h293l131 339q6 21 19.5 41t28.5 20h203q16 0 25 15t9 36q0 20 -9 34.5t-25 14.5h-457h-6.5h-7.5t-6.5 0.5t-6 1t-5 1.5t-5.5 2.5t-4 4t-4 5.5q-5 12 -5 20q0 14 10 27l147 183l-86 83l-339 -236v-503z" />
|
||||
<glyph unicode="" d="M-101 651q0 72 54 110t139 38l302 -1l-85 121q-11 16 -11 32q0 21 14 34l109 113q13 12 29 12q11 0 25 -6l365 -230q7 -4 17 -10.5t26.5 -26t16.5 -36.5v-526q0 -13 -86 -93.5t-94 -80.5h-341q-16 0 -29.5 20t-19.5 41l-130 339h-107q-84 0 -139 39t-55 111zM-1 601h222 q15 0 28.5 -20.5t19.5 -40.5l131 -339h293l107 89v502l-343 237l-87 -83l145 -184q10 -11 10 -26q0 -11 -5 -20q-1 -3 -3.5 -5.5l-4 -4t-5 -2.5t-5.5 -1.5t-6.5 -1t-6.5 -0.5h-7.5h-6.5h-476v-100zM1000 201v600h200v-600h-200z" />
|
||||
<glyph unicode="" d="M97 719l230 -363q4 -6 10.5 -15.5t26 -25t36.5 -15.5h525q13 0 94 83t81 90v342q0 15 -20 28.5t-41 19.5l-339 131v106q0 84 -39 139t-111 55t-110 -53.5t-38 -138.5v-302l-121 84q-15 12 -33.5 11.5t-32.5 -13.5l-112 -110q-22 -22 -6 -53zM172 739l83 86l183 -146 q22 -18 47 -5q3 1 5.5 3.5l4 4t2.5 5t1.5 5.5t1 6.5t0.5 6.5v7.5v6.5v456q0 22 25 31t50 -0.5t25 -30.5v-202q0 -16 20 -29.5t41 -19.5l339 -130v-294l-89 -100h-503zM400 0v200h600v-200h-600z" />
|
||||
<glyph unicode="" d="M2 585q-16 -31 6 -53l112 -110q13 -13 32 -13.5t34 10.5l121 85q0 -51 -0.5 -153.5t-0.5 -148.5q0 -84 38.5 -138t110.5 -54t111 55t39 139v106l339 131q20 6 40.5 19.5t20.5 28.5v342q0 7 -81 90t-94 83h-525q-17 0 -35.5 -14t-28.5 -28l-10 -15zM77 565l236 339h503 l89 -100v-294l-340 -130q-20 -6 -40 -20t-20 -29v-202q0 -22 -25 -31t-50 0t-25 31v456v14.5t-1.5 11.5t-5 12t-9.5 7q-24 13 -46 -5l-184 -146zM305 1104v200h600v-200h-600z" />
|
||||
<glyph unicode="" d="M5 597q0 122 47.5 232.5t127.5 190.5t190.5 127.5t232.5 47.5q162 0 299.5 -80t217.5 -218t80 -300t-80 -299.5t-217.5 -217.5t-299.5 -80t-300 80t-218 217.5t-80 299.5zM298 701l2 -201h300l-2 -194l402 294l-402 298v-197h-300z" />
|
||||
<glyph unicode="" d="M0 597q0 122 47.5 232.5t127.5 190.5t190.5 127.5t231.5 47.5q122 0 232.5 -47.5t190.5 -127.5t127.5 -190.5t47.5 -232.5q0 -162 -80 -299.5t-218 -217.5t-300 -80t-299.5 80t-217.5 217.5t-80 299.5zM200 600l402 -294l-2 194h300l2 201h-300v197z" />
|
||||
<glyph unicode="" d="M5 597q0 122 47.5 232.5t127.5 190.5t190.5 127.5t232.5 47.5q162 0 299.5 -80t217.5 -218t80 -300t-80 -299.5t-217.5 -217.5t-299.5 -80t-300 80t-218 217.5t-80 299.5zM300 600h200v-300h200v300h200l-300 400z" />
|
||||
<glyph unicode="" d="M5 597q0 122 47.5 232.5t127.5 190.5t190.5 127.5t232.5 47.5q162 0 299.5 -80t217.5 -218t80 -300t-80 -299.5t-217.5 -217.5t-299.5 -80t-300 80t-218 217.5t-80 299.5zM300 600l300 -400l300 400h-200v300h-200v-300h-200z" />
|
||||
<glyph unicode="" d="M5 597q0 122 47.5 232.5t127.5 190.5t190.5 127.5t232.5 47.5q121 0 231.5 -47.5t190.5 -127.5t127.5 -190.5t47.5 -232.5q0 -162 -80 -299.5t-217.5 -217.5t-299.5 -80t-300 80t-218 217.5t-80 299.5zM254 780q-8 -33 5.5 -92.5t7.5 -87.5q0 -9 17 -44t16 -60 q12 0 23 -5.5t23 -15t20 -13.5q24 -12 108 -42q22 -8 53 -31.5t59.5 -38.5t57.5 -11q8 -18 -15 -55t-20 -57q42 -71 87 -80q0 -6 -3 -15.5t-3.5 -14.5t4.5 -17q104 -3 221 112q30 29 47 47t34.5 49t20.5 62q-14 9 -37 9.5t-36 7.5q-14 7 -49 15t-52 19q-9 0 -39.5 -0.5 t-46.5 -1.5t-39 -6.5t-39 -16.5q-50 -35 -66 -12q-4 2 -3.5 25.5t0.5 25.5q-6 13 -26.5 17t-24.5 7q2 22 -2 41t-16.5 28t-38.5 -20q-23 -25 -42 4q-19 28 -8 58q6 16 22 22q6 -1 26 -1.5t33.5 -4t19.5 -13.5q12 -19 32 -37.5t34 -27.5l14 -8q0 3 9.5 39.5t5.5 57.5 q-4 23 14.5 44.5t22.5 31.5q5 14 10 35t8.5 31t15.5 22.5t34 21.5q-6 18 10 37q8 0 23.5 -1.5t24.5 -1.5t20.5 4.5t20.5 15.5q-10 23 -30.5 42.5t-38 30t-49 26.5t-43.5 23q11 39 2 44q31 -13 58 -14.5t39 3.5l11 4q7 36 -16.5 53.5t-64.5 28.5t-56 23q-19 -3 -37 0 q-15 -12 -36.5 -21t-34.5 -12t-44 -8t-39 -6q-15 -3 -45.5 0.5t-45.5 -2.5q-21 -7 -52 -26.5t-34 -34.5q-3 -11 6.5 -22.5t8.5 -18.5q-3 -34 -27.5 -90.5t-29.5 -79.5zM518 916q3 12 16 30t16 25q10 -10 18.5 -10t14 6t14.5 14.5t16 12.5q0 -24 17 -66.5t17 -43.5 q-9 2 -31 5t-36 5t-32 8t-30 14zM692 1003h1h-1z" />
|
||||
<glyph unicode="" d="M0 164.5q0 21.5 15 37.5l600 599q-33 101 6 201.5t135 154.5q164 92 306 -9l-259 -138l145 -232l251 126q13 -175 -151 -267q-123 -70 -253 -23l-596 -596q-15 -16 -36.5 -16t-36.5 16l-111 110q-15 15 -15 36.5z" />
|
||||
<glyph unicode="" horiz-adv-x="1220" d="M0 196v100q0 41 29.5 70.5t70.5 29.5h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5zM0 596v100q0 41 29.5 70.5t70.5 29.5h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000 q-41 0 -70.5 29.5t-29.5 70.5zM0 996v100q0 41 29.5 70.5t70.5 29.5h1000q41 0 70.5 -29.5t29.5 -70.5v-100q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5zM600 596h500v100h-500v-100zM800 196h300v100h-300v-100zM900 996h200v100h-200v-100z" />
|
||||
<glyph unicode="" d="M100 1100v100h1000v-100h-1000zM150 1000h900l-350 -500v-300l-200 -200v500z" />
|
||||
<glyph unicode="" d="M0 200v200h1200v-200q0 -41 -29.5 -70.5t-70.5 -29.5h-1000q-41 0 -70.5 29.5t-29.5 70.5zM0 500v400q0 41 29.5 70.5t70.5 29.5h300v100q0 41 29.5 70.5t70.5 29.5h200q41 0 70.5 -29.5t29.5 -70.5v-100h300q41 0 70.5 -29.5t29.5 -70.5v-400h-500v100h-200v-100h-500z M500 1000h200v100h-200v-100z" />
|
||||
<glyph unicode="" d="M0 0v400l129 -129l200 200l142 -142l-200 -200l129 -129h-400zM0 800l129 129l200 -200l142 142l-200 200l129 129h-400v-400zM729 329l142 142l200 -200l129 129v-400h-400l129 129zM729 871l200 200l-129 129h400v-400l-129 129l-200 -200z" />
|
||||
<glyph unicode="" d="M0 596q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM182 596q0 -172 121.5 -293t292.5 -121t292.5 121t121.5 293q0 171 -121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM291 655 q0 23 15.5 38.5t38.5 15.5t39 -16t16 -38q0 -23 -16 -39t-39 -16q-22 0 -38 16t-16 39zM400 850q0 22 16 38.5t39 16.5q22 0 38 -16t16 -39t-16 -39t-38 -16q-23 0 -39 16.5t-16 38.5zM514 609q0 32 20.5 56.5t51.5 29.5l122 126l1 1q-9 14 -9 28q0 22 16 38.5t39 16.5 q22 0 38 -16t16 -39t-16 -39t-38 -16q-14 0 -29 10l-55 -145q17 -22 17 -51q0 -36 -25.5 -61.5t-61.5 -25.5t-61.5 25.5t-25.5 61.5zM800 655q0 22 16 38t39 16t38.5 -15.5t15.5 -38.5t-16 -39t-38 -16q-23 0 -39 16t-16 39z" />
|
||||
<glyph unicode="" d="M-40 375q-13 -95 35 -173q35 -57 94 -89t129 -32q63 0 119 28q33 16 65 40.5t52.5 45.5t59.5 64q40 44 57 61l394 394q35 35 47 84t-3 96q-27 87 -117 104q-20 2 -29 2q-46 0 -78.5 -16.5t-67.5 -51.5l-389 -396l-7 -7l69 -67l377 373q20 22 39 38q23 23 50 23 q38 0 53 -36q16 -39 -20 -75l-547 -547q-52 -52 -125 -52q-55 0 -100 33t-54 96q-5 35 2.5 66t31.5 63t42 50t56 54q24 21 44 41l348 348q52 52 82.5 79.5t84 54t107.5 26.5q25 0 48 -4q95 -17 154 -94.5t51 -175.5q-7 -101 -98 -192l-252 -249l-253 -256l7 -7l69 -60 l517 511q67 67 95 157t11 183q-16 87 -67 154t-130 103q-69 33 -152 33q-107 0 -197 -55q-40 -24 -111 -95l-512 -512q-68 -68 -81 -163z" />
|
||||
<glyph unicode="" d="M80 784q0 131 98.5 229.5t230.5 98.5q143 0 241 -129q103 129 246 129q129 0 226 -98.5t97 -229.5q0 -46 -17.5 -91t-61 -99t-77 -89.5t-104.5 -105.5q-197 -191 -293 -322l-17 -23l-16 23q-43 58 -100 122.5t-92 99.5t-101 100q-71 70 -104.5 105.5t-77 89.5t-61 99 t-17.5 91zM250 784q0 -27 30.5 -70t61.5 -75.5t95 -94.5l22 -22q93 -90 190 -201q82 92 195 203l12 12q64 62 97.5 97t64.5 79t31 72q0 71 -48 119.5t-105 48.5q-74 0 -132 -83l-118 -171l-114 174q-51 80 -123 80q-60 0 -109.5 -49.5t-49.5 -118.5z" />
|
||||
<glyph unicode="" d="M57 353q0 -95 66 -159l141 -142q68 -66 159 -66q93 0 159 66l283 283q66 66 66 159t-66 159l-141 141q-8 9 -19 17l-105 -105l212 -212l-389 -389l-247 248l95 95l-18 18q-46 45 -75 101l-55 -55q-66 -66 -66 -159zM269 706q0 -93 66 -159l141 -141q7 -7 19 -17l105 105 l-212 212l389 389l247 -247l-95 -96l18 -17q47 -49 77 -100l29 29q35 35 62.5 88t27.5 96q0 93 -66 159l-141 141q-66 66 -159 66q-95 0 -159 -66l-283 -283q-66 -64 -66 -159z" />
|
||||
<glyph unicode="" d="M200 100v953q0 21 30 46t81 48t129 38t163 15t162 -15t127 -38t79 -48t29 -46v-953q0 -41 -29.5 -70.5t-70.5 -29.5h-600q-41 0 -70.5 29.5t-29.5 70.5zM300 300h600v700h-600v-700zM496 150q0 -43 30.5 -73.5t73.5 -30.5t73.5 30.5t30.5 73.5t-30.5 73.5t-73.5 30.5 t-73.5 -30.5t-30.5 -73.5z" />
|
||||
<glyph unicode="" d="M0 0l303 380l207 208l-210 212h300l267 279l-35 36q-15 14 -15 35t15 35q14 15 35 15t35 -15l283 -282q15 -15 15 -36t-15 -35q-14 -15 -35 -15t-35 15l-36 35l-279 -267v-300l-212 210l-208 -207z" />
|
||||
<glyph unicode="" d="M295 433h139q5 -77 48.5 -126.5t117.5 -64.5v335q-6 1 -15.5 4t-11.5 3q-46 14 -79 26.5t-72 36t-62.5 52t-40 72.5t-16.5 99q0 92 44 159.5t109 101t144 40.5v78h100v-79q38 -4 72.5 -13.5t75.5 -31.5t71 -53.5t51.5 -84t24.5 -118.5h-159q-8 72 -35 109.5t-101 50.5 v-307l64 -14q34 -7 64 -16.5t70 -31.5t67.5 -52t47.5 -80.5t20 -112.5q0 -139 -89 -224t-244 -96v-77h-100v78q-152 17 -237 104q-40 40 -52.5 93.5t-15.5 139.5zM466 889q0 -29 8 -51t16.5 -34t29.5 -22.5t31 -13.5t38 -10q7 -2 11 -3v274q-61 -8 -97.5 -37.5t-36.5 -102.5 zM700 237q170 18 170 151q0 64 -44 99.5t-126 60.5v-311z" />
|
||||
<glyph unicode="" d="M100 600v100h166q-24 49 -44 104q-10 26 -14.5 55.5t-3 72.5t25 90t68.5 87q97 88 263 88q129 0 230 -89t101 -208h-153q0 52 -34 89.5t-74 51.5t-76 14q-37 0 -79 -14.5t-62 -35.5q-41 -44 -41 -101q0 -28 16.5 -69.5t28 -62.5t41.5 -72h241v-100h-197q8 -50 -2.5 -115 t-31.5 -94q-41 -59 -99 -113q35 11 84 18t70 7q33 1 103 -16t103 -17q76 0 136 30l50 -147q-41 -25 -80.5 -36.5t-59 -13t-61.5 -1.5q-23 0 -128 33t-155 29q-39 -4 -82 -17t-66 -25l-24 -11l-55 145l16.5 11t15.5 10t13.5 9.5t14.5 12t14.5 14t17.5 18.5q48 55 54 126.5 t-30 142.5h-221z" />
|
||||
<glyph unicode="" d="M2 300l298 -300l298 300h-198v900h-200v-900h-198zM602 900l298 300l298 -300h-198v-900h-200v900h-198z" />
|
||||
<glyph unicode="" d="M2 300h198v900h200v-900h198l-298 -300zM700 0v200h100v-100h200v-100h-300zM700 400v100h300v-200h-99v-100h-100v100h99v100h-200zM700 700v500h300v-500h-100v100h-100v-100h-100zM801 900h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M2 300h198v900h200v-900h198l-298 -300zM700 0v500h300v-500h-100v100h-100v-100h-100zM700 700v200h100v-100h200v-100h-300zM700 1100v100h300v-200h-99v-100h-100v100h99v100h-200zM801 200h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M2 300l298 -300l298 300h-198v900h-200v-900h-198zM800 100v400h300v-500h-100v100h-200zM800 1100v100h200v-500h-100v400h-100zM901 200h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M2 300l298 -300l298 300h-198v900h-200v-900h-198zM800 400v100h200v-500h-100v400h-100zM800 800v400h300v-500h-100v100h-200zM901 900h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M2 300l298 -300l298 300h-198v900h-200v-900h-198zM700 100v200h500v-200h-500zM700 400v200h400v-200h-400zM700 700v200h300v-200h-300zM700 1000v200h200v-200h-200z" />
|
||||
<glyph unicode="" d="M2 300l298 -300l298 300h-198v900h-200v-900h-198zM700 100v200h200v-200h-200zM700 400v200h300v-200h-300zM700 700v200h400v-200h-400zM700 1000v200h500v-200h-500z" />
|
||||
<glyph unicode="" d="M0 400v300q0 165 117.5 282.5t282.5 117.5h300q162 0 281 -118.5t119 -281.5v-300q0 -165 -118.5 -282.5t-281.5 -117.5h-300q-165 0 -282.5 117.5t-117.5 282.5zM200 300q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5 h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500z" />
|
||||
<glyph unicode="" d="M0 400v300q0 163 119 281.5t281 118.5h300q165 0 282.5 -117.5t117.5 -282.5v-300q0 -165 -117.5 -282.5t-282.5 -117.5h-300q-163 0 -281.5 117.5t-118.5 282.5zM200 300q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5 h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500zM400 300l333 250l-333 250v-500z" />
|
||||
<glyph unicode="" d="M0 400v300q0 163 117.5 281.5t282.5 118.5h300q163 0 281.5 -119t118.5 -281v-300q0 -165 -117.5 -282.5t-282.5 -117.5h-300q-165 0 -282.5 117.5t-117.5 282.5zM200 300q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5 h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500zM300 700l250 -333l250 333h-500z" />
|
||||
<glyph unicode="" d="M0 400v300q0 165 117.5 282.5t282.5 117.5h300q165 0 282.5 -117.5t117.5 -282.5v-300q0 -162 -118.5 -281t-281.5 -119h-300q-165 0 -282.5 118.5t-117.5 281.5zM200 300q0 -41 29.5 -70.5t70.5 -29.5h500q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5 h-500q-41 0 -70.5 -29.5t-29.5 -70.5v-500zM300 400h500l-250 333z" />
|
||||
<glyph unicode="" d="M0 400v300h300v200l400 -350l-400 -350v200h-300zM500 0v200h500q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5h-500v200h400q165 0 282.5 -117.5t117.5 -282.5v-300q0 -165 -117.5 -282.5t-282.5 -117.5h-400z" />
|
||||
<glyph unicode="" d="M217 519q8 -19 31 -19h302q-155 -438 -160 -458q-5 -21 4 -32l9 -8h9q14 0 26 15q11 13 274.5 321.5t264.5 308.5q14 19 5 36q-8 17 -31 17l-301 -1q1 4 78 219.5t79 227.5q2 15 -5 27l-9 9h-9q-15 0 -25 -16q-4 -6 -98 -111.5t-228.5 -257t-209.5 -237.5q-16 -19 -6 -41 z" />
|
||||
<glyph unicode="" d="M0 400q0 -165 117.5 -282.5t282.5 -117.5h300q47 0 100 15v185h-500q-41 0 -70.5 29.5t-29.5 70.5v500q0 41 29.5 70.5t70.5 29.5h500v185q-14 4 -114 7.5t-193 5.5l-93 2q-165 0 -282.5 -117.5t-117.5 -282.5v-300zM600 400v300h300v200l400 -350l-400 -350v200h-300z " />
|
||||
<glyph unicode="" d="M0 400q0 -165 117.5 -282.5t282.5 -117.5h300q163 0 281.5 117.5t118.5 282.5v98l-78 73l-122 -123v-148q0 -41 -29.5 -70.5t-70.5 -29.5h-500q-41 0 -70.5 29.5t-29.5 70.5v500q0 41 29.5 70.5t70.5 29.5h156l118 122l-74 78h-100q-165 0 -282.5 -117.5t-117.5 -282.5 v-300zM496 709l353 342l-149 149h500v-500l-149 149l-342 -353z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM406 600 q0 80 57 137t137 57t137 -57t57 -137t-57 -137t-137 -57t-137 57t-57 137z" />
|
||||
<glyph unicode="" d="M0 0v275q0 11 7 18t18 7h1048q11 0 19 -7.5t8 -17.5v-275h-1100zM100 800l445 -500l450 500h-295v400h-300v-400h-300zM900 150h100v50h-100v-50z" />
|
||||
<glyph unicode="" d="M0 0v275q0 11 7 18t18 7h1048q11 0 19 -7.5t8 -17.5v-275h-1100zM100 700h300v-300h300v300h295l-445 500zM900 150h100v50h-100v-50z" />
|
||||
<glyph unicode="" d="M0 0v275q0 11 7 18t18 7h1048q11 0 19 -7.5t8 -17.5v-275h-1100zM100 705l305 -305l596 596l-154 155l-442 -442l-150 151zM900 150h100v50h-100v-50z" />
|
||||
<glyph unicode="" d="M0 0v275q0 11 7 18t18 7h1048q11 0 19 -7.5t8 -17.5v-275h-1100zM100 988l97 -98l212 213l-97 97zM200 400l697 1l3 699l-250 -239l-149 149l-212 -212l149 -149zM900 150h100v50h-100v-50z" />
|
||||
<glyph unicode="" d="M0 0v275q0 11 7 18t18 7h1048q11 0 19 -7.5t8 -17.5v-275h-1100zM200 612l212 -212l98 97l-213 212zM300 1200l239 -250l-149 -149l212 -212l149 148l249 -237l-1 697zM900 150h100v50h-100v-50z" />
|
||||
<glyph unicode="" d="M23 415l1177 784v-1079l-475 272l-310 -393v416h-392zM494 210l672 938l-672 -712v-226z" />
|
||||
<glyph unicode="" d="M0 150v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100l200 -200v-850q0 -21 -15 -35.5t-35 -14.5h-150v400h-700v-400h-150q-21 0 -35.5 14.5t-14.5 35.5zM600 1000h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M0 150v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100l200 -200v-218l-276 -275l-120 120l-126 -127h-378v-400h-150q-21 0 -35.5 14.5t-14.5 35.5zM581 306l123 123l120 -120l353 352l123 -123l-475 -476zM600 1000h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M0 150v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100l200 -200v-269l-103 -103l-170 170l-298 -298h-329v-400h-150q-21 0 -35.5 14.5t-14.5 35.5zM600 1000h100v200h-100v-200zM700 133l170 170l-170 170l127 127l170 -170l170 170l127 -128l-170 -169l170 -170 l-127 -127l-170 170l-170 -170z" />
|
||||
<glyph unicode="" d="M0 150v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100l200 -200v-300h-400v-200h-500v-400h-150q-21 0 -35.5 14.5t-14.5 35.5zM600 300l300 -300l300 300h-200v300h-200v-300h-200zM600 1000v200h100v-200h-100z" />
|
||||
<glyph unicode="" d="M0 150v1000q0 20 14.5 35t35.5 15h250v-300h500v300h100l200 -200v-402l-200 200l-298 -298h-402v-400h-150q-21 0 -35.5 14.5t-14.5 35.5zM600 300h200v-300h200v300h200l-300 300zM600 1000v200h100v-200h-100z" />
|
||||
<glyph unicode="" d="M0 250q0 -21 14.5 -35.5t35.5 -14.5h1100q21 0 35.5 14.5t14.5 35.5v550h-1200v-550zM0 900h1200v150q0 21 -14.5 35.5t-35.5 14.5h-1100q-21 0 -35.5 -14.5t-14.5 -35.5v-150zM100 300v200h400v-200h-400z" />
|
||||
<glyph unicode="" d="M0 400l300 298v-198h400v-200h-400v-198zM100 800v200h100v-200h-100zM300 800v200h100v-200h-100zM500 800v200h400v198l300 -298l-300 -298v198h-400zM800 300v200h100v-200h-100zM1000 300h100v200h-100v-200z" />
|
||||
<glyph unicode="" d="M100 700v400l50 100l50 -100v-300h100v300l50 100l50 -100v-300h100v300l50 100l50 -100v-400l-100 -203v-447q0 -21 -14.5 -35.5t-35.5 -14.5h-200q-21 0 -35.5 14.5t-14.5 35.5v447zM800 597q0 -29 10.5 -55.5t25 -43t29 -28.5t25.5 -18l10 -5v-397q0 -21 14.5 -35.5 t35.5 -14.5h200q21 0 35.5 14.5t14.5 35.5v1106q0 31 -18 40.5t-44 -7.5l-276 -116q-25 -17 -43.5 -51.5t-18.5 -65.5v-359z" />
|
||||
<glyph unicode="" d="M100 0h400v56q-75 0 -87.5 6t-12.5 44v394h500v-394q0 -38 -12.5 -44t-87.5 -6v-56h400v56q-4 0 -11 0.5t-24 3t-30 7t-24 15t-11 24.5v888q0 22 25 34.5t50 13.5l25 2v56h-400v-56q75 0 87.5 -6t12.5 -44v-394h-500v394q0 38 12.5 44t87.5 6v56h-400v-56q4 0 11 -0.5 t24 -3t30 -7t24 -15t11 -24.5v-888q0 -22 -25 -34.5t-50 -13.5l-25 -2v-56z" />
|
||||
<glyph unicode="" d="M0 300q0 -41 29.5 -70.5t70.5 -29.5h300q41 0 70.5 29.5t29.5 70.5v500q0 41 -29.5 70.5t-70.5 29.5h-300q-41 0 -70.5 -29.5t-29.5 -70.5v-500zM100 100h400l200 200h105l295 98v-298h-425l-100 -100h-375zM100 300v200h300v-200h-300zM100 600v200h300v-200h-300z M100 1000h400l200 -200v-98l295 98h105v200h-425l-100 100h-375zM700 402v163l400 133v-163z" />
|
||||
<glyph unicode="" d="M16.5 974.5q0.5 -21.5 16 -90t46.5 -140t104 -177.5t175 -208q103 -103 207.5 -176t180 -103.5t137 -47t92.5 -16.5l31 1l163 162q17 18 13.5 41t-22.5 37l-192 136q-19 14 -45 12t-42 -19l-118 -118q-142 101 -268 227t-227 268l118 118q17 17 20 41.5t-11 44.5 l-139 194q-14 19 -36.5 22t-40.5 -14l-162 -162q-1 -11 -0.5 -32.5z" />
|
||||
<glyph unicode="" d="M0 50v212q0 20 10.5 45.5t24.5 39.5l365 303v50q0 4 1 10.5t12 22.5t30 28.5t60 23t97 10.5t97 -10t60 -23.5t30 -27.5t12 -24l1 -10v-50l365 -303q14 -14 24.5 -39.5t10.5 -45.5v-212q0 -21 -14.5 -35.5t-35.5 -14.5h-1100q-20 0 -35 14.5t-15 35.5zM0 712 q0 -21 14.5 -33.5t34.5 -8.5l202 33q20 4 34.5 21t14.5 38v146q141 24 300 24t300 -24v-146q0 -21 14.5 -38t34.5 -21l202 -33q20 -4 34.5 8.5t14.5 33.5v200q-6 8 -19 20.5t-63 45t-112 57t-171 45t-235 20.5q-92 0 -175 -10.5t-141.5 -27t-108.5 -36.5t-81.5 -40 t-53.5 -36.5t-31 -27.5l-9 -10v-200z" />
|
||||
<glyph unicode="" d="M100 0v100h1100v-100h-1100zM175 200h950l-125 150v250l100 100v400h-100v-200h-100v200h-200v-200h-100v200h-200v-200h-100v200h-100v-400l100 -100v-250z" />
|
||||
<glyph unicode="" d="M100 0h300v400q0 41 -29.5 70.5t-70.5 29.5h-100q-41 0 -70.5 -29.5t-29.5 -70.5v-400zM500 0v1000q0 41 29.5 70.5t70.5 29.5h100q41 0 70.5 -29.5t29.5 -70.5v-1000h-300zM900 0v700q0 41 29.5 70.5t70.5 29.5h100q41 0 70.5 -29.5t29.5 -70.5v-700h-300z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 300h300v300h-200v100h200v100h-300v-300h200v-100h-200v-100zM600 300h200v100h100v300h-100v100h-200v-500 zM700 400v300h100v-300h-100z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 300h100v200h100v-200h100v500h-100v-200h-100v200h-100v-500zM600 300h200v100h100v300h-100v100h-200v-500 zM700 400v300h100v-300h-100z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 300h300v100h-200v300h200v100h-300v-500zM600 300h300v100h-200v300h200v100h-300v-500z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 550l300 -150v300zM600 400l300 150l-300 150v-300z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 300v500h700v-500h-700zM300 400h130q41 0 68 42t27 107t-28.5 108t-66.5 43h-130v-300zM575 549 q0 -65 27 -107t68 -42h130v300h-130q-38 0 -66.5 -43t-28.5 -108z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 300h300v300h-200v100h200v100h-300v-300h200v-100h-200v-100zM601 300h100v100h-100v-100zM700 700h100 v-400h100v500h-200v-100z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 300h300v400h-200v100h-100v-500zM301 400v200h100v-200h-100zM601 300h100v100h-100v-100zM700 700h100 v-400h100v500h-200v-100z" />
|
||||
<glyph unicode="" d="M-100 300v500q0 124 88 212t212 88h700q124 0 212 -88t88 -212v-500q0 -124 -88 -212t-212 -88h-700q-124 0 -212 88t-88 212zM100 200h900v700h-900v-700zM200 700v100h300v-300h-99v-100h-100v100h99v200h-200zM201 300v100h100v-100h-100zM601 300v100h100v-100h-100z M700 700v100h200v-500h-100v400h-100z" />
|
||||
<glyph unicode="" d="M4 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM186 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM400 500v200 l100 100h300v-100h-300v-200h300v-100h-300z" />
|
||||
<glyph unicode="" d="M0 600q0 162 80 299t217 217t299 80t299 -80t217 -217t80 -299t-80 -299t-217 -217t-299 -80t-299 80t-217 217t-80 299zM182 600q0 -171 121.5 -292.5t292.5 -121.5t292.5 121.5t121.5 292.5t-121.5 292.5t-292.5 121.5t-292.5 -121.5t-121.5 -292.5zM400 400v400h300 l100 -100v-100h-100v100h-200v-100h200v-100h-200v-100h-100zM700 400v100h100v-100h-100z" />
|
||||
<glyph unicode="" d="M-14 494q0 -80 56.5 -137t135.5 -57h222v300h400v-300h128q120 0 205 86.5t85 207.5t-85 207t-205 86q-46 0 -90 -14q-44 97 -134.5 156.5t-200.5 59.5q-152 0 -260 -107.5t-108 -260.5q0 -25 2 -37q-66 -14 -108.5 -67.5t-42.5 -122.5zM300 200h200v300h200v-300h200 l-300 -300z" />
|
||||
<glyph unicode="" d="M-14 494q0 -80 56.5 -137t135.5 -57h8l414 414l403 -403q94 26 154.5 104.5t60.5 178.5q0 120 -85 206.5t-205 86.5q-46 0 -90 -14q-44 97 -134.5 156.5t-200.5 59.5q-152 0 -260 -107.5t-108 -260.5q0 -25 2 -37q-66 -14 -108.5 -67.5t-42.5 -122.5zM300 200l300 300 l300 -300h-200v-300h-200v300h-200z" />
|
||||
<glyph unicode="" d="M100 200h400v-155l-75 -45h350l-75 45v155h400l-270 300h170l-270 300h170l-300 333l-300 -333h170l-270 -300h170z" />
|
||||
<glyph unicode="" d="M121 700q0 -53 28.5 -97t75.5 -65q-4 -16 -4 -38q0 -74 52.5 -126.5t126.5 -52.5q56 0 100 30v-306l-75 -45h350l-75 45v306q46 -30 100 -30q74 0 126.5 52.5t52.5 126.5q0 24 -9 55q50 32 79.5 83t29.5 112q0 90 -61.5 155.5t-150.5 71.5q-26 89 -99.5 145.5 t-167.5 56.5q-116 0 -197.5 -81.5t-81.5 -197.5q0 -4 1 -11.5t1 -11.5q-14 2 -23 2q-74 0 -126.5 -52.5t-52.5 -126.5z" />
|
||||
</font>
|
||||
</defs></svg>
|
After Width: | Height: | Size: 62 KiB |
Binary file not shown.
Binary file not shown.
Binary file not shown.
After Width: | Height: | Size: 266 KiB |
15
obrand/obrand-admin-server/O-BrandServer/wwwroot/index.html
Normal file
15
obrand/obrand-admin-server/O-BrandServer/wwwroot/index.html
Normal file
@ -0,0 +1,15 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||
<title>obrand-ko</title>
|
||||
<link rel="stylesheet" href="css.css">
|
||||
<script src="scripts.js"></script>
|
||||
</head>
|
||||
<body>
|
||||
<nav-bar params="route: route"></nav-bar>
|
||||
<div id="page" class="container" data-bind="component: { name: route().page, params: route }"></div>
|
||||
|
||||
</body>
|
||||
</html>
|
@ -0,0 +1,3 @@
|
||||
# http://www.robotstxt.org
|
||||
User-agent: *
|
||||
Disallow:
|
18583
obrand/obrand-admin-server/O-BrandServer/wwwroot/scripts.js
Normal file
18583
obrand/obrand-admin-server/O-BrandServer/wwwroot/scripts.js
Normal file
File diff suppressed because one or more lines are too long
4
obrand/obrand-admin/.bowerrc
Normal file
4
obrand/obrand-admin/.bowerrc
Normal file
@ -0,0 +1,4 @@
|
||||
{
|
||||
"directory": "bower_components",
|
||||
"analytics": false
|
||||
}
|
26
obrand/obrand-admin/.editorconfig
Normal file
26
obrand/obrand-admin/.editorconfig
Normal file
@ -0,0 +1,26 @@
|
||||
# EditorConfig helps developers define and maintain consistent
|
||||
# coding styles between different editors and IDEs
|
||||
# editorconfig.org
|
||||
|
||||
root = true
|
||||
|
||||
|
||||
[*]
|
||||
end_of_line = lf
|
||||
charset = utf-8
|
||||
trim_trailing_whitespace = true
|
||||
insert_final_newline = true
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
|
||||
[*.{js,json,hbs,html,css}]
|
||||
indent_style = space
|
||||
indent_size = 2
|
||||
|
||||
[*.hbs]
|
||||
insert_final_newline = false
|
||||
|
||||
[*.{diff,md}]
|
||||
indent_size = 2
|
||||
trim_trailing_whitespace = false
|
||||
|
9
obrand/obrand-admin/.ember-cli
Normal file
9
obrand/obrand-admin/.ember-cli
Normal file
@ -0,0 +1,9 @@
|
||||
{
|
||||
/**
|
||||
Ember CLI sends analytics information by default. The data is completely
|
||||
anonymous, but there are times when you might want to disable this behavior.
|
||||
|
||||
Setting `disableAnalytics` to true will prevent any data from being sent.
|
||||
*/
|
||||
"disableAnalytics": false
|
||||
}
|
192
obrand/obrand-admin/.gitignore
vendored
Normal file
192
obrand/obrand-admin/.gitignore
vendored
Normal file
@ -0,0 +1,192 @@
|
||||
### Archives template
|
||||
# It's better to unpack these files and commit the raw source because
|
||||
# git has its own built in compression methods.
|
||||
*.7z
|
||||
*.jar
|
||||
*.rar
|
||||
*.zip
|
||||
*.gz
|
||||
*.bzip
|
||||
*.bz2
|
||||
*.xz
|
||||
*.lzma
|
||||
*.cab
|
||||
|
||||
#packing-only formats
|
||||
*.iso
|
||||
*.tar
|
||||
|
||||
#package management formats
|
||||
*.dmg
|
||||
*.xpi
|
||||
*.gem
|
||||
*.egg
|
||||
*.deb
|
||||
*.rpm
|
||||
*.msi
|
||||
*.msm
|
||||
*.msp
|
||||
### Windows template
|
||||
# Windows image file caches
|
||||
Thumbs.db
|
||||
ehthumbs.db
|
||||
|
||||
# Folder config file
|
||||
Desktop.ini
|
||||
|
||||
# Recycle Bin used on file shares
|
||||
$RECYCLE.BIN/
|
||||
|
||||
# Windows Installer files
|
||||
*.cab
|
||||
*.msi
|
||||
*.msm
|
||||
*.msp
|
||||
|
||||
# Windows shortcuts
|
||||
*.lnk
|
||||
### JetBrains template
|
||||
# Covers JetBrains IDEs: IntelliJ, RubyMine, PhpStorm, AppCode, PyCharm, CLion, Android Studio
|
||||
|
||||
*.iml
|
||||
|
||||
## Directory-based project format:
|
||||
.idea/
|
||||
# if you remove the above rule, at least ignore the following:
|
||||
|
||||
# User-specific stuff:
|
||||
# .idea/workspace.xml
|
||||
# .idea/tasks.xml
|
||||
# .idea/dictionaries
|
||||
|
||||
# Sensitive or high-churn files:
|
||||
# .idea/dataSources.ids
|
||||
# .idea/dataSources.xml
|
||||
# .idea/sqlDataSources.xml
|
||||
# .idea/dynamic.xml
|
||||
# .idea/uiDesigner.xml
|
||||
|
||||
# Gradle:
|
||||
# .idea/gradle.xml
|
||||
# .idea/libraries
|
||||
|
||||
# Mongo Explorer plugin:
|
||||
# .idea/mongoSettings.xml
|
||||
|
||||
## File-based project format:
|
||||
*.ipr
|
||||
*.iws
|
||||
|
||||
## Plugin-specific files:
|
||||
|
||||
# IntelliJ
|
||||
/out/
|
||||
|
||||
# mpeltonen/sbt-idea plugin
|
||||
.idea_modules/
|
||||
|
||||
# JIRA plugin
|
||||
atlassian-ide-plugin.xml
|
||||
|
||||
# Crashlytics plugin (for Android Studio and IntelliJ)
|
||||
com_crashlytics_export_strings.xml
|
||||
crashlytics.properties
|
||||
crashlytics-build.properties
|
||||
### Xcode template
|
||||
# Xcode
|
||||
#
|
||||
# gitignore contributors: remember to update Global/Xcode.gitignore, Objective-C.gitignore & Swift.gitignore
|
||||
|
||||
## Build generated
|
||||
build/
|
||||
DerivedData
|
||||
|
||||
## Various settings
|
||||
*.pbxuser
|
||||
!default.pbxuser
|
||||
*.mode1v3
|
||||
!default.mode1v3
|
||||
*.mode2v3
|
||||
!default.mode2v3
|
||||
*.perspectivev3
|
||||
!default.perspectivev3
|
||||
xcuserdata
|
||||
|
||||
## Other
|
||||
*.xccheckout
|
||||
*.moved-aside
|
||||
*.xcuserstate
|
||||
### OSX template
|
||||
.DS_Store
|
||||
.AppleDouble
|
||||
.LSOverride
|
||||
|
||||
# Icon must end with two \r
|
||||
Icon
|
||||
|
||||
# Thumbnails
|
||||
._*
|
||||
|
||||
# Files that might appear in the root of a volume
|
||||
.DocumentRevisions-V100
|
||||
.fseventsd
|
||||
.Spotlight-V100
|
||||
.TemporaryItems
|
||||
.Trashes
|
||||
.VolumeIcon.icns
|
||||
|
||||
# Directories potentially created on remote AFP share
|
||||
.AppleDB
|
||||
.AppleDesktop
|
||||
Network Trash Folder
|
||||
Temporary Items
|
||||
.apdisk
|
||||
### Node template
|
||||
# Logs
|
||||
logs
|
||||
*.log
|
||||
npm-debug.log*
|
||||
|
||||
# Runtime data
|
||||
pids
|
||||
*.pid
|
||||
*.seed
|
||||
|
||||
# Directory for instrumented libs generated by jscoverage/JSCover
|
||||
lib-cov
|
||||
|
||||
# Coverage directory used by tools like istanbul
|
||||
coverage
|
||||
|
||||
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
|
||||
.grunt
|
||||
|
||||
# node-waf configuration
|
||||
.lock-wscript
|
||||
|
||||
# Compiled binary addons (http://nodejs.org/api/addons.html)
|
||||
build/Release
|
||||
|
||||
# Dependency directory
|
||||
# https://docs.npmjs.com/misc/faq#should-i-check-my-node-modules-folder-into-git
|
||||
node_modules
|
||||
|
||||
# See http://help.github.com/ignore-files/ for more about ignoring files.
|
||||
|
||||
# compiled output
|
||||
/dist
|
||||
/tmp
|
||||
|
||||
# dependencies
|
||||
/node_modules
|
||||
/bower_components
|
||||
|
||||
# misc
|
||||
/.sass-cache
|
||||
/connect.lock
|
||||
/coverage/*
|
||||
/libpeerconnection.log
|
||||
npm-debug.log
|
||||
testem.log
|
||||
/.cache
|
||||
/.gradle
|
47
obrand/obrand-admin/.jscsrc
Normal file
47
obrand/obrand-admin/.jscsrc
Normal file
@ -0,0 +1,47 @@
|
||||
{
|
||||
"disallowKeywords": ["with"],
|
||||
"disallowKeywordsOnNewLine": ["else"],
|
||||
"disallowMixedSpacesAndTabs": true,
|
||||
"disallowMultipleVarDecl": "exceptUndefined",
|
||||
"disallowNewlineBeforeBlockStatements": true,
|
||||
"disallowQuotedKeysInObjects": true,
|
||||
"disallowSpaceAfterObjectKeys": true,
|
||||
"disallowSpaceAfterPrefixUnaryOperators": true,
|
||||
"disallowSpacesInFunction": {
|
||||
"beforeOpeningRoundBrace": true
|
||||
},
|
||||
"disallowSpacesInsideParentheses": true,
|
||||
"disallowTrailingWhitespace": true,
|
||||
"maximumLineLength": 120,
|
||||
"requireCamelCaseOrUpperCaseIdentifiers": false,
|
||||
"requireCapitalizedComments": true,
|
||||
"requireCapitalizedConstructors": true,
|
||||
"requireCurlyBraces": true,
|
||||
"requireSpaceAfterKeywords": [
|
||||
"if",
|
||||
"else",
|
||||
"for",
|
||||
"while",
|
||||
"do",
|
||||
"switch",
|
||||
"case",
|
||||
"return",
|
||||
"try",
|
||||
"catch",
|
||||
"typeof"
|
||||
],
|
||||
"requireSpaceAfterLineComment": true,
|
||||
"requireSpaceAfterBinaryOperators": true,
|
||||
"requireSpaceBeforeBinaryOperators": true,
|
||||
"requireSpaceBeforeBlockStatements": true,
|
||||
"requireSpaceBeforeObjectValues": true,
|
||||
"requireSpacesInFunction": {
|
||||
"beforeOpeningCurlyBrace": true
|
||||
},
|
||||
"requireTrailingComma": false,
|
||||
"requireEarlyReturn": false,
|
||||
"validateIndentation": 2,
|
||||
"validateLineBreaks": "LF",
|
||||
"validateQuoteMarks": "'",
|
||||
|
||||
}
|
37
obrand/obrand-admin/.jshintrc
Normal file
37
obrand/obrand-admin/.jshintrc
Normal file
@ -0,0 +1,37 @@
|
||||
{
|
||||
"predef": {
|
||||
"document": true,
|
||||
"window": true,
|
||||
"SprintStatusENV": true,
|
||||
"Ember": true, // Added
|
||||
"$": true, // ADDED
|
||||
"Modernizr": true, // ADDED
|
||||
"-Promise": true, // ADDED
|
||||
"server": true // ADDED
|
||||
},
|
||||
"browser": true,
|
||||
"boss": true,
|
||||
"curly": true,
|
||||
"debug": false,
|
||||
"devel": true,
|
||||
"eqeqeq": true,
|
||||
"evil": true,
|
||||
"forin": false,
|
||||
"immed": false,
|
||||
"laxbreak": false,
|
||||
"newcap": true,
|
||||
"noarg": true,
|
||||
"noempty": false,
|
||||
"nonew": false,
|
||||
"nomen": false,
|
||||
"onevar": false,
|
||||
"plusplus": false,
|
||||
"regexp": false,
|
||||
"undef": true,
|
||||
"sub": true,
|
||||
"strict": false,
|
||||
"white": false,
|
||||
"eqnull": true,
|
||||
"esnext": true,
|
||||
"unused": true
|
||||
}
|
23
obrand/obrand-admin/.travis.yml
Normal file
23
obrand/obrand-admin/.travis.yml
Normal file
@ -0,0 +1,23 @@
|
||||
---
|
||||
language: node_js
|
||||
node_js:
|
||||
- "0.12"
|
||||
|
||||
sudo: false
|
||||
|
||||
cache:
|
||||
directories:
|
||||
- node_modules
|
||||
|
||||
before_install:
|
||||
- export PATH=/usr/local/phantomjs-2.0.0/bin:$PATH
|
||||
- "npm config set spin false"
|
||||
- "npm install -g npm@^2"
|
||||
|
||||
install:
|
||||
- npm install -g bower
|
||||
- npm install
|
||||
- bower install
|
||||
|
||||
script:
|
||||
- npm test
|
3
obrand/obrand-admin/.watchmanconfig
Normal file
3
obrand/obrand-admin/.watchmanconfig
Normal file
@ -0,0 +1,3 @@
|
||||
{
|
||||
"ignore_dirs": ["tmp", "dist", "static"]
|
||||
}
|
58
obrand/obrand-admin/README.md
Normal file
58
obrand/obrand-admin/README.md
Normal file
@ -0,0 +1,58 @@
|
||||
# Obrand-admin
|
||||
|
||||
This README outlines the details of collaborating on this Ember application.
|
||||
A short introduction of this app could easily go here.
|
||||
|
||||
## Prerequisites
|
||||
|
||||
You will need the following things properly installed on your computer.
|
||||
|
||||
* [Git](http://git-scm.com/)
|
||||
* [Node.js](http://nodejs.org/) (with NPM)
|
||||
* [Bower](http://bower.io/)
|
||||
* [Ember CLI](http://www.ember-cli.com/)
|
||||
* [PhantomJS](http://phantomjs.org/)
|
||||
|
||||
## Installation
|
||||
|
||||
* `git clone <repository-url>` this repository
|
||||
* change into the new directory
|
||||
* `npm install`
|
||||
* `bower install`
|
||||
|
||||
## Running / Development
|
||||
|
||||
* `ember server`
|
||||
* Visit your app at [http://localhost:4200](http://localhost:4200).
|
||||
|
||||
### Code Generators
|
||||
|
||||
Make use of the many generators for code, try `ember help generate` for more details
|
||||
|
||||
### Running Tests
|
||||
|
||||
* `ember test`
|
||||
* `ember test --server`
|
||||
|
||||
### Building
|
||||
|
||||
* `ember build` (development)
|
||||
* `ember build --environment production` (production)
|
||||
|
||||
### Deploying
|
||||
|
||||
To build do the following:
|
||||
|
||||
* `ember build --environtment production`
|
||||
* copy the contents into the wwwroot folder of obrand-admin-server
|
||||
* deploy obrand-admin-server
|
||||
|
||||
|
||||
## Further Reading / Useful Links
|
||||
|
||||
* [ember.js](http://emberjs.com/)
|
||||
* [ember-cli](http://www.ember-cli.com/)
|
||||
* Development Browser Extensions
|
||||
* [ember inspector for chrome](https://chrome.google.com/webstore/detail/ember-inspector/bmdblncegkenkacieihfhpjfppoconhi)
|
||||
* [ember inspector for firefox](https://addons.mozilla.org/en-US/firefox/addon/ember-inspector/)
|
||||
|
6
obrand/obrand-admin/app/adapters/application.js
Normal file
6
obrand/obrand-admin/app/adapters/application.js
Normal file
@ -0,0 +1,6 @@
|
||||
import DS from 'ember-data';
|
||||
import DataAdapterMixin from 'ember-simple-auth/mixins/data-adapter-mixin';
|
||||
|
||||
export default DS.JSONAPIAdapter.extend(DataAdapterMixin, {
|
||||
authorizer: 'authorizer:application'
|
||||
});
|
5
obrand/obrand-admin/app/adapters/company.js
Normal file
5
obrand/obrand-admin/app/adapters/company.js
Normal file
@ -0,0 +1,5 @@
|
||||
import ApplicationAdapter from './application';
|
||||
|
||||
export default ApplicationAdapter.extend({
|
||||
namespace: 'api'
|
||||
});
|
5
obrand/obrand-admin/app/adapters/newcompany.js
Normal file
5
obrand/obrand-admin/app/adapters/newcompany.js
Normal file
@ -0,0 +1,5 @@
|
||||
import ApplicationAdapter from './application';
|
||||
|
||||
export default ApplicationAdapter.extend({
|
||||
namespace: 'api'
|
||||
});
|
5
obrand/obrand-admin/app/adapters/page.js
Normal file
5
obrand/obrand-admin/app/adapters/page.js
Normal file
@ -0,0 +1,5 @@
|
||||
import ApplicationAdapter from './application';
|
||||
|
||||
export default ApplicationAdapter.extend({
|
||||
namespace: 'api'
|
||||
});
|
5
obrand/obrand-admin/app/adapters/profile.js
Normal file
5
obrand/obrand-admin/app/adapters/profile.js
Normal file
@ -0,0 +1,5 @@
|
||||
import ApplicationAdapter from './application';
|
||||
|
||||
export default ApplicationAdapter.extend({
|
||||
namespace: 'api'
|
||||
});
|
20
obrand/obrand-admin/app/app.js
Normal file
20
obrand/obrand-admin/app/app.js
Normal file
@ -0,0 +1,20 @@
|
||||
import Ember from 'ember';
|
||||
import Resolver from './resolver';
|
||||
import loadInitializers from 'ember-load-initializers';
|
||||
import config from './config/environment';
|
||||
|
||||
let App;
|
||||
|
||||
Ember.MODEL_FACTORY_INJECTIONS = true;
|
||||
Ember.LOG_TRANSITIONS = true;
|
||||
Ember.LOG_TRANSITIONS_INTERNAL = true;
|
||||
|
||||
App = Ember.Application.extend({
|
||||
modulePrefix: config.modulePrefix,
|
||||
podModulePrefix: config.podModulePrefix,
|
||||
Resolver
|
||||
});
|
||||
|
||||
loadInitializers(App, config.modulePrefix);
|
||||
|
||||
export default App;
|
10
obrand/obrand-admin/app/authenticators/oauth2.js
Normal file
10
obrand/obrand-admin/app/authenticators/oauth2.js
Normal file
@ -0,0 +1,10 @@
|
||||
/**
|
||||
*
|
||||
* User: Martin Donnelly
|
||||
* Date: 2016-03-04
|
||||
* Time: 14:23
|
||||
*
|
||||
*/
|
||||
import OAuth2PasswordGrant from 'ember-simple-auth/authenticators/oauth2-password-grant';
|
||||
|
||||
export default OAuth2PasswordGrant.extend();
|
4
obrand/obrand-admin/app/authorizers/application.js
Normal file
4
obrand/obrand-admin/app/authorizers/application.js
Normal file
@ -0,0 +1,4 @@
|
||||
|
||||
import OAuth2Bearer from 'ember-simple-auth/authorizers/oauth2-bearer';
|
||||
|
||||
export default OAuth2Bearer.extend();
|
0
obrand/obrand-admin/app/components/.gitkeep
Normal file
0
obrand/obrand-admin/app/components/.gitkeep
Normal file
17
obrand/obrand-admin/app/components/nav-bar.js
Normal file
17
obrand/obrand-admin/app/components/nav-bar.js
Normal file
@ -0,0 +1,17 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { service } = Ember.inject;
|
||||
|
||||
export default Ember.Component.extend({
|
||||
session: service('session'), sessionAccount: service('session-account'),
|
||||
|
||||
actions: {
|
||||
login() {
|
||||
this.sendAction('onLogin');
|
||||
},
|
||||
|
||||
logout() {
|
||||
this.get('session').invalidate();
|
||||
}
|
||||
}
|
||||
});
|
7
obrand/obrand-admin/app/components/page-manager.js
Normal file
7
obrand/obrand-admin/app/components/page-manager.js
Normal file
@ -0,0 +1,7 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { service } = Ember.inject;
|
||||
|
||||
export default Ember.Component.extend({
|
||||
session: service('session'), sessionAccount: service('session-account')
|
||||
});
|
4
obrand/obrand-admin/app/components/side-bar.js
Normal file
4
obrand/obrand-admin/app/components/side-bar.js
Normal file
@ -0,0 +1,4 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
export default Ember.Component.extend({
|
||||
});
|
0
obrand/obrand-admin/app/controllers/.gitkeep
Normal file
0
obrand/obrand-admin/app/controllers/.gitkeep
Normal file
9
obrand/obrand-admin/app/controllers/application.js
Normal file
9
obrand/obrand-admin/app/controllers/application.js
Normal file
@ -0,0 +1,9 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
export default Ember.Controller.extend({
|
||||
actions: {
|
||||
transitionToLoginRoute() {
|
||||
this.transitionToRoute('login');
|
||||
}
|
||||
}
|
||||
});
|
29
obrand/obrand-admin/app/controllers/company.js
Normal file
29
obrand/obrand-admin/app/controllers/company.js
Normal file
@ -0,0 +1,29 @@
|
||||
import Ember from 'ember';
|
||||
const {service} = Ember.inject;
|
||||
export default Ember.Controller.extend({
|
||||
|
||||
session: service('session'),
|
||||
sessionAccount: service('session-account'),
|
||||
actions: {
|
||||
editCompany: function() {
|
||||
this.set('isEditing', true);
|
||||
}, saveCompany: function() {
|
||||
'use strict';
|
||||
this.set('isEditing', false);
|
||||
var model = this.get('model');
|
||||
|
||||
model.save()
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
}, cancelEdit: function() {
|
||||
'use strict';
|
||||
var model = this.get('model');
|
||||
model.rollbackAttributes();
|
||||
this.set('isEditing', false);
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
});
|
20
obrand/obrand-admin/app/controllers/login.js
Normal file
20
obrand/obrand-admin/app/controllers/login.js
Normal file
@ -0,0 +1,20 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { service } = Ember.inject;
|
||||
|
||||
export default Ember.Controller.extend({
|
||||
session: service('session'),
|
||||
|
||||
actions: {
|
||||
authenticate() {
|
||||
'use strict';
|
||||
let {identification, password } = this.getProperties('identification', 'password');
|
||||
|
||||
this.get('session').authenticate('authenticator:oauth2', identification, password)
|
||||
.catch((reason) => {
|
||||
this.set('errorMessage', reason.error);
|
||||
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
23
obrand/obrand-admin/app/controllers/newcompany.js
Normal file
23
obrand/obrand-admin/app/controllers/newcompany.js
Normal file
@ -0,0 +1,23 @@
|
||||
import Ember from 'ember';
|
||||
const { service } = Ember.inject;
|
||||
export default Ember.Controller.extend({
|
||||
session: service('session'),
|
||||
sessionAccount: service('session-account'),
|
||||
actions: {
|
||||
saveCompany: function() {
|
||||
'use strict';
|
||||
var model = this.get('model');
|
||||
var account = this.get('sessionAccount.account');
|
||||
|
||||
model.set('uid', this.get('sessionAccount.account.uid'));
|
||||
|
||||
model.save()
|
||||
.then(function() {
|
||||
account.set('memberof', model.get('cid'));
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
});
|
||||
}
|
||||
}
|
||||
});
|
78
obrand/obrand-admin/app/controllers/pages.js
Normal file
78
obrand/obrand-admin/app/controllers/pages.js
Normal file
@ -0,0 +1,78 @@
|
||||
import Ember from 'ember';
|
||||
const {service, store} = Ember.inject;
|
||||
export default Ember.Controller.extend({
|
||||
session: service('session'), sessionAccount: service('session-account'),
|
||||
|
||||
actions: {
|
||||
savePage: function() {
|
||||
|
||||
var model = this.get('model');
|
||||
var self = this;
|
||||
|
||||
model.save()
|
||||
.then(function(d) {
|
||||
'use strict';
|
||||
console.log(d);
|
||||
self.send('resetView');
|
||||
})
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
});
|
||||
|
||||
},
|
||||
|
||||
createNew: function() {
|
||||
'use strict';
|
||||
const cid = this.get('sessionAccount.account.memberof');
|
||||
|
||||
var store = this.get('store');
|
||||
|
||||
var newPage = store.createRecord('page', {
|
||||
cid: cid,
|
||||
vid: 'JPnbDnRzwDSNLTCcS4miFq',
|
||||
content: 0,
|
||||
imageUrl: 'http://lorempixel.com/300/300'
|
||||
});
|
||||
|
||||
this.set('content', newPage);
|
||||
|
||||
this.set('isEditing', true);
|
||||
}, cancelEdit: function() {
|
||||
var model = this.get('model');
|
||||
model.rollbackAttributes();
|
||||
|
||||
this.send('resetView');
|
||||
|
||||
}, performEdit: function(id) {
|
||||
'use strict';
|
||||
var self = this;
|
||||
var store = this.get('store');
|
||||
console.log(id);
|
||||
var editPage = this.store.peekRecord('page', id);
|
||||
|
||||
this.set('content', editPage);
|
||||
this.set('isEditing', true);
|
||||
}, resetView() {
|
||||
'use strict';
|
||||
var model = this.get('model');
|
||||
|
||||
model = this.store.findAll('page');
|
||||
this.set('isEditing', false);
|
||||
this.set('model', model);
|
||||
}, performDelete: function(id) {
|
||||
'use strict';
|
||||
console.log('Delete: ', id);
|
||||
var store = this.get('store');
|
||||
console.log(id);
|
||||
var deletePage = this.store.peekRecord('page', id);
|
||||
deletePage.destroyRecord()
|
||||
.then(function(d) {
|
||||
console.log(d);
|
||||
})
|
||||
.catch(function(e) {
|
||||
console.error(e);
|
||||
});
|
||||
}
|
||||
|
||||
}
|
||||
});
|
23
obrand/obrand-admin/app/controllers/profile.js
Normal file
23
obrand/obrand-admin/app/controllers/profile.js
Normal file
@ -0,0 +1,23 @@
|
||||
import Ember from 'ember';
|
||||
const { service } = Ember.inject;
|
||||
export default Ember.Controller.extend({
|
||||
session: service('session'),
|
||||
sessionAccount: service('session-account'),
|
||||
genders: [{g: 'Male', id: 0}, {g: 'Female', id: 1}],
|
||||
actions: {
|
||||
editProfile: function() {
|
||||
this.set('isEditing', true);
|
||||
}, saveProfile: function() {
|
||||
'use strict';
|
||||
var model = this.get('model');
|
||||
this.set('sessionAccount.account.forename', model.get('forename'));
|
||||
|
||||
this.model.save()
|
||||
.catch(function(err) {
|
||||
console.error(err);
|
||||
});
|
||||
this.set('isEditing', false);
|
||||
|
||||
}
|
||||
}
|
||||
});
|
0
obrand/obrand-admin/app/helpers/.gitkeep
Normal file
0
obrand/obrand-admin/app/helpers/.gitkeep
Normal file
5
obrand/obrand-admin/app/helpers/eq.js
Normal file
5
obrand/obrand-admin/app/helpers/eq.js
Normal file
@ -0,0 +1,5 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const eq = (params) => params[0] === params[1];
|
||||
|
||||
export default Ember.Helper.helper(eq);
|
25
obrand/obrand-admin/app/index.html
Normal file
25
obrand/obrand-admin/app/index.html
Normal file
@ -0,0 +1,25 @@
|
||||
<!DOCTYPE html>
|
||||
<html>
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||
<title>ObrandAdmin</title>
|
||||
<meta name="description" content="">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
|
||||
{{content-for "head"}}
|
||||
|
||||
<link rel="stylesheet" href="assets/vendor.css">
|
||||
<link rel="stylesheet" href="assets/obrand-admin.css">
|
||||
|
||||
{{content-for "head-footer"}}
|
||||
</head>
|
||||
<body>
|
||||
{{content-for "body"}}
|
||||
|
||||
<script src="assets/vendor.js"></script>
|
||||
<script src="assets/obrand-admin.js"></script>
|
||||
|
||||
{{content-for "body-footer"}}
|
||||
</body>
|
||||
</html>
|
0
obrand/obrand-admin/app/models/.gitkeep
Normal file
0
obrand/obrand-admin/app/models/.gitkeep
Normal file
12
obrand/obrand-admin/app/models/account.js
Normal file
12
obrand/obrand-admin/app/models/account.js
Normal file
@ -0,0 +1,12 @@
|
||||
import DS from 'ember-data';
|
||||
|
||||
export default DS.Model.extend({
|
||||
uid: DS.attr('string'),
|
||||
login: DS.attr('string'),
|
||||
forename: DS.attr('string'),
|
||||
surname: DS.attr('string'),
|
||||
memberof: DS.attr('string'),
|
||||
fullName: function() {
|
||||
return '%@ %@'.fmt(this.get('forename'), this.get('surname'));
|
||||
}.property('forename', 'surname')
|
||||
});
|
5
obrand/obrand-admin/app/models/application.js
Normal file
5
obrand/obrand-admin/app/models/application.js
Normal file
@ -0,0 +1,5 @@
|
||||
import DS from 'ember-data';
|
||||
|
||||
export default DS.Model.extend({
|
||||
|
||||
});
|
20
obrand/obrand-admin/app/models/company.js
Normal file
20
obrand/obrand-admin/app/models/company.js
Normal file
@ -0,0 +1,20 @@
|
||||
import DS from 'ember-data';
|
||||
|
||||
export default DS.Model.extend({
|
||||
cid: DS.attr('string'),
|
||||
company_name: DS.attr('string'),
|
||||
address1: DS.attr('string'),
|
||||
address2: DS.attr('string'),
|
||||
address3: DS.attr('string'),
|
||||
town: DS.attr('string'),
|
||||
county: DS.attr('string'),
|
||||
postcode: DS.attr('string'),
|
||||
country: DS.attr('string'),
|
||||
pcontact: DS.attr('string'),
|
||||
ocontact: DS.attr('string'),
|
||||
mobile: DS.attr('string'),
|
||||
email: DS.attr('string'),
|
||||
needCompany: function() {
|
||||
return typeof this.get('cid') !== 'undefined';
|
||||
}.property('cid')
|
||||
});
|
19
obrand/obrand-admin/app/models/newcompany.js
Normal file
19
obrand/obrand-admin/app/models/newcompany.js
Normal file
@ -0,0 +1,19 @@
|
||||
import DS from 'ember-data';
|
||||
|
||||
export default DS.Model.extend({
|
||||
uid: DS.attr(),
|
||||
cid: DS.attr('string'),
|
||||
company_name: DS.attr('string'),
|
||||
address1: DS.attr('string'),
|
||||
address2: DS.attr('string'),
|
||||
address3: DS.attr('string'),
|
||||
town: DS.attr('string'),
|
||||
county: DS.attr('string'),
|
||||
postcode: DS.attr('string'),
|
||||
country: DS.attr('string'),
|
||||
pcontact: DS.attr('string'),
|
||||
ocontact: DS.attr('string'),
|
||||
mobile: DS.attr('string'),
|
||||
email: DS.attr('string')
|
||||
});
|
||||
|
33
obrand/obrand-admin/app/models/page-content.js
Normal file
33
obrand/obrand-admin/app/models/page-content.js
Normal file
@ -0,0 +1,33 @@
|
||||
'use strict';
|
||||
|
||||
import DS from 'ember-data';
|
||||
import Ember from 'ember';
|
||||
|
||||
export default DS.Model.extend({
|
||||
page: DS.belongsTo('page'),
|
||||
title: DS.attr('string'),
|
||||
imageUrl: DS.attr('string'),
|
||||
link1Text: DS.attr('string'),
|
||||
link1Url: DS.attr('string'),
|
||||
link2Text: DS.attr('string'),
|
||||
link2Url: DS.attr('string'),
|
||||
link3Text: DS.attr('string'),
|
||||
link3Url: DS.attr('string'),
|
||||
link4Text: DS.attr('string'),
|
||||
link4Url: DS.attr('string'),
|
||||
visibleLink1: function() {
|
||||
return !((Ember.isBlank(this.get('link1Text'))) || (Ember.isBlank(this.get('link1Url'))));
|
||||
}.property('link1Url','link1Text'),
|
||||
visibleLink2: function() {
|
||||
return !((Ember.isBlank(this.get('link2Text'))) && (Ember.isBlank(this.get('link2Url'))));
|
||||
}.property('link2Url','link2Text'),
|
||||
visibleLink3: function() {
|
||||
return !((Ember.isBlank(this.get('link3Text'))) && (Ember.isBlank(this.get('link3Url'))));
|
||||
}.property('link3Url','link3Text'),
|
||||
visibleLink4: function() {
|
||||
return !((Ember.isBlank(this.get('link4Text'))) && (Ember.isBlank(this.get('link4Url'))));
|
||||
}.property('link4Url','link4Text'),
|
||||
noImage: function() {
|
||||
return Ember.isBlank(this.get('imageUrl'));
|
||||
}.property('imageUrl')
|
||||
});
|
44
obrand/obrand-admin/app/models/page.js
Normal file
44
obrand/obrand-admin/app/models/page.js
Normal file
@ -0,0 +1,44 @@
|
||||
import DS from 'ember-data';
|
||||
import Ember from 'ember';
|
||||
|
||||
export default DS.Model.extend({
|
||||
cid: DS.attr('string'),
|
||||
vid: DS.attr('string'),
|
||||
pid: DS.attr('string'),
|
||||
category: DS.attr(),
|
||||
title: DS.attr('string'),
|
||||
content: DS.attr(),
|
||||
imageUrl: DS.attr('string'),
|
||||
link1Text: DS.attr('string'),
|
||||
link1Url: DS.attr('string'),
|
||||
link2Text: DS.attr('string'),
|
||||
link2Url: DS.attr('string'),
|
||||
link3Text: DS.attr('string'),
|
||||
link3Url: DS.attr('string'),
|
||||
link4Text: DS.attr('string'),
|
||||
link4Url: DS.attr('string'),
|
||||
usefulPid: function() {
|
||||
'use strict';
|
||||
|
||||
return !Ember.isBlank(this.get('pid')) ? ('/export/' + this.get('pid') + '.html').toString() : false;
|
||||
}.property('pid'),
|
||||
visibleLink1: function() {
|
||||
return !((Ember.isBlank(this.get('link1Text'))) || (Ember.isBlank(this.get('link1Url'))));
|
||||
}.property('link1Url','link1Text'),
|
||||
visibleLink2: function() {
|
||||
return !((Ember.isBlank(this.get('link2Text'))) || (Ember.isBlank(this.get('link2Url'))));
|
||||
}.property('link2Url','link2Text'),
|
||||
visibleLink3: function() {
|
||||
return !((Ember.isBlank(this.get('link3Text'))) || (Ember.isBlank(this.get('link3Url'))));
|
||||
}.property('link3Url','link3Text'),
|
||||
visibleLink4: function() {
|
||||
return !((Ember.isBlank(this.get('link4Text'))) || (Ember.isBlank(this.get('link4Url'))));
|
||||
}.property('link4Url','link4Text'),
|
||||
noImage: function() {
|
||||
return Ember.isBlank(this.get('imageUrl'));
|
||||
}.property('imageUrl'),
|
||||
pageMode: function() {
|
||||
let modeArray = ['Basic Page', 'Other type 1', 'Other type 2', 'Other type 3'];
|
||||
return modeArray[this.get('content')];
|
||||
}.property('content')
|
||||
});
|
19
obrand/obrand-admin/app/models/profile.js
Normal file
19
obrand/obrand-admin/app/models/profile.js
Normal file
@ -0,0 +1,19 @@
|
||||
import DS from 'ember-data';
|
||||
|
||||
export default DS.Model.extend({
|
||||
uid: DS.attr('string'),
|
||||
forename: DS.attr('string'),
|
||||
surname: DS.attr('string'),
|
||||
gender: DS.attr('number'),
|
||||
dob: DS.attr(),
|
||||
bio: DS.attr('string'),
|
||||
fullName: function() {
|
||||
return '%@ %@'.fmt(this.get('forename'), this.get('surname'));
|
||||
}.property('forename', 'surname'),
|
||||
qualifiedGender: function() {
|
||||
let genderArray = ['Male', 'Female'];
|
||||
return genderArray[this.get('gender')];
|
||||
}.property('gender')
|
||||
});
|
||||
|
||||
|
3
obrand/obrand-admin/app/resolver.js
Normal file
3
obrand/obrand-admin/app/resolver.js
Normal file
@ -0,0 +1,3 @@
|
||||
import Resolver from 'ember-resolver';
|
||||
|
||||
export default Resolver;
|
21
obrand/obrand-admin/app/router.js
Normal file
21
obrand/obrand-admin/app/router.js
Normal file
@ -0,0 +1,21 @@
|
||||
import Ember from 'ember';
|
||||
import config from './config/environment';
|
||||
|
||||
const Router = Ember.Router.extend({
|
||||
location: config.locationType
|
||||
});
|
||||
|
||||
Router.map(function() {
|
||||
this.route('index', {path: '/'});
|
||||
this.route('login');
|
||||
this.route('auth-error');
|
||||
this.route('about');
|
||||
this.route('signup');
|
||||
this.route('profile');
|
||||
this.route('company');
|
||||
this.route('newcompany');
|
||||
this.route('venue');
|
||||
this.route('pages');
|
||||
});
|
||||
|
||||
export default Router;
|
0
obrand/obrand-admin/app/routes/.gitkeep
Normal file
0
obrand/obrand-admin/app/routes/.gitkeep
Normal file
4
obrand/obrand-admin/app/routes/about.js
Normal file
4
obrand/obrand-admin/app/routes/about.js
Normal file
@ -0,0 +1,4 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
export default Ember.Route.extend({
|
||||
});
|
18
obrand/obrand-admin/app/routes/application.js
Normal file
18
obrand/obrand-admin/app/routes/application.js
Normal file
@ -0,0 +1,18 @@
|
||||
import Ember from 'ember';
|
||||
import ApplicationRouteMixin from 'ember-simple-auth/mixins/application-route-mixin';
|
||||
|
||||
const { service } = Ember.inject;
|
||||
|
||||
export default Ember.Route.extend(ApplicationRouteMixin, {
|
||||
sessionAccount: service('session-account'),
|
||||
_loadCurrentUser() {
|
||||
return this.get('sessionAccount').loadCurrentUser();
|
||||
},
|
||||
beforeModel() {
|
||||
return this._loadCurrentUser();
|
||||
},
|
||||
sessionAuthenticated() {
|
||||
this._super(...arguments);
|
||||
this._loadCurrentUser().catch(() => this.get('session').invalidate());
|
||||
}
|
||||
});
|
8
obrand/obrand-admin/app/routes/auth-error.js
Normal file
8
obrand/obrand-admin/app/routes/auth-error.js
Normal file
@ -0,0 +1,8 @@
|
||||
import Ember from 'ember';
|
||||
import AuthenticatedRouteMixin from 'ember-simple-auth/mixins/authenticated-route-mixin';
|
||||
|
||||
export default Ember.Route.extend(AuthenticatedRouteMixin, {
|
||||
model() {
|
||||
return this.get('store').find('post', 3);
|
||||
}
|
||||
});
|
33
obrand/obrand-admin/app/routes/company.js
Normal file
33
obrand/obrand-admin/app/routes/company.js
Normal file
@ -0,0 +1,33 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { inject: { service }, RSVP } = Ember;
|
||||
|
||||
export default Ember.Route.extend({
|
||||
sessionAccount: service('session-account'),
|
||||
beforeModel() {
|
||||
const cid = this.get('sessionAccount.account.memberof');
|
||||
if (typeof cid === 'undefined' || cid === null) {
|
||||
this.transitionTo('newcompany');
|
||||
}
|
||||
},
|
||||
|
||||
model: function() {
|
||||
'use strict';
|
||||
const cid = this.get('sessionAccount.account.memberof');
|
||||
|
||||
if (typeof cid !== 'undefined' && cid !== null) {
|
||||
return new RSVP.Promise((resolve, reject) => {
|
||||
return this.get('store').find('company', cid)
|
||||
.then(resolve, reject);
|
||||
});
|
||||
|
||||
} else {
|
||||
|
||||
return {
|
||||
needNewCompany: true
|
||||
};
|
||||
|
||||
}
|
||||
|
||||
}
|
||||
});
|
4
obrand/obrand-admin/app/routes/index.js
Normal file
4
obrand/obrand-admin/app/routes/index.js
Normal file
@ -0,0 +1,4 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
export default Ember.Route.extend({
|
||||
});
|
6
obrand/obrand-admin/app/routes/login.js
Normal file
6
obrand/obrand-admin/app/routes/login.js
Normal file
@ -0,0 +1,6 @@
|
||||
import Ember from 'ember';
|
||||
import UnauthenticatedRouteMixin from 'ember-simple-auth/mixins/unauthenticated-route-mixin';
|
||||
|
||||
export default Ember.Route.extend(UnauthenticatedRouteMixin);
|
||||
|
||||
|
23
obrand/obrand-admin/app/routes/newcompany.js
Normal file
23
obrand/obrand-admin/app/routes/newcompany.js
Normal file
@ -0,0 +1,23 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { inject: { service }, RSVP } = Ember;
|
||||
|
||||
export default Ember.Route.extend({
|
||||
sessionAccount: service('session-account'),
|
||||
|
||||
model: function() {
|
||||
'use strict';
|
||||
const cid = this.get('sessionAccount.account.memberOf');
|
||||
|
||||
if (typeof cid !== 'undefined') {
|
||||
return new RSVP.Promise((resolve, reject) => {
|
||||
return this.get('store').find('company', cid)
|
||||
.then(resolve, reject);
|
||||
});
|
||||
} else {
|
||||
var newPage = this.store.createRecord('newcompany',{});
|
||||
newPage.set('cid', cid);
|
||||
return newPage;
|
||||
}
|
||||
}
|
||||
});
|
17
obrand/obrand-admin/app/routes/pages.js
Normal file
17
obrand/obrand-admin/app/routes/pages.js
Normal file
@ -0,0 +1,17 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { inject: { service } } = Ember;
|
||||
|
||||
export default Ember.Route.extend({
|
||||
sessionAccount: service('session-account'),
|
||||
beforeModel() {
|
||||
'use strict';
|
||||
const cid = this.get('sessionAccount.account.memberof');
|
||||
this.store.query('page', { filter: { cid: cid } }).then(function(d) {
|
||||
return d;
|
||||
});
|
||||
},
|
||||
model: function() {
|
||||
return this.store.findAll('page');
|
||||
}
|
||||
});
|
18
obrand/obrand-admin/app/routes/profile.js
Normal file
18
obrand/obrand-admin/app/routes/profile.js
Normal file
@ -0,0 +1,18 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { inject: { service }, RSVP } = Ember;
|
||||
|
||||
export default Ember.Route.extend({
|
||||
|
||||
sessionAccount: service('session-account'),
|
||||
model: function() {
|
||||
'use strict';
|
||||
const accountId = this.get('sessionAccount.account.id');
|
||||
|
||||
return new RSVP.Promise((resolve,reject) => {
|
||||
return this.get('store').find('profile',accountId)
|
||||
.then(resolve,reject);
|
||||
});
|
||||
|
||||
}
|
||||
});
|
4
obrand/obrand-admin/app/routes/signup.js
Normal file
4
obrand/obrand-admin/app/routes/signup.js
Normal file
@ -0,0 +1,4 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
export default Ember.Route.extend({
|
||||
});
|
12
obrand/obrand-admin/app/routes/venue.js
Normal file
12
obrand/obrand-admin/app/routes/venue.js
Normal file
@ -0,0 +1,12 @@
|
||||
import Ember from 'ember';
|
||||
const { inject: { service } } = Ember;
|
||||
|
||||
export default Ember.Route.extend({
|
||||
sessionAccount: service('session-account'),
|
||||
beforeModel() {
|
||||
const cid = this.get('sessionAccount.account.memberof');
|
||||
if (typeof cid === 'undefined') {
|
||||
this.transitionTo('newcompany');
|
||||
}
|
||||
}
|
||||
});
|
38
obrand/obrand-admin/app/serializers/useful.js
Normal file
38
obrand/obrand-admin/app/serializers/useful.js
Normal file
@ -0,0 +1,38 @@
|
||||
import DS from 'ember-data';
|
||||
import Ember from 'ember';
|
||||
|
||||
export default DS.JSONAPISerializer.extend({
|
||||
serializeBelongsTo: function(record, json, relationship) {
|
||||
var key = relationship.key;
|
||||
var belongsTo = Ember.get(record, key);
|
||||
key = this.keyForRelationship ? this.keyForRelationship(key, 'belongsTo') : key;
|
||||
|
||||
if (relationship.options.embedded === 'always') {
|
||||
json[key] = belongsTo.serialize();
|
||||
} else {
|
||||
return this._super(record, json, relationship);
|
||||
}
|
||||
},
|
||||
serializeHasMany: function(record, json, relationship) {
|
||||
var key = relationship.key;
|
||||
var hasMany = Ember.get(record, key);
|
||||
var relationshipType = DS.RelationshipChange.determineRelationshipType(
|
||||
record.constructor,
|
||||
relationship);
|
||||
|
||||
if (relationship.options.embedded === 'always') {
|
||||
if (hasMany && relationshipType === 'manyToNone' || relationshipType === 'manyToMany' ||
|
||||
relationshipType === 'manyToOne') {
|
||||
|
||||
json[key] = [];
|
||||
hasMany.forEach(function(item) {
|
||||
json[key].push(item.serialize());
|
||||
});
|
||||
}
|
||||
|
||||
} else {
|
||||
return this._super(record, json, relationship);
|
||||
}
|
||||
}
|
||||
});
|
||||
|
24
obrand/obrand-admin/app/services/session-account.js
Normal file
24
obrand/obrand-admin/app/services/session-account.js
Normal file
@ -0,0 +1,24 @@
|
||||
import Ember from 'ember';
|
||||
|
||||
const { inject: { service }, RSVP } = Ember;
|
||||
|
||||
export default Ember.Service.extend({
|
||||
session: service('session'),
|
||||
store: service(),
|
||||
|
||||
loadCurrentUser() {
|
||||
return new RSVP.Promise((resolve, reject) => {
|
||||
const accountId = this.get('session.data.authenticated.account_id');
|
||||
|
||||
if (!Ember.isEmpty(accountId)) {
|
||||
|
||||
return this.get('store').find('account', accountId).then((account) => {
|
||||
this.set('account', account);
|
||||
return resolve();
|
||||
}, reject);
|
||||
} else {
|
||||
return resolve();
|
||||
}
|
||||
});
|
||||
}
|
||||
});
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue
Block a user