diff --git a/.gitignore b/.gitignore
new file mode 100644
index 0000000..f38fae7
--- /dev/null
+++ b/.gitignore
@@ -0,0 +1,4 @@
+_site
+.sass-cache
+.jekyll-metadata
+*.DS_Store
diff --git a/404.html b/404.html
new file mode 100644
index 0000000..76c6662
--- /dev/null
+++ b/404.html
@@ -0,0 +1,15 @@
+---
+layout: page
+heading: 404 Not found…
+title:
+
+---
+
+
+
+ Not Found :-(
+ The requested page could not be found.
+
+
+
+
diff --git a/Gemfile b/Gemfile
new file mode 100644
index 0000000..d7ad497
--- /dev/null
+++ b/Gemfile
@@ -0,0 +1,30 @@
+source "https://rubygems.org"
+
+# Hello! This is where you manage which Jekyll version is used to run.
+# When you want to use a different version, change it below, save the
+# file and run `bundle install`. Run Jekyll with `bundle exec`, like so:
+#
+# bundle exec jekyll serve
+#
+# This will help ensure the proper Jekyll version is running.
+# Happy Jekylling!
+# gem "jekyll", "~> 3.7.3"
+
+# This is the default theme for new Jekyll sites. You may change this to anything you like.
+
+# If you want to use GitHub Pages, remove the "gem "jekyll"" above and
+# uncomment the line below. To upgrade, run `bundle update github-pages`.
+gem "github-pages", group: :jekyll_plugins
+
+# If you have any plugins, put them here!
+group :jekyll_plugins do
+ gem "jekyll-seo-tag", "~> 2.1"
+ gem "jekyll-feed", "~> 0.9"
+end
+
+# Windows does not include zoneinfo files, so bundle the tzinfo-data gem
+gem "tzinfo-data", platforms: [:mingw, :mswin, :x64_mingw, :jruby]
+
+# Performance-booster for watching directories on Windows
+gem "wdm", "~> 0.1.0" if Gem.win_platform?
+
diff --git a/Gemfile.lock b/Gemfile.lock
new file mode 100644
index 0000000..f109d02
--- /dev/null
+++ b/Gemfile.lock
@@ -0,0 +1,251 @@
+GEM
+ remote: https://rubygems.org/
+ specs:
+ activesupport (4.2.10)
+ i18n (~> 0.7)
+ minitest (~> 5.1)
+ thread_safe (~> 0.3, >= 0.3.4)
+ tzinfo (~> 1.1)
+ addressable (2.5.2)
+ public_suffix (>= 2.0.2, < 4.0)
+ coffee-script (2.4.1)
+ coffee-script-source
+ execjs
+ coffee-script-source (1.11.1)
+ colorator (1.1.0)
+ commonmarker (0.17.13)
+ ruby-enum (~> 0.5)
+ concurrent-ruby (1.0.5)
+ dnsruby (1.61.2)
+ addressable (~> 2.5)
+ em-websocket (0.5.1)
+ eventmachine (>= 0.12.9)
+ http_parser.rb (~> 0.6.0)
+ ethon (0.11.0)
+ ffi (>= 1.3.0)
+ eventmachine (1.2.7)
+ execjs (2.7.0)
+ faraday (0.15.4)
+ multipart-post (>= 1.2, < 3)
+ ffi (1.9.25)
+ forwardable-extended (2.6.0)
+ gemoji (3.0.0)
+ github-pages (190)
+ activesupport (= 4.2.10)
+ github-pages-health-check (= 1.8.1)
+ jekyll (= 3.7.3)
+ jekyll-avatar (= 0.6.0)
+ jekyll-coffeescript (= 1.1.1)
+ jekyll-commonmark-ghpages (= 0.1.5)
+ jekyll-default-layout (= 0.1.4)
+ jekyll-feed (= 0.10.0)
+ jekyll-gist (= 1.5.0)
+ jekyll-github-metadata (= 2.9.4)
+ jekyll-mentions (= 1.4.1)
+ jekyll-optional-front-matter (= 0.3.0)
+ jekyll-paginate (= 1.1.0)
+ jekyll-readme-index (= 0.2.0)
+ jekyll-redirect-from (= 0.14.0)
+ jekyll-relative-links (= 0.5.3)
+ jekyll-remote-theme (= 0.3.1)
+ jekyll-sass-converter (= 1.5.2)
+ jekyll-seo-tag (= 2.5.0)
+ jekyll-sitemap (= 1.2.0)
+ jekyll-swiss (= 0.4.0)
+ jekyll-theme-architect (= 0.1.1)
+ jekyll-theme-cayman (= 0.1.1)
+ jekyll-theme-dinky (= 0.1.1)
+ jekyll-theme-hacker (= 0.1.1)
+ jekyll-theme-leap-day (= 0.1.1)
+ jekyll-theme-merlot (= 0.1.1)
+ jekyll-theme-midnight (= 0.1.1)
+ jekyll-theme-minimal (= 0.1.1)
+ jekyll-theme-modernist (= 0.1.1)
+ jekyll-theme-primer (= 0.5.3)
+ jekyll-theme-slate (= 0.1.1)
+ jekyll-theme-tactile (= 0.1.1)
+ jekyll-theme-time-machine (= 0.1.1)
+ jekyll-titles-from-headings (= 0.5.1)
+ jemoji (= 0.10.1)
+ kramdown (= 1.16.2)
+ liquid (= 4.0.0)
+ listen (= 3.1.5)
+ mercenary (~> 0.3)
+ minima (= 2.5.0)
+ nokogiri (>= 1.8.2, < 2.0)
+ rouge (= 2.2.1)
+ terminal-table (~> 1.4)
+ github-pages-health-check (1.8.1)
+ addressable (~> 2.3)
+ dnsruby (~> 1.60)
+ octokit (~> 4.0)
+ public_suffix (~> 2.0)
+ typhoeus (~> 1.3)
+ html-pipeline (2.10.0)
+ activesupport (>= 2)
+ nokogiri (>= 1.4)
+ http_parser.rb (0.6.0)
+ i18n (0.9.5)
+ concurrent-ruby (~> 1.0)
+ jekyll (3.7.3)
+ addressable (~> 2.4)
+ colorator (~> 1.0)
+ em-websocket (~> 0.5)
+ i18n (~> 0.7)
+ jekyll-sass-converter (~> 1.0)
+ jekyll-watch (~> 2.0)
+ kramdown (~> 1.14)
+ liquid (~> 4.0)
+ mercenary (~> 0.3.3)
+ pathutil (~> 0.9)
+ rouge (>= 1.7, < 4)
+ safe_yaml (~> 1.0)
+ jekyll-avatar (0.6.0)
+ jekyll (~> 3.0)
+ jekyll-coffeescript (1.1.1)
+ coffee-script (~> 2.2)
+ coffee-script-source (~> 1.11.1)
+ jekyll-commonmark (1.2.0)
+ commonmarker (~> 0.14)
+ jekyll (>= 3.0, < 4.0)
+ jekyll-commonmark-ghpages (0.1.5)
+ commonmarker (~> 0.17.6)
+ jekyll-commonmark (~> 1)
+ rouge (~> 2)
+ jekyll-default-layout (0.1.4)
+ jekyll (~> 3.0)
+ jekyll-feed (0.10.0)
+ jekyll (~> 3.3)
+ jekyll-gist (1.5.0)
+ octokit (~> 4.2)
+ jekyll-github-metadata (2.9.4)
+ jekyll (~> 3.1)
+ octokit (~> 4.0, != 4.4.0)
+ jekyll-mentions (1.4.1)
+ html-pipeline (~> 2.3)
+ jekyll (~> 3.0)
+ jekyll-optional-front-matter (0.3.0)
+ jekyll (~> 3.0)
+ jekyll-paginate (1.1.0)
+ jekyll-readme-index (0.2.0)
+ jekyll (~> 3.0)
+ jekyll-redirect-from (0.14.0)
+ jekyll (~> 3.3)
+ jekyll-relative-links (0.5.3)
+ jekyll (~> 3.3)
+ jekyll-remote-theme (0.3.1)
+ jekyll (~> 3.5)
+ rubyzip (>= 1.2.1, < 3.0)
+ jekyll-sass-converter (1.5.2)
+ sass (~> 3.4)
+ jekyll-seo-tag (2.5.0)
+ jekyll (~> 3.3)
+ jekyll-sitemap (1.2.0)
+ jekyll (~> 3.3)
+ jekyll-swiss (0.4.0)
+ jekyll-theme-architect (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-cayman (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-dinky (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-hacker (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-leap-day (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-merlot (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-midnight (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-minimal (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-modernist (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-primer (0.5.3)
+ jekyll (~> 3.5)
+ jekyll-github-metadata (~> 2.9)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-slate (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-tactile (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-theme-time-machine (0.1.1)
+ jekyll (~> 3.5)
+ jekyll-seo-tag (~> 2.0)
+ jekyll-titles-from-headings (0.5.1)
+ jekyll (~> 3.3)
+ jekyll-watch (2.0.0)
+ listen (~> 3.0)
+ jemoji (0.10.1)
+ gemoji (~> 3.0)
+ html-pipeline (~> 2.2)
+ jekyll (~> 3.0)
+ kramdown (1.16.2)
+ liquid (4.0.0)
+ listen (3.1.5)
+ rb-fsevent (~> 0.9, >= 0.9.4)
+ rb-inotify (~> 0.9, >= 0.9.7)
+ ruby_dep (~> 1.2)
+ mercenary (0.3.6)
+ mini_portile2 (2.4.0)
+ minima (2.5.0)
+ jekyll (~> 3.5)
+ jekyll-feed (~> 0.9)
+ jekyll-seo-tag (~> 2.1)
+ minitest (5.11.3)
+ multipart-post (2.0.0)
+ nokogiri (1.10.0)
+ mini_portile2 (~> 2.4.0)
+ octokit (4.13.0)
+ sawyer (~> 0.8.0, >= 0.5.3)
+ pathutil (0.16.1)
+ forwardable-extended (~> 2.6)
+ public_suffix (2.0.5)
+ rb-fsevent (0.10.3)
+ rb-inotify (0.9.10)
+ ffi (>= 0.5.0, < 2)
+ rouge (2.2.1)
+ ruby-enum (0.7.2)
+ i18n
+ ruby_dep (1.5.0)
+ rubyzip (1.2.2)
+ safe_yaml (1.0.4)
+ sass (3.5.6)
+ sass-listen (~> 4.0.0)
+ sass-listen (4.0.0)
+ rb-fsevent (~> 0.9, >= 0.9.4)
+ rb-inotify (~> 0.9, >= 0.9.7)
+ sawyer (0.8.1)
+ addressable (>= 2.3.5, < 2.6)
+ faraday (~> 0.8, < 1.0)
+ terminal-table (1.8.0)
+ unicode-display_width (~> 1.1, >= 1.1.1)
+ thread_safe (0.3.6)
+ typhoeus (1.3.1)
+ ethon (>= 0.9.0)
+ tzinfo (1.2.5)
+ thread_safe (~> 0.1)
+ unicode-display_width (1.4.1)
+
+PLATFORMS
+ ruby
+
+DEPENDENCIES
+ github-pages
+ jekyll-feed (~> 0.9)
+ jekyll-seo-tag (~> 2.1)
+ tzinfo-data
+
+BUNDLED WITH
+ 1.16.3
diff --git a/_config.yml b/_config.yml
index c419263..8fdcf9d 100644
--- a/_config.yml
+++ b/_config.yml
@@ -1 +1,44 @@
-theme: jekyll-theme-cayman
\ No newline at end of file
+# Welcome to Jekyll!
+#
+# This config file is meant for settings that affect your whole blog, values
+# which you are expected to set up once and rarely edit after that. If you find
+# yourself editing this file very often, consider using Jekyll's data files
+# feature for the data you need to update frequently.
+#
+# For technical reasons, this file is *NOT* reloaded automatically when you use
+# 'bundle exec jekyll serve'. If you change this file, please restart the server process.
+
+# Site settings
+# These are used to personalize your new site. If you look in the HTML files,
+# you will see them accessed via {{ site.title }}, {{ site.email }}, and so on.
+# You can create any custom variable you would like, and they will be accessible
+# in the templates via {{ site.myvariable }}.
+title: 3scale API Management
+3scale_docs_url: https://access.redhat.com/documentation/en-us/red_hat_3scale/
+3scale_product_version: 2.3 # used for deep linking to the correct docs on red hat.
+email: your-email@example.com
+description: >- # this means to ignore newlines until "baseurl:"
+ Share, secure, distribute, control, and monetize your APIs.
+baseurl: "" # the subpath of your site, e.g. /blog
+url: "" # the base hostname & protocol for your site, e.g. http://example.com
+twitter_username: 3scale
+github_username: 3scale
+#permalink: pretty
+
+# Build settings
+markdown: kramdown
+plugins:
+ - jekyll-feed
+ - jekyll-seo-tag
+
+# Exclude from processing.
+# The following items will not be processed, by default. Create a custom list
+# to override the default setting.
+# exclude:
+# - Gemfile
+# - Gemfile.lock
+# - node_modules
+# - vendor/bundle/
+# - vendor/cache/
+# - vendor/gems/
+# - vendor/ruby/
diff --git a/_includes/disqus_comments.html b/_includes/disqus_comments.html
new file mode 100644
index 0000000..d9400f2
--- /dev/null
+++ b/_includes/disqus_comments.html
@@ -0,0 +1,20 @@
+{%- if page.comments != false and jekyll.environment == "production" -%}
+
+
+
+ Please enable JavaScript to view the comments powered by Disqus.
+{%- endif -%}
diff --git a/_includes/footer.html b/_includes/footer.html
new file mode 100644
index 0000000..db72885
--- /dev/null
+++ b/_includes/footer.html
@@ -0,0 +1,35 @@
+
diff --git a/_includes/google-analytics.html b/_includes/google-analytics.html
new file mode 100644
index 0000000..e9afb20
--- /dev/null
+++ b/_includes/google-analytics.html
@@ -0,0 +1,12 @@
+
+
diff --git a/_includes/head.html b/_includes/head.html
new file mode 100644
index 0000000..dc6596d
--- /dev/null
+++ b/_includes/head.html
@@ -0,0 +1,14 @@
+
+
+
+
+ {%- seo -%}
+
+
+
+
+ {%- feed_meta -%}
+ {%- if jekyll.environment == 'production' and site.google_analytics -%}
+ {%- include google-analytics.html -%}
+ {%- endif -%}
+
diff --git a/_includes/header.html b/_includes/header.html
new file mode 100644
index 0000000..6a21e16
--- /dev/null
+++ b/_includes/header.html
@@ -0,0 +1,23 @@
+
diff --git a/_includes/icon-github.html b/_includes/icon-github.html
new file mode 100644
index 0000000..e501a16
--- /dev/null
+++ b/_includes/icon-github.html
@@ -0,0 +1 @@
+{% include icon-github.svg %} {{ include.username }}
diff --git a/_includes/icon-github.svg b/_includes/icon-github.svg
new file mode 100644
index 0000000..e6c5f6d
--- /dev/null
+++ b/_includes/icon-github.svg
@@ -0,0 +1 @@
+
diff --git a/_includes/icon-twitter.html b/_includes/icon-twitter.html
new file mode 100644
index 0000000..e623dbd
--- /dev/null
+++ b/_includes/icon-twitter.html
@@ -0,0 +1 @@
+{{ include.username }}
diff --git a/_includes/icon-twitter.svg b/_includes/icon-twitter.svg
new file mode 100644
index 0000000..efc0ecf
--- /dev/null
+++ b/_includes/icon-twitter.svg
@@ -0,0 +1 @@
+
diff --git a/_includes/social.html b/_includes/social.html
new file mode 100644
index 0000000..44046b8
--- /dev/null
+++ b/_includes/social.html
@@ -0,0 +1,14 @@
+
diff --git a/_layouts/default.html b/_layouts/default.html
new file mode 100644
index 0000000..d31a770
--- /dev/null
+++ b/_layouts/default.html
@@ -0,0 +1,20 @@
+
+
+
+ {%- include head.html -%}
+
+
+
+ {%- include header.html -%}
+
+
+
+ {{ content }}
+
+
+
+
+
+
+
+
diff --git a/_layouts/home.html b/_layouts/home.html
new file mode 100644
index 0000000..0eaef02
--- /dev/null
+++ b/_layouts/home.html
@@ -0,0 +1,12 @@
+---
+layout: default
+---
+
+
+
+
{{ page.heading }}
+
+
+
+
+
diff --git a/_layouts/page.html b/_layouts/page.html
new file mode 100644
index 0000000..3ea45c6
--- /dev/null
+++ b/_layouts/page.html
@@ -0,0 +1,11 @@
+---
+layout: default
+---
+
+ {{ page.heading }}
+
+
+ {{ content }}
+
+
+
diff --git a/_layouts/post.html b/_layouts/post.html
new file mode 100644
index 0000000..fe33d2a
--- /dev/null
+++ b/_layouts/post.html
@@ -0,0 +1,28 @@
+---
+layout: default
+---
+
+
+
+
+
+
+ {{ content }}
+
+
+ {%- if site.disqus.shortname -%}
+ {%- include disqus_comments.html -%}
+ {%- endif -%}
+
+
+
diff --git a/_posts/2018-06-17-adding-opentracing-support-to-apicast.md b/_posts/2018-06-17-adding-opentracing-support-to-apicast.md
new file mode 100644
index 0000000..17c1f81
--- /dev/null
+++ b/_posts/2018-06-17-adding-opentracing-support-to-apicast.md
@@ -0,0 +1,278 @@
+---
+layout: post
+title: "Adding OpenTracing support to APIcast"
+date: 2018-09-14 16:31:33 +0200
+categories: istio mesh
+---
+
+
+Going from this:
+
+```
+[17/May/2018:14:19:02 +0000] someclient.production.gw.apicast.io:8080 10.1.13.3:36054 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 747 (0.100) 0.1
+[17/May/2018:14:19:12 +0000] someclient.production.gw.apicast.io:8080 10.1.5.3:33492 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 746 (0.000) 0
+[17/May/2018:14:19:27 +0000] someclient.production.gw.apicast.io:8080 10.1.13.3:36874 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 747 (0.100) 0.1
+[17/May/2018:14:19:37 +0000] someclient.production.gw.apicast.io:8080 10.1.5.3:34364 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 746 (0.000) 0
+[17/May/2018:14:20:17 +0000] someclient.production.gw.apicast.io:8080 10.1.13.3:38518 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 747 (0.100) 0
+[17/May/2018:14:20:32 +0000] someclient.production.gw.apicast.io:8080 10.1.5.3:36206 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 746 (0.000) 0
+[17/May/2018:14:20:37 +0000] someclient.production.gw.apicast.io:8080 10.1.13.3:39170 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 747 (0.100) 0.1
+[17/May/2018:14:20:47 +0000] someclient.production.gw.apicast.io:8080 10.1.5.3:36686 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 746 (0.100) 0.1
+[17/May/2018:14:21:02 +0000] someclient.production.gw.apicast.io:8080 10.1.5.3:37192 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 746 (0.100) 0.1
+[17/May/2018:14:21:22 +0000] someclient.production.gw.apicast.io:8080 10.1.5.3:37826 "GET /?user_key=XXXXXXXXXXXXXXXXXX HTTP/1.1" 200 746 (0.100) 0.1
+
+```
+
+To:
+
+
+
+Let's start by explaining what APIcast, OpenTracing and Jaeger are, and how we improved Observability of our user systems by embracing them.
+
+TL;DR: If you know what APIcast, Jaeger & OpenTracing are, you should jump to the last section :)
+
+### APIcast
+APIcast () is an Opensource API Gateway with it's main focus on high performance and extensibility, is part of the Redhat 3scale API Management solution, and is used by hundreds of companies around the world to expose their APIs in a secure and controlled way.
+
+It's based on Openresty, which is a full-fledged web platform that integrates the standard Nginx core, LuaJIT and Lua Libraries with 3rd-party Nginx modules. So we have the performance and robustness of nginx with an easy way to extend/change it's functionallity by using LUA.
+
+### Improving Observability
+
+APIcast is being deployed in multiple scenarios, but more and more, our users are deploying APIcast as the API Gateway of big and complex microservices deployments.
+
+As you can imagine, we are talking about hundreds of microservices, interacting with each other, and each external requests ends up creating several requests between services. This raises new challenges, and one of them is: "Observability"
+
+* Why this request was so slow?
+* Which service is creating those latency peaks?
+* Which services are interacting when a user hits this endpoint?
+* Why the request failed?
+* Who initiated this request?
+* ...
+
+Right now, answering those questions is slow and complex, as the users start debuging via logs and trying to correlate everything, so we need to we need to start looking at how microservices are monitored, and distributed tracing shows up as the pattern that help us to get insight on what is going on inside the system.
+
+What is required to add distributed tracing to our microservice deployment?
+
+* Each external requests should have a unique request ID attached, usually via a HTTP header
+* Each service should forward the request ID to other services
+* Each service should output the requets ID in the logs
+* Each service should record additional information, like start and end time of the request.
+* Logs will need to be aggregated somewhere, and provide a way to parse via HTTP request ID.
+
+For APIcast, that is simple, attach a unique ID as a HTTP Header and we are done...
+
+But the user will need to define a log format across all the services, what parameters to be stored in the log, the http header to use, how to capture the start/end time of each requests...correlate them, check how to do that in third party applications, try to modify those...
+
+
+So we ask ourselves, *Shouldn't exists a "standard" way of doing this?*
+
+And that's where OpenTracing comes into scene.
+
+### OpenTracing
+
+OpenTracing () offers consistent, vendor-neutral APIs, Opensource libraries and documentation for developers to instrument and add different tracing implementations into their applications.
+
+Currently the OpenTracing project provides libraries for the following languages:
+
+* Go
+* Python
+* Javascript
+* Java
+* C#
+* Objective-C
+* C++
+* Ruby
+* PHP
+
+And there's a huge community pushing new contributions, check: .
+
+Once you have instrumented your application by adding the OpenTracing libraries, you will need to choose the tracing implementation, those are the supported one:
+
+* Jaeger
+* Appdash
+* LightStep
+* Hawkular
+* Instana
+* Apache SkyWalking
+* inspectIT
+* stagemonitor
+* Datadog
+
+We decided to go with Jaeger, as it is part of the CNF, has Openshift ready deployments , and Red Hat is contributing to it.
+
+
+### Tracer: Jaeger
+
+Jaeger is a distributed tracing system developed by Uber Technologies, inspired by Dapper and Openzipkin. It supports multiple storage backends, is OpenTracing native and includes a modern web UI and it's designed for performance.
+
+
+
+As you can see in the diagram, the main components are:
+
+* Jaeger-client: The jaeger library that creates the spans.
+* Jaeger-agent: Reports traces from the jaeger-client to jaeger-collector.
+* Jaeger-collector: Centralizes traces from jaeger-agents and saves them into a storage backend.
+* Jaeger-query: Retrieves traces from a datastore
+* Jaeger-ui: Jaeger UI, uses jaeger-query to get retrieve traces.
+
+Jaeger supports `Adaptative sampling`, which means that we can tune how many traces are sampled by choosing the proper `sampler`:
+
+* Constant: All traces.
+* Probabilistic: can be adjusted from 0% to 100%
+* Rate Limiting: How many traces per second, for ex: 2.0 (only 2 traces per second.)
+* Remote: Checks with the jaeger agent which sampler to use for this service.
+
+If you want to know more about Jaeger, visit:
+
+### Enabling OpenTracing with Jaeger in APIcast
+
+We packaged all the OpenTracing libraries, and the Jaeger Tracer library in the base container image of APIcast, [s2i-openresty](https://github.com/3scale/s2i-openresty) this image is ["source-to-image"](https://github.com/openshift/source-to-image) enabled, so you can use it as the base of your own projects.
+
+We will use [OpenShift](https://www.openshift.com), and the container image of APIcast (), so we assume you have APIcast deployed on top of Openshift and your 3scale account created, if that's not the case, there's an amazing guide to get you up & running in no time here: [Using 3scale API Gateway on Red Hat OpenShift](https://github.com/3scale/apicast/blob/master/doc/openshift-guide.md)
+
+APIcast OpenTracing support is enabled/disabled using ENV vars:
+
+* OPENTRACING_TRACER: Which Tracer implementation to use, right now, only `Jaeger` is available.
+
+* OPENTRACING_CONFIG: Each tracer has a default configuration file, you can see an example here: [jaeger.example.json](https://github.com/3scale/apicast/blob/master/gateway/conf.d/opentracing/jaeger.example.json)
+
+* OPENTRACING_HEADER_FORWARD: By default, uses `uber-trace-id`, if your OpenTracing has a different configuration, you will need to change this value, if not, ignore it.
+
+In the first place let's deploy the Jager All-In-One template, this is not really meant for production environments, but for demo purposes it will be enough.
+
+
+* Install the Jaeger all-in-one in the current namespace:
+
+```
+oc process -f https://raw.githubusercontent.com/jaegertracing/jaeger-openshift/master/all-in-one/jaeger-all-in-one-template.yml | oc create -f -
+```
+
+For more info related to deploying jaeger in a production environment:
+
+* Access the Jaeger-UI:
+
+```
+> oc get route
+
+NAME HOST/PORT PATH SERVICES PORT TERMINATION WILDCARD
+apicast apicast.127.0.0.1.nip.io apicast proxy edge None
+jaeger-query jaeger-query-myproject.127.0.0.1.nip.io jaeger-query query-http edge/Allow None
+```
+
+In my case, the url is https://jaeger-query-myproject.127.0.0.1.nip.io
+
+You should be greeted by this menacing looking gopher:
+
+
+
+* Now, let's create our own Jaeger configuration file:
+
+```json
+cat <jaeger_config.json
+ {
+ "service_name": "apicast",
+ "disabled": false,
+ "sampler": {
+ "type": "const",
+ "param": 1
+ },
+ "reporter": {
+ "queueSize": 100,
+ "bufferFlushInterval": 10,
+ "logSpans": false,
+ "localAgentHostPort": "jaeger-agent:6831"
+ },
+ "headers": {
+ "jaegerDebugHeader": "debug-id",
+ "jaegerBaggageHeader": "baggage",
+ "TraceContextHeaderName": "uber-trace-id",
+ "traceBaggageHeaderPrefix": "testctx-"
+ },
+ "baggage_restrictions": {
+ "denyBaggageOnInitializationFailure": false,
+ "hostPort": "127.0.0.1:5778",
+ "refreshInterval": 60
+ }
+ }
+EOF
+```
+This creates a new file: `jaeger_config.json`
+
+* Let's review the important bits:
+
+Sampler configuration:
+
+```json
+"sampler": {
+ "type": "const",
+ "param": 1
+}
+```
+
+This defines the sampler as [const]ant, with a param of "1", the means, it will sample all the requests.
+
+Reporter:
+
+```json
+"reporter": {
+ "queueSize": 100,
+ "bufferFlushInterval": 10,
+ "logSpans": false,
+ "localAgentHostPort": "jaeger-agent:6831"
+}
+```
+
+Max queue of 100 requests and flush interval of 10s, we are not outputting the spans to the log, and the agent host is expected to be running at "jaeger-agent:6831".
+
+!! You will need to tune those values if your service is doing more than 100 requests in less than 10s, either increase the `queueSize`, or decrease the `bufferFlushInterval`.
+
+Headers:
+
+```json
+"headers": {
+ "jaegerDebugHeader": "debug-id",
+ "jaegerBaggageHeader": "baggage",
+ "TraceContextHeaderName": "uber-trace-id",
+ "traceBaggageHeaderPrefix": "testctx-"
+}
+```
+
+The most important one for now, is the `TraceContextHeaderName`, we are going to use the default value of `uber-trace-id`. This is the HTTP header we need to forward in all our services to propagate the span information and be able to correlate them.
+
+* Let's create a ConfigMap from our jaeger configuration so we can mount it inside APIcast:
+
+```
+oc create configmap jaeger-config --from-file=jaeger.json
+```
+
+* Mount the ConfigMap into APIcast.
+
+```
+oc volume dc/apicast --add -m /tmp/jaeger/ --configmap-name jaeger-config
+```
+
+This will trigger a redeployment of APIcast, now all the PODs will have our new configuration, available at `/tmp/jaeger/jaeger_config.json`.
+
+* Let's enable OpenTracing and Jaeger with our custom configuration.
+
+```
+oc env deploymentConfig/apicast OPENTRACING_TRACER=jaeger OPENTRACING_CONFIG=/tmp/jaeger/jaeger_config.json
+```
+
+This will trigger the redeployment of APIcast, and we should go to our jaeger-UI to see if it's populating with APIcast data.
+
+
+
+
+
+
+
+### Current limitations
+
+As you know, Openresty is Nginx + luaJIT, and right now, we only get OpenTracing information for the "Nginx" part of it, there aren't any OpenTracing libraries for lua.
+
+We are working on being able to use the OpenTracing C++ libraries from LUA, so we can create spans directly from it, and gain even more visibility into APIcast internals. For example, this could help debug if that custom policy you just installed is making things slowers.
+
+
+### We are Hiring!
+
+If you are interested in this kind of projects, we are hiring! :)
diff --git a/_posts/2018-09-14-api-management-and-service-mesh.md b/_posts/2018-09-14-api-management-and-service-mesh.md
new file mode 100644
index 0000000..3e5531d
--- /dev/null
+++ b/_posts/2018-09-14-api-management-and-service-mesh.md
@@ -0,0 +1,36 @@
+---
+layout: post
+title: "API Management and Service Mesh"
+date: 2018-09-14 16:31:33 +0200
+categories: istio mesh
+---
+Why a Service Mesh is not a replacement of API Management
+As a disclaimer, I work at Red Hat, more specifically, at the 3scale Team (acquired 2 years ago) developing the 3scale API Management Solution.
+
+Lately, a question is popping up more and more when talking with our customers: “Why do I need API Management if I use Istio?”
+
+To answer this question, first, we need to understand what is what, but if you want a spoiler: 3scale API Management and Istio are amazing together.
+
+I will try to describe what problems those two solutions aim to solve, focusing on 3scale API Management and Istio Service Mesh (those are the two I know better).
+
+## What is an API Management solution?
+
+If we take a look at Wikipedia:
+> “API management is the process of creating and publishing web APIs, enforcing their usage policies, controlling access, nurturing the subscriber community, collecting and analyzing usage statistics, and reporting on performance.”
+
+This is a good definition. As a company that has created some kind of internal service, I now want to build a business around it by providing an API to external subscribers. Of course, I want to monetize it by offering several subscription plans with different usage limits, scopes, and be able to invoice my customers automatically.
+Additionally, external Developers should find my API easily, and sign up for a plan in a self-service way with just their credit card and all of this should be transparent for my API code…
+
+{% highlight ruby %}
+def print_hi(name)
+ puts "Hi, #{name}"
+end
+print_hi('Tom')
+#=> prints 'Hi, Tom' to STDOUT.
+{% endhighlight %}
+
+Check out the [Jekyll docs][jekyll-docs] for more info on how to get the most out of Jekyll. File all bugs/feature requests at [Jekyll’s GitHub repo][jekyll-gh]. If you have questions, you can ask them on [Jekyll Talk][jekyll-talk].
+
+[jekyll-docs]: https://jekyllrb.com/docs/home
+[jekyll-gh]: https://github.com/jekyll/jekyll
+[jekyll-talk]: https://talk.jekyllrb.com/
diff --git a/_sass/3scale.scss b/_sass/3scale.scss
new file mode 100644
index 0000000..a08cf8a
--- /dev/null
+++ b/_sass/3scale.scss
@@ -0,0 +1,97 @@
+@charset "utf-8";
+
+// Define defaults for each variable.
+$fa-font-path: "../assets/fonts" !default;
+$base-font-family: 'Overpass', helvetica, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol" !default;
+$base-font-size: 16px !default;
+$base-font-weight: 400 !default;
+$small-font-size: $base-font-size * 0.875 !default;
+$base-line-height: 1.5 !default;
+
+$text-color: #111 !default;
+$solid-background-color: rgba(#dadada, .95) !default;
+$background-color: rgba(#dadada, .95) !default;
+$light-background-color: rgba(white, 0.95);
+$appleGreen: #32CD32;
+$brand-color: #FF7314 !default;
+
+$grey-color: #828282 !default;
+$grey-color-light: lighten($grey-color, 40%) !default;
+$grey-color-dark: darken($grey-color, 25%) !default;
+
+$table-text-align: left !default;
+
+// Width of the content area
+$content-width: 100% !default;
+
+$on-palm: 600px !default;
+$on-laptop: 800px !default;
+
+// Use media queries like this:
+// @include media-query($on-palm) {
+// .wrapper {
+// padding-right: $spacing-unit / 2;
+// padding-left: $spacing-unit / 2;
+// }
+// }
+@mixin media-query($device) {
+ @media screen and (max-width: $device) {
+ @content;
+ }
+}
+
+@mixin relative-font-size($ratio) {
+ font-size: $base-font-size * $ratio;
+}
+
+//$minScreen: 1rem;
+//$maxScreen: 20rem;
+$minScreen: 320px;
+$maxScreen: 4000px;
+$minFont: 0.8rem;
+$maxFont: 400rem;
+
+// http://madebymike.com.au/writing/precise-control-responsive-typography/
+// https://gist.github.com/indrekpaas/7f22e44ace49b5124eec
+@mixin fluid-type($properties, $min-vw, $max-vw, $min-value, $max-value) {
+ & {
+ @each $property in $properties {
+ #{$property}: $min-value;
+ }
+
+ @media screen and (min-width: $min-vw) {
+ @each $property in $properties {
+ #{$property}: calc(#{$min-value} + #{strip-unit($max-value - $min-value)} * ((100vw - #{$min-vw}) / #{strip-unit($max-vw - $min-vw)}));
+ }
+ }
+
+ @media screen and (min-width: $max-vw) {
+ @each $property in $properties {
+ #{$property}: $max-value;
+ }
+ }
+ }
+}
+
+@function strip-unit($value) {
+ @return $value / ($value * 0 + 1);
+}
+
+@function line-height-times($multiplier: 1, $subtract-border: false) {
+ $spacer: $base-line-height *1rem * $multiplier;
+
+ @if $subtract-border == true {
+ @return calc(#{$spacer} - #{$border-width});
+ }
+ @else {
+ @return $spacer;
+ }
+}
+
+$spacing-unit: line-height-times(2);
+// Import partials.
+@import
+ "3scale/base",
+ "3scale/layout",
+ "3scale/syntax-highlighting"
+;
diff --git a/_sass/3scale/_base.scss b/_sass/3scale/_base.scss
new file mode 100644
index 0000000..cf551f9
--- /dev/null
+++ b/_sass/3scale/_base.scss
@@ -0,0 +1,249 @@
+/**
+ * Reset some basic elements
+ */
+body, h1, h2, h3, h4, h5, h6,
+p, blockquote, pre, hr,
+dl, dd, ol, ul, figure {
+ margin: 0;
+ padding: 0;
+}
+
+/**
+ * Basic styling
+ */
+body {
+ box-sizing: border-box;
+ font: $base-font-weight #{$base-font-size}/#{$base-line-height} $base-font-family;
+ color: $text-color;
+ background-color: $background-color;
+ -webkit-text-size-adjust: 100%;
+ -webkit-font-feature-settings: "kern" 1;
+ -moz-font-feature-settings: "kern" 1;
+ -o-font-feature-settings: "kern" 1;
+ font-feature-settings: "kern" 1;
+ font-kerning: normal;
+ display: flex;
+ min-height: 100vh;
+ flex-direction: column;
+}
+
+/**
+ * Wrapper
+ */
+.wrapper {
+ //max-width: calc(#{$content-width} - (#{line-height-times(1)} * 2));
+ padding: line-height-times(1/2) line-height-times(2) 0 line-height-times(2);
+
+ margin-right: auto;
+ margin-left: auto;
+ //padding-right: line-height-times(1);
+ //padding-left: line-height-times(1);
+ @extend %clearfix;
+
+ @include media-query($on-laptop) {
+ padding: line-height-times(1/2) line-height-times(1) 0 line-height-times(1);
+ }
+}
+
+/**
+ * Set `margin-bottom` to maintain vertical rhythm
+ */
+h1, h2, h3, h4, h5, h6,
+p, blockquote, pre,
+ul, ol, dl, figure,
+%vertical-rhythm {
+ margin-bottom: $spacing-unit / 2;
+}
+
+/**
+ * `main` element
+ */
+main {
+ display: block; /* Default value of `display` of `main` element is 'inline' in IE 11. */
+}
+
+/**
+ * Images
+ */
+img {
+ max-width: 100%;
+ vertical-align: middle;
+}
+
+/**
+ * Figures
+ */
+figure > img {
+ display: block;
+}
+
+figcaption {
+ font-size: $small-font-size;
+}
+
+/**
+ * Lists
+ */
+ul, ol {
+ margin-left: 0;// line-height-times(1);
+ //list-style: square outside;
+ list-style: none; /* Remove default bullets */
+}
+
+.page-content ul li::before {
+ content: "\25A0"; /* Add content: \2022 is the CSS Code/unicode for a bullet */
+ color: $appleGreen; //$background-color; /* Change the color */
+ font-weight: bold; /* If you want it to be bold */
+ //display: inline-block; /* Needed to add space between the bullet and the text */
+ //width: line-height-times(1.2); /* Also needed for space (tweak if needed) */
+ margin-left: line-height-times(-1.15); /* Also needed for space (tweak if needed) */
+ //@include relative-font-size(2.5);
+ @include fluid-type(font-size, $minScreen, $maxScreen, 1.5rem, 30rem);
+ position: absolute;
+ top: line-height-times(-0.35);
+}
+
+li {
+ position: relative;
+ > ul,
+ > ol {
+ margin-bottom: 0;
+ }
+}
+
+/**
+ * Headings
+ */
+h1, h2, h3, h4, h5, h6 {
+ font-weight: $base-font-weight;
+}
+
+/**
+ * Links
+ */
+a {
+ color: $text-color;
+ text-decoration: underline;
+ transition: 0.3s;
+
+ &:visited {
+ color: $text-color;
+ }
+
+ &:hover {
+
+ color: $brand-color;
+ text-decoration: underline;
+ }
+
+ .social-media-list &:hover {
+ text-decoration: none;
+
+ .username {
+ text-decoration: underline;
+ }
+ }
+}
+
+
+/**
+ * Blockquotes
+ */
+blockquote {
+ color: $grey-color;
+ border-left: 4px solid $grey-color-light;
+ padding-left: $spacing-unit / 2;
+ @include relative-font-size(1.125);
+ letter-spacing: -1px;
+ font-style: italic;
+
+ > :last-child {
+ margin-bottom: 0;
+ }
+}
+
+
+
+/**
+ * Code formatting
+ */
+
+code {
+ //padding: 1px 5px;
+}
+
+pre {
+ white-space: pre-wrap;
+ padding: line-height-times(1);
+ //overflow-x: auto;
+ //overflow: auto;
+ overflow-x:hidden;
+
+ > code {
+ border: 0;
+ padding-right: 0;
+ padding-left: 0;
+ }
+}
+
+
+
+/**
+ * Clearfix
+ */
+%clearfix:after {
+ content: "";
+ display: table;
+ clear: both;
+}
+
+
+
+/**
+ * Icons
+ */
+
+.svg-icon {
+ width: 16px;
+ height: 16px;
+ display: inline-block;
+ fill: #{$grey-color};
+ padding-right: 5px;
+ vertical-align: text-top;
+}
+
+.social-media-list {
+ li + li {
+ padding-top: 5px;
+ }
+}
+
+
+
+/**
+ * Tables
+ */
+table {
+ margin-bottom: $spacing-unit;
+ width: 100%;
+ text-align: $table-text-align;
+ color: lighten($text-color, 18%);
+ border-collapse: collapse;
+ border: 1px solid $grey-color-light;
+ tr {
+ &:nth-child(even) {
+ background-color: lighten($grey-color-light, 6%);
+ }
+ }
+ th, td {
+ padding: ($spacing-unit / 3) ($spacing-unit / 2);
+ }
+ th {
+ background-color: lighten($grey-color-light, 3%);
+ border: 1px solid darken($grey-color-light, 4%);
+ border-bottom-color: darken($grey-color-light, 12%);
+ }
+ td {
+ border: 1px solid $grey-color-light;
+ }
+}
diff --git a/_sass/3scale/_layout.scss b/_sass/3scale/_layout.scss
new file mode 100644
index 0000000..eee20f0
--- /dev/null
+++ b/_sass/3scale/_layout.scss
@@ -0,0 +1,288 @@
+/**
+ * Site header
+ */
+ .site-header {
+ background-color: $background-color;
+ position: fixed;
+ bottom: 0;
+ width: 100%;
+ min-height: 0;
+ padding: line-height-times(1) 0 0 0;
+ font-weight: bold;
+ z-index: 100;
+ }
+
+.site-nav {
+ @include fluid-type(font-size, $minScreen, $maxScreen, $minFont, 30rem);
+ line-height: $base-line-height * $base-font-size * 2.25;
+ white-space: nowrap;
+ overflow-x: auto;
+ overflow-y: visible;
+
+ a {
+ text-decoration: none;
+ }
+
+ .page-link {
+ color: $text-color;
+ line-height: 1;
+ padding: 0 line-height-times(1)line-height-times(1);
+ position: relative;
+ display: block;
+
+ &:hover {
+ color: $brand-color;
+ }
+
+ // Gaps between nav items, but not on the last one
+ &:not(:last-child) {
+ margin-right: 1rem;
+ }
+ }
+}
+
+.page-heading .active,
+.page-link.active {
+ color: $brand-color;
+}
+
+/**
+ * Page content
+ */
+
+
+.page-heading {
+ font-family: 'Overpass';
+ font-size: 9vw;
+ margin-left: 10vw;
+ font-weight: 800;
+ text-align: right;
+ line-height: 1.2;
+ margin-bottom: 2.5vw;
+
+ a {
+ text-decoration: none;
+ }
+}
+
+.page-content {
+ margin-top: 6rem;
+ font-family: 'Overpass Mono';
+ @include fluid-type(font-size, $minScreen, $maxScreen, 0.8rem, 25rem);
+ display: flex;
+ flex-wrap: wrap;
+ justify-content: space-between;
+ margin: line-height-times(3) line-height-times(-1) line-height-times(1.5) line-height-times(-1);
+ flex: 1;
+
+ h1 {
+ font-family: 'Overpass Mono';
+ font-weight: bold;
+ }
+}
+
+.post-list-heading {
+ @include relative-font-size(1.75);
+}
+
+.post-list {
+ margin-left: 0;
+ list-style: none;
+
+ > li {
+ margin-bottom: $spacing-unit;
+ }
+}
+
+.post-meta {
+ font-size: $small-font-size;
+ color: $grey-color;
+}
+
+.post-link {
+ display: block;
+ @include relative-font-size(1.5);
+}
+
+
+
+/**
+ * Posts
+ */
+.post-header {
+ margin-bottom: $spacing-unit;
+}
+
+.post-title {
+ @include relative-font-size(2.625);
+ letter-spacing: -1px;
+ line-height: 1;
+
+ @include media-query($on-laptop) {
+ @include relative-font-size(2.25);
+ }
+}
+
+.post-content {
+ font-family: 'Overpass';
+ margin-bottom: $spacing-unit;
+ margin: 0 0 6rem 0 !important;
+
+ p {
+ //margin-right: line-height-times(30);
+ display: block;
+ width: 100%;
+ }
+
+ h2 {
+ font-size: 120%;
+ }
+
+ h3 {
+ font-size: 110%;
+ }
+
+ h4 {
+ font-size: 105%;
+ }
+}
+
+.chapter {
+ margin: 0 line-height-times(1) line-height-times(2);
+ flex-grow: 1;
+ flex-basis: 45%;
+ display: flex;
+ flex-direction: row;
+ overflow: hidden;
+
+ &.paragraphed {
+ flex-direction: column;
+
+ .summary {
+ margin-bottom: 1.5rem;
+ }
+ }
+
+ &.focus {
+ position: relative;
+ z-index: 10;
+ }
+
+ .summary {
+ padding: 1.5rem;
+ position: relative;
+ z-index: 10;
+ background-color: $light-background-color;
+ //flex-basis: 40%;
+ }
+
+ &.client {
+ flex-basis: 100%;
+ margin-top: -10rem;
+ margin-bottom: -10rem;
+ font-size: 3vw;
+ background-color: transparent;
+ line-height: 1;
+
+ h1 {
+ height: 6rem;
+ }
+ }
+
+ &.api {
+ background-color: transparent;
+ font-size: 9vw;
+ line-height: 1;
+ }
+
+ .policy-chain,
+ .feature-chain {
+ border-left: 1rem solid transparent;
+ background-color: transparent;
+ display: flex;
+ flex-direction: column;
+ height: 100%;
+ margin-left: 0;
+ }
+
+ section {
+ position: relative;
+ flex-basis: 50%;
+
+ h2 {
+ margin-bottom: 0;
+ }
+ }
+
+ .policy, .feature {
+ box-sizing: content-box;
+ background-color: $light-background-color;
+ border-bottom: 1rem solid $solid-background-color;
+ border-right: 0;
+ border-left: 0;
+ padding: 0 1.5rem;
+ text-align: left;
+ list-style: none;
+ flex: 1;
+ display: flex;
+ justify-content: center;
+ flex-direction: column;
+ text-align: center;
+
+ &:first-child {
+ border-top: 0;
+ }
+
+ &:last-child {
+ border-bottom: 0;
+ }
+ }
+
+ .feature {
+ text-align: left;
+ }
+
+ #policy2,
+ #policy3,
+ #policy4 {
+ position: relative;
+ //z-index: 5;
+ }
+
+}
+
+.nav-list {
+ list-style: none;
+ margin-left: 0;
+ margin-bottom: 0;
+ line-height: 1;
+}
+
+.nav-list-item {
+ display: inline-block;
+ border-left: 0.1rem solid $text-color;
+}
+
+
+.nav-list-item:first-child {
+ border-left: 0;
+ margin-left: line-height-times(0.75);
+}
+
+a:focus {
+ color: $brand-color;
+}
+
+:target .conditional-highlight,
+:active .conditional-highlight{
+ color: $brand-color;
+ font-weight: bold;
+ font-family: 'Overpass';
+}
+
+.icon {
+ background-repeat: no-repeat;
+ background-position: line-height-times(2) line-height-times(.2);
+ background-size: line-height-times(1.5) auto;
+ background-image: url(data:image/svg+xml;base64,<?xml version="1.0" encoding="UTF-8"?><svg viewBox="0 0 724 734" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">        <title>icon</title>    <desc>Created with Sketch.</desc>    <g id="Page-1" stroke="none" stroke-width="1" fill="none" fill-rule="evenodd">        <g id="icon" fill-rule="nonzero">            <g id="Group-2" fill="#000000">                <path d="M501.033628,134.16504 C501.033628,123.744454 509.362832,115.929015 518.973452,115.929015 C529.224779,115.929015 536.913274,124.395741 536.913274,134.16504 C536.913274,144.585626 528.58407,152.401065 518.973452,152.401065 C509.362832,152.401065 501.033628,143.934339 501.033628,134.16504 M410.053096,93.7852706 C410.053096,79.4569655 421.585841,68.3850933 435.040709,68.3850933 C448.495575,68.3850933 460.02832,80.1082521 460.02832,93.7852706 C460.02832,108.113576 448.495575,119.185448 435.040709,119.185448 C421.585841,119.185448 410.053096,108.113576 410.053096,93.7852706 M196.697345,666.917479 C196.697345,649.332741 210.792921,635.004436 228.092036,635.004436 C245.391151,635.004436 259.486726,649.332741 259.486726,666.917479 C259.486726,684.502219 245.391151,698.830524 228.092036,698.830524 C210.792921,698.830524 196.697345,684.502219 196.697345,666.917479 M356.233628,567.921916 C356.233628,552.942324 368.407079,540.567879 383.143363,540.567879 C397.879647,540.567879 410.053096,552.942324 410.053096,567.921916 C410.053096,582.901509 397.879647,595.275955 383.143363,595.275955 C368.407079,595.275955 356.233628,582.901509 356.233628,567.921916 M435.681416,603.74268 C435.681416,584.204083 451.058406,568.573202 470.279647,568.573202 C489.500885,568.573202 504.877875,584.204083 504.877875,603.74268 C504.877875,623.281278 489.500885,638.912156 470.279647,638.912156 C451.058406,638.912156 435.681416,623.281278 435.681416,603.74268 M317.150442,265.724934 C317.150442,250.745341 329.323894,239.022182 343.419469,239.022182 C358.155752,239.022182 369.688495,250.745341 369.688495,265.724934 C369.688495,280.704526 358.155752,292.427685 343.419469,292.427685 C328.683185,292.427685 317.150442,280.053239 317.150442,265.724934 M326.761062,181.708962 C326.761062,169.985803 336.37168,160.216504 347.904425,160.216504 C359.437168,160.216504 369.047788,169.985803 369.047788,181.708962 C369.047788,193.432121 359.437168,203.20142 347.904425,203.20142 C336.37168,203.20142 326.761062,193.432121 326.761062,181.708962 M253.079647,422.685004 C253.079647,402.49512 269.097346,385.561669 289.6,385.561669 C309.461947,385.561669 326.120353,402.49512 326.120353,422.685004 C326.120353,442.874889 310.102654,459.80834 289.6,459.80834 C269.097346,459.80834 253.079647,443.526175 253.079647,422.685004 M563.182301,459.157053 C563.182301,441.572315 577.277875,427.24401 594.57699,427.24401 C611.876106,427.24401 625.97168,441.572315 625.97168,459.157053 C625.97168,476.741793 611.876106,491.070098 594.57699,491.070098 C577.277875,491.070098 563.182301,476.741793 563.182301,459.157053 M647.115043,385.561669 C647.115043,364.069209 664.414159,346.484471 685.557522,346.484471 C706.700885,346.484471 724,364.069209 724,385.561669 C724,407.054126 706.700885,424.638864 685.557522,424.638864 C664.414159,424.638864 647.115043,407.054126 647.115043,385.561669 M643.911505,218.832298 C643.911505,201.898846 657.366372,188.221828 674.024779,188.221828 C690.683185,188.221828 704.138053,201.898846 704.138053,218.832298 C704.138053,235.765749 690.683185,249.442768 674.024779,249.442768 C657.366372,249.442768 643.911505,235.765749 643.911505,218.832298 M664.414159,301.545697 C664.414159,289.171252 674.024779,279.401953 686.198231,279.401953 C698.37168,279.401953 707.982301,289.171252 707.982301,301.545697 C707.982301,313.920142 698.37168,323.689441 686.198231,323.689441 C674.024779,324.340727 664.414159,313.920142 664.414159,301.545697 M575.355752,282.007099 C575.355752,270.283941 584.966372,260.51464 596.499115,260.51464 C608.031858,260.51464 617.642478,270.283941 617.642478,282.007099 C617.642478,293.730258 608.031858,303.499557 596.499115,303.499557 C584.325663,303.499557 575.355752,293.730258 575.355752,282.007099 M503.596459,364.720496 C503.596459,355.602484 510.644248,348.438331 519.614159,348.438331 C528.58407,348.438331 535.631858,355.602484 535.631858,364.720496 C535.631858,373.83851 528.58407,381.002663 519.614159,381.002663 C510.644248,381.002663 503.596459,373.83851 503.596459,364.720496 M388.269026,319.130435 C388.269026,302.84827 401.083185,289.822538 417.100885,289.822538 C433.118584,289.822538 445.932743,302.84827 445.932743,319.130435 C445.932743,335.412599 433.118584,348.438331 417.100885,348.438331 C401.083185,348.438331 388.269026,335.412599 388.269026,319.130435 M523.458406,204.503993 C523.458406,185.616682 538.835399,169.985803 557.41593,169.985803 C575.996459,169.985803 591.373452,185.616682 591.373452,204.503993 C591.373452,223.391304 575.996459,239.022182 557.41593,239.022182 C538.835399,239.022182 523.458406,224.042591 523.458406,204.503993 M597.780531,151.749778 C597.780531,136.770186 609.953983,124.395741 624.690265,124.395741 C639.426548,124.395741 651.6,136.770186 651.6,151.749778 C651.6,166.72937 639.426548,179.103815 624.690265,179.103815 C609.953983,179.103815 597.780531,166.72937 597.780531,151.749778 M537.553983,82.7133984 C537.553983,72.2928128 545.883185,64.4773735 555.493805,64.4773735 C565.745132,64.4773735 573.433628,72.9440994 573.433628,82.7133984 C573.433628,93.1339841 565.104425,100.949423 555.493805,100.949423 C545.242478,100.949423 537.553983,92.4826975 537.553983,82.7133984 M410.053096,206.457853 C410.053096,186.919255 425.430089,171.939663 444.01062,171.939663 C463.231858,171.939663 477.968142,187.570541 477.968142,206.457853 C477.968142,225.99645 462.591151,240.976042 444.01062,240.976042 C425.430089,241.627329 410.053096,225.99645 410.053096,206.457853 M337.012389,115.277728 C337.012389,103.55457 346.62301,93.1339841 358.796459,93.1339841 C370.329204,93.1339841 379.939822,102.903283 379.939822,115.277728 C379.939822,127.652174 370.329204,137.421473 358.796459,137.421473 C346.62301,136.770186 337.012389,127.000887 337.012389,115.277728 M391.472567,25.4001774 C391.472567,17.5847382 397.879647,11.0718722 405.568142,11.0718722 C413.256637,11.0718722 419.663716,17.5847382 419.663716,25.4001774 C419.663716,33.2156166 413.256637,39.7284827 405.568142,39.7284827 C397.879647,39.7284827 391.472567,33.2156166 391.472567,25.4001774 M307.539822,34.5181898 C307.539822,14.9795918 322.916815,0 341.497346,0 C360.077875,0 375.454868,15.6308784 375.454868,34.5181898 C375.454868,54.0567879 360.077875,69.0363799 341.497346,69.0363799 C322.916815,69.6876664 307.539822,54.0567879 307.539822,34.5181898 M237.061947,39.7284827 C237.061947,29.3078971 245.391151,20.8411713 255.642478,20.8411713 C265.893805,20.8411713 274.22301,29.3078971 274.22301,39.7284827 C274.22301,50.1490684 265.893805,58.6157942 255.642478,58.6157942 C245.391151,58.6157942 237.061947,50.1490684 237.061947,39.7284827 M163.380531,73.595386 C163.380531,60.569654 174.272566,49.4977818 187.086726,49.4977818 C199.900885,49.4977818 210.792921,60.569654 210.792921,73.595386 C210.792921,86.621118 199.900885,97.6929902 187.086726,97.6929902 C173.631858,97.6929902 163.380531,86.621118 163.380531,73.595386 M140.955752,188.873114 C140.955752,177.801242 149.925664,168.68323 160.817699,168.68323 C171.709735,168.68323 180.679646,177.801242 180.679646,188.873114 C180.679646,199.944987 171.709735,209.062999 160.817699,209.062999 C149.925664,209.062999 140.955752,199.944987 140.955752,188.873114 M90.980531,126.349601 C90.980531,107.462289 106.357522,91.8314109 124.938053,91.8314109 C144.159292,91.8314109 158.895575,107.462289 158.895575,126.349601 C158.895575,145.888199 143.518584,160.867791 124.938053,160.867791 C106.357522,160.867791 90.980531,145.236912 90.980531,126.349601 M57.0230089,194.083407 C57.0230089,184.314108 64.7115043,176.498669 74.3221238,176.498669 C83.9327433,176.498669 91.6212389,184.314108 91.6212389,194.083407 C91.6212389,203.852706 83.9327433,211.668145 74.3221238,211.668145 C64.7115043,211.016859 57.0230089,203.20142 57.0230089,194.083407 M104.435398,248.140194 C104.435398,238.370896 112.123894,230.555457 121.734513,230.555457 C131.345133,230.555457 139.033628,238.370896 139.033628,248.140194 C139.033628,257.909493 131.345133,265.724934 121.734513,265.724934 C112.123894,265.724934 104.435398,257.909493 104.435398,248.140194 M105.076106,339.320319 C105.076106,324.992014 116.60885,313.268855 130.704425,313.268855 C144.8,313.268855 156.332743,324.992014 156.332743,339.320319 C156.332743,353.648624 144.8,365.371782 130.704425,365.371782 C116.60885,365.371782 105.076106,353.648624 105.076106,339.320319 M25.6283185,469.577639 C25.6283185,451.992901 39.7238938,437.664596 57.0230089,437.664596 C74.3221238,437.664596 88.417699,451.992901 88.417699,469.577639 C88.417699,487.162379 74.3221238,501.490684 57.0230089,501.490684 C39.7238938,501.490684 25.6283185,487.162379 25.6283185,469.577639 M0,358.20763 C0,335.412599 17.939823,317.176575 40.3646017,317.176575 C62.7893805,317.176575 80.7292036,335.412599 80.7292036,358.20763 C80.7292036,381.002663 62.7893805,399.238687 40.3646017,399.238687 C17.939823,399.238687 0,381.002663 0,358.20763 M28.1911505,262.468501 C28.1911505,250.094054 37.8017699,240.324755 49.9752212,240.324755 C62.1486726,240.324755 71.7592921,250.094054 71.7592921,262.468501 C71.7592921,274.842947 62.1486726,284.612245 49.9752212,284.612245 C37.8017699,284.612245 28.1911505,274.842947 28.1911505,262.468501 M174.913274,468.275066 C174.913274,455.249334 185.80531,444.177462 198.619469,444.177462 C211.433628,444.177462 222.325663,455.249334 222.325663,468.275066 C222.325663,481.300799 211.433628,492.372671 198.619469,492.372671 C185.80531,492.372671 174.913274,481.300799 174.913274,468.275066 M180.679646,382.305236 C180.679646,369.279504 191.571681,358.20763 204.385841,358.20763 C217.2,358.20763 228.092036,369.279504 228.092036,382.305236 C228.092036,395.330968 217.2,406.40284 204.385841,406.40284 C191.571681,406.40284 180.679646,395.330968 180.679646,382.305236 M67.2743363,554.896184 C67.2743363,537.311446 81.3699115,522.983141 98.6690265,522.983141 C115.968142,522.983141 130.063717,537.311446 130.063717,554.896184 C130.063717,572.480922 115.968142,586.809229 98.6690265,586.809229 C80.7292036,586.809229 67.2743363,572.480922 67.2743363,554.896184 M124.297345,630.44543 C124.297345,620.024845 132.626549,612.209406 142.237168,612.209406 C152.488496,612.209406 160.176991,620.676131 160.176991,630.44543 C160.176991,640.866016 151.847788,648.681455 142.237168,648.681455 C132.626549,648.681455 124.297345,640.866016 124.297345,630.44543 M317.791151,515.818989 C317.791151,507.352263 324.838938,500.188111 333.168142,500.188111 C341.497346,500.188111 348.545132,507.352263 348.545132,515.818989 C348.545132,524.285714 341.497346,531.449867 333.168142,531.449867 C324.198231,531.449867 317.791151,524.285714 317.791151,515.818989 M119.812389,425.941437 C119.812389,417.474712 126.860177,410.310559 135.189381,410.310559 C143.518584,410.310559 150.566372,417.474712 150.566372,425.941437 C150.566372,434.408163 143.518584,441.572315 135.189381,441.572315 C126.860177,441.572315 119.812389,434.408163 119.812389,425.941437 M658.647788,476.090507 C658.647788,467.623779 665.695575,460.459627 674.024779,460.459627 C682.353983,460.459627 689.401769,467.623779 689.401769,476.090507 C689.401769,484.557232 682.353983,491.721385 674.024779,491.721385 C665.695575,491.721385 658.647788,484.557232 658.647788,476.090507 M568.307964,631.096717 C568.307964,622.629991 575.355752,615.465839 583.684957,615.465839 C592.014159,615.465839 599.061947,622.629991 599.061947,631.096717 C599.061947,639.563443 592.014159,646.727595 583.684957,646.727595 C574.715043,646.076308 568.307964,639.563443 568.307964,631.096717 M404.286726,707.948536 C404.286726,695.574091 414.538053,685.153506 426.711505,685.153506 C438.884957,685.153506 449.136284,695.574091 449.136284,707.948536 C449.136284,720.322982 438.884957,730.743567 426.711505,730.743567 C413.897346,730.09228 404.286726,720.322982 404.286726,707.948536 M288.318584,704.040817 C288.318584,687.107366 301.773452,674.081632 317.791151,674.081632 C334.449558,674.081632 347.904425,687.758652 347.904425,704.040817 C347.904425,720.974268 334.449558,734 317.791151,734 C301.773452,734 288.318584,720.974268 288.318584,704.040817 M347.263716,646.076308 C347.263716,629.142857 360.718584,616.117125 376.736284,616.117125 C393.39469,616.117125 406.849558,629.794144 406.849558,646.076308 C406.849558,663.00976 393.39469,676.686778 376.736284,676.686778 C360.718584,676.686778 347.263716,663.00976 347.263716,646.076308 M269.738053,575.737355 C269.738053,558.803903 283.192921,545.778172 299.21062,545.778172 C315.869026,545.778172 329.323894,559.45519 329.323894,575.737355 C329.323894,592.019522 315.869026,606.347827 299.21062,606.347827 C283.192921,606.347827 269.738053,592.670808 269.738053,575.737355 M180.679646,563.36291 C180.679646,545.126885 195.415929,530.147294 213.355752,530.147294 C231.295575,530.147294 246.031858,545.126885 246.031858,563.36291 C246.031858,581.598936 231.295575,596.578528 213.355752,596.578528 C195.415929,595.927241 180.679646,581.598936 180.679646,563.36291 M320.99469,369.930791 C320.99469,358.20763 330.60531,348.438331 342.138053,348.438331 C353.670796,348.438331 363.281416,358.20763 363.281416,369.930791 C363.281416,381.653949 353.670796,391.423248 342.138053,391.423248 C330.60531,391.423248 320.99469,381.653949 320.99469,369.930791 M559.978762,371.233364 C559.978762,357.556343 570.870796,346.484471 584.325663,346.484471 C597.780531,346.484471 608.672567,357.556343 608.672567,371.233364 C608.672567,384.910382 597.780531,395.982254 584.325663,395.982254 C570.870796,395.982254 559.978762,384.910382 559.978762,371.233364 M530.506195,543.173025 C530.506195,529.496007 541.398231,518.424135 554.853096,518.424135 C568.307964,518.424135 579.2,529.496007 579.2,543.173025 C579.2,556.850044 568.307964,567.921916 554.853096,567.921916 C541.398231,568.573202 530.506195,556.850044 530.506195,543.173025 M617.642478,547.732031 C617.642478,526.890861 634.300885,509.957409 654.803541,509.957409 C675.306195,509.957409 691.964601,526.890861 691.964601,547.732031 C691.964601,568.573202 675.306195,585.506656 654.803541,585.506656 C634.300885,585.506656 617.642478,568.573202 617.642478,547.732031 M495.267257,670.173912 C495.267257,655.194321 507.440709,642.819876 522.17699,642.819876 C536.913274,642.819876 549.086726,655.194321 549.086726,670.173912 C549.086726,685.153506 536.913274,697.527951 522.17699,697.527951 C507.440709,697.527951 495.267257,685.153506 495.267257,670.173912 M465.79469,55.3593611 C465.79469,41.0310559 477.327433,29.9591837 490.782301,29.9591837 C504.877875,29.9591837 515.769911,41.6823425 515.769911,55.3593611 C515.769911,69.6876664 504.237168,80.7595387 490.782301,80.7595387 C477.327433,80.7595387 465.79469,69.6876664 465.79469,55.3593611 M232.57699,149.795918 C232.57699,130.25732 247.953983,114.626442 267.175221,114.626442 C286.396459,114.626442 301.773452,130.25732 301.773452,149.795918 C301.773452,169.334516 286.396459,184.965395 267.175221,184.965395 C247.953983,184.965395 232.57699,169.334516 232.57699,149.795918" id="Shape"></path>            </g>            <path d="M176,273.126316 C176,241.8 202.140541,217 233.643243,217 C265.816215,217 291.286487,242.452631 291.286487,273.126316 C291.286487,304.452631 265.145946,329.252631 233.643243,329.252631 C202.140541,329.252631 176,304.452631 176,273.126316 M476.951352,290.747369 C476.951352,271.821053 493.037837,256.157894 512.475676,256.157894 C531.913513,256.157894 548,271.821053 548,290.747369 C548,309.673684 531.913513,325.336843 512.475676,325.336843 C492.367567,325.336843 476.951352,310.326316 476.951352,290.747369 M379.762163,453.252631 C379.762163,412.789473 413.945946,379.505263 455.502702,379.505263 C497.059459,379.505263 531.243243,412.789473 531.243243,453.252631 C531.243243,493.71579 497.059459,527 455.502702,527 C413.945946,527 379.762163,494.36842 379.762163,453.252631" id="Shape" fill="#FF7314"></path>        </g>    </g></svg>);
+}
diff --git a/_sass/3scale/_syntax-highlighting.scss b/_sass/3scale/_syntax-highlighting.scss
new file mode 100644
index 0000000..764f670
--- /dev/null
+++ b/_sass/3scale/_syntax-highlighting.scss
@@ -0,0 +1,72 @@
+/**
+ * Syntax highlighting styles
+ */
+.highlight {
+ background: #fff;
+ @extend %vertical-rhythm;
+ width: 100%;
+
+ .highlighter-rouge & {
+ background: #eef;
+ }
+
+ .c { color: #998; font-style: italic } // Comment
+ .err { color: #a61717; background-color: #e3d2d2 } // Error
+ .k { font-weight: bold } // Keyword
+ .o { font-weight: bold } // Operator
+ .cm { color: #998; font-style: italic } // Comment.Multiline
+ .cp { color: #999; font-weight: bold } // Comment.Preproc
+ .c1 { color: #998; font-style: italic } // Comment.Single
+ .cs { color: #999; font-weight: bold; font-style: italic } // Comment.Special
+ .gd { color: #000; background-color: #fdd } // Generic.Deleted
+ .gd .x { color: #000; background-color: #faa } // Generic.Deleted.Specific
+ .ge { font-style: italic } // Generic.Emph
+ .gr { color: #a00 } // Generic.Error
+ .gh { color: #999 } // Generic.Heading
+ .gi { color: #000; background-color: #dfd } // Generic.Inserted
+ .gi .x { color: #000; background-color: #afa } // Generic.Inserted.Specific
+ .go { color: #888 } // Generic.Output
+ .gp { color: #555 } // Generic.Prompt
+ .gs { font-weight: bold } // Generic.Strong
+ .gu { color: #aaa } // Generic.Subheading
+ .gt { color: #a00 } // Generic.Traceback
+ .kc { font-weight: bold } // Keyword.Constant
+ .kd { font-weight: bold } // Keyword.Declaration
+ .kp { font-weight: bold } // Keyword.Pseudo
+ .kr { font-weight: bold } // Keyword.Reserved
+ .kt { color: #458; font-weight: bold } // Keyword.Type
+ .m { color: #099 } // Literal.Number
+ .s { color: #d14 } // Literal.String
+ .na { color: #008080 } // Name.Attribute
+ .nb { color: #0086B3 } // Name.Builtin
+ .nc { color: #458; font-weight: bold } // Name.Class
+ .no { color: #008080 } // Name.Constant
+ .ni { color: #800080 } // Name.Entity
+ .ne { color: #900; font-weight: bold } // Name.Exception
+ .nf { color: #900; font-weight: bold } // Name.Function
+ .nn { color: #555 } // Name.Namespace
+ .nt { color: #000080 } // Name.Tag
+ .nv { color: #008080 } // Name.Variable
+ .ow { font-weight: bold } // Operator.Word
+ .w { color: #bbb } // Text.Whitespace
+ .mf { color: #099 } // Literal.Number.Float
+ .mh { color: #099 } // Literal.Number.Hex
+ .mi { color: #099 } // Literal.Number.Integer
+ .mo { color: #099 } // Literal.Number.Oct
+ .sb { color: #d14 } // Literal.String.Backtick
+ .sc { color: #d14 } // Literal.String.Char
+ .sd { color: #d14 } // Literal.String.Doc
+ .s2 { color: #d14 } // Literal.String.Double
+ .se { color: #d14 } // Literal.String.Escape
+ .sh { color: #d14 } // Literal.String.Heredoc
+ .si { color: #d14 } // Literal.String.Interpol
+ .sx { color: #d14 } // Literal.String.Other
+ .sr { color: #009926 } // Literal.String.Regex
+ .s1 { color: #d14 } // Literal.String.Single
+ .ss { color: #990073 } // Literal.String.Symbol
+ .bp { color: #999 } // Name.Builtin.Pseudo
+ .vc { color: #008080 } // Name.Variable.Class
+ .vg { color: #008080 } // Name.Variable.Global
+ .vi { color: #008080 } // Name.Variable.Instance
+ .il { color: #099 } // Literal.Number.Integer.Long
+}
diff --git a/apple-touch-icon.png b/apple-touch-icon.png
new file mode 100644
index 0000000..0e42024
Binary files /dev/null and b/apple-touch-icon.png differ
diff --git a/assets/404.js b/assets/404.js
new file mode 100644
index 0000000..2fb02ea
--- /dev/null
+++ b/assets/404.js
@@ -0,0 +1,13 @@
+let nav_404 = document.getElementById('nav_404')
+
+let nav_contribute2contribute = new LeaderLine(
+ LeaderLine.pointAnchor(nav_404, {x: '-5%', y: '50%'}),
+ LeaderLine.pointAnchor(article_404, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ //dash: {animation: false},
+ path: 'straight'
+ }
+);
diff --git a/assets/anim-event.min.js b/assets/anim-event.min.js
new file mode 100644
index 0000000..8fd3c7b
--- /dev/null
+++ b/assets/anim-event.min.js
@@ -0,0 +1,2 @@
+/*! AnimEvent v1.0.16 (c) anseki https://github.com/anseki/anim-event */
+var AnimEvent=function(n){var e={};function t(r){if(e[r])return e[r].exports;var o=e[r]={i:r,l:!1,exports:{}};return n[r].call(o.exports,o,o.exports,t),o.l=!0,o.exports}return t.m=n,t.c=e,t.d=function(n,e,r){t.o(n,e)||Object.defineProperty(n,e,{enumerable:!0,get:r})},t.r=function(n){"undefined"!=typeof Symbol&&Symbol.toStringTag&&Object.defineProperty(n,Symbol.toStringTag,{value:"Module"}),Object.defineProperty(n,"__esModule",{value:!0})},t.t=function(n,e){if(1&e&&(n=t(n)),8&e)return n;if(4&e&&"object"==typeof n&&n&&n.__esModule)return n;var r=Object.create(null);if(t.r(r),Object.defineProperty(r,"default",{enumerable:!0,value:n}),2&e&&"string"!=typeof n)for(var o in n)t.d(r,o,function(e){return n[e]}.bind(null,o));return r},t.n=function(n){var e=n&&n.__esModule?function(){return n.default}:function(){return n};return t.d(e,"a",e),e},t.o=function(n,e){return Object.prototype.hasOwnProperty.call(n,e)},t.p="",t(t.s=0)}([function(n,e,t){"use strict";t.r(e);var r=500,o=[],i=window.requestAnimationFrame||window.mozRequestAnimationFrame||window.webkitRequestAnimationFrame||window.msRequestAnimationFrame||function(n){return setTimeout(n,1e3/60)},u=window.cancelAnimationFrame||window.mozCancelAnimationFrame||window.webkitCancelAnimationFrame||window.msCancelAnimationFrame||function(n){return clearTimeout(n)},a=Date.now(),l=void 0;function c(){var n=void 0,e=void 0;l&&(u.call(window,l),l=null),o.forEach(function(e){var t;(t=e.event)&&(e.event=null,e.listener(t),n=!0)}),n?(a=Date.now(),e=!0):Date.now()-a-1&&(o.splice(e,1),!o.length&&l&&(u.call(window,l),l=null))}};e.default=d}]).default;
\ No newline at end of file
diff --git a/assets/contribute.js b/assets/contribute.js
new file mode 100644
index 0000000..37a8c0e
--- /dev/null
+++ b/assets/contribute.js
@@ -0,0 +1,13 @@
+let nav_contribute = document.getElementById('nav_contribute')
+
+let nav_contribute2contribute = new LeaderLine(
+ LeaderLine.pointAnchor(nav_contribute, {x: '-5%', y: '50%'}),
+ LeaderLine.pointAnchor(contribute, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ //dash: {animation: false},
+ path: 'straight'
+ }
+);
diff --git a/assets/features.js b/assets/features.js
new file mode 100644
index 0000000..6dca590
--- /dev/null
+++ b/assets/features.js
@@ -0,0 +1,71 @@
+let nav_share = document.getElementById('nav_share')
+let nav_secure = document.getElementById('nav_secure')
+let nav_control = document.getElementById('nav_control')
+let nav_analyze = document.getElementById('nav_analyze')
+let nav_monetize = document.getElementById('nav_monetize')
+
+let nav_share2share = new LeaderLine(
+ LeaderLine.pointAnchor(nav_share, {x: '33.5%', y: '55%'}),
+ LeaderLine.pointAnchor(share, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight'
+ }
+);
+
+let nav_secure2secure = new LeaderLine(
+ LeaderLine.pointAnchor(nav_secure, {x: '42.5%', y: '58%'}),
+ LeaderLine.pointAnchor(secure, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight'
+ }
+);
+
+let nav_control2control = new LeaderLine(
+ LeaderLine.pointAnchor(nav_control, {x: '83%', y: '58%'}),
+ LeaderLine.pointAnchor(control, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight'
+ }
+);
+
+let nav_analyze2analyze = new LeaderLine(
+ LeaderLine.pointAnchor(nav_analyze, {x: '39%', y: '64%'}),
+ LeaderLine.pointAnchor(analyze, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight'
+ }
+);
+
+let nav_monetize2monetize = new LeaderLine(
+ LeaderLine.pointAnchor(nav_monetize, {x: '71.6%', y: '25%'}),
+ LeaderLine.pointAnchor(monetize, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight'
+ }
+);
+
+ // Update position delayed so it actually works as somehwo it wasn't on this page
+ window.addEventListener('resize', function(/* event */) {
+ setTimeout(function(){
+ nav_share2share.position();
+ nav_secure2secure.position();
+ nav_control2control.position();
+ nav_analyze2analyze.position();
+ nav_monetize2monetize.position();
+ }, 400);
+ });
diff --git a/assets/grasp.js b/assets/grasp.js
new file mode 100644
index 0000000..2a3da16
--- /dev/null
+++ b/assets/grasp.js
@@ -0,0 +1,350 @@
+let color_request = 'rgba(255, 115, 20, .8)'
+let color_response = 'rgba(0, 136, 206, .8)'
+let color_control = 'rgba(150, 150, 150, 0.5)'
+let color_admin_portal = 'rgba(192, 192, 192, 0.5)'
+let color_dev_portal = 'rgba(230, 230, 230, 0.5)'
+
+let caption_outline_color = '#dadada'
+
+let client = document.getElementById('client')
+let apicast = document.getElementById('apicast')
+let apisonator = document.getElementById('apisonator')
+let apicenter = document.getElementById('apicenter')
+let api = document.getElementById('api')
+
+let client2policy_chain = new LeaderLine(
+ LeaderLine.pointAnchor(client, {x: '77%', y: '100%'}),
+ LeaderLine.pointAnchor(policy_chain, {x: '95%', y: '25%'}),
+ {
+ color: color_request,
+ //startLabel: 'Request',
+ startLabel: LeaderLine.captionLabel('HTTP Request', {color: color_request, outlineColor: caption_outline_color, offset: [10, 0]}),
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy_chain2policy1 = new LeaderLine(
+ LeaderLine.pointAnchor(policy_chain, {x: '95%', y: '60%'}),
+ LeaderLine.pointAnchor(policy1, {x: '95%', y: '25%'}),
+ {
+ color: color_request,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+
+//client2policy1.setOptions({startSocket: 'bottom', endSocket: 'top'});
+
+
+
+let policy12policy2 = new LeaderLine(
+ LeaderLine.pointAnchor(policy1, {x: '95%', y: '60%'}),
+ LeaderLine.pointAnchor(policy2, {x: '95%', y: '25%'}),
+ {
+ color: color_request,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy22policy3 = new LeaderLine(
+ LeaderLine.pointAnchor(policy2, {x: '95%', y: '60%'}),
+ LeaderLine.pointAnchor(policy3, {x: '95%', y: '25%'}),
+ {
+ color: color_request,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy32policy4 = new LeaderLine(
+ LeaderLine.pointAnchor(policy3, {x: '95%', y: '60%'}),
+ LeaderLine.pointAnchor(policy4, {x: '95%', y: '25%'}),
+ {
+ color: color_request,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy42policy5 = new LeaderLine(
+ LeaderLine.pointAnchor(policy4, {x: '95%', y: '60%'}),
+ LeaderLine.pointAnchor(policy5, {x: '95%', y: '35%'}),
+ {
+ color: color_request,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+//policy12policy5.setOptions({startSocket: 'bottom', endSocket: 'top'});
+
+
+let policy52api = new LeaderLine(
+ LeaderLine.pointAnchor(policy5, {x: '95%', y: '75%'}),
+ LeaderLine.pointAnchor(api, {x: '100%', y: '50%'}),
+ {
+ color: color_request,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+//policy52api.setOptions({startSocket: 'bottom', endSocket: 'top'});
+
+
+let api2policy5 = new LeaderLine(
+ LeaderLine.pointAnchor(api, {x: '70%', y: 0}),
+ LeaderLine.pointAnchor(policy5, {x: '5%', y: '75%'}),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy52policy4 = new LeaderLine(
+ LeaderLine.pointAnchor(policy5, {x: '5%', y: '25%' }),
+ LeaderLine.pointAnchor(policy4, {x: '5%', y: '55%'}),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy42policy3 = new LeaderLine(
+ LeaderLine.pointAnchor(policy4, {x: '5%', y: '15%'}),
+ LeaderLine.pointAnchor(policy3, {x: '5%', y: '55%' }),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy32policy2 = new LeaderLine(
+ LeaderLine.pointAnchor(policy3, {x: '5%', y: '15%'}),
+ LeaderLine.pointAnchor(policy2, {x: '5%', y: '55%' }),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy22policy1 = new LeaderLine(
+ LeaderLine.pointAnchor(policy2, {x: '5%', y: '15%'}),
+ LeaderLine.pointAnchor(policy1, {x: '5%', y: '55%' }),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy12policy_chain = new LeaderLine(
+ LeaderLine.pointAnchor(policy1, {x: '5%', y: '15%'}),
+ LeaderLine.pointAnchor(policy_chain, {x: '5%', y: '55%' }),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let policy_chain2client = new LeaderLine(
+ LeaderLine.pointAnchor(policy_chain , {x: '5%', y: '15%'}),
+ LeaderLine.pointAnchor(client, {x: '10%', y: '100%'}),
+ {
+ color: color_response,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ // dash: {animation: false},
+ endLabel: 'Response',
+ endLabel: LeaderLine.captionLabel('HTTP Response', {color: color_response, outlineColor: caption_outline_color, offset: [10, 0]}),
+ path: 'straight',
+ }
+);
+
+//api2policy5.setOptions({startSocket: 'left', endSocket: 'left'});
+
+
+
+//policy52policy1.setOptions({startSocket: 'top', endSocket: 'bottom'});
+
+
+
+
+
+//policy12client.setOptions({startSocket: 'top', endSocket: 'bottom'});
+
+
+
+
+let policy32authrep = new LeaderLine(
+ LeaderLine.pointAnchor(policy3, {x: '95%', y: '20%'}),
+ LeaderLine.pointAnchor(authenticate, {x: '5%', y: '15%'}),
+ {
+ color: color_control,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ //endLabel: 'Control',
+ }
+);
+
+
+
+
+let authenticate2authorize = new LeaderLine(
+ LeaderLine.pointAnchor(authenticate, {x: '5%', y: '70%'}),
+ LeaderLine.pointAnchor(authorize, {x: '5%', y: '20%'}),
+ {
+ color: color_control,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let authorize2policy3 = new LeaderLine(
+ LeaderLine.pointAnchor(authorize, {x: '5%', y: '70%'}),
+ LeaderLine.pointAnchor(policy3, {x: '95%', y: '60%'}),
+ {
+ color: color_control,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let authorize2report = new LeaderLine(
+ LeaderLine.pointAnchor(authorize, {x: '5%', y: '70%'}),
+ LeaderLine.pointAnchor(report, {x: '5%', y: '20%'}),
+ {
+ color: color_control,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+
+
+// Apicenter
+
+let report2analytics = new LeaderLine(
+ LeaderLine.pointAnchor(report, {x: '80%', y: '50%'}),
+ LeaderLine.pointAnchor(analytics, {x: '80%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let report2portal = new LeaderLine(
+ LeaderLine.pointAnchor(report, {x: '90%', y: '50%'}),
+ LeaderLine.pointAnchor(portal, {x: '90%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let services2pisoni = new LeaderLine(
+ LeaderLine.pointAnchor(services, {x: '20%', y: '50%'}),
+ LeaderLine.pointAnchor(pisoni, {x: '20%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let plans2pisoni = new LeaderLine(
+ LeaderLine.pointAnchor(plans, {x: '15%', y: '50%'}),
+ LeaderLine.pointAnchor(pisoni, {x: '15%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let apps2pisoni = new LeaderLine(
+ LeaderLine.pointAnchor(apps, {x: '10%', y: '50%'}),
+ LeaderLine.pointAnchor(pisoni, {x: '10%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let pisoni2internal_api = new LeaderLine(
+ LeaderLine.pointAnchor(pisoni, {x: '25%', y: '50%'}),
+ LeaderLine.pointAnchor(internal_api, {x: '25%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
+
+let policy_chain2services = new LeaderLine(
+ LeaderLine.pointAnchor(policy_chain, {x: '100%', y: '50%'}),
+ LeaderLine.pointAnchor(services, {x: '100%', y: '50%'}),
+ {
+ color: color_admin_portal,
+ startPlug: 'arrow2',
+ endPlug: 'arrow2',
+ path: 'straight',
+ // dash: {animation: false},
+ }
+);
diff --git a/assets/leader-line.min.js b/assets/leader-line.min.js
new file mode 100755
index 0000000..d6e6183
--- /dev/null
+++ b/assets/leader-line.min.js
@@ -0,0 +1,2 @@
+/*! LeaderLine v1.0.5 (c) anseki https://anseki.github.io/leader-line/ */
+var LeaderLine=function(){"use strict";var te,g,y,S,_,o,t,h,f,p,a,i,l,v="leader-line",M=1,I=2,C=3,L=4,n={top:M,right:I,bottom:C,left:L},A=1,V=2,P=3,N=4,T=5,m={straight:A,arc:V,fluid:P,magnet:N,grid:T},ne="behind",r=v+"-defs",s=' ',ae={disc:{elmId:"leader-line-disc",noRotate:!0,bBox:{left:-5,top:-5,width:10,height:10,right:5,bottom:5},widthR:2.5,heightR:2.5,bCircle:5,sideLen:5,backLen:5,overhead:0,outlineBase:1,outlineMax:4},square:{elmId:"leader-line-square",noRotate:!0,bBox:{left:-5,top:-5,width:10,height:10,right:5,bottom:5},widthR:2.5,heightR:2.5,bCircle:5,sideLen:5,backLen:5,overhead:0,outlineBase:1,outlineMax:4},arrow1:{elmId:"leader-line-arrow1",bBox:{left:-8,top:-8,width:16,height:16,right:8,bottom:8},widthR:4,heightR:4,bCircle:8,sideLen:8,backLen:8,overhead:8,outlineBase:2,outlineMax:1.5},arrow2:{elmId:"leader-line-arrow2",bBox:{left:-7,top:-8,width:11,height:16,right:4,bottom:8},widthR:2.75,heightR:4,bCircle:8,sideLen:8,backLen:7,overhead:4,outlineBase:1,outlineMax:1.75},arrow3:{elmId:"leader-line-arrow3",bBox:{left:-4,top:-5,width:12,height:10,right:8,bottom:5},widthR:3,heightR:2.5,bCircle:8,sideLen:5,backLen:4,overhead:8,outlineBase:1,outlineMax:2.5},hand:{elmId:"leader-line-hand",bBox:{left:-3,top:-12,width:40,height:24,right:37,bottom:12},widthR:10,heightR:6,bCircle:37,sideLen:12,backLen:3,overhead:37},crosshair:{elmId:"leader-line-crosshair",noRotate:!0,bBox:{left:-96,top:-96,width:192,height:192,right:96,bottom:96},widthR:48,heightR:48,bCircle:96,sideLen:96,backLen:96,overhead:0}},E={behind:ne,disc:"disc",square:"square",arrow1:"arrow1",arrow2:"arrow2",arrow3:"arrow3",hand:"hand",crosshair:"crosshair"},ie={disc:"disc",square:"square",arrow1:"arrow1",arrow2:"arrow2",arrow3:"arrow3",hand:"hand",crosshair:"crosshair"},W=[M,I,C,L],x="auto",oe={x:"left",y:"top",width:"width",height:"height"},B=80,R=4,F=5,G=120,D=8,z=3.75,j=10,H=30,U=.5522847,Z=.25*Math.PI,u=/^\s*(\-?[\d\.]+)\s*(\%)?\s*$/,b="http://www.w3.org/2000/svg",e="-ms-scroll-limit"in document.documentElement.style&&"-ms-ime-align"in document.documentElement.style&&!window.navigator.msPointerEnabled,le=!e&&!!document.uniqueID,re="MozAppearance"in document.documentElement.style,se=!(e||re||!window.chrome||!window.CSS),ue=!e&&!le&&!re&&!se&&!window.chrome&&"WebkitAppearance"in document.documentElement.style,he=le||e?.2:.1,pe={path:P,lineColor:"coral",lineSize:4,plugSE:[ne,"arrow1"],plugSizeSE:[1,1],lineOutlineEnabled:!1,lineOutlineColor:"indianred",lineOutlineSize:.25,plugOutlineEnabledSE:[!1,!1],plugOutlineSizeSE:[1,1]},k=(a={}.toString,i={}.hasOwnProperty.toString,l=i.call(Object),function(e){var t,n;return e&&"[object Object]"===a.call(e)&&(!(t=Object.getPrototypeOf(e))||(n=t.hasOwnProperty("constructor")&&t.constructor)&&"function"==typeof n&&i.call(n)===l)}),w=Number.isFinite||function(e){return"number"==typeof e&&window.isFinite(e)},c=function(){var e,x={ease:[.25,.1,.25,1],linear:[0,0,1,1],"ease-in":[.42,0,1,1],"ease-out":[0,0,.58,1],"ease-in-out":[.42,0,.58,1]},b=1e3/60/2,t=window.requestAnimationFrame||window.mozRequestAnimationFrame||window.webkitRequestAnimationFrame||window.msRequestAnimationFrame||function(e){setTimeout(e,b)},n=window.cancelAnimationFrame||window.mozCancelAnimationFrame||window.webkitCancelAnimationFrame||window.msCancelAnimationFrame||function(e){clearTimeout(e)},a=Number.isFinite||function(e){return"number"==typeof e&&window.isFinite(e)},k=[],w=0;function l(){var i=Date.now(),o=!1;e&&(n.call(window,e),e=null),k.forEach(function(e){var t,n,a;if(e.framesStart){if((t=i-e.framesStart)>=e.duration&&e.count&&e.loopsLeft<=1)return a=e.frames[e.lastFrame=e.reverse?0:e.frames.length-1],e.frameCallback(a.value,!0,a.timeRatio,a.outputRatio),void(e.framesStart=null);if(t>e.duration){if(n=Math.floor(t/e.duration),e.count){if(n>=e.loopsLeft)return a=e.frames[e.lastFrame=e.reverse?0:e.frames.length-1],e.frameCallback(a.value,!0,a.timeRatio,a.outputRatio),void(e.framesStart=null);e.loopsLeft-=n}e.framesStart+=e.duration*n,t=i-e.framesStart}e.reverse&&(t=e.duration-t),a=e.frames[e.lastFrame=Math.round(t/b)],!1!==e.frameCallback(a.value,!1,a.timeRatio,a.outputRatio)?o=!0:e.framesStart=null}}),o&&(e=t.call(window,l))}function O(e,t){e.framesStart=Date.now(),null!=t&&(e.framesStart-=e.duration*(e.reverse?1-t:t)),e.loopsLeft=e.count,e.lastFrame=null,l()}return{add:function(n,e,t,a,i,o,l){var r,s,u,h,p,c,d,f,y,S,m,g,_,v=++w;function E(e,t){return{value:n(t),timeRatio:e,outputRatio:t}}if("string"==typeof i&&(i=x[i]),n=n||function(){},t=this._endIndex||this._string[this._currentIndex]<"0"||"9"=this._endIndex||this._string[this._currentIndex]<"0"||"9"=this._endIndex)return null;var e=null,t=this._string[this._currentIndex];if(this._currentIndex+=1,"0"===t)e=0;else{if("1"!==t)return null;e=1}return this._skipOptionalSpacesOrDelimiter(),e}};var a=function(e){if(!e||0===e.length)return[];var t=new o(e),n=[];if(t.initialCommandIsMoveTo())for(;t.hasMoreData();){var a=t.parseSegment();if(null===a)break;n.push(a)}return n},n=e.SVGPathElement.prototype.setAttribute,r=e.SVGPathElement.prototype.removeAttribute,d=e.Symbol?e.Symbol():"__cachedPathData",f=e.Symbol?e.Symbol():"__cachedNormalizedPathData",U=function(e,t,n,a,i,o,l,r,s,u){var h,p,c,d,f,y=function(e,t,n){return{x:e*Math.cos(n)-t*Math.sin(n),y:e*Math.sin(n)+t*Math.cos(n)}},S=(h=l,Math.PI*h/180),m=[];if(u)p=u[0],c=u[1],d=u[2],f=u[3];else{var g=y(e,t,-S);e=g.x,t=g.y;var _=y(n,a,-S),v=(e-(n=_.x))/2,E=(t-(a=_.y))/2,x=v*v/(i*i)+E*E/(o*o);1120*Math.PI/180){var C=c,L=n,A=a;c=s&&p=Math.abs(n)?0<=t?I:L:0<=n?C:M))})),E.position_path!==x.position_path||E.position_lineStrokeWidth!==x.position_lineStrokeWidth||[0,1].some(function(e){return E.position_plugOverheadSE[e]!==x.position_plugOverheadSE[e]||(i=b[e],o=x.position_socketXYSE[e],i.x!==o.x||i.y!==o.y||i.socketId!==o.socketId)||(t=_[e],n=x.position_socketGravitySE[e],(a=null==t?"auto":Array.isArray(t)?"array":"number")!==(null==n?"auto":Array.isArray(n)?"array":"number")||("array"===a?t[0]!==n[0]||t[1]!==n[1]:t!==n));var t,n,a,i,o})){switch(u.pathList.baseVal=v=[],u.pathList.animVal=null,E.position_path){case A:v.push([O(b[0]),O(b[1])]);break;case V:t="number"==typeof _[0]&&0<_[0]||"number"==typeof _[1]&&0<_[1],o=Z*(t?-1:1),l=Math.atan2(b[1].y-b[0].y,b[1].x-b[0].x),r=-l+o,c=Math.PI-l-o,d=_e(b[0],b[1])/Math.sqrt(2)*U,S={x:b[0].x+Math.cos(r)*d,y:b[0].y+Math.sin(r)*d*-1},m={x:b[1].x+Math.cos(c)*d,y:b[1].y+Math.sin(c)*d*-1},v.push([O(b[0]),S,m,O(b[1])]);break;case P:case N:s=[_[0],E.position_path===N?0:_[1]],h=[],p=[],b.forEach(function(e,t){var n,a,i,o,l,r=s[t];Array.isArray(r)?n={x:r[0],y:r[1]}:"number"==typeof r?n=e.socketId===M?{x:0,y:-r}:e.socketId===I?{x:r,y:0}:e.socketId===C?{x:0,y:r}:{x:-r,y:0}:(a=b[t?0:1],o=0<(i=E.position_plugOverheadSE[t])?G+(DR?(E.position_lineStrokeWidth-R)*F:0),e.socketId===M?((l=(e.y-a.y)/2)=t.x:t.dirId===r?e.y>=t.y:e.x<=t.x}function y(e,t){return t.dirId===o||t.dirId===r?e.x===t.x:e.y===t.y}function S(e){return e[0]?{contain:0,notContain:1}:{contain:1,notContain:0}}function m(e,t,n){return Math.abs(t[n]-e[n])}function g(e,t,n){return"x"===n?e.x=H?g(h[t.notContain],h[t.contain],o[t.contain]):h[t.contain].dirId)):(i=[{x:h[0].x,y:h[0].y},{x:h[1].x,y:h[1].y}],u.forEach(function(e,t){var n=0===t?1:0,a=m(i[t],i[n],o[t]);aj&&(y[a]-ej&&(y[a]-ea.outlineMax&&(t=a.outlineMax),t*=2*a.outlineBase,v=We(m,_.plugOutline_strokeWidthSE,e,t)||v,v=We(m,_.plugOutline_inStrokeWidthSE,e,_.plugOutline_colorTraSE[e]?t-he/(_.line_strokeWidth/pe.lineSize)/g.plugSizeSE[e]*2:t/2)||v)}),v)),(t.faces||ee.line||ee.plug||ee.lineOutline||ee.plugOutline)&&(ee.faces=(b=(E=e).curStats,k=E.aplStats,w=E.events,O=!1,!b.line_altColor&&We(E,k,"line_color",x=b.line_color,w.apl_line_color)&&(E.lineFace.style.stroke=x,O=!0),We(E,k,"line_strokeWidth",x=b.line_strokeWidth,w.apl_line_strokeWidth)&&(E.lineShape.style.strokeWidth=x+"px",O=!0,(re||le)&&(Ae(E,E.lineShape),le&&(Ae(E,E.lineFace),Ae(E,E.lineMaskCaps)))),We(E,k,"lineOutline_enabled",x=b.lineOutline_enabled,w.apl_lineOutline_enabled)&&(E.lineOutlineFace.style.display=x?"inline":"none",O=!0),b.lineOutline_enabled&&(We(E,k,"lineOutline_color",x=b.lineOutline_color,w.apl_lineOutline_color)&&(E.lineOutlineFace.style.stroke=x,O=!0),We(E,k,"lineOutline_strokeWidth",x=b.lineOutline_strokeWidth,w.apl_lineOutline_strokeWidth)&&(E.lineOutlineMaskShape.style.strokeWidth=x+"px",O=!0,le&&(Ae(E,E.lineOutlineMaskCaps),Ae(E,E.lineOutlineFace))),We(E,k,"lineOutline_inStrokeWidth",x=b.lineOutline_inStrokeWidth,w.apl_lineOutline_inStrokeWidth)&&(E.lineMaskShape.style.strokeWidth=x+"px",O=!0,le&&(Ae(E,E.lineOutlineMaskCaps),Ae(E,E.lineOutlineFace)))),We(E,k,"plug_enabled",x=b.plug_enabled,w.apl_plug_enabled)&&(E.plugsFace.style.display=x?"inline":"none",O=!0),b.plug_enabled&&[0,1].forEach(function(n){var e=b.plug_plugSE[n],t=e!==ne?ae[ie[e]]:null,a=Ne(n,t);We(E,k.plug_enabledSE,n,x=b.plug_enabledSE[n],w.apl_plug_enabledSE)&&(E.plugsFace.style[a.prop]=x?"url(#"+E.plugMarkerIdSE[n]+")":"none",O=!0),b.plug_enabledSE[n]&&(We(E,k.plug_plugSE,n,e,w.apl_plug_plugSE)&&(E.plugFaceSE[n].href.baseVal="#"+t.elmId,Pe(E,E.plugMarkerSE[n],a.orient,t.bBox,E.svg,E.plugMarkerShapeSE[n],E.plugsFace),O=!0,re&&Ae(E,E.plugsFace)),We(E,k.plug_colorSE,n,x=b.plug_colorSE[n],w.apl_plug_colorSE)&&(E.plugFaceSE[n].style.fill=x,O=!0,(se||ue||le)&&!b.line_colorTra&&Ae(E,le?E.lineMaskCaps:E.capsMaskLine)),["markerWidth","markerHeight"].forEach(function(e){var t="plug_"+e+"SE";We(E,k[t],n,x=b[t][n],w["apl_"+t])&&(E.plugMarkerSE[n][e].baseVal.value=x,O=!0)}),We(E,k.plugOutline_enabledSE,n,x=b.plugOutline_enabledSE[n],w.apl_plugOutline_enabledSE)&&(x?(E.plugFaceSE[n].style.mask="url(#"+E.plugMaskIdSE[n]+")",E.plugOutlineFaceSE[n].style.display="inline"):(E.plugFaceSE[n].style.mask="none",E.plugOutlineFaceSE[n].style.display="none"),O=!0),b.plugOutline_enabledSE[n]&&(We(E,k.plugOutline_plugSE,n,e,w.apl_plugOutline_plugSE)&&(E.plugOutlineFaceSE[n].href.baseVal=E.plugMaskShapeSE[n].href.baseVal=E.plugOutlineMaskShapeSE[n].href.baseVal="#"+t.elmId,[E.plugMaskSE[n],E.plugOutlineMaskSE[n]].forEach(function(e){e.x.baseVal.value=t.bBox.left,e.y.baseVal.value=t.bBox.top,e.width.baseVal.value=t.bBox.width,e.height.baseVal.value=t.bBox.height}),O=!0),We(E,k.plugOutline_colorSE,n,x=b.plugOutline_colorSE[n],w.apl_plugOutline_colorSE)&&(E.plugOutlineFaceSE[n].style.fill=x,O=!0,le&&(Ae(E,E.lineMaskCaps),Ae(E,E.lineOutlineMaskCaps))),We(E,k.plugOutline_strokeWidthSE,n,x=b.plugOutline_strokeWidthSE[n],w.apl_plugOutline_strokeWidthSE)&&(E.plugOutlineMaskShapeSE[n].style.strokeWidth=x+"px",O=!0),We(E,k.plugOutline_inStrokeWidthSE,n,x=b.plugOutline_inStrokeWidthSE[n],w.apl_plugOutline_inStrokeWidthSE)&&(E.plugMaskShapeSE[n].style.strokeWidth=x+"px",O=!0)))}),O)),(t.position||ee.line||ee.plug)&&(ee.position=Fe(e)),(t.path||ee.position)&&(ee.path=(C=(M=e).curStats,L=M.aplStats,A=M.pathList.animVal||M.pathList.baseVal,V=C.path_edge,P=!1,A&&(V.x1=V.x2=A[0][0].x,V.y1=V.y2=A[0][0].y,C.path_pathData=I=we(A,function(e){e.xV.x2&&(V.x2=e.x),e.y>V.y2&&(V.y2=e.y)}),Me(I,L.path_pathData)&&(M.linePath.setPathData(I),L.path_pathData=I,P=!0,le?(Ae(M,M.plugsFace),Ae(M,M.lineMaskCaps)):re&&Ae(M,M.linePath),M.events.apl_path&&M.events.apl_path.forEach(function(e){e(M,I)}))),P)),ee.viewBox=(B=(N=e).curStats,R=N.aplStats,F=B.path_edge,G=B.viewBox_bBox,D=R.viewBox_bBox,z=N.svg.viewBox.baseVal,j=N.svg.style,H=!1,T=Math.max(B.line_strokeWidth/2,B.viewBox_plugBCircleSE[0]||0,B.viewBox_plugBCircleSE[1]||0),W={x1:F.x1-T,y1:F.y1-T,x2:F.x2+T,y2:F.y2+T},N.events.new_edge4viewBox&&N.events.new_edge4viewBox.forEach(function(e){e(N,W)}),G.x=B.lineMask_x=B.lineOutlineMask_x=B.maskBGRect_x=W.x1,G.y=B.lineMask_y=B.lineOutlineMask_y=B.maskBGRect_y=W.y1,G.width=W.x2-W.x1,G.height=W.y2-W.y1,["x","y","width","height"].forEach(function(e){var t;(t=G[e])!==D[e]&&(z[e]=D[e]=t,j[oe[e]]=t+("x"===e||"y"===e?N.bodyOffset[e]:0)+"px",H=!0)}),H),ee.mask=(Y=(U=e).curStats,X=U.aplStats,q=!1,Y.plug_enabled?[0,1].forEach(function(e){Y.capsMaskMarker_enabledSE[e]=Y.plug_enabledSE[e]&&Y.plug_colorTraSE[e]||Y.plugOutline_enabledSE[e]&&Y.plugOutline_colorTraSE[e]}):Y.capsMaskMarker_enabledSE[0]=Y.capsMaskMarker_enabledSE[1]=!1,Y.capsMaskMarker_enabled=Y.capsMaskMarker_enabledSE[0]||Y.capsMaskMarker_enabledSE[1],Y.lineMask_outlineMode=Y.lineOutline_enabled,Y.caps_enabled=Y.capsMaskMarker_enabled||Y.capsMaskAnchor_enabledSE[0]||Y.capsMaskAnchor_enabledSE[1],Y.lineMask_enabled=Y.caps_enabled||Y.lineMask_outlineMode,(Y.lineMask_enabled&&!Y.lineMask_outlineMode||Y.lineOutline_enabled)&&["x","y"].forEach(function(e){var t="maskBGRect_"+e;We(U,X,t,Z=Y[t])&&(U.maskBGRect[e].baseVal.value=Z,q=!0)}),We(U,X,"lineMask_enabled",Z=Y.lineMask_enabled)&&(U.lineFace.style.mask=Z?"url(#"+U.lineMaskId+")":"none",q=!0,ue&&Ae(U,U.lineMask)),Y.lineMask_enabled&&(We(U,X,"lineMask_outlineMode",Z=Y.lineMask_outlineMode)&&(Z?(U.lineMaskBG.style.display="none",U.lineMaskShape.style.display="inline"):(U.lineMaskBG.style.display="inline",U.lineMaskShape.style.display="none"),q=!0),["x","y"].forEach(function(e){var t="lineMask_"+e;We(U,X,t,Z=Y[t])&&(U.lineMask[e].baseVal.value=Z,q=!0)}),We(U,X,"caps_enabled",Z=Y.caps_enabled)&&(U.lineMaskCaps.style.display=U.lineOutlineMaskCaps.style.display=Z?"inline":"none",q=!0,ue&&Ae(U,U.capsMaskLine)),Y.caps_enabled&&([0,1].forEach(function(e){var t;We(U,X.capsMaskAnchor_enabledSE,e,Z=Y.capsMaskAnchor_enabledSE[e])&&(U.capsMaskAnchorSE[e].style.display=Z?"inline":"none",q=!0,ue&&Ae(U,U.lineMask)),Y.capsMaskAnchor_enabledSE[e]&&(Me(t=Y.capsMaskAnchor_pathDataSE[e],X.capsMaskAnchor_pathDataSE[e])&&(U.capsMaskAnchorSE[e].setPathData(t),X.capsMaskAnchor_pathDataSE[e]=t,q=!0),We(U,X.capsMaskAnchor_strokeWidthSE,e,Z=Y.capsMaskAnchor_strokeWidthSE[e])&&(U.capsMaskAnchorSE[e].style.strokeWidth=Z+"px",q=!0))}),We(U,X,"capsMaskMarker_enabled",Z=Y.capsMaskMarker_enabled)&&(U.capsMaskLine.style.display=Z?"inline":"none",q=!0),Y.capsMaskMarker_enabled&&[0,1].forEach(function(n){var e=Y.capsMaskMarker_plugSE[n],t=e!==ne?ae[ie[e]]:null,a=Ne(n,t);We(U,X.capsMaskMarker_enabledSE,n,Z=Y.capsMaskMarker_enabledSE[n])&&(U.capsMaskLine.style[a.prop]=Z?"url(#"+U.lineMaskMarkerIdSE[n]+")":"none",q=!0),Y.capsMaskMarker_enabledSE[n]&&(We(U,X.capsMaskMarker_plugSE,n,e)&&(U.capsMaskMarkerShapeSE[n].href.baseVal="#"+t.elmId,Pe(U,U.capsMaskMarkerSE[n],a.orient,t.bBox,U.svg,U.capsMaskMarkerShapeSE[n],U.capsMaskLine),q=!0,re&&(Ae(U,U.capsMaskLine),Ae(U,U.lineFace))),["markerWidth","markerHeight"].forEach(function(e){var t="capsMaskMarker_"+e+"SE";We(U,X[t],n,Z=Y[t][n])&&(U.capsMaskMarkerSE[n][e].baseVal.value=Z,q=!0)}))}))),Y.lineOutline_enabled&&["x","y"].forEach(function(e){var t="lineOutlineMask_"+e;We(U,X,t,Z=Y[t])&&(U.lineOutlineMask[e].baseVal.value=Z,q=!0)}),q),t.effect&&(J=(Q=e).curStats,$=Q.aplStats,Object.keys(te).forEach(function(e){var t=te[e],n=e+"_enabled",a=e+"_options",i=J[a];We(Q,$,n,K=J[n])?(K&&($[a]=de(i)),t[K?"init":"remove"](Q)):K&&ce(i,$[a])&&(t.remove(Q),$[n]=!0,$[a]=de(i),t.init(Q))})),(se||ue)&&ee.line&&!ee.path&&Ae(e,e.lineShape),se&&ee.plug&&!ee.line&&Ae(e,e.plugsFace),Ve(e)}function ze(e,t){return{duration:w(e.duration)&&0i.x2&&(i.x2=t.x2),t.y2>i.y2&&(i.y2=t.y2),["x","y"].forEach(function(e){var t,n="dropShadow_"+e;o[n]=t=i[e+"1"],We(a,l,n,t)&&(a.efc_dropShadow_elmFilter[e].baseVal.value=t)}))}}},Object.keys(te).forEach(function(e){var t=te[e],n=t.stats;n[e+"_enabled"]={iniValue:!1},n[e+"_options"]={hasProps:!0},t.anim&&(n[e+"_animOptions"]={},n[e+"_animId"]={})}),g={none:{defaultAnimOptions:{},init:function(e,t){var n=e.curStats;n.show_animId&&(c.remove(n.show_animId),n.show_animId=null),g.none.start(e,t)},start:function(e,t){g.none.stop(e,!0)},stop:function(e,t,n){var a=e.curStats;return n=null!=n?n:e.aplStats.show_on,a.show_inAnim=!1,t&&Ge(e,n),n?1:0}},fade:{defaultAnimOptions:{duration:300,timing:"linear"},init:function(n,e){var t=n.curStats,a=n.aplStats;t.show_animId&&c.remove(t.show_animId),t.show_animId=c.add(function(e){return e},function(e,t){t?g.fade.stop(n,!0):(n.svg.style.opacity=e+"",le&&(Ae(n,n.svg),Ve(n)))},a.show_animOptions.duration,1,a.show_animOptions.timing,null,!1),g.fade.start(n,e)},start:function(e,t){var n,a=e.curStats;a.show_inAnim&&(n=c.stop(a.show_animId)),Ge(e,1),a.show_inAnim=!0,c.start(a.show_animId,!e.aplStats.show_on,null!=t?t:n)},stop:function(e,t,n){var a,i=e.curStats;return n=null!=n?n:e.aplStats.show_on,a=i.show_inAnim?c.stop(i.show_animId):n?1:0,i.show_inAnim=!1,t&&(e.svg.style.opacity=n?"":"0",Ge(e,n)),a}},draw:{defaultAnimOptions:{duration:500,timing:[.58,0,.42,1]},init:function(n,e){var t=n.curStats,a=n.aplStats,l=n.pathList.baseVal,i=Oe(l),r=i.segsLen,s=i.lenAll;t.show_animId&&c.remove(t.show_animId),t.show_animId=c.add(function(e){var t,n,a,i,o=-1;if(0===e)n=[[l[0][0],l[0][0]]];else if(1===e)n=l;else{for(t=s*e,n=[];t>=r[++o];)n.push(l[o]),t-=r[o];t&&(2===(a=l[o]).length?n.push([a[0],ve(a[0],a[1],t/r[o])]):(i=xe(a[0],a[1],a[2],a[3],ke(a[0],a[1],a[2],a[3],t)),n.push([a[0],i.fromP1,i.fromP2,i])))}return n},function(e,t){t?g.draw.stop(n,!0):(n.pathList.animVal=e,De(n,{path:!0}))},a.show_animOptions.duration,1,a.show_animOptions.timing,null,!1),g.draw.start(n,e)},start:function(e,t){var n,a=e.curStats;a.show_inAnim&&(n=c.stop(a.show_animId)),Ge(e,1),a.show_inAnim=!0,Ie(e,"apl_position",g.draw.update),c.start(a.show_animId,!e.aplStats.show_on,null!=t?t:n)},stop:function(e,t,n){var a,i=e.curStats;return n=null!=n?n:e.aplStats.show_on,a=i.show_inAnim?c.stop(i.show_animId):n?1:0,i.show_inAnim=!1,t&&(e.pathList.animVal=n?null:[[e.pathList.baseVal[0][0],e.pathList.baseVal[0][0]]],De(e,{path:!0}),Ge(e,n)),a},update:function(e){Ce(e,"apl_position",g.draw.update),e.curStats.show_inAnim?g.draw.init(e,g.draw.stop(e)):e.aplStats.show_animOptions={}}}},function(){function r(n){return function(e){var t={};t[n]=e,this.setOptions(t)}}[["start","anchorSE",0],["end","anchorSE",1],["color","lineColor"],["size","lineSize"],["startSocketGravity","socketGravitySE",0],["endSocketGravity","socketGravitySE",1],["startPlugColor","plugColorSE",0],["endPlugColor","plugColorSE",1],["startPlugSize","plugSizeSE",0],["endPlugSize","plugSizeSE",1],["outline","lineOutlineEnabled"],["outlineColor","lineOutlineColor"],["outlineSize","lineOutlineSize"],["startPlugOutline","plugOutlineEnabledSE",0],["endPlugOutline","plugOutlineEnabledSE",1],["startPlugOutlineColor","plugOutlineColorSE",0],["endPlugOutlineColor","plugOutlineColorSE",1],["startPlugOutlineSize","plugOutlineSizeSE",0],["endPlugOutlineSize","plugOutlineSizeSE",1]].forEach(function(e){var t=e[0],n=e[1],a=e[2];Object.defineProperty(Ye.prototype,t,{get:function(){var e=null!=a?K[this._id].options[n][a]:n?K[this._id].options[n]:K[this._id].options[t];return null==e?x:de(e)},set:r(t),enumerable:!0})}),[["path",m],["startSocket",n,"socketSE",0],["endSocket",n,"socketSE",1],["startPlug",E,"plugSE",0],["endPlug",E,"plugSE",1]].forEach(function(e){var a=e[0],i=e[1],o=e[2],l=e[3];Object.defineProperty(Ye.prototype,a,{get:function(){var t,n=null!=l?K[this._id].options[o][l]:o?K[this._id].options[o]:K[this._id].options[a];return n?Object.keys(i).some(function(e){return i[e]===n&&(t=e,!0)})?t:new Error("It's broken"):x},set:r(a),enumerable:!0})}),Object.keys(te).forEach(function(n){var a=te[n];Object.defineProperty(Ye.prototype,n,{get:function(){var u,e,t=K[this._id].options[n];return k(t)?(u=t,e=a.optionsConf.reduce(function(e,t){var n,a=t[0],i=t[1],o=t[2],l=t[3],r=t[4],s=null!=r?u[l][r]:l?u[l]:u[i];return e[i]="id"===a?s?Object.keys(o).some(function(e){return o[e]===s&&(n=e,!0)})?n:new Error("It's broken"):x:null==s?x:de(s),e},{}),a.anim&&(e.animation=de(u.animation)),e):t},set:r(n),enumerable:!0})}),["startLabel","endLabel","middleLabel"].forEach(function(e,n){Object.defineProperty(Ye.prototype,e,{get:function(){var e=K[this._id],t=e.options;return t.labelSEM[n]&&!e.optionIsAttach.labelSEM[n]?$[t.labelSEM[n]._id].text:t.labelSEM[n]||""},set:r(e),enumerable:!0})})}(),Ye.prototype.setOptions=function(e){return Ze(K[this._id],e),this},Ye.prototype.position=function(){return De(K[this._id],{position:!0}),this},Ye.prototype.remove=function(){var t=K[this._id],n=t.curStats;Object.keys(te).forEach(function(e){var t=e+"_animId";n[t]&&c.remove(n[t])}),n.show_animId&&c.remove(n.show_animId),t.attachments.slice().forEach(function(e){Ue(t,e)}),t.baseWindow&&t.svg&&t.baseWindow.document.body.removeChild(t.svg),delete K[this._id]},Ye.prototype.show=function(e,t){return je(K[this._id],!0,e,t),this},Ye.prototype.hide=function(e,t){return je(K[this._id],!1,e,t),this},o=function(t){t&&$[t._id]&&(t.boundTargets.slice().forEach(function(e){Ue(e.props,t,!0)}),t.conf.remove&&t.conf.remove(t),delete $[t._id])},S=function(){function e(e,t){var n,a={conf:e,curStats:{},aplStats:{},boundTargets:[]},i={};e.argOptions.every(function(e){return!(!t.length||("string"==typeof e.type?typeof t[0]!==e.type:"function"!=typeof e.type||!e.type(t[0])))&&(i[e.optionName]=t.shift(),!0)}),n=t.length&&k(t[0])?de(t[0]):{},Object.keys(i).forEach(function(e){n[e]=i[e]}),e.stats&&(Te(a.curStats,e.stats),Te(a.aplStats,e.stats)),Object.defineProperty(this,"_id",{value:++ee}),Object.defineProperty(this,"isRemoved",{get:function(){return!$[this._id]}}),a._id=this._id,e.init&&!e.init(a,n)||($[this._id]=a)}return e.prototype.remove=function(){var t=this,n=$[t._id];n&&(n.boundTargets.slice().forEach(function(e){n.conf.removeOption(n,e)}),Le(function(){var e=$[t._id];e&&(console.error("LeaderLineAttachment was not removed by removeOption"),o(e))}))},e}(),window.LeaderLineAttachment=S,_=function(e,t){return e instanceof S&&(!(e.isRemoved||t&&$[e._id].conf.type!==t)||null)},y={pointAnchor:{type:"anchor",argOptions:[{optionName:"element",type:ye}],init:function(e,t){return e.element=y.pointAnchor.checkElement(t.element),e.x=y.pointAnchor.parsePercent(t.x,!0)||[.5,!0],e.y=y.pointAnchor.parsePercent(t.y,!0)||[.5,!0],!0},removeOption:function(e,t){var n=t.props,a={},i=e.element,o=n.options.anchorSE["start"===t.optionName?1:0];i===o&&(i=o===document.body?new S(y.pointAnchor,[i]):document.body),a[t.optionName]=i,Ze(n,a)},getBBoxNest:function(e,t){var n=ge(e.element,t.baseWindow),a=n.width,i=n.height;return n.width=n.height=0,n.left=n.right=n.left+e.x[0]*(e.x[1]?a:1),n.top=n.bottom=n.top+e.y[0]*(e.y[1]?i:1),n},parsePercent:function(e,t){var n,a,i=!1;return w(e)?a=e:"string"==typeof e&&(n=u.exec(e))&&n[2]&&(i=0!==(a=parseFloat(n[1])/100)),null!=a&&(t||0<=a)?[a,i]:null},checkElement:function(e){if(null==e)e=document.body;else if(!ye(e))throw new Error("`element` must be Element");return e}},areaAnchor:{type:"anchor",argOptions:[{optionName:"element",type:ye},{optionName:"shape",type:"string"}],stats:{color:{},strokeWidth:{},elementWidth:{},elementHeight:{},elementLeft:{},elementTop:{},pathListRel:{},bBoxRel:{},pathData:{},viewBoxBBox:{hasProps:!0},dashLen:{},dashGap:{}},init:function(i,e){var t,n,a,o=[];return i.element=y.pointAnchor.checkElement(e.element),"string"==typeof e.color&&(i.color=e.color.trim()),"string"==typeof e.fillColor&&(i.fill=e.fillColor.trim()),w(e.size)&&0<=e.size&&(i.size=e.size),e.dash&&(i.dash=!0,w(e.dash.len)&&0i.right&&(i.right=t),ni.bottom&&(i.bottom=n)):i={left:t,right:t,top:n,bottom:n},o?P.pathListRel.push([o,{x:t,y:n}]):P.pathListRel=[],o={x:t,y:n}}),P.pathListRel.push([]),e=P.strokeWidth/2,l=[{x:i.left-e,y:i.top-e},{x:i.right+e,y:i.bottom+e}],P.bBoxRel={left:l[0].x,top:l[0].y,right:l[1].x,bottom:l[1].y,width:l[1].x-l[0].x,height:l[1].y-l[0].y}}W.pathListRel=W.bBoxRel=!0}return(W.pathListRel||W.elementLeft||W.elementTop)&&(P.pathData=we(P.pathListRel,function(e){e.x+=a.left,e.y+=a.top})),We(t,N,"strokeWidth",n=P.strokeWidth)&&(t.path.style.strokeWidth=n+"px"),Me(n=P.pathData,N.pathData)&&(t.path.setPathData(n),N.pathData=n,W.pathData=!0),t.dash&&(!W.pathData&&(!W.strokeWidth||t.dashLen&&t.dashGap)||(P.dashLen=t.dashLen||2*P.strokeWidth,P.dashGap=t.dashGap||P.strokeWidth),W.dash=We(t,N,"dashLen",P.dashLen)||W.dash,W.dash=We(t,N,"dashGap",P.dashGap)||W.dash,W.dash&&(t.path.style.strokeDasharray=N.dashLen+","+N.dashGap)),C=P.viewBoxBBox,L=N.viewBoxBBox,A=t.svg.viewBox.baseVal,V=t.svg.style,C.x=P.bBoxRel.left+a.left,C.y=P.bBoxRel.top+a.top,C.width=P.bBoxRel.width,C.height=P.bBoxRel.height,["x","y","width","height"].forEach(function(e){(n=C[e])!==L[e]&&(A[e]=L[e]=n,V[oe[e]]=n+("x"===e||"y"===e?t.bodyOffset[e]:0)+"px")}),W.strokeWidth||W.pathListRel||W.bBoxRel}},mouseHoverAnchor:{type:"anchor",argOptions:[{optionName:"element",type:ye},{optionName:"showEffectName",type:"string"}],style:{backgroundImage:"url('data:image/svg+xml;charset=utf-8;base64,PHN2ZyB2ZXJzaW9uPSIxLjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgd2lkdGg9IjI0IiBoZWlnaHQ9IjI0Ij48cG9seWdvbiBwb2ludHM9IjI0LDAgMCw4IDgsMTEgMCwxOSA1LDI0IDEzLDE2IDE2LDI0IiBmaWxsPSJjb3JhbCIvPjwvc3ZnPg==')",backgroundSize:"",backgroundRepeat:"no-repeat",backgroundColor:"#f8f881",cursor:"default"},hoverStyle:{backgroundImage:"none",backgroundColor:"#fadf8f"},padding:{top:1,right:15,bottom:1,left:2},minHeight:15,backgroundPosition:{right:2,top:2},backgroundSize:{width:12,height:12},dirKeys:[["top","Top"],["right","Right"],["bottom","Bottom"],["left","Left"]],init:function(a,i){var o,t,e,n,l,r,s,u,h,p,c,d=y.mouseHoverAnchor,f={};if(a.element=y.pointAnchor.checkElement(i.element),u=a.element,!((p=u.ownerDocument)&&(h=p.defaultView)&&h.HTMLElement&&u instanceof h.HTMLElement))throw new Error("`element` must be HTML element");return d.style.backgroundSize=d.backgroundSize.width+"px "+d.backgroundSize.height+"px",["style","hoverStyle"].forEach(function(e){var n=d[e];a[e]=Object.keys(n).reduce(function(e,t){return e[t]=n[t],e},{})}),"inline"===(o=a.element.ownerDocument.defaultView.getComputedStyle(a.element,"")).display?a.style.display="inline-block":"none"===o.display&&(a.style.display="block"),y.mouseHoverAnchor.dirKeys.forEach(function(e){var t=e[0],n="padding"+e[1];parseFloat(o[n])e.x2&&(e.x2=a.x2),a.y2>e.y2&&(e.y2=a.y2)},newText:function(e,t,n,a,i){var o,l,r,s,u,h;return(o=t.createElementNS(b,"text")).textContent=e,[o.x,o.y].forEach(function(e){var t=n.createSVGLength();t.newValueSpecifiedUnits(SVGLength.SVG_LENGTHTYPE_PX,0),e.baseVal.initialize(t)}),"boolean"!=typeof f&&(f="paintOrder"in o.style),i&&!f?(r=t.createElementNS(b,"defs"),o.id=a,r.appendChild(o),(u=(l=t.createElementNS(b,"g")).appendChild(t.createElementNS(b,"use"))).href.baseVal="#"+a,(s=l.appendChild(t.createElementNS(b,"use"))).href.baseVal="#"+a,(h=u.style).strokeLinejoin="round",{elmPosition:o,styleText:o.style,styleFill:s.style,styleStroke:h,styleShow:l.style,elmsAppend:[r,l]}):(h=o.style,i&&(h.strokeLinejoin="round",h.paintOrder="stroke"),{elmPosition:o,styleText:h,styleFill:h,styleStroke:i?h:null,styleShow:h,elmsAppend:[o]})},getMidPoint:function(e,t){var n,a,i,o=Oe(e),l=o.segsLen,r=o.lenAll,s=-1;if((n=r/2+(t||0))<=0)return 2===(a=e[0]).length?ve(a[0],a[1],0):xe(a[0],a[1],a[2],a[3],0);if(r<=n)return 2===(a=e[e.length-1]).length?ve(a[0],a[1],1):xe(a[0],a[1],a[2],a[3],1);for(i=[];n>l[++s];)i.push(e[s]),n-=l[s];return 2===(a=e[s]).length?ve(a[0],a[1],n/l[s]):xe(a[0],a[1],a[2],a[3],ke(a[0],a[1],a[2],a[3],n))},initSvg:function(t,n){var e,a,i=y.captionLabel.newText(t.text,n.baseWindow.document,n.svg,v+"-captionLabel-"+t._id,t.outlineColor);["elmPosition","styleFill","styleShow","elmsAppend"].forEach(function(e){t[e]=i[e]}),t.isShown=!1,t.styleShow.visibility="hidden",y.captionLabel.textStyleProps.forEach(function(e){null!=t[e]&&(i.styleText[e]=t[e])}),i.elmsAppend.forEach(function(e){n.svg.appendChild(e)}),e=i.elmPosition.getBBox(),t.width=e.width,t.height=e.height,t.outlineColor&&(a=10<(a=e.height/9)?10:a<2?2:a,i.styleStroke.strokeWidth=a+"px",i.styleStroke.stroke=t.outlineColor),t.strokeWidth=a||0,Te(t.aplStats,y.captionLabel.stats),t.updateColor(n),t.refSocketXY?t.updateSocketXY(n):t.updatePath(n),ue&&De(n,{}),t.updateShow(n)},bind:function(e,t){var n=t.props;return e.color||Ie(n,"cur_line_color",e.updateColor),(e.refSocketXY="startLabel"===t.optionName||"endLabel"===t.optionName)?(e.socketIndex="startLabel"===t.optionName?0:1,Ie(n,"apl_position",e.updateSocketXY),e.offset||(Ie(n,"cur_attach_plugSideLenSE",e.updateSocketXY),Ie(n,"cur_line_strokeWidth",e.updateSocketXY))):Ie(n,"apl_path",e.updatePath),Ie(n,"svgShow",e.updateShow),ue&&Ie(n,"new_edge4viewBox",e.adjustEdge),y.captionLabel.initSvg(e,n),!0},unbind:function(e,t){var n=t.props;e.elmsAppend&&(e.elmsAppend.forEach(function(e){n.svg.removeChild(e)}),e.elmPosition=e.styleFill=e.styleShow=e.elmsAppend=null),Te(e.curStats,y.captionLabel.stats),Te(e.aplStats,y.captionLabel.stats),e.color||Ce(n,"cur_line_color",e.updateColor),e.refSocketXY?(Ce(n,"apl_position",e.updateSocketXY),e.offset||(Ce(n,"cur_attach_plugSideLenSE",e.updateSocketXY),Ce(n,"cur_line_strokeWidth",e.updateSocketXY))):Ce(n,"apl_path",e.updatePath),Ce(n,"svgShow",e.updateShow),ue&&(Ce(n,"new_edge4viewBox",e.adjustEdge),De(n,{}))},removeOption:function(e,t){var n=t.props,a={};a[t.optionName]="",Ze(n,a)},remove:function(t){t.boundTargets.length&&(console.error("LeaderLineAttachment was not unbound by remove"),t.boundTargets.forEach(function(e){y.captionLabel.unbind(t,e)}))}},pathLabel:{type:"label",argOptions:[{optionName:"text",type:"string"}],stats:{color:{},startOffset:{},pathData:{}},init:function(s,t){return"string"==typeof t.text&&(s.text=t.text.trim()),!!s.text&&("string"==typeof t.color&&(s.color=t.color.trim()),s.outlineColor="string"==typeof t.outlineColor?t.outlineColor.trim():"#fff",w(t.lineOffset)&&(s.lineOffset=t.lineOffset),y.captionLabel.textStyleProps.forEach(function(e){null!=t[e]&&(s[e]=t[e])}),s.updateColor=function(e){y.captionLabel.updateColor(s,e)},s.updatePath=function(e){var t,n=s.curStats,a=s.aplStats,i=e.curStats,o=e.pathList.animVal||e.pathList.baseVal;o&&(n.pathData=t=y.pathLabel.getOffsetPathData(o,i.line_strokeWidth/2+s.strokeWidth/2+s.height/4,1.25*s.height),Me(t,a.pathData)&&(s.elmPath.setPathData(t),a.pathData=t,s.bBox=s.elmPosition.getBBox(),s.updateStartOffset(e)))},s.updateStartOffset=function(e){var t,n,a,i,o=s.curStats,l=s.aplStats,r=e.curStats;o.pathData&&((2!==s.semIndex||s.lineOffset)&&(t=o.pathData.reduce(function(e,t){var n,a=t.values;switch(t.type){case"M":i={x:a[0],y:a[1]};break;case"L":n={x:a[0],y:a[1]},i&&(e+=_e(i,n)),i=n;break;case"C":n={x:a[4],y:a[5]},i&&(e+=be(i,{x:a[0],y:a[1]},{x:a[2],y:a[3]},n)),i=n}return e},0),a=0===s.semIndex?0:1===s.semIndex?t:t/2,2!==s.semIndex&&(n=Math.max(r.attach_plugBackLenSE[s.semIndex]||0,r.line_strokeWidth/2)+s.strokeWidth/2+s.height/4,a=(a+=0===s.semIndex?n:-n)<0?0:tx?((t=b.points)[1]=Ee(t[0],t[1],-x),b.len=_e(t[0],t[1])):(b.points=null,b.len=0),e.len>x+n?((t=e.points)[0]=Ee(t[1],t[0],-(x+n)),e.len=_e(t[0],t[1])):(e.points=null,e.len=0)),b=e):b=null}),k.reduce(function(t,e){var n=e.points;return n&&(a&&w(n[0],a)||t.push({type:"M",values:[n[0].x,n[0].y]}),"line"===e.type?t.push({type:"L",values:[n[1].x,n[1].y]}):(n.shift(),n.forEach(function(e){t.push({type:"L",values:[e.x,e.y]})})),a=n[n.length-1]),t},[])},newText:function(e,t,n,a){var i,o,l,r,s,u,h,p,c,d;return(r=(l=t.createElementNS(b,"defs")).appendChild(t.createElementNS(b,"path"))).id=i=n+"-path",(u=(s=t.createElementNS(b,"text")).appendChild(t.createElementNS(b,"textPath"))).href.baseVal="#"+i,u.startOffset.baseVal.newValueSpecifiedUnits(SVGLength.SVG_LENGTHTYPE_PX,0),u.textContent=e,"boolean"!=typeof f&&(f="paintOrder"in s.style),a&&!f?(s.id=o=n+"-text",l.appendChild(s),(c=(h=t.createElementNS(b,"g")).appendChild(t.createElementNS(b,"use"))).href.baseVal="#"+o,(p=h.appendChild(t.createElementNS(b,"use"))).href.baseVal="#"+o,(d=c.style).strokeLinejoin="round",{elmPosition:s,elmPath:r,elmOffset:u,styleText:s.style,styleFill:p.style,styleStroke:d,styleShow:h.style,elmsAppend:[l,h]}):(d=s.style,a&&(d.strokeLinejoin="round",d.paintOrder="stroke"),{elmPosition:s,elmPath:r,elmOffset:u,styleText:d,styleFill:d,styleStroke:a?d:null,styleShow:d,elmsAppend:[l,s]})},initSvg:function(t,n){var e,a,i=y.pathLabel.newText(t.text,n.baseWindow.document,v+"-pathLabel-"+t._id,t.outlineColor);["elmPosition","elmPath","elmOffset","styleFill","styleShow","elmsAppend"].forEach(function(e){t[e]=i[e]}),t.isShown=!1,t.styleShow.visibility="hidden",y.captionLabel.textStyleProps.forEach(function(e){null!=t[e]&&(i.styleText[e]=t[e])}),i.elmsAppend.forEach(function(e){n.svg.appendChild(e)}),i.elmPath.setPathData([{type:"M",values:[0,100]},{type:"h",values:[100]}]),e=i.elmPosition.getBBox(),i.styleText.textAnchor=["start","end","middle"][t.semIndex],2!==t.semIndex||t.lineOffset||i.elmOffset.startOffset.baseVal.newValueSpecifiedUnits(SVGLength.SVG_LENGTHTYPE_PERCENTAGE,50),t.height=e.height,t.outlineColor&&(a=10<(a=e.height/9)?10:a<2?2:a,i.styleStroke.strokeWidth=a+"px",i.styleStroke.stroke=t.outlineColor),t.strokeWidth=a||0,Te(t.aplStats,y.pathLabel.stats),t.updateColor(n),t.updatePath(n),t.updateStartOffset(n),ue&&De(n,{}),t.updateShow(n)},bind:function(e,t){var n=t.props;return e.color||Ie(n,"cur_line_color",e.updateColor),Ie(n,"cur_line_strokeWidth",e.updatePath),Ie(n,"apl_path",e.updatePath),e.semIndex="startLabel"===t.optionName?0:"endLabel"===t.optionName?1:2,(2!==e.semIndex||e.lineOffset)&&Ie(n,"cur_attach_plugBackLenSE",e.updateStartOffset),Ie(n,"svgShow",e.updateShow),ue&&Ie(n,"new_edge4viewBox",e.adjustEdge),y.pathLabel.initSvg(e,n),!0},unbind:function(e,t){var n=t.props;e.elmsAppend&&(e.elmsAppend.forEach(function(e){n.svg.removeChild(e)}),e.elmPosition=e.elmPath=e.elmOffset=e.styleFill=e.styleShow=e.elmsAppend=null),Te(e.curStats,y.pathLabel.stats),Te(e.aplStats,y.pathLabel.stats),e.color||Ce(n,"cur_line_color",e.updateColor),Ce(n,"cur_line_strokeWidth",e.updatePath),Ce(n,"apl_path",e.updatePath),(2!==e.semIndex||e.lineOffset)&&Ce(n,"cur_attach_plugBackLenSE",e.updateStartOffset),Ce(n,"svgShow",e.updateShow),ue&&(Ce(n,"new_edge4viewBox",e.adjustEdge),De(n,{}))},removeOption:function(e,t){var n=t.props,a={};a[t.optionName]="",Ze(n,a)},remove:function(t){t.boundTargets.length&&(console.error("LeaderLineAttachment was not unbound by remove"),t.boundTargets.forEach(function(e){y.pathLabel.unbind(t,e)}))}}},Object.keys(y).forEach(function(e){Ye[e]=function(){return new S(y[e],Array.prototype.slice.call(arguments))}}),Ye.positionByWindowResize=!0,window.addEventListener("resize",O.add(function(){Ye.positionByWindowResize&&Object.keys(K).forEach(function(e){De(K[e],{position:!0})})}),!1),Ye}();
diff --git a/assets/main.scss b/assets/main.scss
new file mode 100644
index 0000000..9f94b11
--- /dev/null
+++ b/assets/main.scss
@@ -0,0 +1,5 @@
+---
+# Only the main Sass file needs front matter (the dashes are enough)
+---
+
+@import "3scale";
diff --git a/assets/minima-social-icons.svg b/assets/minima-social-icons.svg
new file mode 100644
index 0000000..fa7399f
--- /dev/null
+++ b/assets/minima-social-icons.svg
@@ -0,0 +1,33 @@
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
+
diff --git a/assets/use.js b/assets/use.js
new file mode 100644
index 0000000..223c458
--- /dev/null
+++ b/assets/use.js
@@ -0,0 +1,28 @@
+let nav_use = document.getElementById('nav_use')
+let nav_install = document.getElementById('nav_install')
+let use = document.getElementById('use')
+let install = document.getElementById('install')
+
+let nav_use2use = new LeaderLine(
+ LeaderLine.pointAnchor(nav_use, {x: '-10%', y: '50%'}),
+ LeaderLine.pointAnchor(use, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ //dash: {animation: false},
+ path: 'straight'
+ }
+);
+
+let nav_install2install = new LeaderLine(
+ LeaderLine.pointAnchor(nav_install, {x: '50%', y: '100%'}),
+ LeaderLine.pointAnchor(install, {x: '10%', y: 0 }),
+ {
+ color: '#FF7314',
+ startPlug: 'disc',
+ endPlug: 'arrow2',
+ //dash: {animation: false},
+ path: 'straight'
+ }
+);
diff --git a/contribute.md b/contribute.md
new file mode 100644
index 0000000..e5135d3
--- /dev/null
+++ b/contribute.md
@@ -0,0 +1,22 @@
+---
+layout: page
+title: Contribute
+heading: Contribute to grow
+permalink: /contribute
+order: 3
+---
+
+
+
+ Contribute
+ This project is driven by Red Hat but open to anyone for contributions of any kind.
+
+
+
+
diff --git a/favicon.ico b/favicon.ico
new file mode 100644
index 0000000..001e541
Binary files /dev/null and b/favicon.ico differ
diff --git a/grasp.md b/grasp.md
new file mode 100644
index 0000000..f02f9b5
--- /dev/null
+++ b/grasp.md
@@ -0,0 +1,85 @@
+---
+layout: page
+heading: Grasp the inner workings
+title: Grasp
+permalink: /grasp
+order: 2
+---
+
+
+
+
+
+
+
+
+
+
+
+
+ Listener accepts and enques requests to authorize and report
+ Worker performs background tasks off-loaded from the listener.
+ Rescheduler re-queues failed jobs.
+
+
+
+
+
+ authenticator
+ authorizer
+ reporter
+ internal API
+
+
+
+
+
+ API
+
+
+
+
+
+
+ Rails app to manage API(s) & developers through GUI & API
+ Accounts, Applications, Messages, Plans, Billing, Limits, Rules, Policies.
+ Create and nurture a developer portal
+
+
+
+
+ pisoni
+ services
+ plans (rules & limits)
+ apps (auth)
+ analytics
+ developer portal
+
+
+
+
diff --git a/index.md b/index.md
index 4b110eb..6ac0cfa 100644
--- a/index.md
+++ b/index.md
@@ -1,37 +1,95 @@
-## Welcome to GitHub Pages
+---
+# You don't need to edit this file, it's empty on purpose.
+# Edit theme's home layout instead if you wanna make some changes
+# See: https://jekyllrb.com/docs/themes/#overriding-theme-defaults
+layout: page
+title: 3scale API Management
+heading: Share , secure , control , analyze , and monetize your APIs.
+permalink: /
+---
-You can use the [editor on GitHub](https://github.com/3scale/3scale.github.io/edit/master/index.md) to maintain and preview the content for your website in Markdown files.
+
+
+
+
+ Developer Portal
+
+ Share your API's with the world, educate developers with interactive docs and empower them with a private area to manage their subscriptions, keys, and apps.
+
+
+
-Whenever you commit to this repository, GitHub Pages will run [Jekyll](https://jekyllrb.com/) to rebuild the pages in your site, from the content in your Markdown files.
+
+
+
+
+ API Authentication
+
+ Use one of the three different authentication patterns to secure access to your APIs.
+
+
+
-### Markdown
+
+
+
+
+ Plans, Rules & Limits
+
+ Control access to your APIs with plans, metrics, methods, rate limits and pricing rules.
+
+
+
-Markdown is a lightweight and easy-to-use syntax for styling your writing. It includes conventions for
+
+
+
+
+ Analytics
+
+ Analyse your API's usage through daily averages, top applications and response codes.
+
+
+
-```markdown
-Syntax highlighted code block
-
-# Header 1
-## Header 2
-### Header 3
-
-- Bulleted
-- List
-
-1. Numbered
-2. List
-
-**Bold** and _Italic_ and `Code` text
-
-[Link](url) and 
-```
-
-For more details see [GitHub Flavored Markdown](https://guides.github.com/features/mastering-markdown/).
-
-### Jekyll Themes
-
-Your Pages site will use the layout and styles from the Jekyll theme you have selected in your [repository settings](https://github.com/3scale/3scale.github.io/settings). The name of this theme is saved in the Jekyll `_config.yml` configuration file.
-
-### Support or Contact
-
-Having trouble with Pages? Check out our [documentation](https://help.github.com/categories/github-pages-basics/) or [contact support](https://github.com/contact) and we’ll help you sort it out.
+
+
+
+
+ Billing
+
+ Monetize your APIs through pricing rules, paid plans, automated billing and invoicing.
+
+
+
+
diff --git a/use.md b/use.md
new file mode 100644
index 0000000..cb28401
--- /dev/null
+++ b/use.md
@@ -0,0 +1,51 @@
+---
+layout: page
+title: Use
+permalink: /use
+order: 1
+heading: Use now,Install later
+---
+
+
+
+ Use Now
+
+ quick sign up for the saas
+ free plan
+ get a feel for the product
+
+
+
+
+
+
+ Install the full Monty on your laptop
+ Pre-requisite: Minishift .
+
+
+ # 1. Start Minishift with 6gb
+ minishift start --memory 6GB --cpus 2
+ # 2. Create a new application using a minimal 3scale template oc new-app \
+ --param WILDCARD_DOMAIN="$(minishift ip).nip.io" \
+ --param AMP_RELEASE=2.4.0 \
+ -f https://red.ht/2HdoRPB
+ # 3. Sign in to 3scale with Username:admin
+and get password from the terminal output (look for ADMIN_PASSWORD). https://3scale-admin.$(minishift ip).nip.io/
+
+
+ More details in this gist .
+
+
+ Install individual components for evaluation or development purposes
+
+
+
+
+
+
+
+