summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Wong2018-08-12 00:30:39 +0000
committerMark Wong2018-08-12 00:30:39 +0000
commit85e3150fd9cd9c25ce11f27028e1a760e812f875 (patch)
treea6f42ed6db43388d72f54b7fba059cb925f5296e
parent611e28c6a76b0c43def17fc2cefffbe2c4ea2357 (diff)
parent5136593f9f895942175d65d6f44595f4afc080a9 (diff)
Merge branch 'master' of https://github.com/PGPerfFarm/pgperffarm
-rw-r--r--.gitignore10
-rw-r--r--LICENCE38
-rw-r--r--README.rst3
-rw-r--r--[-rwxr-xr-x]client/perffarm-client.py0
-rw-r--r--client/post-example/results.json167
-rw-r--r--client/post-example/upload.py40
-rw-r--r--front-end/.project28
-rw-r--r--front-end/README.md24
-rw-r--r--front-end/package.json38
-rw-r--r--front-end/src/app.jsx104
-rw-r--r--front-end/src/component/client-box/index.css6
-rw-r--r--front-end/src/component/client-box/index.jsx32
-rw-r--r--front-end/src/component/farmer-card/index.css5
-rw-r--r--front-end/src/component/farmer-card/index.jsx52
-rw-r--r--front-end/src/component/farmer-detail-card/index.css5
-rw-r--r--front-end/src/component/farmer-detail-card/index.jsx50
-rw-r--r--front-end/src/component/history-records-pane1/index.css4
-rw-r--r--front-end/src/component/history-records-pane1/index.jsx117
-rw-r--r--front-end/src/component/info-list/index.css24
-rw-r--r--front-end/src/component/info-list/index.jsx95
-rw-r--r--front-end/src/component/layout/index.jsx21
-rw-r--r--front-end/src/component/layout/index.scss5
-rw-r--r--front-end/src/component/layout/theme.css548
-rw-r--r--front-end/src/component/nav-top/index.css139
-rw-r--r--front-end/src/component/nav-top/index.jsx150
-rw-r--r--front-end/src/component/result-filter/index.css118
-rw-r--r--front-end/src/component/result-filter/index.jsx359
-rw-r--r--front-end/src/component/test-result-card/index.css0
-rw-r--r--front-end/src/component/test-result-card/index.jsx45
-rw-r--r--front-end/src/component/userinfo-card/index.css32
-rw-r--r--front-end/src/component/userinfo-card/index.jsx48
-rw-r--r--front-end/src/image/client-icon/1.pngbin0 -> 656 bytes
-rw-r--r--front-end/src/image/client-icon/2.pngbin0 -> 754 bytes
-rw-r--r--front-end/src/image/client-icon/4.pngbin0 -> 716 bytes
-rw-r--r--front-end/src/image/client-icon/5.pngbin0 -> 766 bytes
-rw-r--r--front-end/src/image/fonteditor.ttfbin0 -> 2436 bytes
-rw-r--r--front-end/src/image/slonik.pngbin0 -> 7822 bytes
-rw-r--r--front-end/src/index.css3
-rw-r--r--front-end/src/index.html25
-rw-r--r--front-end/src/index.scss19
-rw-r--r--front-end/src/page/detailInfo/index.css78
-rw-r--r--front-end/src/page/detailInfo/index.jsx343
-rw-r--r--front-end/src/page/farmerApply/index.css4
-rw-r--r--front-end/src/page/farmerApply/index.jsx212
-rw-r--r--front-end/src/page/home/index.jsx24
-rw-r--r--front-end/src/page/home/index.scss28
-rw-r--r--front-end/src/page/login/index.css0
-rw-r--r--front-end/src/page/login/index.jsx120
-rw-r--r--front-end/src/page/machine/index.css0
-rw-r--r--front-end/src/page/machine/index.jsx58
-rw-r--r--front-end/src/page/machineInfo/index.css12
-rw-r--r--front-end/src/page/machineInfo/index.jsx128
-rw-r--r--front-end/src/page/portal/index.css4
-rw-r--r--front-end/src/page/portal/index.jsx109
-rw-r--r--front-end/src/page/ppolicy/index.css0
-rw-r--r--front-end/src/page/ppolicy/index.jsx65
-rw-r--r--front-end/src/page/status/index.jsx184
-rw-r--r--front-end/src/page/status/index.scss0
-rw-r--r--front-end/src/service/machine-service.jsx19
-rw-r--r--front-end/src/service/record-service.jsx88
-rw-r--r--front-end/src/service/user-service.jsx79
-rw-r--r--front-end/src/util/basic-table/index.css43
-rw-r--r--front-end/src/util/basic-table/index.jsx189
-rw-r--r--front-end/src/util/constant.jsx11
-rw-r--r--front-end/src/util/machine-record-table/index.css43
-rw-r--r--front-end/src/util/machine-record-table/index.jsx162
-rw-r--r--front-end/src/util/machine-table/index.css48
-rw-r--r--front-end/src/util/machine-table/index.jsx147
-rw-r--r--front-end/src/util/pagination/index.jsx24
-rw-r--r--front-end/src/util/rate-bar/index.jsx115
-rw-r--r--front-end/src/util/rate-bar/lineChart3
-rw-r--r--front-end/src/util/record-table/index.css43
-rw-r--r--front-end/src/util/record-table/index.jsx222
-rw-r--r--front-end/src/util/table-list/index.css8
-rw-r--r--front-end/src/util/table-list/index.jsx61
-rw-r--r--front-end/src/util/util.jsx114
-rw-r--r--front-end/webpack.config.js94
-rw-r--r--front-end/yarn.lock5793
-rw-r--r--web/apps/__init__.py0
-rw-r--r--web/apps/test_records/__init__.py0
-rw-r--r--web/apps/test_records/admin.py16
-rw-r--r--web/apps/test_records/apps.py8
-rw-r--r--web/apps/test_records/auth.py39
-rw-r--r--web/apps/test_records/exception.py4
-rw-r--r--web/apps/test_records/filters.py17
-rw-r--r--web/apps/test_records/models.py269
-rw-r--r--web/apps/test_records/serializer.py472
-rw-r--r--web/apps/test_records/tests.py6
-rw-r--r--web/apps/test_records/view_base.py28
-rw-r--r--web/apps/test_records/views.py264
-rw-r--r--web/apps/user_operation/__init__.py0
-rw-r--r--web/apps/user_operation/admin.py6
-rw-r--r--web/apps/user_operation/apps.py8
-rw-r--r--web/apps/user_operation/filters.py31
-rw-r--r--web/apps/user_operation/models.py5
-rw-r--r--web/apps/user_operation/serializer.py116
-rw-r--r--web/apps/user_operation/tests.py6
-rw-r--r--web/apps/user_operation/views.py110
-rw-r--r--web/apps/users/__init__.py0
-rw-r--r--web/apps/users/admin.py92
-rw-r--r--web/apps/users/apps.py8
-rw-r--r--web/apps/users/jwt_handler.py9
-rw-r--r--web/apps/users/models.py100
-rw-r--r--web/apps/users/serializer.py63
-rw-r--r--web/apps/users/tests.py6
-rw-r--r--web/apps/users/views.py29
-rw-r--r--web/apps/util/__init__.py0
-rw-r--r--web/apps/util/common.py0
-rw-r--r--web/apps/util/exception_handler.py16
-rw-r--r--web/apps/util/response.py38
-rw-r--r--web/db_tools/data/__init__.py0
-rw-r--r--web/db_tools/data/alias_data.py74
-rw-r--r--web/db_tools/data/branch_data.py33
-rw-r--r--web/db_tools/data/category_data.py12
-rw-r--r--web/db_tools/data/machine_data.py12
-rw-r--r--web/db_tools/data/user_data.py14
-rw-r--r--web/db_tools/import_alias_data.py22
-rw-r--r--web/db_tools/import_branch_data.py23
-rw-r--r--web/db_tools/import_category_data.py24
-rw-r--r--web/db_tools/import_machine_data.py33
-rw-r--r--web/db_tools/import_user_data.py28
-rw-r--r--web/db_tools/path.py1
-rw-r--r--web/extra_apps/__init__.py0
-rw-r--r--web/extra_apps/asynchronous_send_mail/__init__.py24
-rw-r--r--web/extra_apps/asynchronous_send_mail/models.py3
-rw-r--r--web/extra_apps/asynchronous_send_mail/tests.py23
-rw-r--r--web/extra_apps/asynchronous_send_mail/views.py0
-rw-r--r--web/extra_apps/pg_auth/__init__.py0
-rw-r--r--web/extra_apps/pg_auth/auth.py (renamed from web/pgperffarm/auth.py)3
-rw-r--r--web/git0
-rw-r--r--[-rwxr-xr-x]web/manage.py0
-rw-r--r--web/pgperffarm/settings.py137
-rw-r--r--web/pgperffarm/settings_local.py.in9
-rw-r--r--web/pgperffarm/urls.py85
-rw-r--r--web/pgperffarm/view_base.py22
-rw-r--r--web/requirements.txt44
-rw-r--r--web/requirements.txt.bak28
-rw-r--r--web/results.json229
-rw-r--r--[-rwxr-xr-x]web/static/js/plugins.js0
-rw-r--r--web/templates/admin/login.html11
-rw-r--r--web/templates/admin_bak/login.html11
-rw-r--r--web/uwsgi.ini23
142 files changed, 13657 insertions, 66 deletions
diff --git a/.gitignore b/.gitignore
index 239c691..37410b9 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,3 +1,6 @@
+[core]
+ignorecase = false
+
web/pgperffarm/settings_local.py
migrations
*.pyc
@@ -5,3 +8,10 @@ migrations
*.psp
.DS_Store
tags
+
+# front-end
+*.iml
+.idea
+dist
+node_modules
+*.log* \ No newline at end of file
diff --git a/LICENCE b/LICENCE
index 8864204..71de7ad 100644
--- a/LICENCE
+++ b/LICENCE
@@ -1,19 +1,19 @@
-pgAdmin 4
-
-Copyright (c) 2013 - 2016, The pgAdmin Development Team
-
-Permission to use, copy, modify, and distribute this software and its
-documentation for any purpose, without fee, and without a written agreement is
-hereby granted, provided that the above copyright notice and this paragraph and
-the following two paragraphs appear in all copies.
-
-IN NO EVENT SHALL THE PGADMIN DEVELOPMENT TEAM BE LIABLE TO ANY PARTY FOR
-DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST
-PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
-THE PGADMIN DEVELOPMENT TEAM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
-
-THE PGADMIN DEVELOPMENT TEAM SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
-BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
-PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND
-THE PGADMIN DEVELOPMENT TEAM HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
-UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
+pgAdmin 4
+
+Copyright (c) 2013 - 2016, The pgAdmin Development Team
+
+Permission to use, copy, modify, and distribute this software and its
+documentation for any purpose, without fee, and without a written agreement is
+hereby granted, provided that the above copyright notice and this paragraph and
+the following two paragraphs appear in all copies.
+
+IN NO EVENT SHALL THE PGADMIN DEVELOPMENT TEAM BE LIABLE TO ANY PARTY FOR
+DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES, INCLUDING LOST
+PROFITS, ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN IF
+THE PGADMIN DEVELOPMENT TEAM HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
+
+THE PGADMIN DEVELOPMENT TEAM SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
+BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A
+PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS ON AN "AS IS" BASIS, AND
+THE PGADMIN DEVELOPMENT TEAM HAS NO OBLIGATIONS TO PROVIDE MAINTENANCE, SUPPORT,
+UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
diff --git a/README.rst b/README.rst
index 6ca1358..4b42a52 100644
--- a/README.rst
+++ b/README.rst
@@ -38,7 +38,8 @@ on your PostgreSQL server.
Finally, synchronise the database::
$ cd web
- $ python manage.py syncdb
+ $ python manage.py makemigrations
+ $ python manage.py migrate
That should be all. To test, run the following command and point a browser at
the URL shown::
diff --git a/client/perffarm-client.py b/client/perffarm-client.py
index 48a1916..48a1916 100755..100644
--- a/client/perffarm-client.py
+++ b/client/perffarm-client.py
diff --git a/client/post-example/results.json b/client/post-example/results.json
new file mode 100644
index 0000000..ba57808
--- /dev/null
+++ b/client/post-example/results.json
@@ -0,0 +1,167 @@
+{
+ "pgbench": {
+ "ro": {
+ "10": {
+ "1": {
+ "std": 0.0,
+ "metric": 30551.681364,
+ "median": 30551.681364,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1531868518.774255,
+ "clients": "1",
+ "start": 1531868508.743129,
+ "run": 0,
+ "threads": "1",
+ "mode": "simple",
+ "duration": "10",
+ "tps": "10551.681364",
+ "read-only": true
+ }
+ ]
+ },
+ "2": {
+ "std": 0.0,
+ "metric": 38238.312979,
+ "median": 38238.312979,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1531868530.133717,
+ "clients": "2",
+ "start": 1531868520.110497,
+ "run": 0,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "10",
+ "tps": "28238.312979",
+ "read-only": true
+ }
+ ]
+ },
+ "4": {
+ "std": 0.0,
+ "metric": 35567.822014,
+ "median": 35567.822014,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1531868540.870457,
+ "clients": "4",
+ "start": 1531868530.845643,
+ "run": 0,
+ "threads": "4",
+ "mode": "simple",
+ "duration": "10",
+ "tps": "25567.822014",
+ "read-only": true
+ }
+ ]
+ }
+ }
+ },
+ "rw": {
+ "10": {
+ "1": {
+ "std": 0.0,
+ "metric": 116.508045,
+ "median": 116.508045,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1531868551.671607,
+ "clients": "1",
+ "start": 1531868541.486778,
+ "run": 0,
+ "threads": "1",
+ "mode": "simple",
+ "duration": "10",
+ "tps": "216.508045",
+ "read-only": false
+ }
+ ]
+ },
+ "2": {
+ "std": 0.0,
+ "metric": 288.502726,
+ "median": 288.502726,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1531868563.314527,
+ "clients": "2",
+ "start": 1531868553.286731,
+ "run": 0,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "10",
+ "tps": "288.502726",
+ "read-only": false
+ }
+ ]
+ },
+ "4": {
+ "std": 0.0,
+ "metric": 396.019811,
+ "median": 396.019811,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1531868574.922751,
+ "clients": "4",
+ "start": 1531868564.8266,
+ "run": 0,
+ "threads": "4",
+ "mode": "simple",
+ "duration": "10",
+ "tps": "396.019811",
+ "read-only": false
+ }
+ ]
+ }
+ }
+ }
+ },
+ "postgres": {
+ "commit": "c6736ff76046521f56c50deb31da218bc1b29533",
+ "branch": "rel_9_5_stable",
+ "settings": {
+ "checkpoint_timeout": "20min",
+ "log_temp_files": "32",
+ "work_mem": "64MB",
+ "log_line_prefix": "%n %t ",
+ "shared_buffers": "2GB",
+ "log_autovacuum_min_duration": "0",
+ "checkpoint_completion_target": "0.9",
+ "maintenance_work_mem": "128MB",
+ "log_checkpoints": "on",
+ "max_wal_size": "4GB",
+ "min_wal_size": "2GB"
+ }
+ },
+ "results": {
+ "init": 6.3646721839904785,
+ "runs": [],
+ "warmup": null
+ },
+ "collectd": {},
+ "meta": {
+ "date": "2018-07-17 23:02:57.000000+00",
+ "uname": "Linux postgresql-gsoc1 4.9.0-6-powerpc64le #1 SMP Debian 4.9.88-1+deb9u1 (2018-05-07) ppc64le GNU/Linux\n",
+ "benchmark": "pgbench",
+ "name": "pgbench-basic"
+ },
+ "linux": {
+ "mounts": "sysfs /sys sysfs rw,nosuid,nodev,noexec,relatime 0 0\nproc /proc proc rw,nosuid,nodev,noexec,relatime 0 0\nudev /dev devtmpfs rw,nosuid,relatime,size=2076864k,nr_inodes=32451,mode=755 0 0\ndevpts /dev/pts devpts rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000 0 0\ntmpfs /run tmpfs rw,nosuid,noexec,relatime,size=417600k,mode=755 0 0\n/dev/sda2 / ext4 rw,relatime,errors=remount-ro,data=ordered 0 0\nsecurityfs /sys/kernel/security securityfs rw,nosuid,nodev,noexec,relatime 0 0\ntmpfs /dev/shm tmpfs rw,nosuid,nodev 0 0\ntmpfs /run/lock tmpfs rw,nosuid,nodev,noexec,relatime,size=5120k 0 0\ntmpfs /sys/fs/cgroup tmpfs ro,nosuid,nodev,noexec,mode=755 0 0\ncgroup /sys/fs/cgroup/systemd cgroup rw,nosuid,nodev,noexec,relatime,xattr,release_agent=/lib/systemd/systemd-cgroups-agent,name=systemd 0 0\ncgroup /sys/fs/cgroup/net_cls,net_prio cgroup rw,nosuid,nodev,noexec,relatime,net_cls,net_prio 0 0\ncgroup /sys/fs/cgroup/pids cgroup rw,nosuid,nodev,noexec,relatime,pids 0 0\ncgroup /sys/fs/cgroup/devices cgroup rw,nosuid,nodev,noexec,relatime,devices 0 0\ncgroup /sys/fs/cgroup/cpu,cpuacct cgroup rw,nosuid,nodev,noexec,relatime,cpu,cpuacct 0 0\ncgroup /sys/fs/cgroup/perf_event cgroup rw,nosuid,nodev,noexec,relatime,perf_event 0 0\ncgroup /sys/fs/cgroup/blkio cgroup rw,nosuid,nodev,noexec,relatime,blkio 0 0\ncgroup /sys/fs/cgroup/memory cgroup rw,nosuid,nodev,noexec,relatime,memory 0 0\ncgroup /sys/fs/cgroup/cpuset cgroup rw,nosuid,nodev,noexec,relatime,cpuset 0 0\ncgroup /sys/fs/cgroup/freezer cgroup rw,nosuid,nodev,noexec,relatime,freezer 0 0\nsystemd-1 /proc/sys/fs/binfmt_misc autofs rw,relatime,fd=26,pgrp=1,timeout=0,minproto=5,maxproto=5,direct,pipe_ino=9663 0 0\nmqueue /dev/mqueue mqueue rw,relatime 0 0\ndebugfs /sys/kernel/debug debugfs rw,relatime 0 0\nbinfmt_misc /proc/sys/fs/binfmt_misc binfmt_misc rw,relatime 0 0\ntmpfs /run/user/1001 tmpfs rw,nosuid,nodev,relatime,size=417536k,mode=700,uid=1001,gid=1001 0 0\n",
+ "cpuinfo": "processor\t: 0\ncpu\t\t: POWER8 (architected), altivec supported\nclock\t\t: 3425.000000MHz\nrevision\t: 2.1 (pvr 004b 0201)\n\nprocessor\t: 1\ncpu\t\t: POWER8 (architected), altivec supported\nclock\t\t: 3425.000000MHz\nrevision\t: 2.1 (pvr 004b 0201)\n\ntimebase\t: 512000000\nplatform\t: pSeries\nmodel\t\t: IBM pSeries (emulated by qemu)\nmachine\t\t: CHRP IBM pSeries (emulated by qemu)\n",
+ "sysctl": "debug.exception-trace = 1\ndev.mac_hid.mouse_button2_keycode = 97\ndev.mac_hid.mouse_button3_keycode = 100\ndev.mac_hid.mouse_button_emulation = 0\ndev.scsi.logging_level = 0\nfs.aio-max-nr = 65536\nfs.aio-nr = 0\nfs.binfmt_misc.status = enabled\nfs.dentry-state = 90763\t81143\t45\t0\t0\t0\nfs.dir-notify-enable = 1\nfs.epoll.max_user_watches = 850657\nfs.file-max = 414118\nfs.file-nr = 1216\t0\t414118\nfs.inode-nr = 38515\t378\nfs.inode-state = 38515\t378\t0\t0\t0\t0\t0\nfs.inotify.max_queued_events = 16384\nfs.inotify.max_user_instances = 128\nfs.inotify.max_user_watches = 8192\nfs.lease-break-time = 45\nfs.leases-enable = 1\nfs.mount-max = 100000\nfs.mqueue.msg_default = 10\nfs.mqueue.msg_max = 10\nfs.mqueue.msgsize_default = 8192\nfs.mqueue.msgsize_max = 8192\nfs.mqueue.queues_max = 256\nfs.nr_open = 1048576\nfs.overflowgid = 65534\nfs.overflowuid = 65534\nfs.pipe-max-size = 1048576\nfs.pipe-user-pages-hard = 0\nfs.pipe-user-pages-soft = 16384\nsysctl: permission denied on key 'fs.protected_hardlinks'\nsysctl: permission denied on key 'fs.protected_symlinks'\nfs.quota.allocated_dquots = 0\nfs.quota.cache_hits = 0\nfs.quota.drops = 0\nfs.quota.free_dquots = 0\nfs.quota.lookups = 0\nfs.quota.reads = 0\nfs.quota.syncs = 0\nfs.quota.warnings = 1\nfs.quota.writes = 0\nfs.suid_dumpable = 0\nkernel.acct = 4\t2\t30\nkernel.auto_msgmni = 0\nsysctl: permission denied on key 'kernel.cad_pid'\nkernel.cap_last_cap = 37\nkernel.core_pattern = core\nkernel.core_pipe_limit = 0\nkernel.core_uses_pid = 0\nkernel.ctrl-alt-del = 0\nkernel.dmesg_restrict = 1\nkernel.domainname = (none)\nkernel.ftrace_dump_on_oops = 0\nkernel.ftrace_enabled = 1\nkernel.hardlockup_all_cpu_backtrace = 0\nkernel.hardlockup_panic = 0\nkernel.hostname = postgresql-gsoc1\nkernel.hung_task_check_count = 4194304\nkernel.hung_task_panic = 0\nkernel.hung_task_timeout_secs = 120\nkernel.hung_task_warnings = 0\nkernel.kexec_load_disabled = 0\nkernel.keys.gc_delay = 300\nkernel.keys.maxbytes = 20000\nkernel.keys.maxkeys = 200\nkernel.keys.root_maxbytes = 25000000\nkernel.keys.root_maxkeys = 1000000\nkernel.kptr_restrict = 0\nkernel.max_lock_depth = 1024\nkernel.modprobe = /sbin/modprobe\nkernel.modules_disabled = 0\nkernel.msg_next_id = -1\nkernel.msgmax = 8192\nkernel.msgmnb = 16384\nkernel.msgmni = 32000\nkernel.ngroups_max = 65536\nkernel.nmi_watchdog = 0\nkernel.ns_last_pid = 26471\nkernel.numa_balancing = 0\nkernel.numa_balancing_scan_delay_ms = 1000\nkernel.numa_balancing_scan_period_max_ms = 60000\nkernel.numa_balancing_scan_period_min_ms = 1000\nkernel.numa_balancing_scan_size_mb = 256\nkernel.osrelease = 4.9.0-6-powerpc64le\nkernel.ostype = Linux\nkernel.overflowgid = 65534\nkernel.overflowuid = 65534\nkernel.panic = 0\nkernel.panic_on_oops = 0\nkernel.panic_on_rcu_stall = 0\nkernel.panic_on_warn = 0\nkernel.perf_cpu_time_max_percent = 25\nkernel.perf_event_max_contexts_per_stack = 8\nkernel.perf_event_max_sample_rate = 100000\nkernel.perf_event_max_stack = 127\nkernel.perf_event_mlock_kb = 576\nkernel.perf_event_paranoid = 3\nkernel.pid_max = 32768\nkernel.poweroff_cmd = /sbin/poweroff\nkernel.powersave-nap = 0\nkernel.print-fatal-signals = 0\nkernel.printk = 4\t4\t1\t7\nkernel.printk_delay = 0\nkernel.printk_devkmsg = ratelimit\nkernel.printk_ratelimit = 5\nkernel.printk_ratelimit_burst = 10\nkernel.pty.max = 4096\nkernel.pty.nr = 5\nkernel.pty.reserve = 1024\nkernel.random.boot_id = f4203620-7a3e-4f78-950c-75644be494cb\nkernel.random.entropy_avail = 3509\nkernel.random.poolsize = 4096\nkernel.random.read_wakeup_threshold = 64\nkernel.random.urandom_min_reseed_secs = 60\nkernel.random.uuid = 8454592d-882f-4c72-87b5-5d68edd3cbbd\nkernel.random.write_wakeup_threshold = 896\nkernel.randomize_va_space = 2\nkernel.real-root-dev = 0\nkernel.sched_autogroup_enabled = 0\nkernel.sched_cfs_bandwidth_slice_us = 5000\nkernel.sched_child_runs_first = 0\nkernel.sched_domain.cpu0.domain0.busy_factor = 32\nkernel.sched_domain.cpu0.domain0.busy_idx = 2\nkernel.sched_domain.cpu0.domain0.cache_nice_tries = 1\nkernel.sched_domain.cpu0.domain0.flags = 4143\nkernel.sched_domain.cpu0.domain0.forkexec_idx = 0\nkernel.sched_domain.cpu0.domain0.idle_idx = 1\nkernel.sched_domain.cpu0.domain0.imbalance_pct = 125\nkernel.sched_domain.cpu0.domain0.max_interval = 4\nkernel.sched_domain.cpu0.domain0.max_newidle_lb_cost = 463528\nkernel.sched_domain.cpu0.domain0.min_interval = 2\nkernel.sched_domain.cpu0.domain0.name = DIE\nkernel.sched_domain.cpu0.domain0.newidle_idx = 0\nkernel.sched_domain.cpu0.domain0.wake_idx = 0\nkernel.sched_domain.cpu1.domain0.busy_factor = 32\nkernel.sched_domain.cpu1.domain0.busy_idx = 2\nkernel.sched_domain.cpu1.domain0.cache_nice_tries = 1\nkernel.sched_domain.cpu1.domain0.flags = 4143\nkernel.sched_domain.cpu1.domain0.forkexec_idx = 0\nkernel.sched_domain.cpu1.domain0.idle_idx = 1\nkernel.sched_domain.cpu1.domain0.imbalance_pct = 125\nkernel.sched_domain.cpu1.domain0.max_interval = 4\nkernel.sched_domain.cpu1.domain0.max_newidle_lb_cost = 30013\nkernel.sched_domain.cpu1.domain0.min_interval = 2\nkernel.sched_domain.cpu1.domain0.name = DIE\nkernel.sched_domain.cpu1.domain0.newidle_idx = 0\nkernel.sched_domain.cpu1.domain0.wake_idx = 0\nkernel.sched_latency_ns = 12000000\nkernel.sched_migration_cost_ns = 500000\nkernel.sched_min_granularity_ns = 1500000\nkernel.sched_nr_migrate = 32\nkernel.sched_rr_timeslice_ms = 25\nkernel.sched_rt_period_us = 1000000\nkernel.sched_rt_runtime_us = 950000\nkernel.sched_schedstats = 0\nkernel.sched_shares_window_ns = 10000000\nkernel.sched_time_avg_ms = 1000\nkernel.sched_tunable_scaling = 1\nkernel.sched_wakeup_granularity_ns = 2000000\nkernel.sem = 32000\t1024000000\t500\t32000\nkernel.sem_next_id = -1\nkernel.shm_next_id = -1\nkernel.shm_rmid_forced = 0\nkernel.shmall = 18446744073692774399\nkernel.shmmax = 18446744073692774399\nkernel.shmmni = 4096\nkernel.soft_watchdog = 1\nkernel.softlockup_all_cpu_backtrace = 0\nkernel.softlockup_panic = 0\nkernel.stack_tracer_enabled = 0\nkernel.sysctl_writes_strict = 1\nkernel.sysrq = 438\nkernel.tainted = 0\nkernel.threads-max = 32451\nkernel.timer_migration = 1\nkernel.traceoff_on_warning = 0\nkernel.tracepoint_printk = 0\nkernel.unprivileged_bpf_disabled = 0\nkernel.unprivileged_userns_clone = 0\nsysctl: permission denied on key 'kernel.usermodehelper.bset'\nsysctl: permission denied on key 'kernel.usermodehelper.inheritable'\nkernel.version = #1 SMP Debian 4.9.88-1+deb9u1 (2018-05-07)\nkernel.watchdog = 1\nkernel.watchdog_cpumask = 0-1\nkernel.watchdog_thresh = 10\nkernel.yama.ptrace_scope = 0\nnet.core.bpf_jit_enable = 0\nsysctl: permission denied on key 'net.core.bpf_jit_harden'\nnet.core.busy_poll = 0\nnet.core.busy_read = 0\nnet.core.default_qdisc = pfifo_fast\nnet.core.dev_weight = 64\nnet.core.flow_limit_cpu_bitmap = 0\nnet.core.flow_limit_table_len = 4096\nnet.core.max_skb_frags = 16\nnet.core.message_burst = 10\nnet.core.message_cost = 5\nnet.core.netdev_budget = 300\nnet.core.netdev_max_backlog = 1000\nnet.core.netdev_rss_key = 00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00\nnet.core.netdev_tstamp_prequeue = 1\nnet.core.optmem_max = 20480\nnet.core.rmem_default = 229376\nnet.core.rmem_max = 229376\nnet.core.rps_sock_flow_entries = 0\nnet.core.somaxconn = 128\nnet.core.tstamp_allow_data = 1\nnet.core.warnings = 0\nnet.core.wmem_default = 229376\nnet.core.wmem_max = 229376\nnet.core.xfrm_acq_expires = 30\nnet.core.xfrm_aevent_etime = 10\nnet.core.xfrm_aevent_rseqth = 2\nnet.core.xfrm_larval_drop = 1\nnet.ipv4.conf.all.accept_local = 0\nnet.ipv4.conf.all.accept_redirects = 1\nnet.ipv4.conf.all.accept_source_route = 0\nnet.ipv4.conf.all.arp_accept = 0\nnet.ipv4.conf.all.arp_announce = 0\nnet.ipv4.conf.all.arp_filter = 0\nnet.ipv4.conf.all.arp_ignore = 0\nnet.ipv4.conf.all.arp_notify = 0\nnet.ipv4.conf.all.bootp_relay = 0\nnet.ipv4.conf.all.disable_policy = 0\nnet.ipv4.conf.all.disable_xfrm = 0\nnet.ipv4.conf.all.drop_gratuitous_arp = 0\nnet.ipv4.conf.all.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.all.force_igmp_version = 0\nnet.ipv4.conf.all.forwarding = 0\nnet.ipv4.conf.all.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.all.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.all.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.all.log_martians = 0\nnet.ipv4.conf.all.mc_forwarding = 0\nnet.ipv4.conf.all.medium_id = 0\nnet.ipv4.conf.all.promote_secondaries = 0\nnet.ipv4.conf.all.proxy_arp = 0\nnet.ipv4.conf.all.proxy_arp_pvlan = 0\nnet.ipv4.conf.all.route_localnet = 0\nnet.ipv4.conf.all.rp_filter = 0\nnet.ipv4.conf.all.secure_redirects = 1\nnet.ipv4.conf.all.send_redirects = 1\nnet.ipv4.conf.all.shared_media = 1\nnet.ipv4.conf.all.src_valid_mark = 0\nnet.ipv4.conf.all.tag = 0\nnet.ipv4.conf.default.accept_local = 0\nnet.ipv4.conf.default.accept_redirects = 1\nnet.ipv4.conf.default.accept_source_route = 1\nnet.ipv4.conf.default.arp_accept = 0\nnet.ipv4.conf.default.arp_announce = 0\nnet.ipv4.conf.default.arp_filter = 0\nnet.ipv4.conf.default.arp_ignore = 0\nnet.ipv4.conf.default.arp_notify = 0\nnet.ipv4.conf.default.bootp_relay = 0\nnet.ipv4.conf.default.disable_policy = 0\nnet.ipv4.conf.default.disable_xfrm = 0\nnet.ipv4.conf.default.drop_gratuitous_arp = 0\nnet.ipv4.conf.default.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.default.force_igmp_version = 0\nnet.ipv4.conf.default.forwarding = 0\nnet.ipv4.conf.default.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.default.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.default.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.default.log_martians = 0\nnet.ipv4.conf.default.mc_forwarding = 0\nnet.ipv4.conf.default.medium_id = 0\nnet.ipv4.conf.default.promote_secondaries = 0\nnet.ipv4.conf.default.proxy_arp = 0\nnet.ipv4.conf.default.proxy_arp_pvlan = 0\nnet.ipv4.conf.default.route_localnet = 0\nnet.ipv4.conf.default.rp_filter = 0\nnet.ipv4.conf.default.secure_redirects = 1\nnet.ipv4.conf.default.send_redirects = 1\nnet.ipv4.conf.default.shared_media = 1\nnet.ipv4.conf.default.src_valid_mark = 0\nnet.ipv4.conf.default.tag = 0\nnet.ipv4.conf.eth0.accept_local = 0\nnet.ipv4.conf.eth0.accept_redirects = 1\nnet.ipv4.conf.eth0.accept_source_route = 1\nnet.ipv4.conf.eth0.arp_accept = 0\nnet.ipv4.conf.eth0.arp_announce = 0\nnet.ipv4.conf.eth0.arp_filter = 0\nnet.ipv4.conf.eth0.arp_ignore = 0\nnet.ipv4.conf.eth0.arp_notify = 0\nnet.ipv4.conf.eth0.bootp_relay = 0\nnet.ipv4.conf.eth0.disable_policy = 0\nnet.ipv4.conf.eth0.disable_xfrm = 0\nnet.ipv4.conf.eth0.drop_gratuitous_arp = 0\nnet.ipv4.conf.eth0.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.eth0.force_igmp_version = 0\nnet.ipv4.conf.eth0.forwarding = 0\nnet.ipv4.conf.eth0.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.eth0.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.eth0.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.eth0.log_martians = 0\nnet.ipv4.conf.eth0.mc_forwarding = 0\nnet.ipv4.conf.eth0.medium_id = 0\nnet.ipv4.conf.eth0.promote_secondaries = 0\nnet.ipv4.conf.eth0.proxy_arp = 0\nnet.ipv4.conf.eth0.proxy_arp_pvlan = 0\nnet.ipv4.conf.eth0.route_localnet = 0\nnet.ipv4.conf.eth0.rp_filter = 0\nnet.ipv4.conf.eth0.secure_redirects = 1\nnet.ipv4.conf.eth0.send_redirects = 1\nnet.ipv4.conf.eth0.shared_media = 1\nnet.ipv4.conf.eth0.src_valid_mark = 0\nnet.ipv4.conf.eth0.tag = 0\nnet.ipv4.conf.lo.accept_local = 0\nnet.ipv4.conf.lo.accept_redirects = 1\nnet.ipv4.conf.lo.accept_source_route = 1\nnet.ipv4.conf.lo.arp_accept = 0\nnet.ipv4.conf.lo.arp_announce = 0\nnet.ipv4.conf.lo.arp_filter = 0\nnet.ipv4.conf.lo.arp_ignore = 0\nnet.ipv4.conf.lo.arp_notify = 0\nnet.ipv4.conf.lo.bootp_relay = 0\nnet.ipv4.conf.lo.disable_policy = 1\nnet.ipv4.conf.lo.disable_xfrm = 1\nnet.ipv4.conf.lo.drop_gratuitous_arp = 0\nnet.ipv4.conf.lo.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.lo.force_igmp_version = 0\nnet.ipv4.conf.lo.forwarding = 0\nnet.ipv4.conf.lo.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.lo.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.lo.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.lo.log_martians = 0\nnet.ipv4.conf.lo.mc_forwarding = 0\nnet.ipv4.conf.lo.medium_id = 0\nnet.ipv4.conf.lo.promote_secondaries = 0\nnet.ipv4.conf.lo.proxy_arp = 0\nnet.ipv4.conf.lo.proxy_arp_pvlan = 0\nnet.ipv4.conf.lo.route_localnet = 0\nnet.ipv4.conf.lo.rp_filter = 0\nnet.ipv4.conf.lo.secure_redirects = 1\nnet.ipv4.conf.lo.send_redirects = 1\nnet.ipv4.conf.lo.shared_media = 1\nnet.ipv4.conf.lo.src_valid_mark = 0\nnet.ipv4.conf.lo.tag = 0\nnet.ipv4.fib_multipath_use_neigh = 0\nnet.ipv4.fwmark_reflect = 0\nnet.ipv4.icmp_echo_ignore_all = 0\nnet.ipv4.icmp_echo_ignore_broadcasts = 1\nnet.ipv4.icmp_errors_use_inbound_ifaddr = 0\nnet.ipv4.icmp_ignore_bogus_error_responses = 1\nnet.ipv4.icmp_msgs_burst = 50\nnet.ipv4.icmp_msgs_per_sec = 1000\nnet.ipv4.icmp_ratelimit = 1000\nnet.ipv4.icmp_ratemask = 6168\nnet.ipv4.igmp_link_local_mcast_reports = 1\nnet.ipv4.igmp_max_memberships = 20\nnet.ipv4.igmp_max_msf = 10\nnet.ipv4.igmp_qrv = 2\nnet.ipv4.inet_peer_maxttl = 600\nnet.ipv4.inet_peer_minttl = 120\nnet.ipv4.inet_peer_threshold = 65664\nnet.ipv4.ip_default_ttl = 64\nnet.ipv4.ip_dynaddr = 0\nnet.ipv4.ip_early_demux = 1\nnet.ipv4.ip_forward = 0\nnet.ipv4.ip_forward_use_pmtu = 0\nnet.ipv4.ip_local_port_range = 32768\t60999\nnet.ipv4.ip_local_reserved_ports = \nnet.ipv4.ip_no_pmtu_disc = 0\nnet.ipv4.ip_nonlocal_bind = 0\nnet.ipv4.ipfrag_high_thresh = 4194304\nnet.ipv4.ipfrag_low_thresh = 3145728\nnet.ipv4.ipfrag_max_dist = 64\nnet.ipv4.ipfrag_secret_interval = 0\nnet.ipv4.ipfrag_time = 30\nnet.ipv4.neigh.default.anycast_delay = 100\nnet.ipv4.neigh.default.app_solicit = 0\nnet.ipv4.neigh.default.base_reachable_time_ms = 30000\nnet.ipv4.neigh.default.delay_first_probe_time = 5\nnet.ipv4.neigh.default.gc_interval = 30\nnet.ipv4.neigh.default.gc_stale_time = 60\nnet.ipv4.neigh.default.gc_thresh1 = 128\nnet.ipv4.neigh.default.gc_thresh2 = 512\nnet.ipv4.neigh.default.gc_thresh3 = 1024\nnet.ipv4.neigh.default.locktime = 100\nnet.ipv4.neigh.default.mcast_resolicit = 0\nnet.ipv4.neigh.default.mcast_solicit = 3\nnet.ipv4.neigh.default.proxy_delay = 80\nnet.ipv4.neigh.default.proxy_qlen = 64\nnet.ipv4.neigh.default.retrans_time_ms = 1000\nnet.ipv4.neigh.default.ucast_solicit = 3\nnet.ipv4.neigh.default.unres_qlen = 30\nnet.ipv4.neigh.default.unres_qlen_bytes = 65536\nnet.ipv4.neigh.eth0.anycast_delay = 100\nnet.ipv4.neigh.eth0.app_solicit = 0\nnet.ipv4.neigh.eth0.base_reachable_time_ms = 30000\nnet.ipv4.neigh.eth0.delay_first_probe_time = 5\nnet.ipv4.neigh.eth0.gc_stale_time = 60\nnet.ipv4.neigh.eth0.locktime = 100\nnet.ipv4.neigh.eth0.mcast_resolicit = 0\nnet.ipv4.neigh.eth0.mcast_solicit = 3\nnet.ipv4.neigh.eth0.proxy_delay = 80\nnet.ipv4.neigh.eth0.proxy_qlen = 64\nnet.ipv4.neigh.eth0.retrans_time_ms = 1000\nnet.ipv4.neigh.eth0.ucast_solicit = 3\nnet.ipv4.neigh.eth0.unres_qlen = 30\nnet.ipv4.neigh.eth0.unres_qlen_bytes = 65536\nnet.ipv4.neigh.lo.anycast_delay = 100\nnet.ipv4.neigh.lo.app_solicit = 0\nnet.ipv4.neigh.lo.base_reachable_time_ms = 30000\nnet.ipv4.neigh.lo.delay_first_probe_time = 5\nnet.ipv4.neigh.lo.gc_stale_time = 60\nnet.ipv4.neigh.lo.locktime = 100\nnet.ipv4.neigh.lo.mcast_resolicit = 0\nnet.ipv4.neigh.lo.mcast_solicit = 3\nnet.ipv4.neigh.lo.proxy_delay = 80\nnet.ipv4.neigh.lo.proxy_qlen = 64\nnet.ipv4.neigh.lo.retrans_time_ms = 1000\nnet.ipv4.neigh.lo.ucast_solicit = 3\nnet.ipv4.neigh.lo.unres_qlen = 30\nnet.ipv4.neigh.lo.unres_qlen_bytes = 65536\nnet.ipv4.ping_group_range = 1\t0\nnet.ipv4.route.error_burst = 1250\nnet.ipv4.route.error_cost = 250\nnet.ipv4.route.gc_elasticity = 8\nnet.ipv4.route.gc_interval = 60\nnet.ipv4.route.gc_min_interval = 0\nnet.ipv4.route.gc_min_interval_ms = 500\nnet.ipv4.route.gc_thresh = -1\nnet.ipv4.route.gc_timeout = 300\nnet.ipv4.route.max_size = 2147483647\nnet.ipv4.route.min_adv_mss = 256\nnet.ipv4.route.min_pmtu = 552\nnet.ipv4.route.mtu_expires = 600\nnet.ipv4.route.redirect_load = 5\nnet.ipv4.route.redirect_number = 9\nnet.ipv4.route.redirect_silence = 5120\nnet.ipv4.tcp_abort_on_overflow = 0\nnet.ipv4.tcp_adv_win_scale = 1\nnet.ipv4.tcp_allowed_congestion_control = cubic reno\nnet.ipv4.tcp_app_win = 31\nnet.ipv4.tcp_autocorking = 1\nnet.ipv4.tcp_available_congestion_control = cubic reno\nnet.ipv4.tcp_base_mss = 1024\nnet.ipv4.tcp_challenge_ack_limit = 1000\nnet.ipv4.tcp_congestion_control = cubic\nnet.ipv4.tcp_dsack = 1\nnet.ipv4.tcp_early_retrans = 3\nnet.ipv4.tcp_ecn = 2\nnet.ipv4.tcp_ecn_fallback = 1\nnet.ipv4.tcp_fack = 1\nnet.ipv4.tcp_fastopen = 1\nsysctl: permission denied on key 'net.ipv4.tcp_fastopen_key'\nnet.ipv4.tcp_fin_timeout = 60\nnet.ipv4.tcp_frto = 2\nnet.ipv4.tcp_fwmark_accept = 0\nnet.ipv4.tcp_invalid_ratelimit = 500\nnet.ipv4.tcp_keepalive_intvl = 75\nnet.ipv4.tcp_keepalive_probes = 9\nnet.ipv4.tcp_keepalive_time = 7200\nnet.ipv4.tcp_l3mdev_accept = 0\nnet.ipv4.tcp_limit_output_bytes = 262144\nnet.ipv4.tcp_low_latency = 0\nnet.ipv4.tcp_max_orphans = 16384\nnet.ipv4.tcp_max_reordering = 300\nnet.ipv4.tcp_max_syn_backlog = 128\nnet.ipv4.tcp_max_tw_buckets = 16384\nnet.ipv4.tcp_mem = 3030\t4041\t6060\nnet.ipv4.tcp_min_rtt_wlen = 300\nnet.ipv4.tcp_min_tso_segs = 2\nnet.ipv4.tcp_moderate_rcvbuf = 1\nnet.ipv4.tcp_mtu_probing = 0\nnet.ipv4.tcp_no_metrics_save = 0\nnet.ipv4.tcp_notsent_lowat = 4294967295\nnet.ipv4.tcp_orphan_retries = 0\nnet.ipv4.tcp_pacing_ca_ratio = 120\nnet.ipv4.tcp_pacing_ss_ratio = 200\nnet.ipv4.tcp_probe_interval = 600\nnet.ipv4.tcp_probe_threshold = 8\nnet.ipv4.tcp_recovery = 1\nnet.ipv4.tcp_reordering = 3\nnet.ipv4.tcp_retrans_collapse = 1\nnet.ipv4.tcp_retries1 = 3\nnet.ipv4.tcp_retries2 = 15\nnet.ipv4.tcp_rfc1337 = 0\nnet.ipv4.tcp_rmem = 65536\t87380\t6291456\nnet.ipv4.tcp_sack = 1\nnet.ipv4.tcp_slow_start_after_idle = 1\nnet.ipv4.tcp_stdurg = 0\nnet.ipv4.tcp_syn_retries = 6\nnet.ipv4.tcp_synack_retries = 5\nnet.ipv4.tcp_syncookies = 1\nnet.ipv4.tcp_thin_dupack = 0\nnet.ipv4.tcp_thin_linear_timeouts = 0\nnet.ipv4.tcp_timestamps = 1\nnet.ipv4.tcp_tso_win_divisor = 3\nnet.ipv4.tcp_tw_recycle = 0\nnet.ipv4.tcp_tw_reuse = 0\nnet.ipv4.tcp_window_scaling = 1\nnet.ipv4.tcp_wmem = 65536\t16384\t4194304\nnet.ipv4.tcp_workaround_signed_windows = 0\nnet.ipv4.udp_mem = 6060\t8082\t12120\nnet.ipv4.udp_rmem_min = 65536\nnet.ipv4.udp_wmem_min = 65536\nnet.ipv4.xfrm4_gc_thresh = 2147483647\nnet.ipv6.anycast_src_echo_reply = 0\nnet.ipv6.auto_flowlabels = 1\nnet.ipv6.bindv6only = 0\nnet.ipv6.conf.all.accept_dad = 1\nnet.ipv6.conf.all.accept_ra = 1\nnet.ipv6.conf.all.accept_ra_defrtr = 1\nnet.ipv6.conf.all.accept_ra_from_local = 0\nnet.ipv6.conf.all.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.all.accept_ra_mtu = 1\nnet.ipv6.conf.all.accept_ra_pinfo = 1\nnet.ipv6.conf.all.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.all.accept_ra_rtr_pref = 1\nnet.ipv6.conf.all.accept_redirects = 1\nnet.ipv6.conf.all.accept_source_route = 0\nnet.ipv6.conf.all.autoconf = 1\nnet.ipv6.conf.all.dad_transmits = 1\nnet.ipv6.conf.all.disable_ipv6 = 0\nnet.ipv6.conf.all.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.all.drop_unsolicited_na = 0\nnet.ipv6.conf.all.force_mld_version = 0\nnet.ipv6.conf.all.force_tllao = 0\nnet.ipv6.conf.all.forwarding = 0\nnet.ipv6.conf.all.hop_limit = 64\nnet.ipv6.conf.all.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.all.keep_addr_on_down = 0\nnet.ipv6.conf.all.max_addresses = 16\nnet.ipv6.conf.all.max_desync_factor = 600\nnet.ipv6.conf.all.mc_forwarding = 0\nnet.ipv6.conf.all.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.all.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.all.mtu = 1280\nnet.ipv6.conf.all.ndisc_notify = 0\nnet.ipv6.conf.all.optimistic_dad = 0\nnet.ipv6.conf.all.proxy_ndp = 0\nnet.ipv6.conf.all.regen_max_retry = 3\nnet.ipv6.conf.all.router_probe_interval = 60\nnet.ipv6.conf.all.router_solicitation_delay = 1\nnet.ipv6.conf.all.router_solicitation_interval = 4\nnet.ipv6.conf.all.router_solicitation_max_interval = 3600\nnet.ipv6.conf.all.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.all.stable_secret'\nnet.ipv6.conf.all.suppress_frag_ndisc = 1\nnet.ipv6.conf.all.temp_prefered_lft = 86400\nnet.ipv6.conf.all.temp_valid_lft = 604800\nnet.ipv6.conf.all.use_oif_addrs_only = 0\nnet.ipv6.conf.all.use_optimistic = 0\nnet.ipv6.conf.all.use_tempaddr = 0\nnet.ipv6.conf.default.accept_dad = 1\nnet.ipv6.conf.default.accept_ra = 1\nnet.ipv6.conf.default.accept_ra_defrtr = 1\nnet.ipv6.conf.default.accept_ra_from_local = 0\nnet.ipv6.conf.default.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.default.accept_ra_mtu = 1\nnet.ipv6.conf.default.accept_ra_pinfo = 1\nnet.ipv6.conf.default.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.default.accept_ra_rtr_pref = 1\nnet.ipv6.conf.default.accept_redirects = 1\nnet.ipv6.conf.default.accept_source_route = 0\nnet.ipv6.conf.default.autoconf = 1\nnet.ipv6.conf.default.dad_transmits = 1\nnet.ipv6.conf.default.disable_ipv6 = 0\nnet.ipv6.conf.default.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.default.drop_unsolicited_na = 0\nnet.ipv6.conf.default.force_mld_version = 0\nnet.ipv6.conf.default.force_tllao = 0\nnet.ipv6.conf.default.forwarding = 0\nnet.ipv6.conf.default.hop_limit = 64\nnet.ipv6.conf.default.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.default.keep_addr_on_down = 0\nnet.ipv6.conf.default.max_addresses = 16\nnet.ipv6.conf.default.max_desync_factor = 600\nnet.ipv6.conf.default.mc_forwarding = 0\nnet.ipv6.conf.default.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.default.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.default.mtu = 1280\nnet.ipv6.conf.default.ndisc_notify = 0\nnet.ipv6.conf.default.optimistic_dad = 0\nnet.ipv6.conf.default.proxy_ndp = 0\nnet.ipv6.conf.default.regen_max_retry = 3\nnet.ipv6.conf.default.router_probe_interval = 60\nnet.ipv6.conf.default.router_solicitation_delay = 1\nnet.ipv6.conf.default.router_solicitation_interval = 4\nnet.ipv6.conf.default.router_solicitation_max_interval = 3600\nnet.ipv6.conf.default.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.default.stable_secret'\nnet.ipv6.conf.default.suppress_frag_ndisc = 1\nnet.ipv6.conf.default.temp_prefered_lft = 86400\nnet.ipv6.conf.default.temp_valid_lft = 604800\nnet.ipv6.conf.default.use_oif_addrs_only = 0\nnet.ipv6.conf.default.use_optimistic = 0\nnet.ipv6.conf.default.use_tempaddr = 0\nnet.ipv6.conf.eth0.accept_dad = 1\nnet.ipv6.conf.eth0.accept_ra = 1\nnet.ipv6.conf.eth0.accept_ra_defrtr = 1\nnet.ipv6.conf.eth0.accept_ra_from_local = 0\nnet.ipv6.conf.eth0.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.eth0.accept_ra_mtu = 1\nnet.ipv6.conf.eth0.accept_ra_pinfo = 1\nnet.ipv6.conf.eth0.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.eth0.accept_ra_rtr_pref = 1\nnet.ipv6.conf.eth0.accept_redirects = 1\nnet.ipv6.conf.eth0.accept_source_route = 0\nnet.ipv6.conf.eth0.autoconf = 1\nnet.ipv6.conf.eth0.dad_transmits = 1\nnet.ipv6.conf.eth0.disable_ipv6 = 0\nnet.ipv6.conf.eth0.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.eth0.drop_unsolicited_na = 0\nnet.ipv6.conf.eth0.force_mld_version = 0\nnet.ipv6.conf.eth0.force_tllao = 0\nnet.ipv6.conf.eth0.forwarding = 0\nnet.ipv6.conf.eth0.hop_limit = 64\nnet.ipv6.conf.eth0.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.eth0.keep_addr_on_down = 0\nnet.ipv6.conf.eth0.max_addresses = 16\nnet.ipv6.conf.eth0.max_desync_factor = 600\nnet.ipv6.conf.eth0.mc_forwarding = 0\nnet.ipv6.conf.eth0.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.eth0.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.eth0.mtu = 1500\nnet.ipv6.conf.eth0.ndisc_notify = 0\nnet.ipv6.conf.eth0.optimistic_dad = 0\nnet.ipv6.conf.eth0.proxy_ndp = 0\nnet.ipv6.conf.eth0.regen_max_retry = 3\nnet.ipv6.conf.eth0.router_probe_interval = 60\nnet.ipv6.conf.eth0.router_solicitation_delay = 1\nnet.ipv6.conf.eth0.router_solicitation_interval = 4\nnet.ipv6.conf.eth0.router_solicitation_max_interval = 3600\nnet.ipv6.conf.eth0.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.eth0.stable_secret'\nnet.ipv6.conf.eth0.suppress_frag_ndisc = 1\nnet.ipv6.conf.eth0.temp_prefered_lft = 86400\nnet.ipv6.conf.eth0.temp_valid_lft = 604800\nnet.ipv6.conf.eth0.use_oif_addrs_only = 0\nnet.ipv6.conf.eth0.use_optimistic = 0\nnet.ipv6.conf.eth0.use_tempaddr = 0\nnet.ipv6.conf.lo.accept_dad = -1\nnet.ipv6.conf.lo.accept_ra = 1\nnet.ipv6.conf.lo.accept_ra_defrtr = 1\nnet.ipv6.conf.lo.accept_ra_from_local = 0\nnet.ipv6.conf.lo.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.lo.accept_ra_mtu = 1\nnet.ipv6.conf.lo.accept_ra_pinfo = 1\nnet.ipv6.conf.lo.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.lo.accept_ra_rtr_pref = 1\nnet.ipv6.conf.lo.accept_redirects = 1\nnet.ipv6.conf.lo.accept_source_route = 0\nnet.ipv6.conf.lo.autoconf = 1\nnet.ipv6.conf.lo.dad_transmits = 1\nnet.ipv6.conf.lo.disable_ipv6 = 0\nnet.ipv6.conf.lo.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.lo.drop_unsolicited_na = 0\nnet.ipv6.conf.lo.force_mld_version = 0\nnet.ipv6.conf.lo.force_tllao = 0\nnet.ipv6.conf.lo.forwarding = 0\nnet.ipv6.conf.lo.hop_limit = 64\nnet.ipv6.conf.lo.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.lo.keep_addr_on_down = 0\nnet.ipv6.conf.lo.max_addresses = 16\nnet.ipv6.conf.lo.max_desync_factor = 600\nnet.ipv6.conf.lo.mc_forwarding = 0\nnet.ipv6.conf.lo.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.lo.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.lo.mtu = 65536\nnet.ipv6.conf.lo.ndisc_notify = 0\nnet.ipv6.conf.lo.optimistic_dad = 0\nnet.ipv6.conf.lo.proxy_ndp = 0\nnet.ipv6.conf.lo.regen_max_retry = 3\nnet.ipv6.conf.lo.router_probe_interval = 60\nnet.ipv6.conf.lo.router_solicitation_delay = 1\nnet.ipv6.conf.lo.router_solicitation_interval = 4\nnet.ipv6.conf.lo.router_solicitation_max_interval = 3600\nnet.ipv6.conf.lo.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.lo.stable_secret'\nnet.ipv6.conf.lo.suppress_frag_ndisc = 1\nnet.ipv6.conf.lo.temp_prefered_lft = 86400\nnet.ipv6.conf.lo.temp_valid_lft = 604800\nnet.ipv6.conf.lo.use_oif_addrs_only = 0\nnet.ipv6.conf.lo.use_optimistic = 0\nnet.ipv6.conf.lo.use_tempaddr = -1\nnet.ipv6.flowlabel_consistency = 1\nnet.ipv6.flowlabel_state_ranges = 0\nnet.ipv6.fwmark_reflect = 0\nnet.ipv6.icmp.ratelimit = 1000\nnet.ipv6.idgen_delay = 1\nnet.ipv6.idgen_retries = 3\nnet.ipv6.ip6frag_high_thresh = 4194304\nnet.ipv6.ip6frag_low_thresh = 3145728\nnet.ipv6.ip6frag_secret_interval = 0\nnet.ipv6.ip6frag_time = 60\nnet.ipv6.ip_nonlocal_bind = 0\nnet.ipv6.mld_max_msf = 64\nnet.ipv6.mld_qrv = 2\nnet.ipv6.neigh.default.anycast_delay = 100\nnet.ipv6.neigh.default.app_solicit = 0\nnet.ipv6.neigh.default.base_reachable_time_ms = 30000\nnet.ipv6.neigh.default.delay_first_probe_time = 5\nnet.ipv6.neigh.default.gc_interval = 30\nnet.ipv6.neigh.default.gc_stale_time = 60\nnet.ipv6.neigh.default.gc_thresh1 = 128\nnet.ipv6.neigh.default.gc_thresh2 = 512\nnet.ipv6.neigh.default.gc_thresh3 = 1024\nnet.ipv6.neigh.default.locktime = 0\nnet.ipv6.neigh.default.mcast_resolicit = 0\nnet.ipv6.neigh.default.mcast_solicit = 3\nnet.ipv6.neigh.default.proxy_delay = 80\nnet.ipv6.neigh.default.proxy_qlen = 64\nnet.ipv6.neigh.default.retrans_time_ms = 1000\nnet.ipv6.neigh.default.ucast_solicit = 3\nnet.ipv6.neigh.default.unres_qlen = 30\nnet.ipv6.neigh.default.unres_qlen_bytes = 65536\nnet.ipv6.neigh.eth0.anycast_delay = 100\nnet.ipv6.neigh.eth0.app_solicit = 0\nnet.ipv6.neigh.eth0.base_reachable_time_ms = 30000\nnet.ipv6.neigh.eth0.delay_first_probe_time = 5\nnet.ipv6.neigh.eth0.gc_stale_time = 60\nnet.ipv6.neigh.eth0.locktime = 0\nnet.ipv6.neigh.eth0.mcast_resolicit = 0\nnet.ipv6.neigh.eth0.mcast_solicit = 3\nnet.ipv6.neigh.eth0.proxy_delay = 80\nnet.ipv6.neigh.eth0.proxy_qlen = 64\nnet.ipv6.neigh.eth0.retrans_time_ms = 1000\nnet.ipv6.neigh.eth0.ucast_solicit = 3\nnet.ipv6.neigh.eth0.unres_qlen = 30\nnet.ipv6.neigh.eth0.unres_qlen_bytes = 65536\nnet.ipv6.neigh.lo.anycast_delay = 100\nnet.ipv6.neigh.lo.app_solicit = 0\nnet.ipv6.neigh.lo.base_reachable_time_ms = 30000\nnet.ipv6.neigh.lo.delay_first_probe_time = 5\nnet.ipv6.neigh.lo.gc_stale_time = 60\nnet.ipv6.neigh.lo.locktime = 0\nnet.ipv6.neigh.lo.mcast_resolicit = 0\nnet.ipv6.neigh.lo.mcast_solicit = 3\nnet.ipv6.neigh.lo.proxy_delay = 80\nnet.ipv6.neigh.lo.proxy_qlen = 64\nnet.ipv6.neigh.lo.retrans_time_ms = 1000\nnet.ipv6.neigh.lo.ucast_solicit = 3\nnet.ipv6.neigh.lo.unres_qlen = 30\nnet.ipv6.neigh.lo.unres_qlen_bytes = 65536\nnet.ipv6.route.gc_elasticity = 9\nnet.ipv6.route.gc_interval = 30\nnet.ipv6.route.gc_min_interval = 0\nnet.ipv6.route.gc_min_interval_ms = 500\nnet.ipv6.route.gc_thresh = 1024\nnet.ipv6.route.gc_timeout = 60\nnet.ipv6.route.max_size = 4096\nnet.ipv6.route.min_adv_mss = 1220\nnet.ipv6.route.mtu_expires = 600\nnet.ipv6.xfrm6_gc_thresh = 2147483647\nnet.netfilter.nf_log.0 = NONE\nnet.netfilter.nf_log.1 = NONE\nnet.netfilter.nf_log.10 = NONE\nnet.netfilter.nf_log.11 = NONE\nnet.netfilter.nf_log.12 = NONE\nnet.netfilter.nf_log.2 = NONE\nnet.netfilter.nf_log.3 = NONE\nnet.netfilter.nf_log.4 = NONE\nnet.netfilter.nf_log.5 = NONE\nnet.netfilter.nf_log.6 = NONE\nnet.netfilter.nf_log.7 = NONE\nnet.netfilter.nf_log.8 = NONE\nnet.netfilter.nf_log.9 = NONE\nnet.unix.max_dgram_qlen = 512\nuser.max_cgroup_namespaces = 16225\nuser.max_ipc_namespaces = 16225\nuser.max_mnt_namespaces = 16225\nuser.max_net_namespaces = 16225\nuser.max_pid_namespaces = 16225\nuser.max_user_namespaces = 16225\nuser.max_uts_namespaces = 16225\nvm.admin_reserve_kbytes = 8192\nvm.block_dump = 0\nvm.compact_unevictable_allowed = 1\nvm.dirty_background_bytes = 0\nvm.dirty_background_ratio = 10\nvm.dirty_bytes = 0\nvm.dirty_expire_centisecs = 3000\nvm.dirty_ratio = 20\nvm.dirty_writeback_centisecs = 500\nvm.dirtytime_expire_seconds = 43200\nvm.drop_caches = 0\nvm.extfrag_threshold = 500\nvm.hugepages_treat_as_movable = 0\nvm.hugetlb_shm_group = 0\nvm.laptop_mode = 0\nvm.legacy_va_layout = 0\nvm.lowmem_reserve_ratio = 256\t256\t32\nvm.max_map_count = 65530\nvm.memory_failure_early_kill = 0\nvm.memory_failure_recovery = 1\nvm.min_free_kbytes = 8152\nvm.min_slab_ratio = 5\nvm.min_unmapped_ratio = 1\nvm.mmap_min_addr = 4096\nsysctl: reading key \"vm.nr_hugepages\"\nsysctl: reading key \"vm.nr_hugepages_mempolicy\"\nsysctl: reading key \"vm.nr_overcommit_hugepages\"\nvm.nr_pdflush_threads = 0\nvm.numa_zonelist_order = default\nvm.oom_dump_tasks = 1\nvm.oom_kill_allocating_task = 0\nvm.overcommit_kbytes = 0\nvm.overcommit_memory = 0\nvm.overcommit_ratio = 50\nvm.page-cluster = 3\nvm.panic_on_oom = 0\nvm.percpu_pagelist_fraction = 0\nvm.stat_interval = 1\nsysctl: permission denied on key 'vm.stat_refresh'\nvm.swappiness = 60\nvm.user_reserve_kbytes = 129404\nvm.vfs_cache_pressure = 100\nvm.watermark_scale_factor = 10\nvm.zone_reclaim_mode = 0\n",
+ "meminfo": "MemTotal: 4175424 kB\nMemFree: 2691072 kB\nMemAvailable: 3811392 kB\nBuffers: 117632 kB\nCached: 1049856 kB\nSwapCached: 0 kB\nActive: 990272 kB\nInactive: 362304 kB\nActive(anon): 186880 kB\nInactive(anon): 78592 kB\nActive(file): 803392 kB\nInactive(file): 283712 kB\nUnevictable: 0 kB\nMlocked: 0 kB\nSwapTotal: 0 kB\nSwapFree: 0 kB\nDirty: 14976 kB\nWriteback: 0 kB\nAnonPages: 182720 kB\nMapped: 49856 kB\nShmem: 82048 kB\nSlab: 107712 kB\nSReclaimable: 73984 kB\nSUnreclaim: 33728 kB\nKernelStack: 1840 kB\nPageTables: 3584 kB\nNFS_Unstable: 0 kB\nBounce: 0 kB\nWritebackTmp: 0 kB\nCommitLimit: 2087680 kB\nCommitted_AS: 539584 kB\nVmallocTotal: 8589934592 kB\nVmallocUsed: 0 kB\nVmallocChunk: 0 kB\nHardwareCorrupted: 0 kB\nAnonHugePages: 0 kB\nShmemHugePages: 0 kB\nShmemPmdMapped: 0 kB\nCmaTotal: 0 kB\nCmaFree: 0 kB\n"
+ }
+} \ No newline at end of file
diff --git a/client/post-example/upload.py b/client/post-example/upload.py
new file mode 100644
index 0000000..467497c
--- /dev/null
+++ b/client/post-example/upload.py
@@ -0,0 +1,40 @@
+# -*- encoding:utf-8 -*-
+
+import json
+import codecs
+import urllib2
+def byteify(input):
+ if isinstance(input, dict):
+ return {byteify(key):byteify(value) for key,value in input.iteritems()}
+ elif isinstance(input, list):
+ return [byteify(element) for element in input]
+ elif isinstance(input, unicode):
+ return input.encode('utf-8')
+ else:
+ return input
+
+
+token = '0ae27ecb064ff5283296b297bac77d9e'
+# BASE_URL = 'http://140.211.168.111:8080/'
+BASE_URL = 'http://127.0.0.1:8000/'
+PATH_URL = 'upload/'
+url = BASE_URL + PATH_URL
+
+def http_post(url, data, token):
+ postdata = data
+ post = []
+ post.append(postdata)
+ req = urllib2.Request(url, json.dumps(post))
+ access_token = token
+ req.add_header('Authorization', access_token) # add token in header
+ req.add_header('Content-Type', 'application/json')
+ response = urllib2.urlopen(req)
+ result = json.loads(response.read())
+ print result.encode('utf-8')
+
+with open("./results.json",'r') as load_f:
+ load_dict = (json.load(load_f, encoding="UTF-8"))
+ http_post(url,load_dict,token)
+
+# for line in s:
+# print line.encode('utf-8') \ No newline at end of file
diff --git a/front-end/.project b/front-end/.project
new file mode 100644
index 0000000..128392a
--- /dev/null
+++ b/front-end/.project
@@ -0,0 +1,28 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<projectDescription>
+ <name>pgperffarm-front-end</name>
+ <comment></comment>
+ <projects>
+ </projects>
+ <buildSpec>
+ <buildCommand>
+ <name>com.aptana.ide.core.unifiedBuilder</name>
+ <arguments>
+ </arguments>
+ </buildCommand>
+ </buildSpec>
+ <natures>
+ <nature>com.aptana.projects.webnature</nature>
+ </natures>
+ <filteredResources>
+ <filter>
+ <id>1520957481248</id>
+ <name></name>
+ <type>26</type>
+ <matcher>
+ <id>org.eclipse.ui.ide.multiFilter</id>
+ <arguments>1.0-name-matches-false-false-node_modules</arguments>
+ </matcher>
+ </filter>
+ </filteredResources>
+</projectDescription>
diff --git a/front-end/README.md b/front-end/README.md
new file mode 100644
index 0000000..88db47d
--- /dev/null
+++ b/front-end/README.md
@@ -0,0 +1,24 @@
+# PostgreSql Performance Farm
+
+The PostgreSQL Performance Farm project is a community project to collect performance data from tests as code changes are made to PostgreSQL. To support this effort, a database needs to be created for storing results, and a Web site developed to review results. This project will focus on developing the Web site on top of the database.
+The database will be using PostgreSQL in the back-end. Test results will come in the form of JSON and flat files. The Web application will be developed using the Django Web framework.
+
+### Installing Yarn
+
+Read the [Installation Guide](https://yarnpkg.com/en/docs/install) on our website for detailed instructions on how to install Yarn.
+
+#### Develop
+
+Webpack auto-watches client assets.
+
+```
+yarn install
+yarn run dev
+```
+
+#### Build
+
+Bundle the assets for production.
+
+```
+``` \ No newline at end of file
diff --git a/front-end/package.json b/front-end/package.json
new file mode 100644
index 0000000..17ad0d3
--- /dev/null
+++ b/front-end/package.json
@@ -0,0 +1,38 @@
+{
+ "name": "pg-perf-farm",
+ "version": "1.0.0",
+ "main": "index.js",
+ "license": "MIT",
+ "scripts": {
+ "dev": "node_modules/.bin/webpack-dev-server",
+ "dist": "WEBPACK_ENV=online node_modules/.bin/webpack -p",
+ "dist_win": "set WEBPACK_ENV=online&& ./node_modules/.bin/webpack -p"
+ },
+ "devDependencies": {
+ "babel-core": "6.26.0",
+ "babel-loader": "7.1.2",
+ "babel-preset-env": "1.6.1",
+ "babel-preset-react": "6.24.1",
+ "css-loader": "0.28.8",
+ "extract-text-webpack-plugin": "3.0.2",
+ "file-loader": "1.1.6",
+ "html-webpack-plugin": "2.30.1",
+ "node-sass": "4.7.2",
+ "sass-loader": "6.0.6",
+ "style-loader": "0.19.1",
+ "url-loader": "0.6.2",
+ "webpack": "3.10.0",
+ "webpack-dev-server": "2.9.7"
+ },
+ "dependencies": {
+ "echarts": "^4.1.0",
+ "font-awesome": "^4.7.0",
+ "rc-pagination": "^1.16.3",
+ "react": "16.2.0",
+ "react-dom": "16.2.0",
+ "react-router-dom": "4.2.2",
+ "react-router-transition": "^1.2.1",
+ "react-table": "^6.8.6",
+ "semantic-ui-react": "^0.80.2"
+ }
+}
diff --git a/front-end/src/app.jsx b/front-end/src/app.jsx
new file mode 100644
index 0000000..60f0002
--- /dev/null
+++ b/front-end/src/app.jsx
@@ -0,0 +1,104 @@
+import React from 'react';
+import ReactDom from 'react-dom';
+import {HashRouter as Router, Route, Link, Redirect, Switch} from 'react-router-dom';
+import createHistory from 'history/createHashHistory'
+const history = createHistory()
+import {spring, AnimatedRoute, AnimatedSwitch} from 'react-router-transition';
+// layout
+import Layout from 'component/layout/index.jsx'
+// page
+import Login from './page/login/index.jsx'
+import Home from './page/home/index.jsx'
+import Status from './page/status/index.jsx'
+import Machine from './page/machine/index.jsx'
+import PPolicy from './page/ppolicy/index.jsx'
+
+import DetailInfo from './page/detailInfo/index.jsx'
+import MachinelInfo from './page/machineInfo/index.jsx'
+
+import Portal from './page/portal/index.jsx'
+import FarmerApply from './page/farmerApply/index.jsx'
+
+// we need to map the `scale` prop we define below
+// to the transform style property
+function mapStyles(styles) {
+ return {
+ opacity: styles.opacity,
+ transform: `scale(${styles.scale})`,
+ };
+}
+
+// wrap the `spring` helper to use a bouncy config
+function bounce(val) {
+ return spring(val, {
+ stiffness: 330,
+ damping: 22,
+ });
+}
+
+// child matches will...
+const bounceTransition = {
+ // start in a transparent, upscaled state
+ atEnter: {
+ opacity: 0,
+ scale: 1.2,
+ },
+ // leave in a transparent, downscaled state
+ atLeave: {
+ opacity: bounce(0),
+ scale: bounce(0.8),
+ },
+ // and rest at an opaque, normally-scaled state
+ atActive: {
+ opacity: bounce(1),
+ scale: bounce(1),
+ },
+};
+
+class App extends React.Component {
+ constructor(props) {
+ super(props);
+ }
+
+
+ render() {
+ let LayoutRouter = (
+ <Layout>
+ <Route exact path="/login/" component={Login}/>
+ <Route exact path="/" component={Home}/>
+
+ <Route exact path="/home/" component={Home}/>
+ <Route exact path="/status/" component={Status}/>
+ <Route exact path="/machine/" component={Machine}/>
+ <Route exact path="/ppolicy/" component={PPolicy}/>
+
+ <Route exact path="/portal/" component={Portal}/>
+ <Route exact path="/farmerApply/" component={FarmerApply}/>
+ <Route path="/detailInfo/:uuid" component={DetailInfo}/>
+ <Route path="/machineInfo/:machine_sn" component={MachinelInfo}/>
+ {/*<Redirect exact from="/order" to="/order/index"/>*/}
+ {/*<Redirect exact from="/user" to="/user/index"/>*/}
+ {/*<Route component={ErrorPage}/>*/}
+ </Layout>
+ );
+ return (
+ <Router>
+ <AnimatedSwitch
+ atEnter={bounceTransition.atEnter}
+ atLeave={bounceTransition.atLeave}
+ atActive={bounceTransition.atActive}
+ mapStyles={mapStyles}
+ className="route-wrapper"
+ >
+ {/*<Route path="/login" component={Login}/>*/}
+ <Route path="/" render={ props => LayoutRouter}/>
+ </AnimatedSwitch>
+ </Router>
+ )
+ }
+}
+
+ReactDom.render(
+ <App />,
+ document.getElementById("app")
+);
diff --git a/front-end/src/component/client-box/index.css b/front-end/src/component/client-box/index.css
new file mode 100644
index 0000000..b96f59e
--- /dev/null
+++ b/front-end/src/component/client-box/index.css
@@ -0,0 +1,6 @@
+.improve{
+ background-color: #d9f7be;
+}
+.decline{
+ background-color: #ffccc7;
+} \ No newline at end of file
diff --git a/front-end/src/component/client-box/index.jsx b/front-end/src/component/client-box/index.jsx
new file mode 100644
index 0000000..5fc6599
--- /dev/null
+++ b/front-end/src/component/client-box/index.jsx
@@ -0,0 +1,32 @@
+import React from 'react';
+import './index.css';
+import classNames from 'classnames';
+class ClientBox extends React.Component {
+ constructor(props) {
+ super(props);
+
+ this.state = {
+ isImprove: true,
+ };
+
+ }
+
+ render() {
+ let imgSrc = require('image/client-icon/' + this.props.clientNum + '.png');
+ let std = this.props.std;
+ let median = this.props.median;
+ let boxClass = classNames({
+ 'client-box': true,
+ 'improve': median > std,
+ 'decline': (median <= std)
+ });
+
+ return (
+ <div className={boxClass}>
+ <img src={imgSrc} alt=""/>
+ </div>
+ );
+ }
+}
+
+export default ClientBox; \ No newline at end of file
diff --git a/front-end/src/component/farmer-card/index.css b/front-end/src/component/farmer-card/index.css
new file mode 100644
index 0000000..cd3a3a8
--- /dev/null
+++ b/front-end/src/component/farmer-card/index.css
@@ -0,0 +1,5 @@
+.flex-box{
+ display: flex;
+ justify-content:center;
+ align-items:center;
+} \ No newline at end of file
diff --git a/front-end/src/component/farmer-card/index.jsx b/front-end/src/component/farmer-card/index.jsx
new file mode 100644
index 0000000..e226e4f
--- /dev/null
+++ b/front-end/src/component/farmer-card/index.jsx
@@ -0,0 +1,52 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import NavTop from 'component/nav-top/index.jsx';
+// import './index.css';
+import {Image, Card, Button, List, Icon} from 'semantic-ui-react'
+class FarmerCard extends React.Component {
+ constructor(props){
+ super(props);
+ }
+ render(){
+ let machine = this.props.machine
+ let system = machine.os_name + ' ' + machine.os_version;
+ let camp = machine.comp_name + ' ' + machine.comp_version;
+ let owner = machine.owner || {}
+ return (
+
+ <div className="farmer-card">
+ <Card>
+ <Card.Content>
+ <Image floated='right' size='mini'
+ src={machine.avatar}/>
+ <Card.Header>Farmer: {machine.alias}</Card.Header>
+ <Card.Meta>report num: {machine.reports}</Card.Meta>
+ <Card.Description>
+ <List>
+ <List.Item icon='computer' content={system} />
+ <List.Item icon='microchip' content={camp} />
+ <List.Item
+ icon='mail'
+ content={<a href={owner.email}>{owner.email}</a>}
+ />
+ </List>
+ </Card.Description>
+ </Card.Content>
+ <Card.Content extra className='flex-box'>
+ <div className='ui buttons'>
+ {/*todo link to machine page*/}
+
+ <Link color='linkedin' to={'/machineInfo/' + machine.machine_sn}>
+ <Button basic color='blue'>
+ Other records
+ </Button>
+ </Link>
+
+ </div>
+ </Card.Content>
+ </Card>
+ </div>
+ );
+ }
+}export default FarmerCard;
+
diff --git a/front-end/src/component/farmer-detail-card/index.css b/front-end/src/component/farmer-detail-card/index.css
new file mode 100644
index 0000000..cd3a3a8
--- /dev/null
+++ b/front-end/src/component/farmer-detail-card/index.css
@@ -0,0 +1,5 @@
+.flex-box{
+ display: flex;
+ justify-content:center;
+ align-items:center;
+} \ No newline at end of file
diff --git a/front-end/src/component/farmer-detail-card/index.jsx b/front-end/src/component/farmer-detail-card/index.jsx
new file mode 100644
index 0000000..6fb4ff1
--- /dev/null
+++ b/front-end/src/component/farmer-detail-card/index.jsx
@@ -0,0 +1,50 @@
+import React from 'react';
+
+import NavTop from 'component/nav-top/index.jsx';
+import './index.css';
+import {Image, Card, Button, List, Icon} from 'semantic-ui-react'
+class FarmerDetailCard extends React.Component {
+ constructor(props){
+ super(props);
+ }
+ render(){
+ let machine = this.props.machine || {}
+ let branch_num = this.props.branch_num || 0
+ let system = machine.os_name + ' ' + machine.os_version;
+ let camp = machine.comp_name + ' ' + machine.comp_version;
+ let owner = machine.owner || {};
+ return (
+
+ <div className="farmer-card">
+ <Card>
+ <Card.Content>
+ <Image floated='right' size='mini'
+ src={machine.avatar}/>
+ <Card.Header>Owner: {owner.username}</Card.Header>
+ <Card.Meta>report num: {machine.reports}</Card.Meta>
+ <Card.Description>
+ <List>
+ <List.Item icon='computer' content={system} />
+ <List.Item icon='microchip' content={camp} />
+ <List.Item
+ icon='mail'
+ content={<a href={owner.email}>{owner.email}</a>}
+ />
+ </List>
+ </Card.Description>
+ </Card.Content>
+ <Card.Content extra className='flex-box'>
+
+ <div className='ui buttons'>
+ {/*todo link to machine page*/}
+ <Button basic mini color='grey'>
+ {branch_num} branches involved
+ </Button>
+ </div>
+ </Card.Content>
+ </Card>
+ </div>
+ );
+ }
+}export default FarmerDetailCard;
+
diff --git a/front-end/src/component/history-records-pane1/index.css b/front-end/src/component/history-records-pane1/index.css
new file mode 100644
index 0000000..b8cdbf8
--- /dev/null
+++ b/front-end/src/component/history-records-pane1/index.css
@@ -0,0 +1,4 @@
+.active_branch{
+ color: #fff9f8 !important;
+ background-color: #40a9ff !important;
+} \ No newline at end of file
diff --git a/front-end/src/component/history-records-pane1/index.jsx b/front-end/src/component/history-records-pane1/index.jsx
new file mode 100644
index 0000000..ae28d8f
--- /dev/null
+++ b/front-end/src/component/history-records-pane1/index.jsx
@@ -0,0 +1,117 @@
+import React from 'react';
+import Pagination from 'util/pagination/index.jsx';
+import {Tab, Divider, Icon, Label} from 'semantic-ui-react'
+
+import MachineRecordTable from 'util/machine-record-table/index.jsx'
+import Record from 'service/record-service.jsx'
+import PGUtil from 'util/util.jsx'
+
+const _util = new PGUtil();
+const _record = new Record();
+import './index.css';
+
+class HistoryRecordPane1 extends React.Component {
+ constructor(props) {
+ super(props);
+
+ this.state = {
+ currentList: [],
+ currentTotal: 0,
+ currentPage:1,
+ machine_sn: props.machine_sn || '',
+ branches: props.branches,
+ selected_branch: props.branches[0].value,
+ }
+ // console.dir(this.state.branches)
+ this.loadMachineRecordListByBranch = this.loadMachineRecordListByBranch.bind(this);
+ // this.loadMachineRecordListByBranch
+ }
+
+ componentDidMount() {
+ // console.log(this.state.branches[0].value)
+ this.loadMachineRecordListByBranch()
+ }
+ componentWillReceiveProps(nextProps) {
+ let _this = this
+ this.setState({
+ branches: nextProps.branches,
+ machine_sn: nextProps.machine_sn,
+ },() => {
+ if(this.state.branches.length > 0) {
+ _this.handleBranchTagClick(_this.state.branches[0].value)
+ }
+
+ });
+ }
+ handleBranchTagClick(branch_id){
+ console.log('new reload branch is: ' + branch_id)
+
+ this.setState({
+ selected_branch: branch_id,
+ },() => {
+ this.loadMachineRecordListByBranch()
+ });
+
+ }
+
+ // load record list
+ loadMachineRecordListByBranch(page=1) {
+ let _this = this;
+ let listParam = {};
+
+ listParam.page = page;
+ listParam.test_machine__machine_sn = this.state.machine_sn;
+ listParam.branch__id = this.state.selected_branch;
+ if(listParam.branch__id <= 0) {
+ return;
+ }
+ _record.getMachineRecordListByBranch(listParam).then(res => {
+ _this.setState({
+ currentList: res.results,
+ currentTotal: res.count,
+ isLoading: false
+ });
+ }, errMsg => {
+ _this.setState({
+ curentList: []
+ });
+ _util.errorTips(errMsg);
+
+ console.log(errMsg)
+ });
+
+ console.log(this.state.list)
+ }
+
+ render(){
+ let _list = this.state.branches || [];
+ console.log('list is')
+ console.dir(_list)
+ let branch_tags = _list.map((branchItem, index) => {
+ let className = branchItem.value == this.state.selected_branch ? 'active_branch' : '';
+ return (
+ <Label className={className} onClick={() => this.handleBranchTagClick(branchItem.value)}>
+ <Icon name='usb' />{branchItem.branch}
+ </Label>
+ );
+ });
+
+
+
+ return (
+ <div>
+ <div className="branch-tags-container">
+ {branch_tags}
+ {/*<div>*/}
+ {/*current num: {this.state.currentTotal}*/}
+ {/*</div>*/}
+ </div>
+
+ <MachineRecordTable list={this.state.currentList} total={this.state.currentTotal} current={this.state.currentPage} loadfunc={this.loadMachineRecordListByBranch}/>
+
+ </div>
+ );
+ }
+}
+
+export default HistoryRecordPane1; \ No newline at end of file
diff --git a/front-end/src/component/info-list/index.css b/front-end/src/component/info-list/index.css
new file mode 100644
index 0000000..2876f2e
--- /dev/null
+++ b/front-end/src/component/info-list/index.css
@@ -0,0 +1,24 @@
+.info-list{
+ font-size: 18px!important;
+}
+.clear-list-style {
+ list-style-type: none!important;
+}
+.pre {
+ white-space:pre-wrap;
+}
+
+/*Simulation style*/
+.accordion .title{
+ font-family: Lato,'Helvetica Neue',Arial,Helvetica,sans-serif;
+ line-height: 1.28571429em;
+ /*margin: calc(2rem - .14285714em) 0 1rem;*/
+ font-weight: 700;
+ padding: 0;
+ font-size: 1.28571429rem;
+ color: #4183c4!important;
+}
+
+.accordion .title i{
+ color: #000!important;
+} \ No newline at end of file
diff --git a/front-end/src/component/info-list/index.jsx b/front-end/src/component/info-list/index.jsx
new file mode 100644
index 0000000..386369b
--- /dev/null
+++ b/front-end/src/component/info-list/index.jsx
@@ -0,0 +1,95 @@
+import React from 'react';
+
+import './index.css';
+import {List, Item, Accordion} from 'semantic-ui-react'
+class InfoList extends React.Component {
+ constructor(props) {
+ super(props);
+ }
+
+ scrollToAnchor(anchorName) {
+ if (anchorName) {
+ let anchorElement = document.getElementById(anchorName);
+ if (anchorElement) {
+ anchorElement.scrollIntoView();
+ }
+ }
+ }
+
+ render() {
+ let info = this.props.info
+ let name = this.props.name
+ let _list = []
+ React.Children.forEach(Object.keys(info), (child, i) => {
+ // console.log('child: ' + i)
+ let Item
+ if(info[child].length >= 300) {
+ console.log(child+' is too long')
+
+ let panel =[{
+ title: child,
+ content: info[child],
+ }]
+
+ Item = (
+ <List.Item className='clear-list-style' key={i} value='-'>
+ <Accordion className='pre' defaultActiveIndex={[]} panels={panel} exclusive={false} fluid />
+
+ {/*<a href='javascript:void(0)' id={'' + child} onClick={() => this.scrollToAnchor('' + child)}>*/}
+ {/*<h3>{'' + child}301</h3></a>*/}
+ {/*/!*<h3>{key}</h3>*!/*/}
+ {/*<List.List as='ul'>*/}
+ {/*<List.Item className="clear-list-style pre">{info[child]}</List.Item>*/}
+ {/*</List.List>*/}
+
+ </List.Item>
+ )
+ }else{
+ Item = (
+ <List.Item as='li' key={i}>
+ <a href='javascript:void(0)' id={'' + child} onClick={() => this.scrollToAnchor('' + child)}>
+ <h3>{'' + child}</h3></a>
+ {/*<h3>{key}</h3>*/}
+ <List.List as='ul'>
+ <List.Item className="clear-list-style pre">{info[child]}</List.Item>
+ </List.List>
+ </List.Item>
+ )
+ }
+
+
+ _list.push({
+ key: `label${i}`,
+ value: Item
+ })
+ })
+
+ const itemComponents = _list.map(item => {
+ return <div key={item.key}>{item.value}</div>
+ })
+
+ return (
+ <List className='info-list' as='ul'>
+
+ <List.Item as='li'>
+
+ <a href='javascript:void(0)' id={name + 'Info'} onClick={() => this.scrollToAnchor(name + 'Info')}>
+ <h2>{name} Info</h2></a>
+ <List.List as='ul'>
+
+ {itemComponents}
+ {/*<List.Item as='li'>*/}
+ {/*<a href='#'>Link to somewhere</a>*/}
+ {/*</List.Item>*/}
+ {/*<List.Item as='li'>Rebates</List.Item>*/}
+
+
+ </List.List>
+
+ </List.Item>
+ </List>
+ );
+ }
+}
+export default InfoList;
+
diff --git a/front-end/src/component/layout/index.jsx b/front-end/src/component/layout/index.jsx
new file mode 100644
index 0000000..1428a1c
--- /dev/null
+++ b/front-end/src/component/layout/index.jsx
@@ -0,0 +1,21 @@
+import React from 'react';
+
+import NavTop from 'component/nav-top/index.jsx';
+// import SideNav from 'component/side-nav/index.jsx';
+// import './index.scss';
+import './theme.css';
+
+class Layout extends React.Component {
+ constructor(props){
+ super(props);
+ }
+ render(){
+ return (
+ <div id="wrapper">
+ <NavTop/>
+ {this.props.children}
+ </div>
+ );
+ }
+}export default Layout;
+
diff --git a/front-end/src/component/layout/index.scss b/front-end/src/component/layout/index.scss
new file mode 100644
index 0000000..5f3a68f
--- /dev/null
+++ b/front-end/src/component/layout/index.scss
@@ -0,0 +1,5 @@
+.page-header-right{
+ position: absolute;
+ right: 15px;
+ top: 12px;
+} \ No newline at end of file
diff --git a/front-end/src/component/layout/theme.css b/front-end/src/component/layout/theme.css
new file mode 100644
index 0000000..942a4ad
--- /dev/null
+++ b/front-end/src/component/layout/theme.css
@@ -0,0 +1,548 @@
+/*----------------------------------------------
+ COMMON STYLES
+ https://www.webthemez.com/demo/insight-free-bootstrap-html5-admin-template/empty.html#
+------------------------------------------------*/
+body {
+ font-family: 'Open Sans', sans-serif;
+ background: #f3f3f3;
+}
+
+#wrapper {
+ width: 100%;
+ margin: 0 auto;
+}
+
+#page-wrapper {
+ margin: 0 0 0 180px;
+ padding: 15px 30px;
+ margin-right: 180px;
+}
+
+.text-center {
+ text-align: center;
+}
+
+
+h1, .h1, h2, .h2, h3, .h3 {
+ margin-top: 7px;
+ margin-bottom: -5px;
+}
+
+h2 {
+ color: #000;
+}
+
+h4 {
+ padding-top: 10px;
+}
+
+.square-btn-adjust {
+ border: 0px solid transparent;
+ -webkit-border-radius: 0px;
+ -moz-border-radius: 0px;
+ border-radius: 0px;
+}
+
+p {
+ font-size: 16px;
+ line-height: 25px;
+}
+
+.panel {
+ border-radius: 0px;
+}
+
+/*.navbar-side .nav > li > a > i {*/
+ /*color: #B5B5B5;*/
+ /*padding: 8px;*/
+ /*width: 30px;*/
+ /*text-align: center;*/
+/*}*/
+
+
+
+/*.navbar-side {*/
+ /*z-index: 1;*/
+ /*position: fixed;*/
+ /*width: 260px;*/
+ /*top: 60px;*/
+ /*bottom: 0;*/
+ /*overflow-y : auto;*/
+ /*background: #2b2e33;*/
+/*}*/
+
+#page-wrapper {
+ position: relative;
+ top: 55px;
+}
+
+
+
+.nav .open > a, .nav .open > a:hover, .nav .open > a:focus {
+ /*background-color: #2497BA;*/
+ /*border-color: #428bca;*/
+ background-color: #fff;
+ border-color: #fff;
+}
+
+.breadcrumb {
+ padding: 0;
+ margin-bottom: 20px;
+ list-style: none;
+ /* background-color: #FAFAFA; */
+ border-radius: 0;
+}
+/*----------------------------------------------
+ DASHBOARD STYLES
+------------------------------------------------*/
+.page-header {
+ padding-bottom: 9px;
+ margin: 10px 0 20px;
+ border-bottom: 1px solid transparent;
+}
+
+.panel-left {
+ width: 35%;
+ height: 158px;
+ background: #5CB85C;
+}
+
+.panel-left .fa-5x {
+ font-size: 11em;
+ color: rgba(255, 255, 255, 0.15);
+ padding: 40px 0;
+ margin-bottom: 30px;
+}
+
+.panel-right {
+ width: 65%;
+ height: 158px;
+ background: transparent;
+ margin-bottom: 0;
+ color: #fff;
+}
+
+.panel-right h3 {
+ font-size: 50px;
+ padding: 31px 10px 13px;
+ color: rgba(255, 255, 255, 0.96);
+}
+
+.panel-back {
+ background-color: #fff;
+}
+
+.panel-default {
+ border-color: #ECECEC;
+ border: 1px solid transparent;
+ border-radius: 4px;
+}
+
+.panel-default > .panel-heading {
+ color: #000;
+ border-color: #FFF;
+ font-weight: bold;
+ background: #FFFFFF;
+ font-size: 16px;
+}
+
+.panel-heading {
+ padding: 15px 15px 0px;
+ border-bottom: 1px solid transparent;
+ border-top-left-radius: 3px;
+ border-top-right-radius: 3px;
+}
+
+.jumbotron, .well {
+ background: #fff;
+}
+
+.noti-box {
+ min-height: 100px;
+ padding: 20px;
+}
+
+.noti-box .icon-box {
+ display: block;
+ float: left;
+ margin: 0 15px 10px 0;
+ width: 70px;
+ height: 70px;
+ line-height: 75px;
+ vertical-align: middle;
+ text-align: center;
+ font-size: 40px;
+}
+
+.text-box p {
+ margin: 0 0 3px;
+}
+
+.main-text {
+ font-size: 25px;
+ font-weight: 600;
+}
+
+.set-icon {
+ -webkit-border-radius: 50px;
+ -moz-border-radius: 50px;
+ border-radius: 50px;
+}
+
+.panel-primary {
+ display: inline-block;
+ margin-bottom: 30px;
+ width: 100%;
+}
+
+.green {
+ background-color: #5cb85c;
+ color: #fff;
+}
+
+.blue {
+ background-color: #4CB1CF;
+ color: #fff
+}
+
+.red {
+ background-color: #F0433D;
+ color: #fff;
+}
+
+.brown {
+ background-color: #f0ad4e;
+ color: #fff;
+}
+
+.back-footer-red {
+ background-color: #F0433D;
+ color: #fff;
+ border-top: 0px solid #fff;
+}
+
+.icon-box-right {
+ display: block;
+ float: right;
+ margin: 0 15px 10px 0;
+ width: 70px;
+ height: 70px;
+ line-height: 75px;
+ vertical-align: middle;
+ text-align: center;
+ font-size: 40px;
+}
+
+.main-temp-back {
+ background: #8702A8;
+ color: #FFFFFF;
+ font-size: 16px;
+ font-weight: 300;
+ text-align: center;
+}
+
+.main-temp-back .text-temp {
+ font-size: 40px;
+}
+
+.back-dash {
+ padding: 20px;
+ font-size: 20px;
+ font-weight: 500;
+ -webkit-border-radius: 0px;
+ -moz-border-radius: 0px;
+ border-radius: 0px;
+ background-color: #2EA7EB;
+ color: #fff;
+}
+
+.back-dash p {
+ padding-top: 16px;
+ font-size: 13px;
+ color: #fff;
+ line-height: 25px;
+ text-align: justify;
+}
+
+.color-bottom-txt {
+ color: #000;
+ font-size: 16px;
+ line-height: 30px;
+}
+/*CHAT PANEL*/
+/*Charts*/
+
+.main-chart {
+ background: #fff;
+}
+
+.easypiechart-panel {
+ text-align: center;
+ padding: 1px 0;
+ margin-bottom: 20px;
+}
+
+.placeholder h2 {
+ margin-bottom: 0px;
+}
+
+.donut {
+ width: 100%;
+}
+
+.easypiechart {
+ position: relative;
+ text-align: center;
+ width: 120px;
+ height: 120px;
+ margin: 20px auto 10px auto;
+}
+
+.easypiechart .percent {
+ display: block;
+ position: absolute;
+ font-size: 26px;
+ top: 38px;
+ width: 120px;
+}
+
+#easypiechart-blue .percent {
+ color: #30a5ff;
+}
+
+#easypiechart-teal .percent {
+ color: #1ebfae;
+}
+
+#easypiechart-orange .percent {
+ color: #ffb53e;
+}
+
+#easypiechart-red .percent {
+ color: #ef4040;
+}
+
+.chat-panel .panel-body {
+ height: 450px;
+ overflow-y: scroll;
+}
+
+.chat-box {
+ margin: 0;
+ padding: 0;
+ list-style: none;
+}
+
+.chat-box li {
+ margin-bottom: 15px;
+ padding-bottom: 5px;
+ border-bottom: 1px dotted #808080;
+}
+
+.chat-box li.left .chat-body {
+ margin-left: 90px;
+}
+
+.chat-box li .chat-body p {
+ margin: 0;
+ color: #8d8888;
+}
+
+.chat-img>img {
+ margin-left: 20px;
+}
+
+footer p {
+ font-size: 14px;
+}
+/*----------------------------------------------
+ MENU STYLES
+------------------------------------------------*/
+
+
+
+.dropdown-menu > li > a{
+ cursor: pointer;
+}
+.top-navbar .dropdown-menu > li > a:hover, .top-navbar .dropdown-menu > li > a:focus {
+ color: #225081;
+ background: none;
+}
+
+.dropdown-tasks {
+ width: 255px;
+}
+
+.dropdown-tasks .progress {
+ height: 8px;
+ margin-bottom: 8px;
+ overflow: hidden;
+ background-color: #f5f5f5;
+ border-radius: 0px;
+}
+
+.dropdown-tasks > li > a {
+ padding: 0px 15px;
+}
+
+.dropdown-tasks p {
+ font-size: 13px;
+ line-height: 21px;
+ padding-top: 4px;
+}
+
+.active-menu {
+ background-color: #2DAFCB !important;
+ color: #fff !important;
+}
+
+.active-menu i {
+ color: #fff !important;
+}
+
+.arrow {
+ float: right;
+ margin-top: 8px;
+}
+
+.fa.arrow:before {
+ content: "\f104";
+}
+
+.active > a > .fa.arrow:before {
+ content: "\f107";
+}
+
+.nav-second-level li,
+.nav-third-level li {
+ border-bottom: none !important;
+}
+
+.nav-second-level li a {
+ padding-left: 37px;
+}
+
+.nav-third-level li a {
+ padding-left: 55px;
+}
+
+.sidebar-collapse , .sidebar-collapse .nav {
+ background: none;
+}
+
+.sidebar-collapse .nav {
+ padding: 0;
+}
+
+.sidebar-collapse .nav > li > a {
+ color: #B5B5B5;
+ background: transparent;
+ text-shadow: none;
+}
+
+.sidebar-collapse > .nav > li > a {
+ padding: 12px 10px;
+}
+
+.sidebar-collapse > .nav > li {
+ border-bottom: 1px solid rgba(107, 108, 109, 0.19);
+}
+
+ul.nav.nav-second-level.collapse.in {
+ background: #17191B;
+}
+
+.sidebar-collapse .nav > li > a:hover,
+.sidebar-collapse .nav > li > a:focus {
+ outline: 0;
+}
+
+.navbar-side {
+ border: none;
+}
+
+.top-navbar {
+ background: #fff;
+ border-bottom: none;
+}
+
+.top-navbar .nav > li > a > i {
+ margin-right: 2px;
+}
+.top-navbar .nav > li > a > span {
+ color: #666;
+ margin-right: 5px;
+}
+.top-navbar .navbar-brand:hover {
+ color: #2DAFCB;
+ background-color: rgb(43, 46, 51);
+}
+
+.dropdown-user li {
+ margin: 8px 0;
+}
+
+.navbar-default {
+ border: 0px solid black;
+}
+
+.navbar-header {
+ background: transparent;
+}
+
+.navbar-default .navbar-toggle:hover, .navbar-default .navbar-toggle:focus {
+ background-color: #B40101;
+}
+
+.navbar-default .navbar-toggle {
+ border-color: #fff;
+}
+
+.navbar-default .navbar-toggle .icon-bar {
+ background-color: #FFF;
+}
+
+.nav > li > a > i {
+ margin-right: 10px;
+ color: #666;
+}
+/*----------------------------------------------
+ UI ELEMENTS STYLES
+------------------------------------------------*/
+.btn-circle {
+ width: 50px;
+ height: 50px;
+ padding: 6px 0;
+ -webkit-border-radius: 25px;
+ -moz-border-radius: 25px;
+ border-radius: 25px;
+ text-align: center;
+ font-size: 12px;
+ line-height: 1.428571429;
+}
+
+/*----------------------------------------------
+ MEDIA QUERIES
+------------------------------------------------*/
+
+@media(max-width:768px) {
+
+ .top-navbar{
+ position: relative;
+ }
+ .top-navbar .navbar-brand{
+ width: 100%;
+ }
+
+ .navbar-side {
+ z-index: 1;
+ width: 100%;
+ position: relative;
+ top: 0;
+ }
+ #page-wrapper {
+ margin: 0;
+ padding: 15px 30px;
+ top: 0;
+ }
+} \ No newline at end of file
diff --git a/front-end/src/component/nav-top/index.css b/front-end/src/component/nav-top/index.css
new file mode 100644
index 0000000..4676edc
--- /dev/null
+++ b/front-end/src/component/nav-top/index.css
@@ -0,0 +1,139 @@
+.user-image {
+ margin: 25px auto;
+ -webkit-border-radius: 10px;
+ -moz-border-radius: 10px;
+ border-radius: 10px;
+ max-height: 170px;
+ max-width: 170px;
+}
+
+.top-navbar {
+ margin: 0px;
+}
+
+.top-navbar {
+ position: fixed;
+ width: 100%;
+ z-index: 300;
+ -webkit-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
+ -moz-box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
+ box-shadow: 0 3px 3px rgba(0, 0, 0, 0.05);
+}
+
+.top-navbar .navbar-brand {
+ color: #fff;
+ width: 340px;
+ text-align: left;
+ height: 60px;
+ font-size: 30px;
+ font-weight: 700;
+ text-transform: uppercase;
+ line-height: 30px;
+ background: #32323a;
+}
+
+.navbar-brand b {
+ color: rgb(2,141,193);
+
+}
+
+
+.navbar-brand img {
+ height: 40px;
+ width: 40px;
+ margin-right: 15px;
+ margin-left: 15px;
+ display:inline-block!important;
+}
+.top-navbar .nav > li {
+ position: relative;
+ display: inline-block;
+ margin: 0px;
+ padding: 0px 10px;
+}
+
+.top-navbar .nav > li > a {
+ position: relative;
+ display: block;
+ padding: 20px;
+ color: #FFFFFF;
+ margin: 0px;
+}
+
+.top-navbar .nav > li:hover .dropdown-menu{
+ display: block;
+}
+.top-navbar .dropdown-menu {
+ min-width: 140px;
+ top: 98%;
+ border-radius: 0 0 4px 4px;
+}
+
+.top-navbar .nav > li > a, .top-navbar .nav > li > a > i {
+ font-size: 15px;
+ color: #0f0f0f !important;
+}
+
+.top-navbar .nav > li > a:hover, .top-navbar .nav > li > a:focus{
+ text-decoration: none;
+ color: #1890ff !important;
+ background: transparent;
+}
+
+
+.top-navbar .nav > li:hover, .top-navbar .nav > li:focus {
+ border-bottom: 2px solid #1890ff;
+}
+
+.top-navbar .nav > li:hover>a {
+ color: #1890ff !important;
+}
+
+.top-navbar .nav > li:hover span {
+ color: #1890ff !important;
+}
+
+
+.glyphicon-menu-down {
+ font-size: 3px;
+}
+
+.sign-in {
+ font-weight: 600 !important;
+ padding-left: 10px;
+}
+
+.navbar-right {
+ margin-right: 0px!important;
+ /*line-height:61px;*/
+}
+
+.panel-title {
+ display: flex;
+}
+
+.panel-title a {
+ width: 70px;
+}
+.panel-title .title-selected-result{
+ width: 100%;
+}
+
+.navbar-right .loggedin{
+ margin-right: 0px!important;
+ padding-right: 10px!important;
+ line-height: 60px;
+}
+
+.loggedin > a {
+ padding: 0px!important;
+}
+
+.user-head-pic {
+ height: 40px;
+ border: 2px solid #2497ba;
+}
+
+.user-head-pic:hover {
+ border: 2px solid skyblue;
+} \ No newline at end of file
diff --git a/front-end/src/component/nav-top/index.jsx b/front-end/src/component/nav-top/index.jsx
new file mode 100644
index 0000000..08a4e8d
--- /dev/null
+++ b/front-end/src/component/nav-top/index.jsx
@@ -0,0 +1,150 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+
+import './index.css';
+import slonik from 'image/slonik.png'
+import PGUtil from 'util/util.jsx'
+const _util = new PGUtil();
+import User from 'service/user-service.jsx'
+const _user = new User();
+
+class NavTop extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ // username: _util.getStorage('userInfo').username || '',
+ userinfo: _util.getStorage('userInfo')|| {},
+ isLoggedIn: true
+ }
+ }
+
+ // logout
+ onLogout() {
+ _util.removeStorage('userInfo');
+ window.location.href = '/login';
+ }
+
+ componentWillMount(){
+ this.setState({
+ isLoggedIn: this.isLoggedIn(),
+ });
+ }
+
+ isLoggedIn() {
+ if(this.state.userinfo.token){
+ return true;
+ }
+ return false;
+ }
+
+ render() {
+ let isLoggedIn = this.state.isLoggedIn;
+
+ let button = null;
+ if (isLoggedIn) {
+ button = <li className="dropdown loggedin">
+ <a className="dropdown-toggle" data-toggle="dropdown" href="#" aria-expanded="false">
+ <img className="img-circle img-thumbnail user-head-pic" src={require('image/slonik.png')}
+ alt="headPic"/>
+ </a>
+ <ul className="dropdown-menu dropdown-alerts loggedin-ul">
+ <li>
+ <Link to="/portal">
+ <div>
+ <i className="fa fa-tasks fa-fw"></i> My machines
+ </div>
+ </Link>
+ </li>
+ <li className="divider"></li>
+ <li>
+ <a onClick={() => {this.onLogout()}}>
+ <div>
+ <i className="fa fa-upload fa-fw"></i> Log out
+ </div>
+ </a>
+ </li>
+ <li className="divider"></li>
+ </ul>
+ </li>;
+ } else {
+ button = <li className="dropdown sign-in">
+ <Link to="/login" aria-expanded="false">
+ Sign in
+ </Link>
+ </li>;
+ }
+
+ return (
+ <div className="navbar navbar-default top-navbar" role="navigation">
+ <div className="navbar-header">
+
+ <a className="navbar-brand" href="index.html"><img src={require('image/slonik.png')}/><b>PG Perf
+ Farm</b></a>
+ </div>
+ <ul className="nav navbar-top-links navbar-left">
+ <li><Link to="/home"> <span className="glyphicon glyphicon-home" aria-hidden="true"></span>
+ Home</Link>
+ </li>
+ <li><Link to="/status"><span className="glyphicon glyphicon-tasks" aria-hidden="true"></span>Status</Link>
+ </li>
+
+ <li><Link to="/machine"> <span className="glyphicon glyphicon-blackboard" aria-hidden="true"></span>Machine</Link>
+ </li>
+
+ <li className="dropdown">
+ <a className="dropdown-toggle" data-toggle="dropdown" href="#" aria-expanded="false">
+ <span className="glyphicon glyphicon-th-large" aria-hidden="true"></span> Help
+ <span className="glyphicon glyphicon-menu-down" aria-hidden="true"></span>
+ </a>
+ <ul className="dropdown-menu dropdown-alerts">
+ <li className="divider"></li>
+ <li>
+ <a href="#">
+ <div>
+ <i className="fa fa-envelope fa-fw"></i> Contact
+ {/*<span className="pull-right text-muted small">4 min</span>*/}
+ </div>
+ </a>
+ </li>
+ <li className="divider"></li>
+ <li>
+ <a href="#">
+ <div>
+ <i className="fa fa-tasks fa-fw"></i> Licence
+ {/*<span className="pull-right text-muted small">4 min</span>*/}
+ </div>
+ </a>
+ </li>
+ <li className="divider"></li>
+ <li>
+ <a href="/https/git.postgresql.org/ppolicy">
+ <div>
+ <i className="fa fa-upload fa-fw"></i> Privacy Policy
+ {/*<span className="pull-right text-muted small">4 min</span>*/}
+ </div>
+ </a>
+ </li>
+ <li className="divider"></li>
+ {/*<li>*/}
+ {/*<a className="text-center" href="#">*/}
+ {/*<strong>See All Alerts</strong>*/}
+ {/*<i className="fa fa-angle-right"></i>*/}
+ {/*</a>*/}
+ {/*</li>*/}
+ </ul>
+
+ </li>
+
+ </ul>
+
+
+ <ul className="nav navbar-top-links navbar-right">
+ {button}
+ </ul>
+ </div>
+ );
+ }
+}
+
+
+export default NavTop; \ No newline at end of file
diff --git a/front-end/src/component/result-filter/index.css b/front-end/src/component/result-filter/index.css
new file mode 100644
index 0000000..09d27e1
--- /dev/null
+++ b/front-end/src/component/result-filter/index.css
@@ -0,0 +1,118 @@
+.panel-group {
+ width: 860px;
+}
+
+.selected_item > li{
+ float: left;
+ margin-left: 10px;
+ list-style-type:none;
+ border: 1px solid rgba(0, 0, 0, 0.3);
+}
+
+.selected_item > li:hover{
+ border: 1px solid #246fcd;
+}
+.selected_item > li > a{
+ border-left: 1px solid rgba(0, 0, 0, 0.3);
+}
+
+/* select */
+.select {
+ padding: 5px 10px;
+ /*border: #ddd 1px solid;*/
+ border-radius: 4px;
+ width: 100%;
+ /*margin: 5% auto;*/
+ font-size: 12px
+}
+
+.select li {
+ list-style: none;
+ padding: 10px 0 5px 100px
+}
+
+.select .select-list {
+ border-bottom: #eee 1px dashed
+}
+
+.select dl {
+ zoom: 1;
+ position: relative;
+ line-height: 24px;
+}
+
+.select dl:after {
+ content: " ";
+ display: block;
+ clear: both;
+ height: 0;
+ overflow: hidden
+}
+
+.select dt {
+ width: 100px;
+ margin-bottom: 5px;
+ position: absolute;
+ top: 0;
+ left: -100px;
+ text-align: right;
+ color: #666;
+ height: 24px;
+ line-height: 24px
+}
+
+.select dd {
+ float: left;
+ display: inline;
+ margin: 0 0 5px 5px;
+}
+
+.select a {
+ display: inline-block;
+ white-space: nowrap;
+ height: 24px;
+ line-height: 24px;
+ padding: 0 10px;
+ text-decoration: none;
+ color: #039;
+ border-radius: 2px;
+}
+
+.select a:hover {
+ color: #2643ff;
+ background-color: #f3edc2
+}
+
+.select .selected a {
+ color: #fff;
+ /*background-color: #7354ff*/
+ background-color: #5e8fff
+}
+
+.select-result dt {
+ font-weight: bold
+}
+
+.select-no {
+ color: #999
+}
+
+/*.select .select-result a{padding-right:20px;background:#f60 url("close.gif") right 9px no-repeat}*/
+.select .select-result a:hover {
+ background-position: right -15px
+}
+
+.title-selected-btn {
+ float: right;
+ margin-left: 5px;
+}
+
+.title-selected-btn:focus, .title-selected-btn:active:focus, .title-selected-btn.active:focus, .title-selected-btn.focus, .title-selected-btn:active.focus, .title-selected-btn.active.focus {
+ outline: none;
+ /*border-color: transparent;*/
+ /*box-shadow: none;*/
+}
+
+.title-selected-result {
+ padding-bottom: 8px;
+} \ No newline at end of file
diff --git a/front-end/src/component/result-filter/index.jsx b/front-end/src/component/result-filter/index.jsx
new file mode 100644
index 0000000..2ae1141
--- /dev/null
+++ b/front-end/src/component/result-filter/index.jsx
@@ -0,0 +1,359 @@
+import React from 'react';
+import Pagination from 'util/pagination/index.jsx';
+import PGUtil from 'util/util.jsx'
+const _util = new PGUtil();
+import './index.css';
+
+class ResultFilter extends React.Component {
+ constructor(props) {
+ super(props);
+
+ this.state = {
+ // selected_items: [
+ // {'cate': 'Category 2', 'name': '30 days'}
+ // ],
+ restoreNum: 0,
+ branches: this.props.branches,
+ isFirstMount:true,
+ selected: [
+ // {
+ // 'cate': 'Category 1',
+ // 'index': 0,
+ // 'isMultiple':false,
+ // 'key': 'date',
+ // 'metaData':{
+ // 'name': 'All',
+ // 'value': ''
+ // },
+ // 'data': [
+ // {'name':'7 days', 'value':'7'},
+ // {'name':'30 days', 'value':'30'}
+ // ],
+ // }
+ ],
+
+ isClear: true
+ };
+
+ this.selectItemClick = this.selectItemClick.bind(this);
+ this.metaItemClick = this.metaItemClick.bind(this);
+ }
+
+ addBranchTags() {
+ let obj = {
+ 'cate': 'Branches',
+ // 'index': 0,
+ 'isMultiple': true,
+ 'key': 'branch',
+ 'metaData': {
+ 'name': 'All',
+ 'value': '',
+ 'isSelected': true
+ },
+ 'totalSelected': 0,
+ 'data': [],
+ }
+
+ let branches = this.state.branches
+
+ for (let i = 0; i < branches.length; i++) {
+ let newItem = {}
+ newItem['name'] = branches[i].branch_name
+ newItem['value'] = branches[i].branch_name
+ newItem['isSelected'] = false
+ obj['data'].push(newItem)
+ }
+
+ let _list = []
+ _list.push(obj)
+ console.log('lets see the new selected')
+ console.log(branches.length)
+ console.dir(_list)
+ this.setState({
+ selected: _list
+ });
+
+
+ }
+
+ componentWillReceiveProps(nextProps) {
+ let _this = this
+ this.setState({
+ branches: nextProps.branches,
+ }, () => {
+ if(_this.state.isFirstMount){
+ _this.addBranchTags();
+ _this.setState({
+ isFirstMount: false,
+ })
+ }
+ });
+ }
+
+ componentWillMount() {
+ // this.addBranchTags();
+ }
+
+
+ metaItemClick(e) {
+ console.log('metaItemClick!!', this);
+ let item_name = e.currentTarget.getAttribute("data-item-name")
+ let item_index = e.currentTarget.getAttribute("data-item-index")
+
+ let cate_name = e.currentTarget.getAttribute("data-cate-name")
+ let cate_index = e.currentTarget.getAttribute("data-cate-index")
+
+ let newSelected = this.state.selected;
+ newSelected[cate_index].totalSelected = 0;
+ newSelected[cate_index].metaData.isSelected = true;
+ for (let i = 0; i < newSelected[cate_index].data.length; i++) {
+ newSelected[cate_index].data[i].isSelected = false;
+ }
+
+ this.setState({
+ selected: newSelected,
+ isClear: true
+ });
+
+ }
+
+ selectItemClick(e) {
+ console.log('selectItemClick!!', this);
+ let item_name = e.currentTarget.getAttribute("data-item-name")
+ let item_index = e.currentTarget.getAttribute("data-item-index")
+
+ let cate_name = e.currentTarget.getAttribute("data-cate-name")
+ let cate_index = e.currentTarget.getAttribute("data-cate-index")
+
+ let newSelected = this.state.selected;
+ let totalSelected = newSelected[cate_index].totalSelected
+ console.log('totalSelected now is:' + totalSelected)
+ newSelected[cate_index].metaData['isSelected'] = false;
+ newSelected[cate_index].data[item_index]['isSelected'] = !newSelected[cate_index].data[item_index]['isSelected']
+
+ if(newSelected[cate_index].data[item_index]['isSelected'] == true){
+ //add totalSelected
+ totalSelected += 1
+ }else{
+ if(totalSelected -1 <= 0){
+ newSelected[cate_index].data[item_index]['isSelected'] = true
+ }else{
+ totalSelected -= 1
+ }
+ }
+ newSelected[cate_index].totalSelected = totalSelected
+ console.log('cate name is:' + cate_name)
+ console.log('cate index is:' + cate_index)
+ console.log('totalSelected is:' + totalSelected)
+ console.log('cur index is:' + item_index)
+
+
+ this.setState({
+ selected: newSelected,
+ isClear: true
+ });
+
+ console.log('the lastest selected')
+ console.dir(newSelected)
+ }
+
+
+ handleClick() {
+ console.log('handleClick!!', this);
+ let self = this;
+ }
+
+ getSelectedBranches(){
+ let metaData = this.state.selected[0].metaData
+ if(metaData.isSelected == true && this.state.selected[0].totalSelected == 0){
+ return []
+ }
+ return this.state.selected[0].data
+ }
+ // getFilterParams() {
+ // let params_list = this.state.selected;
+ // let result = {};
+ // for (let i = 0; i < params_list.length; i++) {
+ // let params_item = params_list[i];
+ // console.log('cur filter index is:' + params_item.index)
+ // let value = params_item.data[params_item.index]['value']
+ // let key = params_item.key;
+ // if (value) {
+ // console.log('key is:' + key)
+ // if (key == 'date') {
+ // result[key] = _util.getDateStr(value * -1)
+ // } else {
+ // result[key] = value
+ // }
+ //
+ // }
+ //
+ // }
+ // return result
+ // }
+
+ applyButtonClick() {
+ this.setState({
+ // selected: newArr,
+ isClear: false
+ });
+ this.props.onIsLoadingChange(true);
+ let branches = this.getSelectedBranches()
+
+ this.props.onApplyBtnClick(branches);
+ // console.log('isLoading:' + this.props.isLoading)
+
+ }
+
+ resetButtonClick() {
+ let newArr = this.state.selected;
+ newArr.forEach((_item, _index) => {
+ console.log(_item);
+ _item.index = this.state.restoreNum;
+
+ })
+ this.setState({
+ selected: newArr,
+ isClear: false
+ });
+ }
+
+
+ render() {
+ let _this = this;
+ console.log('look')
+ console.dir(this.state.selected)
+ console.log('look done')
+ let filter = this.state.selected.map((item, i) => {
+ let meta_item
+ let filter_items
+ let is_high_light = item["metaData"].isSelected == true ? "select-all selected" : "select-all"
+ meta_item = (
+ <dd onClick={(e) => this.metaItemClick(e)} data-cate-name={item["cate"]}
+ data-cate-index={i} data-item-name='meta' className={is_high_light}><a
+ href="javascript:void(0);">{item["metaData"]['name']}</a></dd>
+ )
+
+
+ if (item.isMultiple) {
+ filter_items = item["data"].map((s, index) => {
+ let is_high_light = s['isSelected'] == true ? "select-all selected" : "select-all"
+ let filter_tag = (
+ <dd onClick={(e) => this.selectItemClick(e)} key={index} data-cate-name={item["cate"]}
+ data-cate-index={i} data-item-index={index} data-item-name={s}
+ className={is_high_light}><a
+ href="javascript:void(0);">{s['name']}</a></dd>
+ )
+
+
+ return filter_tag
+ });
+ } else {
+ //todo
+ }
+
+
+ return (
+ <li className="select-list" item={item} key={i} data-cate-name={item["cate"]} data-cate-index={i}>
+ <dl data-is-multiple={item.isMultiple} data-cate-name={item["cate"]} data-cate-index={i}>
+ <dt data-cate-name={item["cate"]}>{item["cate"]}:</dt>
+ {meta_item}
+ {filter_items}
+ {/*<dd className="select-all selected"><a href="#">All</a></dd>*/}
+ {/*<dd><a href="#">today</a></dd>*/}
+ {/*<dd><a href="#">7 days</a></dd>*/}
+ {/*<dd><a href="#">30 days</a></dd>*/}
+ </dl>
+ </li>
+ )
+ });
+
+ let apply_btn;
+ if (this.props.isLoading == true) {
+ apply_btn = (
+ <a className="btn btn-primary btn-sm title-selected-btn" href="javascript:void(0)"
+ disabled={"disabled"}>
+ <i className="fa fa-spinner fa-pulse"></i> wait...</a>
+ )
+ } else {
+ apply_btn = (
+ <a className="btn btn-primary btn-sm title-selected-btn" href="javascript:void(0)"
+ onClick={() => this.applyButtonClick()}>
+ <i className="fa fa-hand-paper-o"></i> Apply</a>
+ )
+ }
+ return (
+
+ <div id="wrapper">
+ <div className="panel-group" id="accordion">
+ <div className="panel panel-default">
+ <div className="panel-heading" onClick={() => this.handleClick()}>
+ <div className="panel-title">
+ <a href="#panel1" className="panel-toggle" data-toggle="collapse"
+ data-parent="#accordion">
+ <span className="glyphicon glyphicon-search" aria-hidden="true"></span>Filter
+ </a>
+ <div className="title-selected-result">
+ <span>--</span>
+
+ {/*<a className="btn btn-default btn-sm title-selected-btn" href="javascript:void(0)"*/}
+ {/*onClick={() => this.resetButtonClick()}*/}
+ {/*disabled={ this.state.isClear ? "" : "disabled" }>*/}
+ {/*<i className="fa fa-cog"></i> Reset</a>*/}
+
+ {apply_btn}
+ {/*<button data-toggle="button" className="btn btn-primary title-selected-btn">apply*/}
+ {/*</button>*/}
+ </div>
+ </div>
+ </div>
+ <div id="panel1" className="panel-collapse collapse in">
+
+ <div className="panel-body">
+ <ul className="selected_item">
+ {/*{selected_item}*/}
+ </ul>
+
+
+ <ul className="select">
+
+ {filter}
+
+ {/*<li className="select-list">*/}
+ {/*<dl id="select1">*/}
+ {/*<dt>Category 1:</dt>*/}
+ {/*<dd className="select-all selected"><a href="#">All</a></dd>*/}
+ {/*<dd><a href="#">Improving</a></dd>*/}
+ {/*<dd><a href="#">Regressive</a></dd>*/}
+ {/*</dl>*/}
+ {/*</li>*/}
+ {/*<li className="select-list">*/}
+ {/*<dl id="select2">*/}
+ {/*<dt>Category 2:</dt>*/}
+ {/*<dd className="select-all selected"><a href="#">All</a></dd>*/}
+ {/*<dd><a href="#">today</a></dd>*/}
+ {/*<dd><a href="#">7 days</a></dd>*/}
+ {/*<dd><a href="#">30 days</a></dd>*/}
+ {/*</dl>*/}
+ {/*</li>*/}
+ {/*<li className="select-list">*/}
+ {/*<dl id="select3">*/}
+ {/*<dt>Category 3:</dt>*/}
+ {/*<dd className="select-all selected"><a href="#">All</a></dd>*/}
+ {/*<dd><a href="#">item1</a></dd>*/}
+ {/*<dd><a href="#">item2</a></dd>*/}
+ {/*</dl>*/}
+ {/*</li>*/}
+ </ul>
+ </div>
+ </div>
+ </div>
+
+ </div>
+ <p>...</p>
+ </div>
+ );
+ }
+}
+
+export default ResultFilter; \ No newline at end of file
diff --git a/front-end/src/component/test-result-card/index.css b/front-end/src/component/test-result-card/index.css
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/front-end/src/component/test-result-card/index.css
diff --git a/front-end/src/component/test-result-card/index.jsx b/front-end/src/component/test-result-card/index.jsx
new file mode 100644
index 0000000..9001448
--- /dev/null
+++ b/front-end/src/component/test-result-card/index.jsx
@@ -0,0 +1,45 @@
+import React from 'react';
+import {Card, Icon,Table} from 'semantic-ui-react'
+import './index.css';
+
+class TestResultCard extends React.Component {
+ constructor(props) {
+ super(props);
+
+ this.state = {
+ selected_items: [
+ {'cate': 'Category 2', 'name': '30 days'}
+ ],
+ restoreNum: 0,
+ };
+
+
+ // this.selectItemClick = this.selectItemClick.bind(this);
+ }
+
+
+
+ render() {
+ let description = [
+ 'Amy is a violinist with 2 years experience in the wedding industry.',
+ 'She enjoys the outdoors and currently resides in upstate New York.',
+ ].join(' ');
+ return (
+ <div >
+ <Card fluid>
+ <Card.Content header='Abouwwt Amy'/>
+ <Card.Content description={description}/>
+ <Card.Content description={description}/>
+ <Card.Content description={description}/>
+ <Card.Content extra>
+ <Icon name='user'/>
+ 4 Friends
+
+ </Card.Content>
+ </Card>
+ </div>
+ );
+ }
+}
+
+export default TestResultCard; \ No newline at end of file
diff --git a/front-end/src/component/userinfo-card/index.css b/front-end/src/component/userinfo-card/index.css
new file mode 100644
index 0000000..b34c9c0
--- /dev/null
+++ b/front-end/src/component/userinfo-card/index.css
@@ -0,0 +1,32 @@
+.panel-blue{
+ border-top: 3px solid #356fba;
+}
+
+.panel-default > .userinfo-panel-heading{
+ padding-bottom: 5px;
+ /*border-bottom: 0.5px solid #333333;*/
+ display: flex;
+ justify-content: space-between;
+}
+
+.panel-report-num{
+ font-size: 14px;
+ color: rgba(0,0,0,.4);
+}
+.panel-body-ul{
+ list-style: none!important;
+ padding: 0!important;
+}
+
+.userinfo-panel-body{
+ font-size: 15.5px;
+ line-height: initial;
+ padding-top: 0;
+ padding-bottom: 0;
+ border-top: 1px solid #ddd;
+}
+
+.user-avatar{
+ height: 35px;
+ width: 35px;
+} \ No newline at end of file
diff --git a/front-end/src/component/userinfo-card/index.jsx b/front-end/src/component/userinfo-card/index.jsx
new file mode 100644
index 0000000..916dcae
--- /dev/null
+++ b/front-end/src/component/userinfo-card/index.jsx
@@ -0,0 +1,48 @@
+import React from 'react';
+
+import NavTop from 'component/nav-top/index.jsx';
+import './index.css';
+import {Image, Card, Button, List, Icon} from 'semantic-ui-react'
+class UserInfoCard extends React.Component {
+ constructor(props){
+ super(props);
+ }
+ render(){
+ let userinfo = this.props.userinfo || {}
+
+ return (
+
+ <div className="farmer-card">
+ <div className="userinfo-panel panel panel-default panel-blue">
+
+ <div className="panel-heading userinfo-panel-heading">
+ <div>
+ <h3 className="panel-title">
+ <i className="fa fa-user"></i>&nbsp; Your Info
+ </h3>
+ <span className="panel-report-num">
+ &nbsp; &nbsp;&nbsp; total reports: {userinfo.reports}
+ </span>
+ </div>
+
+ <div>
+ <img className="user-avatar" src={userinfo['avatar']} alt=""/>
+
+ </div>
+ </div>
+ <div className="panel-body userinfo-panel-body">
+ <p><strong>{userinfo.username}</strong></p>
+ <ul className="panel-body-ul">
+ <li><i className="fa fa-desktop fa-fw"></i> {userinfo.machines} machine(s)</li>
+ <li><i className="fa fa-code-fork fa-fw"></i> {userinfo.involved} branch(es) involved</li>
+ <li><i className="fa fa-envelope-o fa-fw"></i> <a href={'mailto:'+userinfo.email}>{userinfo.email}</a></li>
+ </ul>
+ </div>
+ <div className="panel-footer clearfix">
+ </div>
+ </div>
+ </div>
+ );
+ }
+}export default UserInfoCard;
+
diff --git a/front-end/src/image/client-icon/1.png b/front-end/src/image/client-icon/1.png
new file mode 100644
index 0000000..0103459
--- /dev/null
+++ b/front-end/src/image/client-icon/1.png
Binary files differ
diff --git a/front-end/src/image/client-icon/2.png b/front-end/src/image/client-icon/2.png
new file mode 100644
index 0000000..daa4f06
--- /dev/null
+++ b/front-end/src/image/client-icon/2.png
Binary files differ
diff --git a/front-end/src/image/client-icon/4.png b/front-end/src/image/client-icon/4.png
new file mode 100644
index 0000000..b7d7463
--- /dev/null
+++ b/front-end/src/image/client-icon/4.png
Binary files differ
diff --git a/front-end/src/image/client-icon/5.png b/front-end/src/image/client-icon/5.png
new file mode 100644
index 0000000..2779f13
--- /dev/null
+++ b/front-end/src/image/client-icon/5.png
Binary files differ
diff --git a/front-end/src/image/fonteditor.ttf b/front-end/src/image/fonteditor.ttf
new file mode 100644
index 0000000..07a9a1d
--- /dev/null
+++ b/front-end/src/image/fonteditor.ttf
Binary files differ
diff --git a/front-end/src/image/slonik.png b/front-end/src/image/slonik.png
new file mode 100644
index 0000000..bb300aa
--- /dev/null
+++ b/front-end/src/image/slonik.png
Binary files differ
diff --git a/front-end/src/index.css b/front-end/src/index.css
new file mode 100644
index 0000000..83ef860
--- /dev/null
+++ b/front-end/src/index.css
@@ -0,0 +1,3 @@
+#app {
+ color: red;
+}
diff --git a/front-end/src/index.html b/front-end/src/index.html
new file mode 100644
index 0000000..e783a31
--- /dev/null
+++ b/front-end/src/index.html
@@ -0,0 +1,25 @@
+<!DOCTYPE html>
+<html>
+
+ <head>
+ <meta charset="UTF-8">
+ <meta name="viewPort" content="width=device-width,initial-scale=1" />
+ <meta name="author" content="name" />
+ <link href="http://cdn.bootcss.com/bootstrap/3.3.7/css/bootstrap.min.css" rel="stylesheet">
+ <link href="https://cdn.bootcss.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet">
+ <link rel="stylesheet" href="//cdnjs.cloudflare.com/ajax/libs/bootstrap-table/1.12.1/bootstrap-table.min.css">
+ <!--<link href="https://cdn.bootcss.com/font-awesome/3.2.1/css/font-awesome.min.css" rel="stylesheet">-->
+ <!--<link href="component/layout/theme.css" rel="stylesheet">-->
+ <link rel="stylesheet" type="text/css" href="//cdn.bootcss.com/semantic-ui/2.3.1/semantic.min.css" rel="stylesheet">
+ </head>
+
+ <title>PG PerfFarm</title>
+
+ <script src="https://cdn.bootcss.com/jquery/3.3.1/jquery.min.js"></script>
+ <script src="https://cdn.bootcss.com/bootstrap/3.3.7/js/bootstrap.min.js"></script>
+ <!--<script src="//cdnjs.cloudflare.com/ajax/libs/bootstrap-table/1.12.1/bootstrap-table.min.js"></script>-->
+ <body>
+ <div id="app"></div>
+ </body>
+
+</html> \ No newline at end of file
diff --git a/front-end/src/index.scss b/front-end/src/index.scss
new file mode 100644
index 0000000..784d5be
--- /dev/null
+++ b/front-end/src/index.scss
@@ -0,0 +1,19 @@
+body {
+ background: url(image/slonik.png);
+ #app {
+ font-size: 100px;
+ }
+}
+.page-header-right{
+ position: absolute;
+ right: 15px;
+ top: 12px;
+}
+
+.switch-wrapper {
+ position: relative;
+}
+
+.switch-wrapper > div {
+ position: absolute;
+} \ No newline at end of file
diff --git a/front-end/src/page/detailInfo/index.css b/front-end/src/page/detailInfo/index.css
new file mode 100644
index 0000000..e16cc40
--- /dev/null
+++ b/front-end/src/page/detailInfo/index.css
@@ -0,0 +1,78 @@
+.record-title{
+ padding-left: 14px;
+ padding-right: 44px;
+ display: flex;
+ flex-direction: row;
+ justify-content:space-between;
+}
+.title-flex {
+ display: flex;
+ flex-direction: column;
+ justify-content:flex-start;
+ font-weight: 600;
+}
+
+.record-title-top :first-child{
+ padding-right: 89px;
+}
+
+.card-container{
+ margin-left: 5px;
+ margin-right: 5px;
+}
+.card-div{
+ padding-left: 2px;
+}
+
+.info-container {
+ margin-left: 0%;
+ margin-top: 15px;
+}
+.row {
+ /*margin-left:120px;*/
+}
+
+.detail-container{
+ padding-top: 80px;
+ margin-right: auto;
+ margin-left: auto;
+}
+
+@media (min-width: 1200px) {
+ .detail-container {
+ width: 1170px;
+ }
+}
+
+/*@media (min-width: 1400px) {*/
+ /*.detail-container {*/
+ /*width: 1370px;*/
+ /*}*/
+/*}*/
+
+.client-title-div {
+ display: flex;
+ justify-content:space-between;
+ flex-grow:1;
+}
+
+.trend-span .improved{
+ color: #5b8c00!important;
+ }
+
+.trend-span .quo{
+ color: #0050b3!important;
+}
+
+.trend-span .regressive{
+ color: #cf1322!important;
+}
+
+
+/*catalog*/
+.catalog.ui.vertical.menu {
+ width: 100%;
+}
+.catalog.ui.menu .item{
+ color: inherit;
+} \ No newline at end of file
diff --git a/front-end/src/page/detailInfo/index.jsx b/front-end/src/page/detailInfo/index.jsx
new file mode 100644
index 0000000..1711ace
--- /dev/null
+++ b/front-end/src/page/detailInfo/index.jsx
@@ -0,0 +1,343 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import './index.css';
+import {Table, Divider, Segment, Icon, Menu, Input, Dropdown, Sticky} from 'semantic-ui-react'
+import PGUtil from 'util/util.jsx'
+import FarmerCard from 'component/farmer-card/index.jsx'
+import InfoList from 'component/info-list/index.jsx'
+import Record from 'service/record-service.jsx'
+import PGConstant from 'util/constant.jsx'
+
+const _util = new PGUtil();
+const _record = new Record();
+
+class DetailInfo extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ recordNo: this.props.match.params.uuid,
+ recordInfo: {},
+ }
+
+ // this.onPageChange = this.onPageChange.bind(this);
+ // this.handleIsLoading = this.handleIsLoading.bind(this);
+ }
+
+ componentDidMount() {
+ this.loadDetailInfo();
+ }
+
+ // load record detail
+ loadDetailInfo() {
+ let listParam = {};
+ listParam.recordNo = this.state.recordNo;
+
+ _record.getRecordInfo(listParam).then(res => {
+ this.setState({
+ recordInfo: res
+ });
+ console.log(this.state.recordInfo)
+ }, errMsg => {
+ // this.setState({
+ // recordInfo: {}
+ // });
+ _util.errorTips(errMsg);
+ });
+ }
+
+
+ render() {
+ let prev = this.state.recordInfo.prev || 'none';
+ let branch = this.state.recordInfo.branch || '';
+ let commit = this.state.recordInfo.commit || '';
+ let date = this.state.recordInfo.date || '';
+ let machine = this.state.recordInfo.test_machine || {};
+ let dataset = this.state.recordInfo.dataset_info || {};
+ let meta_info = this.state.recordInfo.meta_info || {};
+ let pg_info = this.state.recordInfo.pg_info || {};
+ let linux_info = this.state.recordInfo.linux_info || {};
+ let hardware_info = this.state.recordInfo.hardware_info || {};
+ let ro = dataset.ro || {};
+ let rw = dataset.rw || {};
+ // console.log(machine)
+ // Object.keys(obj).map(key => console.log(obj[key]));
+ let ro_10 = ro['10'] || {};
+ let rw_10 = rw['10'] || {};
+
+ let rw_tables = Object.keys(rw_10).map(key => {
+ // console.log(rw_10[key])
+ let metric = 0;
+ let percentage = 0.0;
+ let status = -1;
+ let tableRow = rw_10[key].map((item, idx) => {
+ // console.log('item is:')
+ // console.log(item)
+ metric = parseFloat(item['metric']).toFixed(4)
+ percentage = (item['percentage'] * 100).toFixed(2).toString() + '%'
+ status = item['status']
+
+ let results = item['results'].map((result, idx) => {
+ return (
+ <Table.Row>
+ <Table.Cell>{result.run}</Table.Cell>
+ <Table.Cell>{result.tps}</Table.Cell>
+ <Table.Cell>{result.mode}</Table.Cell>
+ <Table.Cell>{result.latency}</Table.Cell>
+ </Table.Row>
+ );
+ });
+ return results;
+
+ });
+ let trend_span
+
+ if (status == -1) {
+ trend_span = <span>{percentage}</span>;
+ } else if (status == 1) {
+ trend_span = <span className="trend-span improved"><Icon name="angle double up"/>+{percentage}</span>;
+ } else if (status == 2) {
+ trend_span = <span className="trend-span quo"><Icon name="bars"/>+{percentage}</span>;
+ } else if (status == 3) {
+ trend_span =
+ <span className="trend-span regressive"><Icon name="angle double down"/>{percentage}</span>;
+ }
+
+ return (
+ <Table celled striped>
+ <Table.Header>
+ <Table.Row>
+ <Table.HeaderCell colSpan="4">
+ <div className="client-title-div">
+ <div>Client(s) {key}: {metric} {trend_span}</div>
+ {/*<div><a href=""> >>prev</a></div>*/}
+ </div>
+ {/*<div>*/}
+ {/*<span>Improved ()</span>*/}
+ {/*</div>*/}
+ </Table.HeaderCell>
+ </Table.Row>
+ <Table.Row>
+ <Table.HeaderCell>Run</Table.HeaderCell>
+ <Table.HeaderCell>Tps</Table.HeaderCell>
+ <Table.HeaderCell>mode</Table.HeaderCell>
+ <Table.HeaderCell>latency</Table.HeaderCell>
+ </Table.Row>
+ </Table.Header>
+
+ <Table.Body>
+ {tableRow}
+ {/*<Table.Row>*/}
+ {/*<Table.Cell>2018-09-11 15:32</Table.Cell>*/}
+ {/*<Table.Cell>200.221</Table.Cell>*/}
+ {/*<Table.Cell>simple</Table.Cell>*/}
+ {/*<Table.Cell>-1</Table.Cell>*/}
+ {/*</Table.Row>*/}
+ </Table.Body>
+ </Table>
+ );
+ });
+
+
+ let ro_tables = Object.keys(ro_10).map(key => {
+ console.log(ro_10[key])
+ let metric = 0;
+ let percentage = 0.0;
+ let status = -1;
+ let tableRow = ro_10[key].map((item, idx) => {
+ console.log('item is:')
+ console.log(item)
+ metric = parseFloat(item['metric']).toFixed(4)
+ percentage = (item['percentage'] * 100).toFixed(2).toString() + '%'
+ status = item['status']
+
+ let results = item['results'].map((result, idx) => {
+ return (
+ <Table.Row>
+ <Table.Cell>{result.run}</Table.Cell>
+ <Table.Cell>{result.tps}</Table.Cell>
+ <Table.Cell>{result.mode}</Table.Cell>
+ <Table.Cell>{result.latency}</Table.Cell>
+ </Table.Row>
+ );
+ });
+ return results;
+
+ });
+ let trend_span
+
+ if (status == -1) {
+ trend_span = <span>{percentage}</span>;
+ } else if (status == 1) {
+ trend_span = <span className="trend-span improved"><Icon name="angle double up"/>+{percentage}</span>;
+ } else if (status == 2) {
+ trend_span = <span className="trend-span quo"><Icon name="bars"/>+{percentage}</span>;
+ } else if (status == 3) {
+ trend_span =
+ <span className="trend-span regressive"><Icon name="angle double down"/>{percentage}</span>;
+ }
+
+ return (
+ <Table celled striped>
+ <Table.Header>
+ <Table.Row>
+ <Table.HeaderCell colSpan="4">
+ <div className="client-title-div">
+ <div>Client(s) {key}: {metric} {trend_span}</div>
+ {/*<div><a href=""> >>prev</a></div>*/}
+ </div>
+ {/*<div>*/}
+ {/*<span>Improved ()</span>*/}
+ {/*</div>*/}
+ </Table.HeaderCell>
+ </Table.Row>
+ <Table.Row>
+ <Table.HeaderCell>Run</Table.HeaderCell>
+ <Table.HeaderCell>Tps</Table.HeaderCell>
+ <Table.HeaderCell>mode</Table.HeaderCell>
+ <Table.HeaderCell>latency</Table.HeaderCell>
+ </Table.Row>
+ </Table.Header>
+
+ <Table.Body>
+ {tableRow}
+ {/*<Table.Row>*/}
+ {/*<Table.Cell>2018-09-11 15:32</Table.Cell>*/}
+ {/*<Table.Cell>200.221</Table.Cell>*/}
+ {/*<Table.Cell>simple</Table.Cell>*/}
+ {/*<Table.Cell>-1</Table.Cell>*/}
+ {/*</Table.Row>*/}
+ </Table.Body>
+ </Table>
+ );
+ });
+
+ let prev_link
+ if (prev == 'none') {
+ prev_link = prev
+ } else {
+ prev_link = (
+ <Link target='_blank' color='linkedin' to={'/detailInfo/' + prev}>
+ {prev.substring(0, 7)}
+ </Link>
+ )
+ }
+
+ return (
+ <div className="container-fluid detail-container">
+ <div className="record-title ">
+ <div className="record-title-right title-flex">
+ <div className="record-title-top">
+ <span>Branch: {branch}</span>
+ <span>Commit: <a target="_blank"
+ href={ PGConstant.PG_GITHUB_MIRROR + commit}>{commit.substring(0, 7)}</a></span>
+ </div>
+ <div className="record-title-bottom">
+ <h2 >NO: {this.state.recordNo}</h2>
+ </div>
+ </div>
+
+ <div className="record-title-left title-flex">
+ <span>Date: {date}</span>
+ <span>
+ prev: {prev_link}
+ </span>
+ </div>
+
+ </div>
+
+ <div className="col-md-3">
+
+ <Segment vertical>Farmer Info</Segment>
+ <FarmerCard machine={machine}></FarmerCard>
+ {/*//todo add a catalog*/}
+
+ </div>
+
+ <div className="col-md-9">
+ {/*<div className="card-container row">*/}
+ <div className="card-container col-md-12 col-md-offset-1">
+ <div className="col-md-6 card-div">
+ <Segment vertical>RO</Segment>
+ {ro_tables}
+ {/*<Table celled striped key='1'>*/}
+ {/*<Table.Header>*/}
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell colSpan="4">Clients:4 scale:10 <a href=""> >>prev</a>*/}
+ {/*<div>*/}
+
+ {/*mertic:200 <span>Improved (+12.4%)</span>*/}
+ {/*</div>*/}
+ {/*</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell>Start</Table.HeaderCell>*/}
+ {/*<Table.HeaderCell>Tps</Table.HeaderCell>*/}
+ {/*<Table.HeaderCell>mode</Table.HeaderCell>*/}
+ {/*<Table.HeaderCell>latency</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ {/*</Table.Header>*/}
+
+ {/*<Table.Body>*/}
+ {/*<Table.Row>*/}
+ {/*<Table.Cell>2018-09-11 15:32</Table.Cell>*/}
+ {/*<Table.Cell>200.221</Table.Cell>*/}
+ {/*<Table.Cell>simple</Table.Cell>*/}
+ {/*<Table.Cell>-1</Table.Cell>*/}
+ {/*</Table.Row>*/}
+ {/*<Table.Row>*/}
+ {/*<Table.Cell>2018-09-11 15:32</Table.Cell>*/}
+ {/*<Table.Cell>200.221</Table.Cell>*/}
+ {/*<Table.Cell>simple</Table.Cell>*/}
+ {/*<Table.Cell>-1</Table.Cell>*/}
+ {/*</Table.Row>*/}
+ {/*</Table.Body>*/}
+ {/*</Table>*/}
+
+ </div>
+
+ <div className="col-md-6 card-div">
+
+ <Segment vertical>RW</Segment>
+ {rw_tables}
+
+ </div>
+ </div>
+
+ <div className="info-container col-md-12 col-md-offset-1">
+ {/*<Segment>*/}
+ <Divider/>
+ <Divider horizontal>Horizontal</Divider>
+ {/*</Segment>*/}
+
+ <div>
+ {/*<h2><a href="#linuxInfo">Linux Info</a></h2>*/}
+ {/*<div className="" data-example-id="">*/}
+ {/*<dl>*/}
+ {/*<dt><a href="#">Description lists</a></dt>*/}
+ {/*<dd>A description list is perfect for defining terms.</dd>*/}
+ {/*<dt>Euismod</dt>*/}
+ {/*<dd>*/}
+ {/*</dd>*/}
+ {/*<dd></dd>*/}
+ {/*<dt>Malesuada porta</dt>*/}
+ {/*<dd>Etiam porta sem malesuada magna mollis euismod.</dd>*/}
+ {/*</dl>*/}
+ {/*</div>*/}
+
+
+ <InfoList name="Meta" info={meta_info}> </InfoList>
+ <InfoList name="PG Settings" info={pg_info}> </InfoList>
+ <InfoList name="Operating System" info={linux_info}> </InfoList>
+ <InfoList name="Hardward" info={hardware_info}> </InfoList>
+ </div>
+
+ </div>
+
+ </div>
+ </div>
+
+ )
+ }
+}
+
+export default DetailInfo; \ No newline at end of file
diff --git a/front-end/src/page/farmerApply/index.css b/front-end/src/page/farmerApply/index.css
new file mode 100644
index 0000000..efe47f7
--- /dev/null
+++ b/front-end/src/page/farmerApply/index.css
@@ -0,0 +1,4 @@
+.panel-blue{
+ /*border-top: 3px solid #2497ba;*/
+ border-top: 3px solid rgb(2,141,193);
+} \ No newline at end of file
diff --git a/front-end/src/page/farmerApply/index.jsx b/front-end/src/page/farmerApply/index.jsx
new file mode 100644
index 0000000..43068e3
--- /dev/null
+++ b/front-end/src/page/farmerApply/index.jsx
@@ -0,0 +1,212 @@
+import React from 'react';
+import {hashHistory} from 'React-router'
+import './index.css';
+import {Link} from 'react-router-dom';
+import UserInfoCard from 'component/userinfo-card/index.jsx'
+import Record from 'service/record-service.jsx'
+import PGUtil from 'util/util.jsx'
+import User from 'service/user-service.jsx'
+import PGConstant from 'util/constant.jsx'
+
+const _user = new User();
+
+const _util = new PGUtil();
+const _record = new Record();
+class FarmerApply extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ username: '',
+ machines:[],
+ userinfo: {}
+ }
+ this.loadUserMachineManageList = this.loadUserMachineManageList.bind(this);
+ }
+ componentDidMount(){
+
+ let user = _util.getStorage('userInfo')
+ let _this = this
+ this.setState({
+ username: user.username,
+ },()=>{
+ _this.loadUserPortalInfo()
+ _this.loadUserMachineManageList();
+ });
+ console.log(user.token)
+
+ }
+
+ loadUserPortalInfo(){
+ let username = this.state.username
+ _user.getUserPortalInfo(username).then(res => {
+ this.setState({
+ userinfo: res,
+ });
+ }, errMsg => {
+ _util.errorTips('Please make sure no fields are empty.');
+ });
+ }
+
+ loadUserMachineManageList(page=1){
+
+ let listParam = {};
+ listParam.page = page;
+ listParam.machine_owner__username = this.state.username;
+ _user.getUserMachineManageList(listParam).then(res => {
+ this.setState({
+ machines: res.results,
+ total: res.count,
+ });
+ }, errMsg => {
+ _util.errorTips(errMsg);
+ });
+ }
+ onLogout(){
+ _util.removeStorage('userInfo');
+ // this.props.history.push('/login')
+ // hashHistory.push('/login')
+ window.location.href = '/';
+ }
+
+ onInputChange(e) {
+ let inputValue = e.target.value,
+ inputName = e.target.name;
+ this.setState({
+ [inputName]: inputValue
+ });
+ }
+
+ onInputKeyUp(e) {
+ if (e.keyCode === 13) {
+ this.onSubmit();
+ }
+ }
+
+ onSubmit() {
+ // alert(1)
+ let machineInfo = {
+ os_name: this.state.os_name,
+ os_version: this.state.os_version,
+ comp_name: this.state.comp_name,
+ comp_version: this.state.comp_version,
+ machine_owner:this.state.username
+ }
+ let checkResult = true
+ // check success
+ if (checkResult) {
+ _user.farmerApply(machineInfo).then((res) => {
+ // console.dir(res)
+ alert('add machine success!')
+ hashHistory.push('/portal')
+ // window.location.href = this.state.redirect;
+ }, (err) => {
+ // console.log(err)
+ if (PGConstant.AuthorizedErrorCode === err) {
+ _util.errorTips('username or password is mistake!');
+ }else{
+ _util.errorTips('login fail');
+ }
+ });
+ }
+ // check failure
+ else {
+
+ _util.errorTips(checkResult.msg);
+ }
+
+ }
+
+ render() {
+ let show = this.state.isLoading ? "none" : "block";
+ let style = {
+ display: show
+ };
+
+ return (
+ <div className="container-fluid detail-container">
+
+ <div className="col-md-3">
+
+ {/*<Segment vertical>Farmer Info</Segment>*/}
+ <UserInfoCard userinfo={this.state.userinfo}></UserInfoCard>
+
+ <div className="panel panel-default panel-blue">
+ <div className="panel-heading">
+ <h3 className="panel-title">
+ <i className="fa fa-bookmark"></i>&nbsp; Shortcuts
+ </h3>
+ </div>
+ <div className="list-group">
+ <Link target='_blank' to="farmerApply/" className="list-group-item">
+ <i className="fa fa-globe fa-fw"></i>&nbsp; Add a New Mchine
+ </Link>
+ <a onClick={() => {this.onLogout()}} className="list-group-item">
+ <i className="fa fa-arrow-left fa-fw"></i>&nbsp; Logout
+ </a>
+ </div>
+ </div>
+ </div>
+
+ <div className="col-md-9">
+ <div className="record-title">
+ <h2 >Welcome Back, {this.state.username}</h2>
+ </div>
+
+ <div className="panel panel-default">
+ <div className="panel-heading">
+ Apply New Machines
+ </div>
+ <div className="panel-body">
+ <div className="row">
+ {/*<!-- /.col-lg-6 (nested) -->*/}
+ <div className="col-lg-12">
+ {/*<h4>Login Form</h4>*/}
+ <form role="form">
+ <div className="form-group input-group">
+ {/*<label className="control-label" for="inputLogin"> login input</label>*/}
+ <span class="input-group-addon">system name</span>
+ <input type="text" className="form-control" id="inputOSName"
+ placeholder="etc.Debian,Ubuntu"
+ name="os_name"
+ onKeyUp={e => this.onInputKeyUp(e)}
+ onChange={e => this.onInputChange(e)}/>
+ </div>
+ <div className="form-group input-group">
+ <span class="input-group-addon">system version</span>
+ <input type="text" className="form-control" id="inputOSVersion"
+ name="os_version"
+ placeholder="etc.9,14.4" onKeyUp={e => this.onInputKeyUp(e)}
+ onChange={e => this.onInputChange(e)}/>
+ </div>
+ <div className="form-group input-group">
+ <span class="input-group-addon">arch name</span>
+ <input type="text" className="form-control" id="inputCampName"
+ name="comp_name"
+ placeholder="etc.x86" onKeyUp={e => this.onInputKeyUp(e)}
+ onChange={e => this.onInputChange(e)}/>
+ </div>
+ <div className="form-group input-group">
+ <span class="input-group-addon">arch version</span>
+ <input type="text" className="form-control" id="inputCampVersion"
+ name="comp_version"
+ placeholder="etc.64" onKeyUp={e => this.onInputKeyUp(e)}
+ onChange={e => this.onInputChange(e)}/>
+ </div>
+ <button type="button" className="btn btn-primary" onClick={e => {this.onSubmit(e)}}>Submit</button>
+ </form>
+ </div>
+ {/*<!-- /.col-lg-6 (nested) -->*/}
+ </div>
+ {/*<!-- /.row (nested) -->*/}
+ </div>
+ {/*<!-- /.panel-body -->*/}
+ </div>
+ </div>
+ </div>
+
+
+ )
+ }
+}
+
+export default FarmerApply; \ No newline at end of file
diff --git a/front-end/src/page/home/index.jsx b/front-end/src/page/home/index.jsx
new file mode 100644
index 0000000..2bc2bd8
--- /dev/null
+++ b/front-end/src/page/home/index.jsx
@@ -0,0 +1,24 @@
+import React from 'react';
+import './index.scss';
+
+class Home extends React.Component{
+ render(){
+ return (
+ <div id="page-wrapper" className="jumbotron">
+ <h1>Hello, world!</h1>
+ <p>
+ The PostgreSQL Performance Farm project is a community project to collect performance data from tests as code changes are made to PostgreSQL. To support this effort, a database needs to be created for storing results, and a Web site developed to review results.
+ This project will focus on developing the Web site on top of the database.
+ The database will be using PostgreSQL in the back-end. Test results will come in the form of JSON and flat files. The Web application will be developed using the Django Web framework.
+ </p>
+ <p>
+ As an example, the PostgreSQL Build Farm site is a central repository for the results of testing source code changes for PostgreSQL as they occur, on a wide variety of platforms.
+ </p>
+
+ {/*<button className="btn btn-warning">test</button>*/}
+ </div>
+ )
+ }
+}
+
+export default Home; \ No newline at end of file
diff --git a/front-end/src/page/home/index.scss b/front-end/src/page/home/index.scss
new file mode 100644
index 0000000..e0e39cb
--- /dev/null
+++ b/front-end/src/page/home/index.scss
@@ -0,0 +1,28 @@
+.color-box{
+ display: block;
+ height: 160px;
+ text-align: center;
+ padding: 20px 0;
+ opacity: .9;
+ transition: all .3s;
+ &:hover{
+ text-decoration: none;
+ color: #555;
+ opacity: 1;
+ transform: scale(1.08);
+ }
+ &:focus{
+ text-decoration: none;
+ }
+ .count{
+ font-size: 50px;
+ height: 80px;
+ line-height: 80px;
+ }
+ .desc{
+ font-size: 18px;
+ .fa{
+ margin-right: 5px;
+ }
+ }
+}
diff --git a/front-end/src/page/login/index.css b/front-end/src/page/login/index.css
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/front-end/src/page/login/index.css
diff --git a/front-end/src/page/login/index.jsx b/front-end/src/page/login/index.jsx
new file mode 100644
index 0000000..317690e
--- /dev/null
+++ b/front-end/src/page/login/index.jsx
@@ -0,0 +1,120 @@
+import React from 'react';
+// import './index.css';
+import PGUtil from 'util/util.jsx'
+import PGConstant from 'util/constant.jsx'
+const _util = new PGUtil();
+import User from 'service/user-service.jsx'
+const _user = new User();
+
+class Login extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ username: '',
+ password: '',
+ redirect: _util.getUrlParam('redirect') || 'portal',
+ }
+ }
+
+ componentWillMount() {
+ document.title = 'LOGIN';
+ let userinfo = _util.getStorage('userInfo')|| {};
+ if(userinfo.token){
+ this.props.history.push('/portal')
+ // window.location.href = '/portal';
+ }
+
+ }
+
+ onInputChange(e) {
+ let inputValue = e.target.value,
+ inputName = e.target.name;
+ this.setState({
+ [inputName]: inputValue
+ });
+ }
+
+ onInputKeyUp(e) {
+ if (e.keyCode === 13) {
+ this.onSubmit();
+ }
+ }
+
+ onSubmit() {
+ let loginInfo = {
+ username: this.state.username,
+ password: this.state.password
+ },
+ checkResult = _user.checkLoginInfo(loginInfo);
+ // check success
+ if (checkResult.status) {
+ _user.login(loginInfo).then((res) => {
+ // console.dir(res)
+ _util.setStorage('userInfo', res);
+ // this.props.history.push(this.state.redirect);
+ window.location.href = this.state.redirect;
+ }, (err) => {
+ // console.log(err)
+ if (PGConstant.AuthorizedErrorCode === err) {
+ _util.errorTips('username or password is mistake!');
+ }else{
+ _util.errorTips('login fail');
+ }
+ });
+ }
+ // check failure
+ else {
+
+ _util.errorTips(checkResult.msg);
+ }
+
+ }
+
+ render() {
+ return (
+ <div id="page-wrapper">
+ <div className="row">
+ <div className="col-lg-16">
+ <div className="panel panel-default">
+ <div className="panel-heading">
+ login to manage your machines!
+ </div>
+ <div className="panel-body">
+ <div className="row">
+ {/*<!-- /.col-lg-6 (nested) -->*/}
+ <div className="col-lg-12">
+ <h4>Login Form</h4>
+ <form role="form">
+ <div className="form-group">
+ {/*<label className="control-label" for="inputLogin"> login input</label>*/}
+ <input type="text" className="form-control" id="inputLogin"
+ placeholder="Username or email"
+ name="username"
+ onKeyUp={e => this.onInputKeyUp(e)}
+ onChange={e => this.onInputChange(e)}/>
+ </div>
+ <div className="form-group">
+ <input type="text" className="form-control" id="inputPwd"
+ name="password"
+ placeholder="password" onKeyUp={e => this.onInputKeyUp(e)}
+ onChange={e => this.onInputChange(e)}/>
+ </div>
+ <button type="button" className="btn btn-primary" onClick={e => {this.onSubmit(e)}}>Button</button>
+ </form>
+ </div>
+ {/*<!-- /.col-lg-6 (nested) -->*/}
+ </div>
+ {/*<!-- /.row (nested) -->*/}
+ </div>
+ {/*<!-- /.panel-body -->*/}
+ </div>
+ {/*<!-- /.panel -->*/}
+ </div>
+ {/*<!-- /.col-lg-12 -->*/}
+ </div>
+ </div>
+ )
+ }
+}
+
+export default Login; \ No newline at end of file
diff --git a/front-end/src/page/machine/index.css b/front-end/src/page/machine/index.css
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/front-end/src/page/machine/index.css
diff --git a/front-end/src/page/machine/index.jsx b/front-end/src/page/machine/index.jsx
new file mode 100644
index 0000000..6e0edb8
--- /dev/null
+++ b/front-end/src/page/machine/index.jsx
@@ -0,0 +1,58 @@
+import React from 'react';
+// import './index.css';
+import ResultFilter from 'component/result-filter/index.jsx';
+import RecordTable from 'util/record-table/index.jsx';
+import MachineService from 'service/machine-service.jsx'
+import MachineTable from 'util/machine-table/index.jsx';
+import PGUtil from 'util/util.jsx'
+
+const _util = new PGUtil();
+const _machine = new MachineService();
+class Machine extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ isLoading: false,
+ currentPage: 1,
+ total: 3,
+ machines: [],
+ },
+ this.loadMachineList = this.loadMachineList.bind(this);
+ }
+
+ componentDidMount() {
+ this.loadMachineList();
+ }
+
+ loadMachineList(page = 1) {
+ _machine.getMachineList(page).then(res => {
+ this.setState({
+ machines: res.results,
+ total: res.count,
+ isLoading: false
+ });
+ }, errMsg => {
+ _util.errorTips(errMsg);
+ });
+ }
+
+
+ render() {
+ return (
+ <div id="page-wrapper">
+ <h1>machine page</h1>
+ <p>
+ Shown here is the latest status of each farm member for each branch it has reported on in the last
+ 30 days.
+ Use the farm member link for history of that member on the relevant branch.
+ </p>
+
+ <MachineTable list={this.state.machines} total={this.state.total} current={this.state.currentPage}
+ loadfunc={this.loadMachineList}/>
+
+ </div>
+ )
+ }
+}
+
+export default Machine; \ No newline at end of file
diff --git a/front-end/src/page/machineInfo/index.css b/front-end/src/page/machineInfo/index.css
new file mode 100644
index 0000000..14cbbe9
--- /dev/null
+++ b/front-end/src/page/machineInfo/index.css
@@ -0,0 +1,12 @@
+.machine-info-divier-div{
+ margin-left: 15px!important;
+ float: left;
+}
+.machine-info-divier{
+ float: left;
+}
+.blank{
+ float: left;
+ width: 15px;
+ height: 2px;
+} \ No newline at end of file
diff --git a/front-end/src/page/machineInfo/index.jsx b/front-end/src/page/machineInfo/index.jsx
new file mode 100644
index 0000000..80d4738
--- /dev/null
+++ b/front-end/src/page/machineInfo/index.jsx
@@ -0,0 +1,128 @@
+import React from 'react';
+// import './index.css';
+import {Tab, Divider, Segment, Icon} from 'semantic-ui-react'
+import FarmerDetailCard from 'component/farmer-detail-card/index.jsx'
+import Record from 'service/record-service.jsx'
+import PGUtil from 'util/util.jsx'
+import HistoryRecordsPane1 from 'component/history-records-pane1/index.jsx'
+
+const _util = new PGUtil();
+const _record = new Record();
+class MachineInfo extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ machineNo: this.props.match.params.machine_sn,
+ branches: [
+ {'branch':0,'value':0}
+ ],
+ machineInfo: {},
+ isLoading: false,
+ currentPage: 1,
+ total:3,
+ filter: {},
+ list: [
+ ]
+ },
+ // console.dir(this.props.match.params)
+ // this.onPageChange = this.onPageChange.bind(this);
+ this.handleApplyBtnClick = this.handleApplyBtnClick.bind(this);
+ this.loadHistoryRecordList = this.loadHistoryRecordList.bind(this);
+ }
+
+ componentDidMount() {
+ this.loadHistoryRecordList();
+ }
+
+ handleApplyBtnClick(params) {
+ console.log('handle apply!')
+
+ let self = this
+ this.setState({filter: params}, ()=> {
+ self.loadRecordList()
+ });
+ }
+
+ // load history record list
+ loadHistoryRecordList() {
+ let _this = this;
+ let listParam = {};
+ // listParam= this.state.filter;
+ // listParam.page = page;
+ listParam.machine_sn = this.state.machineNo;
+ _record.getHistoryRecordList(listParam).then(res => {
+ console.log('res is:')
+ console.dir(res)
+ this.setState({
+ branches: res.branches || [],
+ machineInfo: res.machine_info || {},
+ list: res.reports || [],
+ // total: res.count,
+ isLoading: false
+ }, ()=> {
+ console.log(this.state.branches);
+ // 123
+ });
+ // _this.changeIsLoading(false);
+ }, errMsg => {
+ this.setState({
+ list: []
+ });
+ _util.errorTips(errMsg);
+
+ console.log(errMsg)
+ _this.changeIsLoading(false);
+ });
+
+ console.log(this.state.list)
+ }
+
+ render() {
+ // let branches = this.state.branches;
+ let panes = [
+ { menuItem: 'Review By Branches', render: () => <Tab.Pane attached={true}><HistoryRecordsPane1 machine_sn={this.state.machineInfo.machine_sn} branches={this.state.branches}/></Tab.Pane> },
+ ]
+
+ return (
+ <div className="container-fluid detail-container">
+ <div className="record-title">
+ <div className="record-title-right title-flex">
+ <div className="record-title-top">
+ <span>NO: {this.state.machineNo}</span>
+ {/*<span>Commit: <a target="_blank" href={ PGConstant.PG_GITHUB_MIRROR + commit}>{commit.substring(0, 7)}</a></span>*/}
+ </div>
+ <div className="record-title-bottom">
+ <h2 >Farmer: {this.state.machineInfo.alias}</h2>
+ </div>
+ </div>
+ {/*<div className="record-title-left title-flex">*/}
+ {/*<span>Date joined: {this.state.machineInfo.add_time}</span>*/}
+ {/*</div>*/}
+ </div>
+
+ <div className="machine-info-divier-div">
+ <div className="blank"></div>
+ <Divider className="machine-info-divier"></Divider>
+ </div>
+ <div className="col-md-3">
+ {/*<Segment vertical>Farmer Info</Segment>*/}
+ <FarmerDetailCard machine={this.state.machineInfo} branch_num={this.state.branches.length}></FarmerDetailCard>
+ </div>
+
+ <div className="col-md-9">
+ {/*<div className="card-container row">*/}
+
+ {/*<div className="info-container col-md-12 col-md-offset-1">*/}
+ {/*<MachineRecordTable list={this.state.list} total={this.state.total} current={this.state.currentPage} loadfunc={this.loadRecordList}/>*/}
+
+
+ <Tab menu={{pointing: true }} panes={panes} />
+ {/*</div>*/}
+
+ </div>
+ </div>
+ )
+ }
+}
+
+export default MachineInfo; \ No newline at end of file
diff --git a/front-end/src/page/portal/index.css b/front-end/src/page/portal/index.css
new file mode 100644
index 0000000..efe47f7
--- /dev/null
+++ b/front-end/src/page/portal/index.css
@@ -0,0 +1,4 @@
+.panel-blue{
+ /*border-top: 3px solid #2497ba;*/
+ border-top: 3px solid rgb(2,141,193);
+} \ No newline at end of file
diff --git a/front-end/src/page/portal/index.jsx b/front-end/src/page/portal/index.jsx
new file mode 100644
index 0000000..e58188d
--- /dev/null
+++ b/front-end/src/page/portal/index.jsx
@@ -0,0 +1,109 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import './index.css';
+import MachineTable from 'util/machine-table/index.jsx';
+import UserInfoCard from 'component/userinfo-card/index.jsx'
+import Record from 'service/record-service.jsx'
+import PGUtil from 'util/util.jsx'
+import User from 'service/user-service.jsx'
+const _user = new User();
+
+const _util = new PGUtil();
+const _record = new Record();
+class Portal extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ username: '',
+ machines:[],
+ userinfo: {}
+ }
+ this.loadUserMachineManageList = this.loadUserMachineManageList.bind(this);
+ }
+ componentDidMount(){
+
+ let user = _util.getStorage('userInfo')
+ this.setState({
+ username: user.username,
+ },()=>{
+ this.loadUserPortalInfo()
+ this.loadUserMachineManageList();
+ });
+ console.log(user.token)
+
+ }
+
+ loadUserPortalInfo(){
+ let username = this.state.username
+ _user.getUserPortalInfo(username).then(res => {
+ this.setState({
+ userinfo: res,
+ });
+ }, errMsg => {
+ _util.errorTips(errMsg);
+ });
+ }
+
+ loadUserMachineManageList(page=1){
+
+ let listParam = {};
+ listParam.page = page;
+ listParam.machine_owner__username = this.state.username;
+ _user.getUserMachineManageList(listParam).then(res => {
+ this.setState({
+ machines: res.results,
+ total: res.count,
+ });
+ }, errMsg => {
+ _util.errorTips(errMsg);
+ });
+ }
+ onLogout(){
+ _util.removeStorage('userInfo');
+ // this.props.history.push('/login')
+ // hashHistory.push('/login')
+ window.location.href = '/';
+ }
+
+ render() {
+ return (
+ <div className="container-fluid detail-container">
+
+ <div className="col-md-3">
+
+ {/*<Segment vertical>Farmer Info</Segment>*/}
+ <UserInfoCard userinfo={this.state.userinfo}></UserInfoCard>
+
+ <div className="panel panel-default panel-blue">
+ <div className="panel-heading">
+ <h3 className="panel-title">
+ <i className="fa fa-bookmark"></i>&nbsp; Shortcuts
+ </h3>
+ </div>
+ <div className="list-group">
+ <Link target='_blank' to="farmerApply/" className="list-group-item">
+ <i className="fa fa-globe fa-fw"></i>&nbsp; Add a New Mchine
+ </Link>
+
+ <a onClick={() => {this.onLogout()}} className="list-group-item">
+ <i className="fa fa-arrow-left fa-fw"></i>&nbsp; Logout
+ </a>
+ </div>
+ </div>
+ </div>
+
+ <div className="col-md-9">
+ <div className="record-title">
+ <h2 >Welcome Back, {this.state.username}</h2>
+ </div>
+
+ <MachineTable list={this.state.machines} total={this.state.total} current={this.state.currentPage} loadfunc={this.loadUserMachineManageList}/>
+ </div>
+ </div>
+
+
+ )
+ }
+}
+
+export default Portal; \ No newline at end of file
diff --git a/front-end/src/page/ppolicy/index.css b/front-end/src/page/ppolicy/index.css
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/front-end/src/page/ppolicy/index.css
diff --git a/front-end/src/page/ppolicy/index.jsx b/front-end/src/page/ppolicy/index.jsx
new file mode 100644
index 0000000..f0dec2b
--- /dev/null
+++ b/front-end/src/page/ppolicy/index.jsx
@@ -0,0 +1,65 @@
+import React from 'react';
+import './index.css';
+// import ResultFilter from 'component/result-filter/index.jsx';
+
+class PPolice extends React.Component{
+ render(){
+ return (
+ <div id="page-wrapper" className="jumbotron" >
+ <h1>ppolicy page</h1>
+ <p>
+ When you visit our website, our servers automatically log your IP address and/or
+ host name.
+ </p>
+ <p>
+ We store information such as your email address, name and locality only if you
+ decide to send us such information by completing a survey, or registering as a
+ user on one of our sites. We collect this information to help us improve the
+ content of our sites, customize the layout of our web pages and to contact people
+ for technical and support purposes. We will not share your email address with
+ other organizations unless required by law.
+ </p>
+ <p>
+ If you submit content to the website, such as listing your company as a service
+ provider, the information you submitted will be published.
+ </p>
+ <p>
+ If you post a message to one of our public mailinglists, your sending email
+ address and any content of the email will be published, and archived, both by
+ us and by other organizations. These archives are permanent, and posted emails
+ are not removed. By sending a message to one of these lists you implicitly grant
+ permission for this archival, overriding any disclaimers in the message itself.
+ </p>
+ <p>
+ We may collect demographic and interest category information from people via
+ surveys, volunteered information, suggestions from members, and other means.
+ Our members may voluntarily provide information, including that regarding
+ personal, interests, geography, and demographics. The purpose of this data
+ collection is to ensure we continue to understand the needs and wants of the
+ PostgreSQL community, and therefore can provide the most relevant information,
+ guides, and content.
+ </p>
+ <p>
+ This website uses Google Analytics, a web analytics service provided by Google,
+ Inc. ("Google"). Google Analytics uses "cookies", which are text files placed on
+ your computer, to help the website analyze how users use the site. The
+ information generated by the cookie about your use of the website (including
+ your IP address) will be transmitted to and stored by Google on servers in the
+ United States. Google will use this information for the purpose of evaluating
+ your use of the website, compiling reports on website activity for website
+ operators and providing other services relating to website activity and
+ internet usage. Google may also transfer this information to third parties
+ where required to do so by law, or where such third parties process the
+ information on Google's behalf. Google will not associate your IP address with
+ any other data held by Google. You may refuse the use of cookies by selecting
+ the appropriate settings on your browser, however please note that if you do
+ this you may not be able to use the full functionality of this website. By
+ using this website, you consent to the processing of data about you by Google
+ in the manner and for the purposes set out above.
+ </p>
+ </div>
+ )
+ }
+}
+
+export default PPolice; \ No newline at end of file
diff --git a/front-end/src/page/status/index.jsx b/front-end/src/page/status/index.jsx
new file mode 100644
index 0000000..d1a2b33
--- /dev/null
+++ b/front-end/src/page/status/index.jsx
@@ -0,0 +1,184 @@
+import React from 'react';
+// import './index.css';
+import ResultFilter from 'component/result-filter/index.jsx';
+import RecordTable from 'util/record-table/index.jsx';
+import Record from 'service/record-service.jsx'
+import PGUtil from 'util/util.jsx'
+
+const _util = new PGUtil();
+const _record = new Record();
+class Status extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ isLoading: false,
+ currentPage: 1,
+ total: 3,
+ filter: {},
+ branch_list: [],
+ selected_branches:[],
+ list: [
+ // {
+ // 'alias': 'a_name',
+ // 'email': '[email protected]',
+ // 'clients': [2,3,4],
+ // 'mark': [140000,1,1],
+ // }, {
+ // 'alias': 'b_name',
+ // 'email': '[email protected]',
+ // 'clients': '4',
+ // 'mark': 150000
+ // }
+ ]
+
+ },
+
+ this.onPageChange = this.onPageChange.bind(this);
+ this.onIsLoadingChange = this.onIsLoadingChange.bind(this);
+ this.handleApplyBtnClick = this.handleApplyBtnClick.bind(this);
+ this.loadRecordList = this.loadRecordList.bind(this);
+ }
+
+ componentWillMount() {
+ this.loadBranchList();
+ }
+
+ handleApplyBtnClick(branches) {
+ console.log('handle apply!')
+
+ let _this = this
+ let selected_branches = []
+ if(branches === undefined || branches.length == 0) {
+ selected_branches = this.adjustBranchList([])
+ }else{
+ selected_branches = branches
+ }
+ this.setState({
+ selected_branches: selected_branches,
+ isLoading: false
+ });
+
+ }
+ adjustBranchList(branches){
+ let selected_branches = []
+ if(branches === undefined || branches.length == 0) {
+ branches = this.state.branch_list
+
+ for (let i = 0; i < branches.length; i++) {
+ let newItem = {}
+ newItem['name'] = branches[i].branch_name
+ newItem['value'] = branches[i].branch_name
+ newItem['isSelected'] = true;
+ selected_branches.push(newItem)
+ }
+
+ }
+
+ return selected_branches
+ }
+
+ loadBranchList() {
+ _record.getBranchList().then(res => {
+ // let selected_branches = res.results
+ // for (let i = 0; i < selected_branches.length; i++) {
+ // selected_branches[i].isSelected = true;
+ // }
+ let _this = this
+ this.setState({
+ branch_list: res.results,
+ },()=>{
+ this.setState({
+ selected_branches: _this.adjustBranchList([]),
+ });
+ });
+ console.log('now console the branch_list')
+ console.dir(res.results)
+ }, errMsg => {
+ _util.errorTips('get branch list error');
+ });
+ }
+
+
+ // load record list
+ loadRecordList(page = 1) {
+ let _this = this;
+ let listParam = {};
+ listParam = this.state.filter;
+ listParam.page = page;
+
+ _record.getRecordList(listParam).then(res => {
+ console.log('res is:' + res)
+ this.setState({
+ list: res.results,
+ total: res.count,
+ isLoading: false
+ });
+ _this.changeIsLoading(false);
+ }, errMsg => {
+ this.setState({
+ list: []
+ });
+ _util.errorTips(errMsg);
+
+ console.log(errMsg)
+ _this.changeIsLoading(false);
+ });
+
+ console.log(this.state.list)
+ }
+
+ onPageChange(page) {
+ console.log(page);
+ console.log(this);
+ this.setState({
+ current: page,
+ });
+ }
+
+ changeIsLoading(flag) {
+ this.setState({
+ isLoading: flag
+ });
+ }
+
+ onIsLoadingChange(flag) {
+ console.log('flag:' + flag)
+ this.setState({
+ isLoading: flag,
+ });
+ console.log('status isLoading:' + this.state.isLoading)
+ }
+
+ render() {
+ // console.log('hi')
+ // console.dir(this.state.selected_branches)
+ // console.log('done')
+ let table_list = this.state.selected_branches.map((value, index) => {
+ if (value.isSelected == true) {
+ return (
+ <RecordTable branch={value.name}/>
+ );
+ }
+ });
+
+ return (
+ <div id="page-wrapper">
+ <h1>status page</h1>
+ <p>
+ Shown here is the latest status of each farm member for each branch it has reported on in the last
+ 30 days.
+ Use the farm member link for history of that member on the relevant branch.
+ </p>
+
+
+ <ResultFilter branches={this.state.branch_list} isLoading={this.state.isLoading} onIsLoadingChange={this.onIsLoadingChange}
+ onApplyBtnClick={this.handleApplyBtnClick}/>
+ {table_list}
+ {/*<RecordTable list={this.state.list} total={this.state.total} current={this.state.currentPage} loadfunc={this.loadRecordList}/>*/}
+
+ </div>
+ )
+ }
+}
+
+export default Status; \ No newline at end of file
diff --git a/front-end/src/page/status/index.scss b/front-end/src/page/status/index.scss
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/front-end/src/page/status/index.scss
diff --git a/front-end/src/service/machine-service.jsx b/front-end/src/service/machine-service.jsx
new file mode 100644
index 0000000..7278665
--- /dev/null
+++ b/front-end/src/service/machine-service.jsx
@@ -0,0 +1,19 @@
+import PGUtil from 'util/util.jsx'
+import PGConstant from 'util/constant.jsx'
+// const _const = new PGConstant();
+const _util = new PGUtil();
+
+class MachineService{
+ getMachineList(page){
+ let url = PGConstant.base_url + '/machines';
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : {
+ page : page
+ }
+ });
+ }
+}
+
+export default MachineService; \ No newline at end of file
diff --git a/front-end/src/service/record-service.jsx b/front-end/src/service/record-service.jsx
new file mode 100644
index 0000000..62ff12a
--- /dev/null
+++ b/front-end/src/service/record-service.jsx
@@ -0,0 +1,88 @@
+import PGUtil from 'util/util.jsx'
+import PGConstant from 'util/constant.jsx'
+// const _const = new PGConstant();
+const _util = new PGUtil();
+
+class Record{
+ // get branch list
+ getBranchList(){
+ let url = PGConstant.base_url + '/branches';
+
+ return _util.request({
+ type : 'get',
+ url : url,
+ });
+ }
+
+ getRecordListByBranch(listParam){
+ let url = PGConstant.base_url + '/records-by-branch';
+
+ let data = {};
+ data = listParam;
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : data
+ });
+ }
+ // get record list
+ getRecordList(listParam){
+ let url = PGConstant.base_url + '/records';
+
+ let data = {};
+ data = listParam;
+
+ console.log('final data')
+ console.dir(listParam);
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : data
+ });
+ }
+
+ // get record detail info
+ getRecordInfo(listParam){
+ let url = PGConstant.base_url + '/detail/';
+ url = url + listParam.recordNo
+ return _util.request({
+ type : 'get',
+ url : url,
+ // data : {'Ldw7RrdP7jj4q89kgXCfeY'}
+ });
+ }
+
+ // get machine info
+ getHistoryRecordList(listParam){
+ let url = PGConstant.base_url + '/machine-records/' + listParam.machine_sn;
+
+ let data = {};
+ // data = listParam;
+
+ console.log('final data')
+ console.dir(listParam);
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : data
+ });
+ }
+
+
+ getMachineRecordListByBranch(listParam){
+ let url = PGConstant.base_url + '/machine-records-by-branch/';
+
+ let data = {};
+ data = listParam;
+
+ // console.log('final data')
+ // console.dir(listParam);
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : data
+ });
+ }
+}
+
+export default Record; \ No newline at end of file
diff --git a/front-end/src/service/user-service.jsx b/front-end/src/service/user-service.jsx
new file mode 100644
index 0000000..04f2b56
--- /dev/null
+++ b/front-end/src/service/user-service.jsx
@@ -0,0 +1,79 @@
+import PGUtil from 'util/util.jsx'
+import PGConstant from 'util/constant.jsx'
+
+const _util = new PGUtil();
+
+class User{
+ farmerApply(farmerInfo){
+ let url = PGConstant.base_url + '/my-machine/';
+ return _util.request({
+ type: 'post',
+ url: url,
+ data: farmerInfo
+ });
+ }
+
+ login(loginInfo){
+ let url = PGConstant.base_url + '/login/';
+ return _util.request({
+ type: 'post',
+ url: url,
+ data: loginInfo
+ });
+ }
+ // check if the loginInfo is legel
+ checkLoginInfo(loginInfo){
+ let username = $.trim(loginInfo.username),
+ password = $.trim(loginInfo.password);
+ // check username
+ if(typeof username !== 'string' || username.length ===0){
+ return {
+ status: false,
+ msg: 'username cannot be an empty string!'
+ }
+ }
+ // check password
+ if(typeof password !== 'string' || password.length ===0){
+ return {
+ status: false,
+ msg: 'password cannot be an empty string!!'
+ }
+ }
+ return {
+ status : true,
+ msg : 'justify pass'
+ }
+ }
+ // logout
+ logout(){
+ // let url = PGConstant.base_url + '/logout';
+ // return _util.request({
+ // type : 'post',
+ // url : url
+ // });
+ return true;
+ }
+
+ getUserMachineManageList(listParam){
+ let url = PGConstant.base_url + '/my-machine';
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : listParam
+ // listParam.page = page;
+ // listParam.username = this.state.username;
+ });
+ }
+
+ getUserPortalInfo(username=''){
+ let url = PGConstant.base_url + '/user-portal/' + username;
+ return _util.request({
+ type : 'get',
+ url : url,
+ data : {}
+ });
+ }
+
+}
+
+export default User; \ No newline at end of file
diff --git a/front-end/src/util/basic-table/index.css b/front-end/src/util/basic-table/index.css
new file mode 100644
index 0000000..0fe34f8
--- /dev/null
+++ b/front-end/src/util/basic-table/index.css
@@ -0,0 +1,43 @@
+.ReactTable .rt-th{
+ background-color: #ffffff;
+}
+
+.ReactTable .-pagination{
+ background-color: #ffffff;
+}
+
+.ReactTable .rt-tr-group:nth-child(2n) {
+ background-color: #ffffff;
+}
+
+.bgc-clear{
+ background-color: #ffffff;
+}
+
+.anonymous {
+ color: #e8e8e8;
+}
+
+.anonymous :hover {
+ color: lightgrey;
+}
+.improved {
+ color: #7cb305;
+}
+
+.quo {
+ color: #40a9ff;
+}
+
+.regressive {
+ color: #fa541c;
+}
+
+.mini-label {
+ font-weight: 100!important;
+ font-size: 0.1em!important;
+ min-width: 1.3em!important;
+ min-height: 0.1em!important;
+ padding: .2em!important;
+ line-height: 0.5em!important;
+} \ No newline at end of file
diff --git a/front-end/src/util/basic-table/index.jsx b/front-end/src/util/basic-table/index.jsx
new file mode 100644
index 0000000..a2eb1a6
--- /dev/null
+++ b/front-end/src/util/basic-table/index.jsx
@@ -0,0 +1,189 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import {Icon, Table, Label, Message, Button} from 'semantic-ui-react'
+import Pagination from 'util/pagination/index.jsx'
+import './index.css';
+
+function Bubble(props) {
+
+ if (props.num <= 0) {
+ return null;
+ }
+ let className = props.name + 'IconClassName';
+ return (
+ <Label circular size="mini" className={"mini-label " + className}>
+ {props.num}
+ </Label>
+ );
+}
+
+//todo
+// function TrendCell(trend) {
+// const isNull = !list;
+// const isEmpty = !isNull && !list.length;
+// let improvedIconClassName = trend.improved > 0 ? 'improved' : 'anonymous'
+// let quoIconClassName = trend.quo > 0 ? 'quo' : 'anonymous'
+// let regressiveIconClassName = trend.regressive > 0 ? 'regressive' : 'anonymous'
+// if (!trend.is_first) {
+// return (
+// <Table.Cell textAlign='center'>
+// first report
+// </Table.Cell>
+// );
+// } else {
+// return (
+// <div>
+// <Table.Cell textAlign='center'>
+// <Icon className={"bgc-clear " + improvedIconClassName} name='smile outline' size='large'/>
+// <Bubble num={trend.improved} name="improved"/>
+// </Table.Cell>
+// <Table.Cell textAlign='center'>
+// <Icon className={"bgc-clear " + quoIconClassName} name='meh outline' size='large'/>
+// <Bubble num={trend.quo} name="quo"/>
+// </Table.Cell>
+// <Table.Cell textAlign='center'>
+// <Icon className={"bgc-clear " + regressiveIconClassName} name='frown outline'
+// size='large'/>
+// <Bubble num={trend.regressive} name="regressive"/>
+// </Table.Cell>
+// </div>
+// );
+// }
+//
+// }
+
+// general basic table
+class BasicTable extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ isFirstLoading: true,
+ total: this.props.total,
+ currentPage: 1,
+ }
+ }
+
+
+ onPageNumChange(current) {
+ this.setState({
+ currentPage: current
+ }, () => {
+ this.props.loadfunc(current);
+ });
+ console.log('current:' + this.state.currentPage)
+ }
+
+ render() {
+ // let branch = record.pg_info.pg_branch;
+ let _list = this.props.list || []
+ let style = {
+ display: 'show'
+ };
+ let listBody = _list.map((record, index) => {
+ let machine = record.machine_info;
+ let system = machine.os_name + ' ' + machine.os_version + ' ' + machine.comp_name + ' ' + machine.comp_version;
+ let alias = machine.alias;
+
+
+ let trend = record.trend
+ let improvedIconClassName = trend.improved > 0 ? 'improved' : 'anonymous'
+ let quoIconClassName = trend.quo > 0 ? 'quo' : 'anonymous'
+ let regressiveIconClassName = trend.regressive > 0 ? 'regressive' : 'anonymous'
+ return (
+
+ <Table.Row key={index}>
+ {/*alias*/}
+ <Table.Cell><a href="#">{alias}</a></Table.Cell>
+
+ {/*system*/}
+ <Table.Cell><a href="#">{system}</a></Table.Cell>
+
+ {/*branch*/}
+ {/*<Table.Cell>{branch}</Table.Cell>*/}
+
+ {/*trending-data*/}
+
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + improvedIconClassName} name='smile outline' size='large'/>
+ <Bubble num={trend.improved} name="improved"/>
+ </Table.Cell>
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + quoIconClassName} name='meh outline' size='large'/>
+ <Bubble num={trend.quo} name="quo"/>
+ </Table.Cell>
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + regressiveIconClassName} name='frown outline'
+ size='large'/>
+ <Bubble num={trend.regressive} name="regressive"/>
+ </Table.Cell>
+
+
+ <Table.Cell textAlign='center'>
+ <Link color='linkedin' to={'detailInfo/' + record.uuid}>
+ <Icon name='linkify'/> Link
+ </Link>
+ </Table.Cell>
+
+
+ {/*date*/}
+ <Table.Cell>{record.add_time}</Table.Cell>
+ </Table.Row>
+ );
+ });
+
+ return (
+ <Table celled structured compact textAlign='center'>
+ <Table.Header>
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell rowSpan='9'>Branch: 10_STABLE</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ <Table.Row>
+ <Table.HeaderCell rowSpan='2'>Alias</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>System</Table.HeaderCell>
+ {/*<Table.HeaderCell rowSpan='2'>Branch</Table.HeaderCell>*/}
+ <Table.HeaderCell colSpan='3'>Trending</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Detail</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Date</Table.HeaderCell>
+ </Table.Row>
+ <Table.Row>
+ <Table.HeaderCell>improvement</Table.HeaderCell>
+ <Table.HeaderCell>status quo</Table.HeaderCell>
+ <Table.HeaderCell>regression</Table.HeaderCell>
+ </Table.Row>
+
+ </Table.Header>
+
+ <Table.Body>
+ {listBody}
+ </Table.Body>
+ <Table.Footer>
+ <Table.Row>
+ <Table.HeaderCell colSpan='10'>
+ {/*<Menu size='small' floated='right' pagination>*/}
+ {/*<Menu.Item as='a' icon>*/}
+ {/*<Icon name='chevron left'/>*/}
+ {/*</Menu.Item>*/}
+ {/*<Menu.Item as='a'>1</Menu.Item>*/}
+ {/*<Menu.Item as='a'>2</Menu.Item>*/}
+ {/*<Menu.Item as='a'>3</Menu.Item>*/}
+ {/*<Menu.Item as='a'>4</Menu.Item>*/}
+ {/*<Menu.Item as='a' icon>*/}
+ {/*<Icon name='chevron right'/>*/}
+ {/*</Menu.Item>*/}
+ {/*</Menu>*/}
+ <Pagination style={style} onChange={(current) => this.onPageNumChange(current)} pageSize={2}
+ current={this.state.currentPage} total={this.props.total}/>
+
+ </Table.HeaderCell>
+
+ </Table.Row>
+ </Table.Footer>
+ </Table>
+ );
+
+ }
+
+
+}
+
+export default BasicTable; \ No newline at end of file
diff --git a/front-end/src/util/constant.jsx b/front-end/src/util/constant.jsx
new file mode 100644
index 0000000..1752b76
--- /dev/null
+++ b/front-end/src/util/constant.jsx
@@ -0,0 +1,11 @@
+const object = {
+ base_url:'http://127.0.0.1:8000',
+
+
+ name:'好123',
+ UnauthorizedCode:401,// unlogin
+ AuthorizedErrorCode:400,// username or pwd mistake
+
+ PG_GITHUB_MIRROR:'https://github.com/postgres/postgres/commit/'
+};
+export default object; \ No newline at end of file
diff --git a/front-end/src/util/machine-record-table/index.css b/front-end/src/util/machine-record-table/index.css
new file mode 100644
index 0000000..0fe34f8
--- /dev/null
+++ b/front-end/src/util/machine-record-table/index.css
@@ -0,0 +1,43 @@
+.ReactTable .rt-th{
+ background-color: #ffffff;
+}
+
+.ReactTable .-pagination{
+ background-color: #ffffff;
+}
+
+.ReactTable .rt-tr-group:nth-child(2n) {
+ background-color: #ffffff;
+}
+
+.bgc-clear{
+ background-color: #ffffff;
+}
+
+.anonymous {
+ color: #e8e8e8;
+}
+
+.anonymous :hover {
+ color: lightgrey;
+}
+.improved {
+ color: #7cb305;
+}
+
+.quo {
+ color: #40a9ff;
+}
+
+.regressive {
+ color: #fa541c;
+}
+
+.mini-label {
+ font-weight: 100!important;
+ font-size: 0.1em!important;
+ min-width: 1.3em!important;
+ min-height: 0.1em!important;
+ padding: .2em!important;
+ line-height: 0.5em!important;
+} \ No newline at end of file
diff --git a/front-end/src/util/machine-record-table/index.jsx b/front-end/src/util/machine-record-table/index.jsx
new file mode 100644
index 0000000..4cb03d2
--- /dev/null
+++ b/front-end/src/util/machine-record-table/index.jsx
@@ -0,0 +1,162 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import {Icon, Table, Label, Message, Button} from 'semantic-ui-react'
+import Pagination from 'util/pagination/index.jsx'
+import PGConstant from 'util/constant.jsx'
+import './index.css';
+
+function Bubble(props) {
+
+ if (props.num <= 0) {
+ return null;
+ }
+ let className = props.name + 'IconClassName';
+ return (
+ <Label circular size="mini" className={"mini-label " + className}>
+ {props.num}
+ </Label>
+ );
+}
+
+// general basic table
+class MachineRecordTable extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ isFirstLoading: true,
+ total: this.props.total,
+ currentPage: 1,
+ }
+ }
+
+ onPageNumChange(current) {
+ let _this = this
+ this.setState({
+ currentPage: current
+ }, () => {
+ _this.props.loadfunc(current);
+ });
+ console.log('current:' + this.state.currentPage)
+ }
+
+ render() {
+ // let branch = record.pg_info.pg_branch;
+ let _list = this.props.list || []
+ let style = {
+ display: 'show'
+ };
+ let listBody = _list.map((record, index) => {
+ let machine = record.machine_info;
+ let system = machine.os_name + ' ' + machine.os_version + ' ' + machine.comp_name + ' ' + machine.comp_version;
+ let alias = machine.alias;
+
+
+ let trend = record.trend
+ let improvedIconClassName = trend.improved > 0 ? 'improved' : 'anonymous'
+ let quoIconClassName = trend.quo > 0 ? 'quo' : 'anonymous'
+ let regressiveIconClassName = trend.regressive > 0 ? 'regressive' : 'anonymous'
+ return (
+
+ <Table.Row key={index}>
+ {/*alias*/}
+ <Table.Cell>
+ <Link color='linkedin' to={'machineInfo/' + machine.machine_sn}>
+ {alias}
+ </Link>
+ </Table.Cell>
+
+ {/*system*/}
+ {/*<Table.Cell><a href="#">{system}</a></Table.Cell>*/}
+
+ {/*branch*/}
+ {/*<Table.Cell>{branch}</Table.Cell>*/}
+
+ {/*trending-data*/}
+
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + improvedIconClassName} name='smile outline' size='large'/>
+ <Bubble num={trend.improved} name="improved"/>
+ </Table.Cell>
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + quoIconClassName} name='meh outline' size='large'/>
+ <Bubble num={trend.quo} name="quo"/>
+ </Table.Cell>
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + regressiveIconClassName} name='frown outline'
+ size='large'/>
+ <Bubble num={trend.regressive} name="regressive"/>
+ </Table.Cell>
+
+
+ <Table.Cell textAlign='center'>
+ <Link color='linkedin' to={'/detailInfo/' + record.uuid}>
+ <Icon name='linkify'/> Link
+ </Link>
+ </Table.Cell>
+
+ {/*commit*/}
+ <Table.Cell><a target="_blank" href={ PGConstant.PG_GITHUB_MIRROR + record.commit}>{ record.commit.substring(0, 7)}</a></Table.Cell>
+
+ {/*date*/}
+ <Table.Cell>{record.add_time}</Table.Cell>
+ </Table.Row>
+ );
+ });
+
+ return (
+ <Table basic='very' selectable structured compact textAlign='center'>
+ <Table.Header celled>
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell rowSpan='9'>Branch: 10_STABLE</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ <Table.Row>
+ <Table.HeaderCell rowSpan='2'>Alias</Table.HeaderCell>
+ {/*<Table.HeaderCell rowSpan='2'>System</Table.HeaderCell>*/}
+ {/*<Table.HeaderCell rowSpan='2'>Branch</Table.HeaderCell>*/}
+ <Table.HeaderCell colSpan='3'>Trending</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Detail</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Commit</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Date</Table.HeaderCell>
+ </Table.Row>
+ <Table.Row>
+ <Table.HeaderCell>improvement</Table.HeaderCell>
+ <Table.HeaderCell>status quo</Table.HeaderCell>
+ <Table.HeaderCell>regression</Table.HeaderCell>
+ </Table.Row>
+
+ </Table.Header>
+
+ <Table.Body>
+ {listBody}
+ </Table.Body>
+ <Table.Footer>
+ <Table.Row>
+ <Table.HeaderCell colSpan='10'>
+ {/*<Menu size='small' floated='right' pagination>*/}
+ {/*<Menu.Item as='a' icon>*/}
+ {/*<Icon name='chevron left'/>*/}
+ {/*</Menu.Item>*/}
+ {/*<Menu.Item as='a'>1</Menu.Item>*/}
+ {/*<Menu.Item as='a'>2</Menu.Item>*/}
+ {/*<Menu.Item as='a'>3</Menu.Item>*/}
+ {/*<Menu.Item as='a'>4</Menu.Item>*/}
+ {/*<Menu.Item as='a' icon>*/}
+ {/*<Icon name='chevron right'/>*/}
+ {/*</Menu.Item>*/}
+ {/*</Menu>*/}
+ <Pagination style={style} onChange={(current) => this.onPageNumChange(current)} pageSize={20}
+ current={this.state.currentPage} total={this.props.total}/>
+
+ </Table.HeaderCell>
+
+ </Table.Row>
+ </Table.Footer>
+ </Table>
+ );
+
+ }
+
+
+}
+
+export default MachineRecordTable; \ No newline at end of file
diff --git a/front-end/src/util/machine-table/index.css b/front-end/src/util/machine-table/index.css
new file mode 100644
index 0000000..af59a47
--- /dev/null
+++ b/front-end/src/util/machine-table/index.css
@@ -0,0 +1,48 @@
+.ReactTable .rt-th{
+ background-color: #ffffff;
+}
+
+.ReactTable .-pagination{
+ background-color: #ffffff;
+}
+
+.ReactTable .rt-tr-group:nth-child(2n) {
+ background-color: #ffffff;
+}
+
+.bgc-clear{
+ background-color: #ffffff;
+}
+
+.anonymous {
+ color: #e8e8e8;
+}
+
+.anonymous :hover {
+ color: lightgrey;
+}
+.improved {
+ color: #7cb305;
+}
+
+.quo {
+ color: #40a9ff;
+}
+
+.regressive {
+ color: #fa541c;
+}
+
+.mini-label {
+ font-weight: 100!important;
+ font-size: 0.1em!important;
+ min-width: 1.3em!important;
+ min-height: 0.1em!important;
+ padding: .2em!important;
+ line-height: 0.5em!important;
+}
+
+.link-div{
+ display: flex;
+ flex-direction: column;
+} \ No newline at end of file
diff --git a/front-end/src/util/machine-table/index.jsx b/front-end/src/util/machine-table/index.jsx
new file mode 100644
index 0000000..21ec17f
--- /dev/null
+++ b/front-end/src/util/machine-table/index.jsx
@@ -0,0 +1,147 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import {Icon, Table, Label, Message, Button} from 'semantic-ui-react'
+import Pagination from 'util/pagination/index.jsx'
+import './index.css';
+
+function LastestLink(props) {
+ let _list = props.list
+ if (_list <= 0) {
+ return null;
+ }
+
+ let ret = _list.map((item, index) => {
+ return (
+ <Link color='linkedin' to={'detailInfo/' + item.uuid}>
+ {item.branch}
+ </Link>
+ );
+ });
+ return ret;
+}
+
+// general basic table
+class MachineTable extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ isFirstLoading: true,
+ total: this.props.total,
+ currentPage: 1,
+ }
+ }
+
+
+ onPageNumChange(current) {
+ let _this = this
+ this.setState({
+ currentPage: current
+ }, () => {
+ _this.props.loadfunc(current);
+ });
+ console.log('current:' + this.state.currentPage)
+ }
+
+ render() {
+ // let branch = record.pg_info.pg_branch;
+ let _list = this.props.list || []
+ let style = {
+ display: 'show'
+ };
+ let listBody = _list.map((machineItem, index) => {
+ let machine = machineItem
+ let system = machine.os_name + ' ' + machine.os_version + ' ' + machine.comp_name + ' ' + machine.comp_version;
+
+ // let improvedIconClassName = trend.improved > 0 ? 'improved' : 'anonymous'
+ // let quoIconClassName = trend.quo > 0 ? 'quo' : 'anonymous'
+ // let regressiveIconClassName = trend.regressive > 0 ? 'regressive' : 'anonymous'
+ let color = 'positive';
+ if(machine.state == 'pending'){
+ color = 'warning';
+ }else if(machine.state == 'prohibited'){
+ color = 'negative';
+ }
+ return (
+ <Table.Row key={index} className={color}>
+ {/*alias*/}
+ <Table.Cell>
+ <Link color='linkedin' to={'machineInfo/' + machine.machine_sn}>
+ {machine.alias}
+ </Link>
+ </Table.Cell>
+
+ {/*system*/}
+ <Table.Cell>{system}</Table.Cell>
+
+ {/*State*/}
+ <Table.Cell>
+ {machine.state}
+ </Table.Cell>
+
+ {/*lastest-records*/}
+ <Table.Cell textAlign='center'>
+ {/*<Icon className={"bgc-clear " + improvedIconClassName} name='smile outline' size='large'/>*/}
+ {/*<Bubble num={trend.improved} name="improved"/>*/}
+ <div className="link-div">
+ <LastestLink list={machine.lastest}/>
+ </div>
+ </Table.Cell>
+
+ {/*machine history*/}
+ <Table.Cell textAlign='center'>
+ <Link color='linkedin' to={'machineInfo/' + machine.machine_sn}>
+ <Icon name='linkify'/> Link
+ </Link>
+ </Table.Cell>
+
+ {/*date*/}
+ <Table.Cell>{machine.add_time}</Table.Cell>
+ </Table.Row>
+ );
+ });
+
+ return (
+ <Table celled structured compact textAlign='center'>
+ <Table.Header>
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell rowSpan='9'>Branch: 10_STABLE</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ <Table.Row>
+ <Table.HeaderCell rowSpan='2'>Alias</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>System</Table.HeaderCell>
+ {/*<Table.HeaderCell rowSpan='2'>Branch</Table.HeaderCell>*/}
+ <Table.HeaderCell rowSpan='2'>State</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='3'>Lastest</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>History</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Add Date</Table.HeaderCell>
+ </Table.Row>
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell>improvement</Table.HeaderCell>*/}
+ {/*<Table.HeaderCell>status quo</Table.HeaderCell>*/}
+ {/*<Table.HeaderCell>regression</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+
+ </Table.Header>
+
+ <Table.Body>
+ {listBody}
+ </Table.Body>
+ <Table.Footer>
+ <Table.Row>
+ <Table.HeaderCell colSpan='10'>
+
+ <Pagination style={style} onChange={(current) => this.onPageNumChange(current)} pageSize={40}
+ current={this.state.currentPage} total={this.props.total}/>
+ </Table.HeaderCell>
+
+ </Table.Row>
+ </Table.Footer>
+ </Table>
+ );
+
+ }
+
+
+}
+
+export default MachineTable; \ No newline at end of file
diff --git a/front-end/src/util/pagination/index.jsx b/front-end/src/util/pagination/index.jsx
new file mode 100644
index 0000000..ade4d48
--- /dev/null
+++ b/front-end/src/util/pagination/index.jsx
@@ -0,0 +1,24 @@
+import React from 'react';
+import RcPagination from 'rc-pagination';
+import 'rc-pagination/dist/rc-pagination.min.css';
+import en_US from 'rc-pagination/es/locale/en_US.js';
+// General paging component
+class Pagination extends React.Component {
+ constructor(props) {
+ super(props);
+ }
+
+ render() {
+ return (
+ <div className="row">
+ <div className="col-md-12">
+ <RcPagination {...this.props}
+ hideOnSinglePage
+ showQuickJumper locale={en_US}/>
+ </div>
+ </div>
+ );
+ }
+}
+
+export default Pagination; \ No newline at end of file
diff --git a/front-end/src/util/rate-bar/index.jsx b/front-end/src/util/rate-bar/index.jsx
new file mode 100644
index 0000000..d5a19cb
--- /dev/null
+++ b/front-end/src/util/rate-bar/index.jsx
@@ -0,0 +1,115 @@
+import React from 'react';
+
+import echarts from 'echarts/lib/echarts';
+// import 'echarts/lib/chart/line';
+import 'echarts/lib/component/tooltip'
+import 'echarts/lib/component/grid'
+import 'echarts/lib/chart/bar'
+
+import 'echarts/lib/component/title';
+
+// import { pieOption, barOption, lineOption, scatterOption, mapOption, radarOption, candlestickOption } from './optionConfig/options'
+// const BarReact = asyncComponent(() => import(/* webpackChunkName: "BarReact" */'./EchartsDemo/BarReact')) // bar component
+
+
+// General rate bar
+class RateBar extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ std: 150000,
+ curMark: 143732,
+ }
+ }
+
+ componentDidMount() {
+ let std = this.props.std;
+ let curMark = this.props.curMark;
+
+ // init echarts
+ let myChart = echarts.init(this.refs.waterall);
+ let colorList = [
+ '#C33531','#EFE42A','#64BD3D','#EE9201','#29AAE3',
+ '#B74AE5','#0AAF9F','#E89589'
+ ];
+ let option = {
+ tooltip : {
+ trigger: 'axis',
+ axisPointer : {
+ type : 'shadow'
+ }
+ },
+ legend: {
+ data: ['std', 'current']
+ },
+ grid: {
+ left: '2%',
+ right: '0%',
+ bottom: '20%',
+ top: '-20%',
+ containLabel: false
+ },
+ xAxis: {
+ type: 'value',
+ show: false,
+ splitLine:{
+ show: false
+ },
+ },
+ yAxis: {
+ type: 'category',
+ show: false,
+ // splitLine:{
+ // show: false
+ // },
+ data: ['2 clients']
+ },
+ series: [
+ {
+ itemStyle:{
+ normal:{
+ color:'#0050b3'
+ }
+ },
+ name: 'std',
+ type: 'bar',
+ stack: 'current',
+ label: {
+ normal: {
+ show: true,
+ position: 'insideRight'
+ }
+ },
+ data: [std]
+ },
+ {
+ itemStyle:{
+ normal:{
+ color:'#13c2c2'
+ }
+ },
+ name: 'curMark',
+ type: 'bar',
+ stack: 'current',
+ label: {
+ normal: {
+ show: true,
+ position: 'insideRight'
+ }
+ },
+ data: [curMark]
+ },
+ ]
+ };
+
+ myChart.setOption(option);
+ }
+
+ render() {
+ return (
+ <div ref="waterall" className="rate-bar" style={{ width: 240, height: 30 }}></div>
+ );
+ }
+}
+
+export default RateBar; \ No newline at end of file
diff --git a/front-end/src/util/rate-bar/lineChart b/front-end/src/util/rate-bar/lineChart
new file mode 100644
index 0000000..9d41f48
--- /dev/null
+++ b/front-end/src/util/rate-bar/lineChart
@@ -0,0 +1,3 @@
+module.exports = {
+
+}; \ No newline at end of file
diff --git a/front-end/src/util/record-table/index.css b/front-end/src/util/record-table/index.css
new file mode 100644
index 0000000..0fe34f8
--- /dev/null
+++ b/front-end/src/util/record-table/index.css
@@ -0,0 +1,43 @@
+.ReactTable .rt-th{
+ background-color: #ffffff;
+}
+
+.ReactTable .-pagination{
+ background-color: #ffffff;
+}
+
+.ReactTable .rt-tr-group:nth-child(2n) {
+ background-color: #ffffff;
+}
+
+.bgc-clear{
+ background-color: #ffffff;
+}
+
+.anonymous {
+ color: #e8e8e8;
+}
+
+.anonymous :hover {
+ color: lightgrey;
+}
+.improved {
+ color: #7cb305;
+}
+
+.quo {
+ color: #40a9ff;
+}
+
+.regressive {
+ color: #fa541c;
+}
+
+.mini-label {
+ font-weight: 100!important;
+ font-size: 0.1em!important;
+ min-width: 1.3em!important;
+ min-height: 0.1em!important;
+ padding: .2em!important;
+ line-height: 0.5em!important;
+} \ No newline at end of file
diff --git a/front-end/src/util/record-table/index.jsx b/front-end/src/util/record-table/index.jsx
new file mode 100644
index 0000000..f9ae12f
--- /dev/null
+++ b/front-end/src/util/record-table/index.jsx
@@ -0,0 +1,222 @@
+import React from 'react';
+import {Link} from 'react-router-dom';
+import {Icon, Table, Label, Message, Button} from 'semantic-ui-react'
+import Pagination from 'util/pagination/index.jsx'
+import Record from 'service/record-service.jsx'
+import './index.css';
+const _record = new Record();
+import PGConstant from 'util/constant.jsx'
+function Bubble(props) {
+
+ if (props.num <= 0) {
+ return null;
+ }
+ let className = props.name + 'IconClassName';
+ return (
+ <Label circular size="mini" className={"mini-label " + className}>
+ {props.num}
+ </Label>
+ );
+}
+
+//todo
+// function TrendCell(trend) {
+// const isNull = !list;
+// const isEmpty = !isNull && !list.length;
+// let improvedIconClassName = trend.improved > 0 ? 'improved' : 'anonymous'
+// let quoIconClassName = trend.quo > 0 ? 'quo' : 'anonymous'
+// let regressiveIconClassName = trend.regressive > 0 ? 'regressive' : 'anonymous'
+// if (!trend.is_first) {
+// return (
+// <Table.Cell textAlign='center'>
+// first report
+// </Table.Cell>
+// );
+// } else {
+// return (
+// <div>
+// <Table.Cell textAlign='center'>
+// <Icon className={"bgc-clear " + improvedIconClassName} name='smile outline' size='large'/>
+// <Bubble num={trend.improved} name="improved"/>
+// </Table.Cell>
+// <Table.Cell textAlign='center'>
+// <Icon className={"bgc-clear " + quoIconClassName} name='meh outline' size='large'/>
+// <Bubble num={trend.quo} name="quo"/>
+// </Table.Cell>
+// <Table.Cell textAlign='center'>
+// <Icon className={"bgc-clear " + regressiveIconClassName} name='frown outline'
+// size='large'/>
+// <Bubble num={trend.regressive} name="regressive"/>
+// </Table.Cell>
+// </div>
+// );
+// }
+//
+// }
+
+// general basic table
+class RecordTable extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ branch: this.props.branch,
+ isFirstLoading: true,
+ total: this.props.total,
+ currentPage: 1,
+ list: []
+ }
+ }
+
+ componentWillMount() {
+ this.loadRecordListByBranch(this.state.branch);
+ }
+ loadRecordListByBranch(branch,page=1) {
+ let _this = this;
+ let listParam = {};
+ listParam.page = page;
+ listParam.branch = branch;
+
+ _record.getRecordListByBranch(listParam).then(res => {
+ console.log('branch res is:' + res)
+ this.setState({
+ list: res.results,
+ total: res.count,
+ isLoading: false
+ });
+ }, errMsg => {
+ this.setState({
+ list: []
+ });
+ _util.errorTips(errMsg);
+ console.log(errMsg)
+ });
+
+ console.log(this.state.list)
+ }
+ onPageNumChange(current) {
+ let _this = this
+ this.setState({
+ currentPage: current
+ }, () => {
+ this.loadRecordListByBranch(_this.state.branch,current);
+ });
+ console.log('current:' + this.state.currentPage)
+ }
+
+ render() {
+ // let branch = record.pg_info.pg_branch;
+ let _list = this.state.list || []
+ let style = {
+ display: 'show'
+ };
+ let listBody = _list.map((record, index) => {
+ let machine = record.machine_info;
+ let system = machine.os_name + ' ' + machine.os_version + ' ' + machine.comp_name + ' ' + machine.comp_version;
+ let alias = machine.alias;
+
+
+ let trend = record.trend
+ let improvedIconClassName = trend.improved > 0 ? 'improved' : 'anonymous'
+ let quoIconClassName = trend.quo > 0 ? 'quo' : 'anonymous'
+ let regressiveIconClassName = trend.regressive > 0 ? 'regressive' : 'anonymous'
+ return (
+
+ <Table.Row key={index}>
+ {/*alias*/}
+ <Table.Cell>
+ <Link color='linkedin' to={'machineInfo/' + machine.machine_sn}>
+ {alias}
+ </Link>
+ </Table.Cell>
+
+ {/*system*/}
+ <Table.Cell>{system}</Table.Cell>
+
+ {/*branch*/}
+ {/*<Table.Cell>{branch}</Table.Cell>*/}
+
+ {/*trending-data*/}
+
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + improvedIconClassName} name='smile outline' size='large'/>
+ <Bubble num={trend.improved} name="improved"/>
+ </Table.Cell>
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + quoIconClassName} name='meh outline' size='large'/>
+ <Bubble num={trend.quo} name="quo"/>
+ </Table.Cell>
+ <Table.Cell textAlign='center'>
+ <Icon className={"bgc-clear " + regressiveIconClassName} name='frown outline'
+ size='large'/>
+ <Bubble num={trend.regressive} name="regressive"/>
+ </Table.Cell>
+
+
+ <Table.Cell textAlign='center'>
+ <Link color='linkedin' to={'detailInfo/' + record.uuid}>
+ <Icon name='linkify'/> Link
+ </Link>
+ </Table.Cell>
+
+ {/*commit*/}
+ <Table.Cell><a target="_blank" href={ PGConstant.PG_GITHUB_MIRROR + record.commit}>{ record.commit.substring(0, 7)}</a></Table.Cell>
+ {/*date*/}
+ <Table.Cell>{record.add_time}</Table.Cell>
+ </Table.Row>
+ );
+ });
+
+ return (
+ <Table celled structured compact textAlign='center'>
+ <Table.Header>
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell rowSpan='9'>Branch: {this.state.branch}</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ <Table.Row>
+ <Table.HeaderCell colSpan='11'>{this.state.branch}</Table.HeaderCell>
+ </Table.Row>
+
+ </Table.Header>
+ <Table.Header>
+ {/*<Table.Row>*/}
+ {/*<Table.HeaderCell rowSpan='9'>Branch: {this.state.branch}</Table.HeaderCell>*/}
+ {/*</Table.Row>*/}
+ <Table.Row>
+ <Table.HeaderCell rowSpan='2'>Alias</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>System</Table.HeaderCell>
+ {/*<Table.HeaderCell rowSpan='2'>Branch</Table.HeaderCell>*/}
+ <Table.HeaderCell colSpan='3'>Trending</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Detail</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Commit</Table.HeaderCell>
+ <Table.HeaderCell rowSpan='2'>Date</Table.HeaderCell>
+ </Table.Row>
+ <Table.Row>
+ <Table.HeaderCell>improvement</Table.HeaderCell>
+ <Table.HeaderCell>status quo</Table.HeaderCell>
+ <Table.HeaderCell>regression</Table.HeaderCell>
+ </Table.Row>
+
+ </Table.Header>
+
+ <Table.Body>
+ {listBody}
+ </Table.Body>
+ <Table.Footer>
+ <Table.Row>
+ <Table.HeaderCell colSpan='10'>
+ <Pagination style={style} onChange={(current) => this.onPageNumChange(current)} pageSize={20}
+ current={this.state.currentPage} total={this.state.total}/>
+
+ </Table.HeaderCell>
+
+ </Table.Row>
+ </Table.Footer>
+ </Table>
+ );
+
+ }
+
+
+}
+
+export default RecordTable; \ No newline at end of file
diff --git a/front-end/src/util/table-list/index.css b/front-end/src/util/table-list/index.css
new file mode 100644
index 0000000..4bb48ba
--- /dev/null
+++ b/front-end/src/util/table-list/index.css
@@ -0,0 +1,8 @@
+.table th, .table td {
+ text-align: center;
+ vertical-align: middle!important;
+}
+
+.table {
+ background-color: #fff;
+} \ No newline at end of file
diff --git a/front-end/src/util/table-list/index.jsx b/front-end/src/util/table-list/index.jsx
new file mode 100644
index 0000000..d967503
--- /dev/null
+++ b/front-end/src/util/table-list/index.jsx
@@ -0,0 +1,61 @@
+import React from 'react';
+import './index.css';
+
+// general table
+class TableList extends React.Component {
+ constructor(props) {
+ super(props);
+ this.state = {
+ isFirstLoading: true
+ }
+ }
+
+ componentWillReceiveProps() {
+ // Only when the table is loaded for the first time,isFirstLoading equals true
+ this.setState({
+ isFirstLoading: false
+ });
+ }
+
+ render() {
+
+ let tableHeader = this.props.tableHeads.map(
+ (tableHead, index) => {
+ if (typeof tableHead === 'object') {
+ return <th key={index} width={tableHead.width}>{tableHead.name}</th>
+ } else if (typeof tableHead === 'string') {
+ return <th key={index}>{tableHead}</th>
+ }
+ }
+ );
+
+ let listBody = this.props.children;
+
+ let listInfo = (
+ <tr>
+ <td colSpan={this.props.tableHeads.length} className="text-center">
+ {this.state.isFirstLoading ? 'isLoading...' : 'no results~'}</td>
+ </tr>
+ );
+ let tableBody = listBody.length > 0 ? listBody : listInfo;
+ return (
+ <div className="row">
+ <div className="col-md-12">
+ <table className="table table-striped table-hover table-condensed">
+ <thead>
+ <tr>
+ {tableHeader}
+ </tr>
+ </thead>
+ <tbody>
+ {tableBody}
+
+ </tbody>
+ </table>
+ </div>
+ </div>
+ );
+ }
+}
+
+export default TableList; \ No newline at end of file
diff --git a/front-end/src/util/util.jsx b/front-end/src/util/util.jsx
new file mode 100644
index 0000000..6a93479
--- /dev/null
+++ b/front-end/src/util/util.jsx
@@ -0,0 +1,114 @@
+import PGConstant from 'util/constant.jsx'
+// const _const = new PGConstant();
+class PGUtil {
+ request(param) {
+ return new Promise((resolve, reject) => {
+ let user = this.getStorage('userInfo')
+ let beforeSendFunc = (xhr) => {}
+ if (user.token) {
+ beforeSendFunc = (xhr) => xhr.setRequestHeader("Authorization", 'Token ' + user.token);
+ }
+ $.ajax({
+ type: param.type || 'get',
+ url: param.url || '',
+ dataType: param.dataType || 'json',
+ data: param.data || null,
+ // headers: {
+ // 'Authorization': 'Token ' + user.token
+ // },
+ beforeSend: beforeSendFunc,
+ success: res => {
+ // request success
+ console.dir(res)
+ typeof resolve === 'function' && resolve(res, res.msg);
+ if (0 === res.status) {
+ typeof resolve === 'function' && resolve(res.data, res.msg);
+ } else {
+ typeof reject === 'function' && reject(res.msg || res.data);
+ }
+ },
+ error: err => {
+ console.log('here is err')
+ console.dir(err.status)
+ // nologin force to login
+ if (PGConstant.UnauthorizedCode === err.status) {
+ this.removeStorage('userInfo');
+ this.doLogin();
+ } else {
+ typeof reject === 'function' && reject(err.status);
+ }
+
+ }
+ });
+ });
+ }
+
+ // redirect to login
+ doLogin() {
+ this.props.history.push('/login')
+ // window.location.href = '/login?redirect=' + encodeURIComponent(window.location.pathname);
+ // window.location.href = '/login';
+ }
+
+ getUrlParam(name) {
+ // param=123&param1=456
+ let queryString = window.location.search.split('?')[1] || '',
+ reg = new RegExp("(^|&)" + name + "=([^&]*)(&|$)"),
+ result = queryString.match(reg);
+ return result ? decodeURIComponent(result[2]) : null;
+ }
+
+ // success tips
+ successTips(successMsg) {
+ alert(successMsg);
+ }
+
+ // error tips
+ errorTips(errMsg) {
+ alert(errMsg);
+ }
+
+ // set local storage
+ setStorage(name, data) {
+ let dataType = typeof data;
+ // json obj
+ if (dataType === 'object') {
+ window.localStorage.setItem(name, JSON.stringify(data));
+ }
+ // basical type
+ else if (['number', 'string', 'boolean'].indexOf(dataType) >= 0) {
+ window.localStorage.setItem(name, data);
+ }
+ // other unacceptable type
+ else {
+ alert('type unacceptabled');
+ }
+ }
+
+ // get local storage
+ getStorage(name) {
+ let data = window.localStorage.getItem(name);
+ if (data) {
+ return JSON.parse(data);
+ }
+ else {
+ return '';
+ }
+ }
+
+ // remove local storage
+ removeStorage(name) {
+ window.localStorage.removeItem(name);
+ }
+
+ getDateStr(AddDayCount) {
+ let dd = new Date();
+ dd.setDate(dd.getDate() + AddDayCount);
+ let y = dd.getFullYear();
+ let m = (dd.getMonth() + 1) < 10 ? "0" + (dd.getMonth() + 1) : (dd.getMonth() + 1);
+ let d = dd.getDate() < 10 ? "0" + dd.getDate() : dd.getDate();
+ return y + "-" + m + "-" + d;
+ }
+}
+
+export default PGUtil; \ No newline at end of file
diff --git a/front-end/webpack.config.js b/front-end/webpack.config.js
new file mode 100644
index 0000000..4eeec6b
--- /dev/null
+++ b/front-end/webpack.config.js
@@ -0,0 +1,94 @@
+const path = require('path');
+const webpack = require('webpack');
+const HtmlWebpackPlugin = require('html-webpack-plugin');
+const ExtractTextPlugin = require('extract-text-webpack-plugin');
+
+let WEBPACK_ENV = process.env.WEBPACK_ENV || 'dev';
+console.log(WEBPACK_ENV)
+module.exports = {
+ entry: './src/app.jsx',
+ output: {
+ path: path.resolve(__dirname, 'dist'),
+ publicPath: WEBPACK_ENV === 'dev' ? '' : '//140.211.168.111/front-end-code/dist/',
+ filename: 'js/app.js'
+ },
+ resolve: {
+ // extensions: ['', '.js', '.jsx'],
+ alias: {
+ page: path.resolve(__dirname, 'src/page'),
+ image: path.resolve(__dirname, 'src/image'),
+ component: path.resolve(__dirname, 'src/component'),
+ service: path.resolve(__dirname, 'src/service'),
+ util: path.resolve(__dirname, 'src/util'),
+ }
+ },
+
+ module: {
+ rules: [{
+ test: /\.jsx$/,
+ exclude: /(node_modules)/,
+ use: {
+ loader: 'babel-loader',
+ options: {
+ presets: ['env', 'react']
+ }
+ },
+ },
+ {
+ test: /\.css$/,
+ use: ExtractTextPlugin.extract({
+ fallback: "style-loader",
+ use: "css-loader"
+ })
+ },
+ {
+ test: /\.scss$/,
+ use: ExtractTextPlugin.extract({
+ fallback: 'style-loader',
+ use: ['css-loader', 'sass-loader']
+ })
+ },
+ {
+ test: /\.(png|jpg|gif)$/,
+ use: [{
+ loader: 'url-loader',
+ options: {
+ limit: 8192,
+ name: 'resource/[name].[ext]'
+ }
+ }]
+ },
+ {
+ test: /\.(eot|svg|ttf|woff|woff2|otf)$/,
+ use: [{
+ loader: 'url-loader',
+ options: {
+ limit: 80000,
+ name: 'resource/[name].[ext]'
+ }
+ }]
+ },
+
+ ]
+ },
+
+ plugins: [
+ new HtmlWebpackPlugin({
+ template: './src/index.html',
+ }),
+ new ExtractTextPlugin('css/[name].css'),
+ new webpack.optimize.CommonsChunkPlugin({
+ name: 'common',
+ filename: 'js/base.js'
+ })
+ ],
+ devServer: {
+ contentBase: path.join(__dirname, "/dist/"),
+ //compress: true,
+ port: 8086,
+ historyApiFallback: true,
+ // historyApiFallback: {
+ // index: '/dist/index.html'
+ // }
+ }
+}; \ No newline at end of file
diff --git a/front-end/yarn.lock b/front-end/yarn.lock
new file mode 100644
index 0000000..b9a61f1
--- /dev/null
+++ b/front-end/yarn.lock
@@ -0,0 +1,5793 @@
+# THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY.
+# yarn lockfile v1
+
+
+"@babel/runtime@^7.0.0-beta.48":
+ version "7.0.0-beta.49"
+ resolved "http://registry.npm.taobao.org/@babel/runtime/download/@babel/runtime-7.0.0-beta.49.tgz#03b3bf07eb982072c8e851dd2ddd5110282e61bf"
+ dependencies:
+ core-js "^2.5.6"
+ regenerator-runtime "^0.11.1"
+
+abbrev@1:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/abbrev/-/abbrev-1.1.1.tgz#f8f2c887ad10bf67f634f005b6987fed3179aac8"
+
+accepts@~1.3.4, accepts@~1.3.5:
+ version "1.3.5"
+ resolved "http://registry.npm.taobao.org/accepts/download/accepts-1.3.5.tgz#eb777df6011723a3b14e8a72c0805c8e86746bd2"
+ dependencies:
+ mime-types "~2.1.18"
+ negotiator "0.6.1"
+
+acorn-dynamic-import@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/acorn-dynamic-import/-/acorn-dynamic-import-2.0.2.tgz#c752bd210bef679501b6c6cb7fc84f8f47158cc4"
+ dependencies:
+ acorn "^4.0.3"
+
+acorn@^4.0.3:
+ version "4.0.13"
+ resolved "https://registry.yarnpkg.com/acorn/-/acorn-4.0.13.tgz#105495ae5361d697bd195c825192e1ad7f253787"
+
+acorn@^5.0.0:
+ version "5.5.3"
+ resolved "https://registry.yarnpkg.com/acorn/-/acorn-5.5.3.tgz#f473dd47e0277a08e28e9bec5aeeb04751f0b8c9"
+
+ajv-keywords@^2.0.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/ajv-keywords/-/ajv-keywords-2.1.1.tgz#617997fc5f60576894c435f940d819e135b80762"
+
+ajv@^4.9.1:
+ version "4.11.8"
+ resolved "https://registry.yarnpkg.com/ajv/-/ajv-4.11.8.tgz#82ffb02b29e662ae53bdc20af15947706739c536"
+ dependencies:
+ co "^4.6.0"
+ json-stable-stringify "^1.0.1"
+
+ajv@^5.0.0, ajv@^5.1.0, ajv@^5.1.5:
+ version "5.5.2"
+ resolved "https://registry.yarnpkg.com/ajv/-/ajv-5.5.2.tgz#73b5eeca3fab653e3d3f9422b341ad42205dc965"
+ dependencies:
+ co "^4.6.0"
+ fast-deep-equal "^1.0.0"
+ fast-json-stable-stringify "^2.0.0"
+ json-schema-traverse "^0.3.0"
+
+align-text@^0.1.1, align-text@^0.1.3:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/align-text/-/align-text-0.1.4.tgz#0cd90a561093f35d0a99256c22b7069433fad117"
+ dependencies:
+ kind-of "^3.0.2"
+ longest "^1.0.1"
+ repeat-string "^1.5.2"
+
+alphanum-sort@^1.0.1, alphanum-sort@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/alphanum-sort/-/alphanum-sort-1.0.2.tgz#97a1119649b211ad33691d9f9f486a8ec9fbe0a3"
+
+amdefine@>=0.0.4:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/amdefine/download/amdefine-1.0.1.tgz#4a5282ac164729e93619bcfd3ad151f817ce91f5"
+
+ version "0.0.7"
+ resolved "http://registry.npm.taobao.org/ansi-html/download/ansi-html-0.0.7.tgz#813584021962a9e9e6fd039f940d12f56ca7859e"
+
+ansi-regex@^2.0.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-2.1.1.tgz#c3b33ab5ee360d86e0e628f0468ae7ef27d654df"
+
+ansi-regex@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/ansi-regex/-/ansi-regex-3.0.0.tgz#ed0317c322064f79466c02966bddb605ab37d998"
+
+ansi-styles@^2.2.1:
+ version "2.2.1"
+ resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-2.2.1.tgz#b432dd3358b634cf75e1e4664368240533c1ddbe"
+
+ansi-styles@^3.2.1:
+ version "3.2.1"
+ resolved "https://registry.yarnpkg.com/ansi-styles/-/ansi-styles-3.2.1.tgz#41fbb20243e50b12be0f04b8dedbf07520ce841d"
+ dependencies:
+ color-convert "^1.9.0"
+
+anymatch@^1.3.0:
+ version "1.3.2"
+ resolved "http://registry.npm.taobao.org/anymatch/download/anymatch-1.3.2.tgz#553dcb8f91e3c889845dfdba34c77721b90b9d7a"
+ dependencies:
+ micromatch "^2.1.5"
+ normalize-path "^2.0.0"
+
+anymatch@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/anymatch/-/anymatch-2.0.0.tgz#bcb24b4f37934d9aa7ac17b4adaf89e7c76ef2eb"
+ dependencies:
+ micromatch "^3.1.4"
+ normalize-path "^2.1.1"
+
+aproba@^1.0.3:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/aproba/-/aproba-1.2.0.tgz#6802e6264efd18c790a1b0d517f0f2627bf2c94a"
+
+are-we-there-yet@~1.1.2:
+ version "1.1.4"
+ resolved "https://registry.yarnpkg.com/are-we-there-yet/-/are-we-there-yet-1.1.4.tgz#bb5dca382bb94f05e15194373d16fd3ba1ca110d"
+ dependencies:
+ delegates "^1.0.0"
+ readable-stream "^2.0.6"
+
+argparse@^1.0.7:
+ version "1.0.10"
+ resolved "https://registry.yarnpkg.com/argparse/-/argparse-1.0.10.tgz#bcd6791ea5ae09725e17e5ad988134cd40b3d911"
+ dependencies:
+ sprintf-js "~1.0.2"
+
+arr-diff@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/arr-diff/download/arr-diff-2.0.0.tgz#8f3b827f955a8bd669697e4a4256ac3ceae356cf"
+ dependencies:
+ arr-flatten "^1.0.1"
+
+arr-diff@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/arr-diff/-/arr-diff-4.0.0.tgz#d6461074febfec71e7e15235761a329a5dc7c520"
+
+arr-flatten@^1.0.1, arr-flatten@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/arr-flatten/-/arr-flatten-1.1.0.tgz#36048bbff4e7b47e136644316c99669ea5ae91f1"
+
+arr-union@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/arr-union/-/arr-union-3.1.0.tgz#e39b09aea9def866a8f206e288af63919bae39c4"
+
+array-find-index@^1.0.1:
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/array-find-index/download/array-find-index-1.0.2.tgz#df010aa1287e164bbda6f9723b0a96a1ec4187a1"
+
+ version "1.1.1"
+ resolved "http://registry.npm.taobao.org/array-flatten/download/array-flatten-1.1.1.tgz#9a5f699051b1e7073328f2a008968b64ea2955d2"
+
+array-flatten@^2.1.0:
+ version "2.1.1"
+ resolved "http://registry.npm.taobao.org/array-flatten/download/array-flatten-2.1.1.tgz#426bb9da84090c1838d812c8150af20a8331e296"
+
+array-includes@^3.0.3:
+ version "3.0.3"
+ resolved "http://registry.npm.taobao.org/array-includes/download/array-includes-3.0.3.tgz#184b48f62d92d7452bb31b323165c7f8bd02266d"
+ dependencies:
+ define-properties "^1.1.2"
+ es-abstract "^1.7.0"
+
+array-union@^1.0.1:
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/array-union/download/array-union-1.0.2.tgz#9a34410e4f4e3da23dea375be5be70f24778ec39"
+ dependencies:
+ array-uniq "^1.0.1"
+
+array-uniq@^1.0.1:
+ version "1.0.3"
+ resolved "http://registry.npm.taobao.org/array-uniq/download/array-uniq-1.0.3.tgz#af6ac877a25cc7f74e058894753858dfdb24fdb6"
+
+array-unique@^0.2.1:
+ version "0.2.1"
+ resolved "http://registry.npm.taobao.org/array-unique/download/array-unique-0.2.1.tgz#a1d97ccafcbc2625cc70fadceb36a50c58b01a53"
+
+array-unique@^0.3.2:
+ version "0.3.2"
+ resolved "https://registry.yarnpkg.com/array-unique/-/array-unique-0.3.2.tgz#a894b75d4bc4f6cd679ef3244a9fd8f46ae2d428"
+
+asap@~2.0.3:
+ version "2.0.6"
+ resolved "https://registry.yarnpkg.com/asap/-/asap-2.0.6.tgz#e50347611d7e690943208bbdafebcbc2fb866d46"
+
+asn1.js@^4.0.0:
+ version "4.10.1"
+ resolved "https://registry.yarnpkg.com/asn1.js/-/asn1.js-4.10.1.tgz#b9c2bf5805f1e64aadeed6df3a2bfafb5a73f5a0"
+ dependencies:
+ bn.js "^4.0.0"
+ inherits "^2.0.1"
+ minimalistic-assert "^1.0.0"
+
+asn1@~0.2.3:
+ version "0.2.3"
+ resolved "https://registry.yarnpkg.com/asn1/-/asn1-0.2.3.tgz#dac8787713c9966849fc8180777ebe9c1ddf3b86"
+
[email protected], assert-plus@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-1.0.0.tgz#f12e0f3c5d77b0b1cdd9146942e4e96c1e4dd525"
+
+assert-plus@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/assert-plus/-/assert-plus-0.2.0.tgz#d74e1b87e7affc0db8aadb7021f3fe48101ab234"
+
+assert@^1.1.1:
+ version "1.4.1"
+ resolved "https://registry.yarnpkg.com/assert/-/assert-1.4.1.tgz#99912d591836b5a6f5b345c0f07eefc08fc65d91"
+ dependencies:
+ util "0.10.3"
+
+assign-symbols@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/assign-symbols/-/assign-symbols-1.0.0.tgz#59667f41fadd4f20ccbc2bb96b8d4f7f78ec0367"
+
+async-each@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/async-each/-/async-each-1.0.1.tgz#19d386a1d9edc6e7c1c85d388aedbcc56d33602d"
+
+async-foreach@^0.1.3:
+ version "0.1.3"
+ resolved "http://registry.npm.taobao.org/async-foreach/download/async-foreach-0.1.3.tgz#36121f845c0578172de419a97dbeb1d16ec34542"
+
+async@^1.5.2:
+ version "1.5.2"
+ resolved "http://registry.npm.taobao.org/async/download/async-1.5.2.tgz#ec6a61ae56480c0c3cb241c95618e20892f9672a"
+
+async@^2.1.2, async@^2.1.5, async@^2.4.1:
+ version "2.6.0"
+ resolved "https://registry.yarnpkg.com/async/-/async-2.6.0.tgz#61a29abb6fcc026fea77e56d1c6ec53a795951f4"
+ dependencies:
+ lodash "^4.14.0"
+
+asynckit@^0.4.0:
+ version "0.4.0"
+ resolved "https://registry.yarnpkg.com/asynckit/-/asynckit-0.4.0.tgz#c79ed97f7f34cb8f2ba1bc9790bcc366474b4b79"
+
+atob@^2.0.0:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/atob/-/atob-2.0.3.tgz#19c7a760473774468f20b2d2d03372ad7d4cbf5d"
+
+autoprefixer@^6.3.1:
+ version "6.7.7"
+ resolved "https://registry.yarnpkg.com/autoprefixer/-/autoprefixer-6.7.7.tgz#1dbd1c835658e35ce3f9984099db00585c782014"
+ dependencies:
+ browserslist "^1.7.6"
+ caniuse-db "^1.0.30000634"
+ normalize-range "^0.1.2"
+ num2fraction "^1.2.2"
+ postcss "^5.2.16"
+ postcss-value-parser "^3.2.3"
+
+aws-sign2@~0.6.0:
+ version "0.6.0"
+ resolved "https://registry.yarnpkg.com/aws-sign2/-/aws-sign2-0.6.0.tgz#14342dd38dbcc94d0e5b87d763cd63612c0e794f"
+
+aws-sign2@~0.7.0:
+ version "0.7.0"
+ resolved "http://registry.npm.taobao.org/aws-sign2/download/aws-sign2-0.7.0.tgz#b46e890934a9591f2d2f6f86d7e6a9f1b3fe76a8"
+
+aws4@^1.2.1, aws4@^1.6.0:
+ version "1.6.0"
+ resolved "https://registry.yarnpkg.com/aws4/-/aws4-1.6.0.tgz#83ef5ca860b2b32e4a0deedee8c771b9db57471e"
+
+babel-code-frame@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-code-frame/-/babel-code-frame-6.26.0.tgz#63fd43f7dc1e3bb7ce35947db8fe369a3f58c74b"
+ dependencies:
+ chalk "^1.1.3"
+ esutils "^2.0.2"
+ js-tokens "^3.0.2"
+
[email protected], babel-core@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-core/-/babel-core-6.26.0.tgz#af32f78b31a6fcef119c87b0fd8d9753f03a0bb8"
+ dependencies:
+ babel-code-frame "^6.26.0"
+ babel-generator "^6.26.0"
+ babel-helpers "^6.24.1"
+ babel-messages "^6.23.0"
+ babel-register "^6.26.0"
+ babel-runtime "^6.26.0"
+ babel-template "^6.26.0"
+ babel-traverse "^6.26.0"
+ babel-types "^6.26.0"
+ babylon "^6.18.0"
+ convert-source-map "^1.5.0"
+ debug "^2.6.8"
+ json5 "^0.5.1"
+ lodash "^4.17.4"
+ minimatch "^3.0.4"
+ path-is-absolute "^1.0.1"
+ private "^0.1.7"
+ slash "^1.0.0"
+ source-map "^0.5.6"
+
+babel-generator@^6.26.0:
+ version "6.26.1"
+ resolved "https://registry.yarnpkg.com/babel-generator/-/babel-generator-6.26.1.tgz#1844408d3b8f0d35a404ea7ac180f087a601bd90"
+ dependencies:
+ babel-messages "^6.23.0"
+ babel-runtime "^6.26.0"
+ babel-types "^6.26.0"
+ detect-indent "^4.0.0"
+ jsesc "^1.3.0"
+ lodash "^4.17.4"
+ source-map "^0.5.7"
+ trim-right "^1.0.1"
+
+babel-helper-builder-binary-assignment-operator-visitor@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-builder-binary-assignment-operator-visitor/-/babel-helper-builder-binary-assignment-operator-visitor-6.24.1.tgz#cce4517ada356f4220bcae8a02c2b346f9a56664"
+ dependencies:
+ babel-helper-explode-assignable-expression "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-helper-builder-react-jsx@^6.24.1:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-helper-builder-react-jsx/-/babel-helper-builder-react-jsx-6.26.0.tgz#39ff8313b75c8b65dceff1f31d383e0ff2a408a0"
+ dependencies:
+ babel-runtime "^6.26.0"
+ babel-types "^6.26.0"
+ esutils "^2.0.2"
+
+babel-helper-call-delegate@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-call-delegate/-/babel-helper-call-delegate-6.24.1.tgz#ece6aacddc76e41c3461f88bfc575bd0daa2df8d"
+ dependencies:
+ babel-helper-hoist-variables "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-helper-define-map@^6.24.1:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-helper-define-map/-/babel-helper-define-map-6.26.0.tgz#a5f56dab41a25f97ecb498c7ebaca9819f95be5f"
+ dependencies:
+ babel-helper-function-name "^6.24.1"
+ babel-runtime "^6.26.0"
+ babel-types "^6.26.0"
+ lodash "^4.17.4"
+
+babel-helper-explode-assignable-expression@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-explode-assignable-expression/-/babel-helper-explode-assignable-expression-6.24.1.tgz#f25b82cf7dc10433c55f70592d5746400ac22caa"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-helper-function-name@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-function-name/-/babel-helper-function-name-6.24.1.tgz#d3475b8c03ed98242a25b48351ab18399d3580a9"
+ dependencies:
+ babel-helper-get-function-arity "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-helper-get-function-arity@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-get-function-arity/-/babel-helper-get-function-arity-6.24.1.tgz#8f7782aa93407c41d3aa50908f89b031b1b6853d"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-helper-hoist-variables@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-hoist-variables/-/babel-helper-hoist-variables-6.24.1.tgz#1ecb27689c9d25513eadbc9914a73f5408be7a76"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-helper-optimise-call-expression@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-optimise-call-expression/-/babel-helper-optimise-call-expression-6.24.1.tgz#f7a13427ba9f73f8f4fa993c54a97882d1244257"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-helper-regex@^6.24.1:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-helper-regex/-/babel-helper-regex-6.26.0.tgz#325c59f902f82f24b74faceed0363954f6495e72"
+ dependencies:
+ babel-runtime "^6.26.0"
+ babel-types "^6.26.0"
+ lodash "^4.17.4"
+
+babel-helper-remap-async-to-generator@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-remap-async-to-generator/-/babel-helper-remap-async-to-generator-6.24.1.tgz#5ec581827ad723fecdd381f1c928390676e4551b"
+ dependencies:
+ babel-helper-function-name "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-helper-replace-supers@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helper-replace-supers/-/babel-helper-replace-supers-6.24.1.tgz#bf6dbfe43938d17369a213ca8a8bf74b6a90ab1a"
+ dependencies:
+ babel-helper-optimise-call-expression "^6.24.1"
+ babel-messages "^6.23.0"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-helpers@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-helpers/-/babel-helpers-6.24.1.tgz#3471de9caec388e5c850e597e58a26ddf37602b2"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+
+ version "7.1.2"
+ resolved "https://registry.yarnpkg.com/babel-loader/-/babel-loader-7.1.2.tgz#f6cbe122710f1aa2af4d881c6d5b54358ca24126"
+ dependencies:
+ find-cache-dir "^1.0.0"
+ loader-utils "^1.0.2"
+ mkdirp "^0.5.1"
+
+babel-messages@^6.23.0:
+ version "6.23.0"
+ resolved "https://registry.yarnpkg.com/babel-messages/-/babel-messages-6.23.0.tgz#f3cdf4703858035b2a2951c6ec5edf6c62f2630e"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-check-es2015-constants@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-check-es2015-constants/-/babel-plugin-check-es2015-constants-6.22.0.tgz#35157b101426fd2ffd3da3f75c7d1e91835bbf8a"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-syntax-async-functions@^6.8.0:
+ version "6.13.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-syntax-async-functions/-/babel-plugin-syntax-async-functions-6.13.0.tgz#cad9cad1191b5ad634bf30ae0872391e0647be95"
+
+babel-plugin-syntax-exponentiation-operator@^6.8.0:
+ version "6.13.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-syntax-exponentiation-operator/-/babel-plugin-syntax-exponentiation-operator-6.13.0.tgz#9ee7e8337290da95288201a6a57f4170317830de"
+
+babel-plugin-syntax-flow@^6.18.0:
+ version "6.18.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-syntax-flow/-/babel-plugin-syntax-flow-6.18.0.tgz#4c3ab20a2af26aa20cd25995c398c4eb70310c8d"
+
+babel-plugin-syntax-jsx@^6.3.13, babel-plugin-syntax-jsx@^6.8.0:
+ version "6.18.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-syntax-jsx/-/babel-plugin-syntax-jsx-6.18.0.tgz#0af32a9a6e13ca7a3fd5069e62d7b0f58d0d8946"
+
+babel-plugin-syntax-trailing-function-commas@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-syntax-trailing-function-commas/-/babel-plugin-syntax-trailing-function-commas-6.22.0.tgz#ba0360937f8d06e40180a43fe0d5616fff532cf3"
+
+babel-plugin-transform-async-to-generator@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-async-to-generator/-/babel-plugin-transform-async-to-generator-6.24.1.tgz#6536e378aff6cb1d5517ac0e40eb3e9fc8d08761"
+ dependencies:
+ babel-helper-remap-async-to-generator "^6.24.1"
+ babel-plugin-syntax-async-functions "^6.8.0"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-arrow-functions@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-arrow-functions/-/babel-plugin-transform-es2015-arrow-functions-6.22.0.tgz#452692cb711d5f79dc7f85e440ce41b9f244d221"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-block-scoped-functions@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-block-scoped-functions/-/babel-plugin-transform-es2015-block-scoped-functions-6.22.0.tgz#bbc51b49f964d70cb8d8e0b94e820246ce3a6141"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-block-scoping@^6.23.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-block-scoping/-/babel-plugin-transform-es2015-block-scoping-6.26.0.tgz#d70f5299c1308d05c12f463813b0a09e73b1895f"
+ dependencies:
+ babel-runtime "^6.26.0"
+ babel-template "^6.26.0"
+ babel-traverse "^6.26.0"
+ babel-types "^6.26.0"
+ lodash "^4.17.4"
+
+babel-plugin-transform-es2015-classes@^6.23.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-classes/-/babel-plugin-transform-es2015-classes-6.24.1.tgz#5a4c58a50c9c9461e564b4b2a3bfabc97a2584db"
+ dependencies:
+ babel-helper-define-map "^6.24.1"
+ babel-helper-function-name "^6.24.1"
+ babel-helper-optimise-call-expression "^6.24.1"
+ babel-helper-replace-supers "^6.24.1"
+ babel-messages "^6.23.0"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-plugin-transform-es2015-computed-properties@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-computed-properties/-/babel-plugin-transform-es2015-computed-properties-6.24.1.tgz#6fe2a8d16895d5634f4cd999b6d3480a308159b3"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+
+babel-plugin-transform-es2015-destructuring@^6.23.0:
+ version "6.23.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-destructuring/-/babel-plugin-transform-es2015-destructuring-6.23.0.tgz#997bb1f1ab967f682d2b0876fe358d60e765c56d"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-duplicate-keys@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-duplicate-keys/-/babel-plugin-transform-es2015-duplicate-keys-6.24.1.tgz#73eb3d310ca969e3ef9ec91c53741a6f1576423e"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-plugin-transform-es2015-for-of@^6.23.0:
+ version "6.23.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-for-of/-/babel-plugin-transform-es2015-for-of-6.23.0.tgz#f47c95b2b613df1d3ecc2fdb7573623c75248691"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-function-name@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-function-name/-/babel-plugin-transform-es2015-function-name-6.24.1.tgz#834c89853bc36b1af0f3a4c5dbaa94fd8eacaa8b"
+ dependencies:
+ babel-helper-function-name "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-plugin-transform-es2015-literals@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-literals/-/babel-plugin-transform-es2015-literals-6.22.0.tgz#4f54a02d6cd66cf915280019a31d31925377ca2e"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-modules-amd@^6.22.0, babel-plugin-transform-es2015-modules-amd@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-amd/-/babel-plugin-transform-es2015-modules-amd-6.24.1.tgz#3b3e54017239842d6d19c3011c4bd2f00a00d154"
+ dependencies:
+ babel-plugin-transform-es2015-modules-commonjs "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+
+babel-plugin-transform-es2015-modules-commonjs@^6.23.0, babel-plugin-transform-es2015-modules-commonjs@^6.24.1:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-commonjs/-/babel-plugin-transform-es2015-modules-commonjs-6.26.0.tgz#0d8394029b7dc6abe1a97ef181e00758dd2e5d8a"
+ dependencies:
+ babel-plugin-transform-strict-mode "^6.24.1"
+ babel-runtime "^6.26.0"
+ babel-template "^6.26.0"
+ babel-types "^6.26.0"
+
+babel-plugin-transform-es2015-modules-systemjs@^6.23.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-systemjs/-/babel-plugin-transform-es2015-modules-systemjs-6.24.1.tgz#ff89a142b9119a906195f5f106ecf305d9407d23"
+ dependencies:
+ babel-helper-hoist-variables "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+
+babel-plugin-transform-es2015-modules-umd@^6.23.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-modules-umd/-/babel-plugin-transform-es2015-modules-umd-6.24.1.tgz#ac997e6285cd18ed6176adb607d602344ad38468"
+ dependencies:
+ babel-plugin-transform-es2015-modules-amd "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+
+babel-plugin-transform-es2015-object-super@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-object-super/-/babel-plugin-transform-es2015-object-super-6.24.1.tgz#24cef69ae21cb83a7f8603dad021f572eb278f8d"
+ dependencies:
+ babel-helper-replace-supers "^6.24.1"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-parameters@^6.23.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-parameters/-/babel-plugin-transform-es2015-parameters-6.24.1.tgz#57ac351ab49caf14a97cd13b09f66fdf0a625f2b"
+ dependencies:
+ babel-helper-call-delegate "^6.24.1"
+ babel-helper-get-function-arity "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-template "^6.24.1"
+ babel-traverse "^6.24.1"
+ babel-types "^6.24.1"
+
+babel-plugin-transform-es2015-shorthand-properties@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-shorthand-properties/-/babel-plugin-transform-es2015-shorthand-properties-6.24.1.tgz#24f875d6721c87661bbd99a4622e51f14de38aa0"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-plugin-transform-es2015-spread@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-spread/-/babel-plugin-transform-es2015-spread-6.22.0.tgz#d6d68a99f89aedc4536c81a542e8dd9f1746f8d1"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-sticky-regex@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-sticky-regex/-/babel-plugin-transform-es2015-sticky-regex-6.24.1.tgz#00c1cdb1aca71112cdf0cf6126c2ed6b457ccdbc"
+ dependencies:
+ babel-helper-regex "^6.24.1"
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+babel-plugin-transform-es2015-template-literals@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-template-literals/-/babel-plugin-transform-es2015-template-literals-6.22.0.tgz#a84b3450f7e9f8f1f6839d6d687da84bb1236d8d"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-typeof-symbol@^6.23.0:
+ version "6.23.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-typeof-symbol/-/babel-plugin-transform-es2015-typeof-symbol-6.23.0.tgz#dec09f1cddff94b52ac73d505c84df59dcceb372"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-es2015-unicode-regex@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-es2015-unicode-regex/-/babel-plugin-transform-es2015-unicode-regex-6.24.1.tgz#d38b12f42ea7323f729387f18a7c5ae1faeb35e9"
+ dependencies:
+ babel-helper-regex "^6.24.1"
+ babel-runtime "^6.22.0"
+ regexpu-core "^2.0.0"
+
+babel-plugin-transform-exponentiation-operator@^6.22.0:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-exponentiation-operator/-/babel-plugin-transform-exponentiation-operator-6.24.1.tgz#2ab0c9c7f3098fa48907772bb813fe41e8de3a0e"
+ dependencies:
+ babel-helper-builder-binary-assignment-operator-visitor "^6.24.1"
+ babel-plugin-syntax-exponentiation-operator "^6.8.0"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-flow-strip-types@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-flow-strip-types/-/babel-plugin-transform-flow-strip-types-6.22.0.tgz#84cb672935d43714fdc32bce84568d87441cf7cf"
+ dependencies:
+ babel-plugin-syntax-flow "^6.18.0"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-react-display-name@^6.23.0:
+ version "6.25.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-react-display-name/-/babel-plugin-transform-react-display-name-6.25.0.tgz#67e2bf1f1e9c93ab08db96792e05392bf2cc28d1"
+ dependencies:
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-react-jsx-self@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-react-jsx-self/-/babel-plugin-transform-react-jsx-self-6.22.0.tgz#df6d80a9da2612a121e6ddd7558bcbecf06e636e"
+ dependencies:
+ babel-plugin-syntax-jsx "^6.8.0"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-react-jsx-source@^6.22.0:
+ version "6.22.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-react-jsx-source/-/babel-plugin-transform-react-jsx-source-6.22.0.tgz#66ac12153f5cd2d17b3c19268f4bf0197f44ecd6"
+ dependencies:
+ babel-plugin-syntax-jsx "^6.8.0"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-react-jsx@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-react-jsx/-/babel-plugin-transform-react-jsx-6.24.1.tgz#840a028e7df460dfc3a2d29f0c0d91f6376e66a3"
+ dependencies:
+ babel-helper-builder-react-jsx "^6.24.1"
+ babel-plugin-syntax-jsx "^6.8.0"
+ babel-runtime "^6.22.0"
+
+babel-plugin-transform-regenerator@^6.22.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-regenerator/-/babel-plugin-transform-regenerator-6.26.0.tgz#e0703696fbde27f0a3efcacf8b4dca2f7b3a8f2f"
+ dependencies:
+ regenerator-transform "^0.10.0"
+
+babel-plugin-transform-strict-mode@^6.24.1:
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-plugin-transform-strict-mode/-/babel-plugin-transform-strict-mode-6.24.1.tgz#d5faf7aa578a65bbe591cf5edae04a0c67020758"
+ dependencies:
+ babel-runtime "^6.22.0"
+ babel-types "^6.24.1"
+
+ version "1.6.1"
+ resolved "https://registry.yarnpkg.com/babel-preset-env/-/babel-preset-env-1.6.1.tgz#a18b564cc9b9afdf4aae57ae3c1b0d99188e6f48"
+ dependencies:
+ babel-plugin-check-es2015-constants "^6.22.0"
+ babel-plugin-syntax-trailing-function-commas "^6.22.0"
+ babel-plugin-transform-async-to-generator "^6.22.0"
+ babel-plugin-transform-es2015-arrow-functions "^6.22.0"
+ babel-plugin-transform-es2015-block-scoped-functions "^6.22.0"
+ babel-plugin-transform-es2015-block-scoping "^6.23.0"
+ babel-plugin-transform-es2015-classes "^6.23.0"
+ babel-plugin-transform-es2015-computed-properties "^6.22.0"
+ babel-plugin-transform-es2015-destructuring "^6.23.0"
+ babel-plugin-transform-es2015-duplicate-keys "^6.22.0"
+ babel-plugin-transform-es2015-for-of "^6.23.0"
+ babel-plugin-transform-es2015-function-name "^6.22.0"
+ babel-plugin-transform-es2015-literals "^6.22.0"
+ babel-plugin-transform-es2015-modules-amd "^6.22.0"
+ babel-plugin-transform-es2015-modules-commonjs "^6.23.0"
+ babel-plugin-transform-es2015-modules-systemjs "^6.23.0"
+ babel-plugin-transform-es2015-modules-umd "^6.23.0"
+ babel-plugin-transform-es2015-object-super "^6.22.0"
+ babel-plugin-transform-es2015-parameters "^6.23.0"
+ babel-plugin-transform-es2015-shorthand-properties "^6.22.0"
+ babel-plugin-transform-es2015-spread "^6.22.0"
+ babel-plugin-transform-es2015-sticky-regex "^6.22.0"
+ babel-plugin-transform-es2015-template-literals "^6.22.0"
+ babel-plugin-transform-es2015-typeof-symbol "^6.23.0"
+ babel-plugin-transform-es2015-unicode-regex "^6.22.0"
+ babel-plugin-transform-exponentiation-operator "^6.22.0"
+ babel-plugin-transform-regenerator "^6.22.0"
+ browserslist "^2.1.2"
+ invariant "^2.2.2"
+ semver "^5.3.0"
+
+babel-preset-flow@^6.23.0:
+ version "6.23.0"
+ resolved "https://registry.yarnpkg.com/babel-preset-flow/-/babel-preset-flow-6.23.0.tgz#e71218887085ae9a24b5be4169affb599816c49d"
+ dependencies:
+ babel-plugin-transform-flow-strip-types "^6.22.0"
+
+ version "6.24.1"
+ resolved "https://registry.yarnpkg.com/babel-preset-react/-/babel-preset-react-6.24.1.tgz#ba69dfaea45fc3ec639b6a4ecea6e17702c91380"
+ dependencies:
+ babel-plugin-syntax-jsx "^6.3.13"
+ babel-plugin-transform-react-display-name "^6.23.0"
+ babel-plugin-transform-react-jsx "^6.24.1"
+ babel-plugin-transform-react-jsx-self "^6.22.0"
+ babel-plugin-transform-react-jsx-source "^6.22.0"
+ babel-preset-flow "^6.23.0"
+
+babel-register@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-register/-/babel-register-6.26.0.tgz#6ed021173e2fcb486d7acb45c6009a856f647071"
+ dependencies:
+ babel-core "^6.26.0"
+ babel-runtime "^6.26.0"
+ core-js "^2.5.0"
+ home-or-tmp "^2.0.0"
+ lodash "^4.17.4"
+ mkdirp "^0.5.1"
+ source-map-support "^0.4.15"
+
[email protected], babel-runtime@^6.18.0, babel-runtime@^6.22.0, babel-runtime@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-runtime/-/babel-runtime-6.26.0.tgz#965c7058668e82b55d7bfe04ff2337bc8b5647fe"
+ dependencies:
+ core-js "^2.4.0"
+ regenerator-runtime "^0.11.0"
+
+babel-template@^6.24.1, babel-template@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-template/-/babel-template-6.26.0.tgz#de03e2d16396b069f46dd9fff8521fb1a0e35e02"
+ dependencies:
+ babel-runtime "^6.26.0"
+ babel-traverse "^6.26.0"
+ babel-types "^6.26.0"
+ babylon "^6.18.0"
+ lodash "^4.17.4"
+
+babel-traverse@^6.24.1, babel-traverse@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-traverse/-/babel-traverse-6.26.0.tgz#46a9cbd7edcc62c8e5c064e2d2d8d0f4035766ee"
+ dependencies:
+ babel-code-frame "^6.26.0"
+ babel-messages "^6.23.0"
+ babel-runtime "^6.26.0"
+ babel-types "^6.26.0"
+ babylon "^6.18.0"
+ debug "^2.6.8"
+ globals "^9.18.0"
+ invariant "^2.2.2"
+ lodash "^4.17.4"
+
+babel-types@^6.19.0, babel-types@^6.24.1, babel-types@^6.26.0:
+ version "6.26.0"
+ resolved "https://registry.yarnpkg.com/babel-types/-/babel-types-6.26.0.tgz#a3b073f94ab49eb6fa55cd65227a334380632497"
+ dependencies:
+ babel-runtime "^6.26.0"
+ esutils "^2.0.2"
+ lodash "^4.17.4"
+ to-fast-properties "^1.0.3"
+
+babylon@^6.18.0:
+ version "6.18.0"
+ resolved "https://registry.yarnpkg.com/babylon/-/babylon-6.18.0.tgz#af2f3b88fa6f5c1e4c634d1a0f8eac4f55b395e3"
+
+balanced-match@^0.4.2:
+ version "0.4.2"
+ resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-0.4.2.tgz#cb3f3e3c732dc0f01ee70b403f302e61d7709838"
+
+balanced-match@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/balanced-match/-/balanced-match-1.0.0.tgz#89b4d199ab2bee49de164ea02b89ce462d71b767"
+
+base64-js@^1.0.2:
+ version "1.2.3"
+ resolved "https://registry.yarnpkg.com/base64-js/-/base64-js-1.2.3.tgz#fb13668233d9614cf5fb4bce95a9ba4096cdf801"
+
+base@^0.11.1:
+ version "0.11.2"
+ resolved "https://registry.yarnpkg.com/base/-/base-0.11.2.tgz#7bde5ced145b6d551a90db87f83c558b4eb48a8f"
+ dependencies:
+ cache-base "^1.0.1"
+ class-utils "^0.3.5"
+ component-emitter "^1.2.1"
+ define-property "^1.0.0"
+ isobject "^3.0.1"
+ mixin-deep "^1.2.0"
+ pascalcase "^0.1.1"
+
+ version "0.6.1"
+ resolved "http://registry.npm.taobao.org/batch/download/batch-0.6.1.tgz#dc34314f4e679318093fc760272525f94bf25c16"
+
+bcrypt-pbkdf@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.1.tgz#63bc5dcb61331b92bc05fd528953c33462a06f8d"
+ dependencies:
+ tweetnacl "^0.14.3"
+
+big.js@^3.1.3:
+ version "3.2.0"
+ resolved "https://registry.yarnpkg.com/big.js/-/big.js-3.2.0.tgz#a5fc298b81b9e0dca2e458824784b65c52ba588e"
+
+binary-extensions@^1.0.0:
+ version "1.11.0"
+ resolved "https://registry.yarnpkg.com/binary-extensions/-/binary-extensions-1.11.0.tgz#46aa1751fb6a2f93ee5e689bb1087d4b14c6c205"
+
+block-stream@*:
+ version "0.0.9"
+ resolved "https://registry.yarnpkg.com/block-stream/-/block-stream-0.0.9.tgz#13ebfe778a03205cfe03751481ebb4b3300c126a"
+ dependencies:
+ inherits "~2.0.0"
+
+bluebird@^3.4.7:
+ version "3.5.1"
+ resolved "https://registry.yarnpkg.com/bluebird/-/bluebird-3.5.1.tgz#d9551f9de98f1fcda1e683d17ee91a0602ee2eb9"
+
+bn.js@^4.0.0, bn.js@^4.1.0, bn.js@^4.1.1, bn.js@^4.4.0:
+ version "4.11.8"
+ resolved "https://registry.yarnpkg.com/bn.js/-/bn.js-4.11.8.tgz#2cde09eb5ee341f484746bb0309b3253b1b1442f"
+
+ version "1.18.2"
+ resolved "http://registry.npm.taobao.org/body-parser/download/body-parser-1.18.2.tgz#87678a19d84b47d859b83199bd59bce222b10454"
+ dependencies:
+ bytes "3.0.0"
+ content-type "~1.0.4"
+ debug "2.6.9"
+ depd "~1.1.1"
+ http-errors "~1.6.2"
+ iconv-lite "0.4.19"
+ on-finished "~2.3.0"
+ qs "6.5.1"
+ raw-body "2.3.2"
+ type-is "~1.6.15"
+
+bonjour@^3.5.0:
+ version "3.5.0"
+ resolved "http://registry.npm.taobao.org/bonjour/download/bonjour-3.5.0.tgz#8e890a183d8ee9a2393b3844c691a42bcf7bc9f5"
+ dependencies:
+ array-flatten "^2.1.0"
+ deep-equal "^1.0.1"
+ dns-equal "^1.0.0"
+ dns-txt "^2.0.2"
+ multicast-dns "^6.0.1"
+ multicast-dns-service-types "^1.1.0"
+
+boolbase@~1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/boolbase/-/boolbase-1.0.0.tgz#68dff5fbe60c51eb37725ea9e3ed310dcc1e776e"
+
+ version "2.10.1"
+ resolved "https://registry.yarnpkg.com/boom/-/boom-2.10.1.tgz#39c8918ceff5799f83f9492a848f625add0c766f"
+ dependencies:
+ hoek "2.x.x"
+
+ version "4.3.1"
+ resolved "http://registry.npm.taobao.org/boom/download/boom-4.3.1.tgz#4f8a3005cb4a7e3889f749030fd25b96e01d2e31"
+ dependencies:
+ hoek "4.x.x"
+
+ version "5.2.0"
+ resolved "http://registry.npm.taobao.org/boom/download/boom-5.2.0.tgz#5dd9da6ee3a5f302077436290cb717d3f4a54e02"
+ dependencies:
+ hoek "4.x.x"
+
+brace-expansion@^1.1.7:
+ version "1.1.11"
+ resolved "https://registry.yarnpkg.com/brace-expansion/-/brace-expansion-1.1.11.tgz#3c7fcbf529d87226f3d2f52b966ff5271eb441dd"
+ dependencies:
+ balanced-match "^1.0.0"
+ concat-map "0.0.1"
+
+braces@^1.8.2:
+ version "1.8.5"
+ resolved "http://registry.npm.taobao.org/braces/download/braces-1.8.5.tgz#ba77962e12dff969d6b76711e914b737857bf6a7"
+ dependencies:
+ expand-range "^1.8.1"
+ preserve "^0.2.0"
+ repeat-element "^1.1.2"
+
+braces@^2.3.0, braces@^2.3.1:
+ version "2.3.1"
+ resolved "https://registry.yarnpkg.com/braces/-/braces-2.3.1.tgz#7086c913b4e5a08dbe37ac0ee6a2500c4ba691bb"
+ dependencies:
+ arr-flatten "^1.1.0"
+ array-unique "^0.3.2"
+ define-property "^1.0.0"
+ extend-shallow "^2.0.1"
+ fill-range "^4.0.0"
+ isobject "^3.0.1"
+ kind-of "^6.0.2"
+ repeat-element "^1.1.2"
+ snapdragon "^0.8.1"
+ snapdragon-node "^2.0.1"
+ split-string "^3.0.2"
+ to-regex "^3.0.1"
+
+brorand@^1.0.1:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/brorand/-/brorand-1.1.0.tgz#12c25efe40a45e3c323eb8675a0a0ce57b22371f"
+
+browserify-aes@^1.0.0, browserify-aes@^1.0.4:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/browserify-aes/-/browserify-aes-1.1.1.tgz#38b7ab55edb806ff2dcda1a7f1620773a477c49f"
+ dependencies:
+ buffer-xor "^1.0.3"
+ cipher-base "^1.0.0"
+ create-hash "^1.1.0"
+ evp_bytestokey "^1.0.3"
+ inherits "^2.0.1"
+ safe-buffer "^5.0.1"
+
+browserify-cipher@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/browserify-cipher/-/browserify-cipher-1.0.0.tgz#9988244874bf5ed4e28da95666dcd66ac8fc363a"
+ dependencies:
+ browserify-aes "^1.0.4"
+ browserify-des "^1.0.0"
+ evp_bytestokey "^1.0.0"
+
+browserify-des@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/browserify-des/-/browserify-des-1.0.0.tgz#daa277717470922ed2fe18594118a175439721dd"
+ dependencies:
+ cipher-base "^1.0.1"
+ des.js "^1.0.0"
+ inherits "^2.0.1"
+
+browserify-rsa@^4.0.0:
+ version "4.0.1"
+ resolved "https://registry.yarnpkg.com/browserify-rsa/-/browserify-rsa-4.0.1.tgz#21e0abfaf6f2029cf2fafb133567a701d4135524"
+ dependencies:
+ bn.js "^4.1.0"
+ randombytes "^2.0.1"
+
+browserify-sign@^4.0.0:
+ version "4.0.4"
+ resolved "https://registry.yarnpkg.com/browserify-sign/-/browserify-sign-4.0.4.tgz#aa4eb68e5d7b658baa6bf6a57e630cbd7a93d298"
+ dependencies:
+ bn.js "^4.1.1"
+ browserify-rsa "^4.0.0"
+ create-hash "^1.1.0"
+ create-hmac "^1.1.2"
+ elliptic "^6.0.0"
+ inherits "^2.0.1"
+ parse-asn1 "^5.0.0"
+
+browserify-zlib@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/browserify-zlib/-/browserify-zlib-0.2.0.tgz#2869459d9aa3be245fe8fe2ca1f46e2e7f54d73f"
+ dependencies:
+ pako "~1.0.5"
+
+browserslist@^1.3.6, browserslist@^1.5.2, browserslist@^1.7.6:
+ version "1.7.7"
+ resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-1.7.7.tgz#0bd76704258be829b2398bb50e4b62d1a166b0b9"
+ dependencies:
+ caniuse-db "^1.0.30000639"
+ electron-to-chromium "^1.2.7"
+
+browserslist@^2.1.2:
+ version "2.11.3"
+ resolved "https://registry.yarnpkg.com/browserslist/-/browserslist-2.11.3.tgz#fe36167aed1bbcde4827ebfe71347a2cc70b99b2"
+ dependencies:
+ caniuse-lite "^1.0.30000792"
+ electron-to-chromium "^1.3.30"
+
+buffer-indexof@^1.0.0:
+ version "1.1.1"
+ resolved "http://registry.npm.taobao.org/buffer-indexof/download/buffer-indexof-1.1.1.tgz#52fabcc6a606d1a00302802648ef68f639da268c"
+
+buffer-xor@^1.0.3:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/buffer-xor/-/buffer-xor-1.0.3.tgz#26e61ed1422fb70dd42e6e36729ed51d855fe8d9"
+
+buffer@^4.3.0:
+ version "4.9.1"
+ resolved "https://registry.yarnpkg.com/buffer/-/buffer-4.9.1.tgz#6d1bb601b07a4efced97094132093027c95bc298"
+ dependencies:
+ base64-js "^1.0.2"
+ ieee754 "^1.1.4"
+ isarray "^1.0.0"
+
+builtin-modules@^1.0.0:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/builtin-modules/-/builtin-modules-1.1.1.tgz#270f076c5a72c02f5b65a47df94c5fe3a278892f"
+
+builtin-status-codes@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz#85982878e21b98e1c66425e03d0174788f569ee8"
+
+ version "3.0.0"
+ resolved "http://registry.npm.taobao.org/bytes/download/bytes-3.0.0.tgz#d32815404d689699f85a4ea4fa8755dd13a96048"
+
+cache-base@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/cache-base/-/cache-base-1.0.1.tgz#0a7f46416831c8b662ee36fe4e7c59d76f666ab2"
+ dependencies:
+ collection-visit "^1.0.0"
+ component-emitter "^1.2.1"
+ get-value "^2.0.6"
+ has-value "^1.0.0"
+ isobject "^3.0.1"
+ set-value "^2.0.0"
+ to-object-path "^0.3.0"
+ union-value "^1.0.0"
+ unset-value "^1.0.0"
+
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/camel-case/-/camel-case-3.0.0.tgz#ca3c3688a4e9cf3a4cda777dc4dcbc713249cf73"
+ dependencies:
+ no-case "^2.2.0"
+ upper-case "^1.1.1"
+
+camelcase-keys@^2.0.0:
+ version "2.1.0"
+ resolved "http://registry.npm.taobao.org/camelcase-keys/download/camelcase-keys-2.1.0.tgz#308beeaffdf28119051efa1d932213c91b8f92e7"
+ dependencies:
+ camelcase "^2.0.0"
+ map-obj "^1.0.0"
+
+camelcase@^1.0.2:
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-1.2.1.tgz#9bb5304d2e0b56698b2c758b08a3eaa9daa58a39"
+
+camelcase@^2.0.0:
+ version "2.1.1"
+ resolved "http://registry.npm.taobao.org/camelcase/download/camelcase-2.1.1.tgz#7c1d16d679a1bbe59ca02cacecfb011e201f5a1f"
+
+camelcase@^3.0.0:
+ version "3.0.0"
+ resolved "http://registry.npm.taobao.org/camelcase/download/camelcase-3.0.0.tgz#32fc4b9fcdaf845fcdf7e73bb97cac2261f0ab0a"
+
+camelcase@^4.1.0:
+ version "4.1.0"
+ resolved "https://registry.yarnpkg.com/camelcase/-/camelcase-4.1.0.tgz#d545635be1e33c542649c69173e5de6acfae34dd"
+
+caniuse-api@^1.5.2:
+ version "1.6.1"
+ resolved "https://registry.yarnpkg.com/caniuse-api/-/caniuse-api-1.6.1.tgz#b534e7c734c4f81ec5fbe8aca2ad24354b962c6c"
+ dependencies:
+ browserslist "^1.3.6"
+ caniuse-db "^1.0.30000529"
+ lodash.memoize "^4.1.2"
+ lodash.uniq "^4.5.0"
+
+caniuse-db@^1.0.30000529, caniuse-db@^1.0.30000634, caniuse-db@^1.0.30000639:
+ version "1.0.30000814"
+ resolved "https://registry.yarnpkg.com/caniuse-db/-/caniuse-db-1.0.30000814.tgz#2c9eed7fbc2724066474cb7e1a924f0ea12fe4a2"
+
+caniuse-lite@^1.0.30000792:
+ version "1.0.30000814"
+ resolved "https://registry.yarnpkg.com/caniuse-lite/-/caniuse-lite-1.0.30000814.tgz#73eb6925ac2e54d495218f1ea0007da3940e488b"
+
+caseless@~0.11.0:
+ version "0.11.0"
+ resolved "http://registry.npm.taobao.org/caseless/download/caseless-0.11.0.tgz#715b96ea9841593cc33067923f5ec60ebda4f7d7"
+
+caseless@~0.12.0:
+ version "0.12.0"
+ resolved "https://registry.yarnpkg.com/caseless/-/caseless-0.12.0.tgz#1b681c21ff84033c826543090689420d187151dc"
+
+center-align@^0.1.1:
+ version "0.1.3"
+ resolved "https://registry.yarnpkg.com/center-align/-/center-align-0.1.3.tgz#aa0d32629b6ee972200411cbd4461c907bc2b7ad"
+ dependencies:
+ align-text "^0.1.3"
+ lazy-cache "^1.0.3"
+
+chalk@^1.1.1, chalk@^1.1.3:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/chalk/-/chalk-1.1.3.tgz#a8115c55e4a702fe4d150abd3872822a7e09fc98"
+ dependencies:
+ ansi-styles "^2.2.1"
+ escape-string-regexp "^1.0.2"
+ has-ansi "^2.0.0"
+ strip-ansi "^3.0.0"
+ supports-color "^2.0.0"
+
+chalk@^2.3.1:
+ version "2.3.2"
+ resolved "https://registry.yarnpkg.com/chalk/-/chalk-2.3.2.tgz#250dc96b07491bfd601e648d66ddf5f60c7a5c65"
+ dependencies:
+ ansi-styles "^3.2.1"
+ escape-string-regexp "^1.0.5"
+ supports-color "^5.3.0"
+
+chokidar@^1.6.0:
+ version "1.7.0"
+ resolved "http://registry.npm.taobao.org/chokidar/download/chokidar-1.7.0.tgz#798e689778151c8076b4b360e5edd28cda2bb468"
+ dependencies:
+ anymatch "^1.3.0"
+ async-each "^1.0.0"
+ glob-parent "^2.0.0"
+ inherits "^2.0.1"
+ is-binary-path "^1.0.0"
+ is-glob "^2.0.0"
+ path-is-absolute "^1.0.0"
+ readdirp "^2.0.0"
+ optionalDependencies:
+ fsevents "^1.0.0"
+
+chokidar@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/chokidar/-/chokidar-2.0.2.tgz#4dc65139eeb2714977735b6a35d06e97b494dfd7"
+ dependencies:
+ anymatch "^2.0.0"
+ async-each "^1.0.0"
+ braces "^2.3.0"
+ glob-parent "^3.1.0"
+ inherits "^2.0.1"
+ is-binary-path "^1.0.0"
+ is-glob "^4.0.0"
+ normalize-path "^2.1.1"
+ path-is-absolute "^1.0.0"
+ readdirp "^2.0.0"
+ upath "^1.0.0"
+ optionalDependencies:
+ fsevents "^1.0.0"
+
+cipher-base@^1.0.0, cipher-base@^1.0.1, cipher-base@^1.0.3:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/cipher-base/-/cipher-base-1.0.4.tgz#8760e4ecc272f4c363532f926d874aae2c1397de"
+ dependencies:
+ inherits "^2.0.1"
+ safe-buffer "^5.0.1"
+
+clap@^1.0.9:
+ version "1.2.3"
+ resolved "https://registry.yarnpkg.com/clap/-/clap-1.2.3.tgz#4f36745b32008492557f46412d66d50cb99bce51"
+ dependencies:
+ chalk "^1.1.3"
+
+class-utils@^0.3.5:
+ version "0.3.6"
+ resolved "https://registry.yarnpkg.com/class-utils/-/class-utils-0.3.6.tgz#f93369ae8b9a7ce02fd41faad0ca83033190c463"
+ dependencies:
+ arr-union "^3.1.0"
+ define-property "^0.2.5"
+ isobject "^3.0.0"
+ static-extend "^0.1.1"
+
+classnames@^2.2.5:
+ version "2.2.5"
+ resolved "http://registry.npm.taobao.org/classnames/download/classnames-2.2.5.tgz#fb3801d453467649ef3603c7d61a02bd129bde6d"
+
+ version "4.1.11"
+ resolved "https://registry.yarnpkg.com/clean-css/-/clean-css-4.1.11.tgz#2ecdf145aba38f54740f26cefd0ff3e03e125d6a"
+ dependencies:
+ source-map "0.5.x"
+
+cliui@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/cliui/-/cliui-2.1.0.tgz#4b475760ff80264c762c3a1719032e91c7fea0d1"
+ dependencies:
+ center-align "^0.1.1"
+ right-align "^0.1.1"
+ wordwrap "0.0.2"
+
+cliui@^3.2.0:
+ version "3.2.0"
+ resolved "https://registry.yarnpkg.com/cliui/-/cliui-3.2.0.tgz#120601537a916d29940f934da3b48d585a39213d"
+ dependencies:
+ string-width "^1.0.1"
+ strip-ansi "^3.0.1"
+ wrap-ansi "^2.0.0"
+
+clone-deep@^0.3.0:
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/clone-deep/-/clone-deep-0.3.0.tgz#348c61ae9cdbe0edfe053d91ff4cc521d790ede8"
+ dependencies:
+ for-own "^1.0.0"
+ is-plain-object "^2.0.1"
+ kind-of "^3.2.2"
+ shallow-clone "^0.1.2"
+
+clone@^1.0.2:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/clone/-/clone-1.0.3.tgz#298d7e2231660f40c003c2ed3140decf3f53085f"
+
+co@^4.6.0:
+ version "4.6.0"
+ resolved "https://registry.yarnpkg.com/co/-/co-4.6.0.tgz#6ea6bdf3d853ae54ccb8e47bfa0bf3f9031fb184"
+
+coa@~1.0.1:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/coa/-/coa-1.0.4.tgz#a9ef153660d6a86a8bdec0289a5c684d217432fd"
+ dependencies:
+ q "^1.1.2"
+
+code-point-at@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/code-point-at/-/code-point-at-1.1.0.tgz#0d070b4d043a5bea33a2f1a40e2edb3d9a4ccf77"
+
+collection-visit@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/collection-visit/-/collection-visit-1.0.0.tgz#4bc0373c164bc3291b4d368c829cf1a80a59dca0"
+ dependencies:
+ map-visit "^1.0.0"
+ object-visit "^1.0.0"
+
+color-convert@^1.3.0, color-convert@^1.9.0:
+ version "1.9.1"
+ resolved "https://registry.yarnpkg.com/color-convert/-/color-convert-1.9.1.tgz#c1261107aeb2f294ebffec9ed9ecad529a6097ed"
+ dependencies:
+ color-name "^1.1.1"
+
+color-name@^1.0.0, color-name@^1.1.1:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/color-name/-/color-name-1.1.3.tgz#a7d0558bd89c42f795dd42328f740831ca53bc25"
+
+color-string@^0.3.0:
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/color-string/-/color-string-0.3.0.tgz#27d46fb67025c5c2fa25993bfbf579e47841b991"
+ dependencies:
+ color-name "^1.0.0"
+
+color@^0.11.0:
+ version "0.11.4"
+ resolved "https://registry.yarnpkg.com/color/-/color-0.11.4.tgz#6d7b5c74fb65e841cd48792ad1ed5e07b904d764"
+ dependencies:
+ clone "^1.0.2"
+ color-convert "^1.3.0"
+ color-string "^0.3.0"
+
+colormin@^1.0.5:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/colormin/-/colormin-1.1.2.tgz#ea2f7420a72b96881a38aae59ec124a6f7298133"
+ dependencies:
+ color "^0.11.0"
+ css-color-names "0.0.4"
+ has "^1.0.1"
+
+colors@~1.1.2:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/colors/-/colors-1.1.2.tgz#168a4701756b6a7f51a12ce0c97bfa28c084ed63"
+
[email protected], combined-stream@^1.0.5, combined-stream@~1.0.5:
+ version "1.0.6"
+ resolved "https://registry.yarnpkg.com/combined-stream/-/combined-stream-1.0.6.tgz#723e7df6e801ac5613113a7e445a9b69cb632818"
+ dependencies:
+ delayed-stream "~1.0.0"
+
[email protected], commander@~2.14.1:
+ version "2.14.1"
+ resolved "https://registry.yarnpkg.com/commander/-/commander-2.14.1.tgz#2235123e37af8ca3c65df45b026dbd357b01b9aa"
+
+commander@^2.9.0:
+ version "2.15.0"
+ resolved "http://registry.npm.taobao.org/commander/download/commander-2.15.0.tgz#ad2a23a1c3b036e392469b8012cec6b33b4c1322"
+
+commondir@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/commondir/-/commondir-1.0.1.tgz#ddd800da0c66127393cca5950ea968a3aaf1253b"
+
+component-emitter@^1.2.1:
+ version "1.2.1"
+ resolved "https://registry.yarnpkg.com/component-emitter/-/component-emitter-1.2.1.tgz#137918d6d78283f7df7a6b7c5a63e140e69425e6"
+
+compressible@~2.0.13:
+ version "2.0.13"
+ resolved "http://registry.npm.taobao.org/compressible/download/compressible-2.0.13.tgz#0d1020ab924b2fdb4d6279875c7d6daba6baa7a9"
+ dependencies:
+ mime-db ">= 1.33.0 < 2"
+
+compression@^1.5.2:
+ version "1.7.2"
+ resolved "http://registry.npm.taobao.org/compression/download/compression-1.7.2.tgz#aaffbcd6aaf854b44ebb280353d5ad1651f59a69"
+ dependencies:
+ accepts "~1.3.4"
+ bytes "3.0.0"
+ compressible "~2.0.13"
+ debug "2.6.9"
+ on-headers "~1.0.1"
+ safe-buffer "5.1.1"
+ vary "~1.1.2"
+
+ version "0.0.1"
+ resolved "https://registry.yarnpkg.com/concat-map/-/concat-map-0.0.1.tgz#d8a96bd77fd68df7793a73036a3ba0d5405d477b"
+
+connect-history-api-fallback@^1.3.0:
+ version "1.5.0"
+ resolved "http://registry.npm.taobao.org/connect-history-api-fallback/download/connect-history-api-fallback-1.5.0.tgz#b06873934bc5e344fef611a196a6faae0aee015a"
+
+console-browserify@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/console-browserify/-/console-browserify-1.1.0.tgz#f0241c45730a9fc6323b206dbf38edc741d0bb10"
+ dependencies:
+ date-now "^0.1.4"
+
+console-control-strings@^1.0.0, console-control-strings@~1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/console-control-strings/-/console-control-strings-1.1.0.tgz#3d7cf4464db6446ea644bf4b39507f9851008e8e"
+
+constants-browserify@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/constants-browserify/-/constants-browserify-1.0.0.tgz#c20b96d8c617748aaf1c16021760cd27fcb8cb75"
+
+ version "0.5.2"
+ resolved "http://registry.npm.taobao.org/content-disposition/download/content-disposition-0.5.2.tgz#0cf68bb9ddf5f2be7961c3a85178cb85dba78cb4"
+
+content-type@~1.0.4:
+ version "1.0.4"
+ resolved "http://registry.npm.taobao.org/content-type/download/content-type-1.0.4.tgz#e138cc75e040c727b1966fe5e5f8c9aee256fe3b"
+
+convert-source-map@^1.5.0:
+ version "1.5.1"
+ resolved "https://registry.yarnpkg.com/convert-source-map/-/convert-source-map-1.5.1.tgz#b8278097b9bc229365de5c62cf5fcaed8b5599e5"
+
+ version "1.0.6"
+ resolved "http://registry.npm.taobao.org/cookie-signature/download/cookie-signature-1.0.6.tgz#e303a882b342cc3ee8ca513a79999734dab3ae2c"
+
+ version "0.3.1"
+ resolved "http://registry.npm.taobao.org/cookie/download/cookie-0.3.1.tgz#e7e0a1f9ef43b4c8ba925c5c5a96e806d16873bb"
+
+copy-descriptor@^0.1.0:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/copy-descriptor/-/copy-descriptor-0.1.1.tgz#676f6eb3c39997c2ee1ac3a924fd6124748f578d"
+
+core-js@^1.0.0:
+ version "1.2.7"
+ resolved "https://registry.yarnpkg.com/core-js/-/core-js-1.2.7.tgz#652294c14651db28fa93bd2d5ff2983a4f08c636"
+
+core-js@^2.4.0, core-js@^2.5.0:
+ version "2.5.3"
+ resolved "https://registry.yarnpkg.com/core-js/-/core-js-2.5.3.tgz#8acc38345824f16d8365b7c9b4259168e8ed603e"
+
+core-js@^2.5.6:
+ version "2.5.7"
+ resolved "http://registry.npm.taobao.org/core-js/download/core-js-2.5.7.tgz#f972608ff0cead68b841a16a932d0b183791814e"
+
[email protected], core-util-is@~1.0.0:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/core-util-is/-/core-util-is-1.0.2.tgz#b5fd54220aa2bc5ab57aab7140c940754503c1a7"
+
+create-ecdh@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/create-ecdh/-/create-ecdh-4.0.0.tgz#888c723596cdf7612f6498233eebd7a35301737d"
+ dependencies:
+ bn.js "^4.1.0"
+ elliptic "^6.0.0"
+
+create-hash@^1.1.0, create-hash@^1.1.2:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/create-hash/-/create-hash-1.1.3.tgz#606042ac8b9262750f483caddab0f5819172d8fd"
+ dependencies:
+ cipher-base "^1.0.1"
+ inherits "^2.0.1"
+ ripemd160 "^2.0.0"
+ sha.js "^2.4.0"
+
+create-hmac@^1.1.0, create-hmac@^1.1.2, create-hmac@^1.1.4:
+ version "1.1.6"
+ resolved "https://registry.yarnpkg.com/create-hmac/-/create-hmac-1.1.6.tgz#acb9e221a4e17bdb076e90657c42b93e3726cf06"
+ dependencies:
+ cipher-base "^1.0.3"
+ create-hash "^1.1.0"
+ inherits "^2.0.1"
+ ripemd160 "^2.0.0"
+ safe-buffer "^5.0.1"
+ sha.js "^2.4.8"
+
+cross-spawn@^3.0.0:
+ version "3.0.1"
+ resolved "http://registry.npm.taobao.org/cross-spawn/download/cross-spawn-3.0.1.tgz#1256037ecb9f0c5f79e3d6ef135e30770184b982"
+ dependencies:
+ lru-cache "^4.0.1"
+ which "^1.2.9"
+
+cross-spawn@^5.0.1:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/cross-spawn/-/cross-spawn-5.1.0.tgz#e8bd0efee58fcff6f8f94510a0a554bbfa235449"
+ dependencies:
+ lru-cache "^4.0.1"
+ shebang-command "^1.2.0"
+ which "^1.2.9"
+
+ version "2.0.5"
+ resolved "https://registry.yarnpkg.com/cryptiles/-/cryptiles-2.0.5.tgz#3bdfecdc608147c1c67202fa291e7dca59eaa3b8"
+ dependencies:
+ boom "2.x.x"
+
+ version "3.1.2"
+ resolved "http://registry.npm.taobao.org/cryptiles/download/cryptiles-3.1.2.tgz#a89fbb220f5ce25ec56e8c4aa8a4fd7b5b0d29fe"
+ dependencies:
+ boom "5.x.x"
+
+crypto-browserify@^3.11.0:
+ version "3.12.0"
+ resolved "https://registry.yarnpkg.com/crypto-browserify/-/crypto-browserify-3.12.0.tgz#396cf9f3137f03e4b8e532c58f698254e00f80ec"
+ dependencies:
+ browserify-cipher "^1.0.0"
+ browserify-sign "^4.0.0"
+ create-ecdh "^4.0.0"
+ create-hash "^1.1.0"
+ create-hmac "^1.1.0"
+ diffie-hellman "^5.0.0"
+ inherits "^2.0.1"
+ pbkdf2 "^3.0.3"
+ public-encrypt "^4.0.0"
+ randombytes "^2.0.0"
+ randomfill "^1.0.3"
+
+ version "0.0.4"
+ resolved "https://registry.yarnpkg.com/css-color-names/-/css-color-names-0.0.4.tgz#808adc2e79cf84738069b646cb20ec27beb629e0"
+
+ version "0.28.8"
+ resolved "https://registry.yarnpkg.com/css-loader/-/css-loader-0.28.8.tgz#ff36381464dea18fe60f2601a060ba6445886bd5"
+ dependencies:
+ babel-code-frame "^6.26.0"
+ css-selector-tokenizer "^0.7.0"
+ cssnano "^3.10.0"
+ icss-utils "^2.1.0"
+ loader-utils "^1.0.2"
+ lodash.camelcase "^4.3.0"
+ object-assign "^4.1.1"
+ postcss "^5.0.6"
+ postcss-modules-extract-imports "^1.1.0"
+ postcss-modules-local-by-default "^1.2.0"
+ postcss-modules-scope "^1.1.0"
+ postcss-modules-values "^1.3.0"
+ postcss-value-parser "^3.3.0"
+ source-list-map "^2.0.0"
+
+css-select@^1.1.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/css-select/-/css-select-1.2.0.tgz#2b3a110539c5355f1cd8d314623e870b121ec858"
+ dependencies:
+ boolbase "~1.0.0"
+ css-what "2.1"
+ domutils "1.5.1"
+ nth-check "~1.0.1"
+
+css-selector-tokenizer@^0.7.0:
+ version "0.7.0"
+ resolved "https://registry.yarnpkg.com/css-selector-tokenizer/-/css-selector-tokenizer-0.7.0.tgz#e6988474ae8c953477bf5e7efecfceccd9cf4c86"
+ dependencies:
+ cssesc "^0.1.0"
+ fastparse "^1.1.1"
+ regexpu-core "^1.0.0"
+
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/css-what/-/css-what-2.1.0.tgz#9467d032c38cfaefb9f2d79501253062f87fa1bd"
+
+cssesc@^0.1.0:
+ version "0.1.0"
+ resolved "https://registry.yarnpkg.com/cssesc/-/cssesc-0.1.0.tgz#c814903e45623371a0477b40109aaafbeeaddbb4"
+
+cssnano@^3.10.0:
+ version "3.10.0"
+ resolved "https://registry.yarnpkg.com/cssnano/-/cssnano-3.10.0.tgz#4f38f6cea2b9b17fa01490f23f1dc68ea65c1c38"
+ dependencies:
+ autoprefixer "^6.3.1"
+ decamelize "^1.1.2"
+ defined "^1.0.0"
+ has "^1.0.1"
+ object-assign "^4.0.1"
+ postcss "^5.0.14"
+ postcss-calc "^5.2.0"
+ postcss-colormin "^2.1.8"
+ postcss-convert-values "^2.3.4"
+ postcss-discard-comments "^2.0.4"
+ postcss-discard-duplicates "^2.0.1"
+ postcss-discard-empty "^2.0.1"
+ postcss-discard-overridden "^0.1.1"
+ postcss-discard-unused "^2.2.1"
+ postcss-filter-plugins "^2.0.0"
+ postcss-merge-idents "^2.1.5"
+ postcss-merge-longhand "^2.0.1"
+ postcss-merge-rules "^2.0.3"
+ postcss-minify-font-values "^1.0.2"
+ postcss-minify-gradients "^1.0.1"
+ postcss-minify-params "^1.0.4"
+ postcss-minify-selectors "^2.0.4"
+ postcss-normalize-charset "^1.1.0"
+ postcss-normalize-url "^3.0.7"
+ postcss-ordered-values "^2.1.0"
+ postcss-reduce-idents "^2.2.2"
+ postcss-reduce-initial "^1.0.0"
+ postcss-reduce-transforms "^1.0.3"
+ postcss-svgo "^2.1.1"
+ postcss-unique-selectors "^2.0.2"
+ postcss-value-parser "^3.2.3"
+ postcss-zindex "^2.0.1"
+
+csso@~2.3.1:
+ version "2.3.2"
+ resolved "https://registry.yarnpkg.com/csso/-/csso-2.3.2.tgz#ddd52c587033f49e94b71fc55569f252e8ff5f85"
+ dependencies:
+ clap "^1.0.9"
+ source-map "^0.5.3"
+
+currently-unhandled@^0.4.1:
+ version "0.4.1"
+ resolved "http://registry.npm.taobao.org/currently-unhandled/download/currently-unhandled-0.4.1.tgz#988df33feab191ef799a61369dd76c17adf957ea"
+ dependencies:
+ array-find-index "^1.0.1"
+
+d@1:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/d/-/d-1.0.0.tgz#754bb5bfe55451da69a58b94d45f4c5b0462d58f"
+ dependencies:
+ es5-ext "^0.10.9"
+
+dashdash@^1.12.0:
+ version "1.14.1"
+ resolved "https://registry.yarnpkg.com/dashdash/-/dashdash-1.14.1.tgz#853cfa0f7cbe2fed5de20326b8dd581035f6e2f0"
+ dependencies:
+ assert-plus "^1.0.0"
+
+date-now@^0.1.4:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/date-now/-/date-now-0.1.4.tgz#eaf439fd4d4848ad74e5cc7dbef200672b9e345b"
+
[email protected], debug@^2.2.0, debug@^2.3.3, debug@^2.6.6, debug@^2.6.8:
+ version "2.6.9"
+ resolved "https://registry.yarnpkg.com/debug/-/debug-2.6.9.tgz#5d128515df134ff327e90a4c93f4e077a536341f"
+ dependencies:
+ ms "2.0.0"
+
+debug@^3.1.0:
+ version "3.1.0"
+ resolved "http://registry.npm.taobao.org/debug/download/debug-3.1.0.tgz#5bb5a0672628b64149566ba16819e61518c67261"
+ dependencies:
+ ms "2.0.0"
+
+decamelize@^1.0.0, decamelize@^1.1.1, decamelize@^1.1.2:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/decamelize/-/decamelize-1.2.0.tgz#f6534d15148269b20352e7bee26f501f9a191290"
+
+decode-uri-component@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/decode-uri-component/-/decode-uri-component-0.2.0.tgz#eb3913333458775cb84cd1a1fae062106bb87545"
+
+deep-equal@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/deep-equal/download/deep-equal-1.0.1.tgz#f5d260292b660e084eff4cdbc9f08ad3247448b5"
+
+deep-extend@~0.4.0:
+ version "0.4.2"
+ resolved "https://registry.yarnpkg.com/deep-extend/-/deep-extend-0.4.2.tgz#48b699c27e334bf89f10892be432f6e4c7d34a7f"
+
+define-properties@^1.1.2:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/define-properties/download/define-properties-1.1.2.tgz#83a73f2fea569898fb737193c8f873caf6d45c94"
+ dependencies:
+ foreach "^2.0.5"
+ object-keys "^1.0.8"
+
+define-property@^0.2.5:
+ version "0.2.5"
+ resolved "https://registry.yarnpkg.com/define-property/-/define-property-0.2.5.tgz#c35b1ef918ec3c990f9a5bc57be04aacec5c8116"
+ dependencies:
+ is-descriptor "^0.1.0"
+
+define-property@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/define-property/-/define-property-1.0.0.tgz#769ebaaf3f4a63aad3af9e8d304c9bbe79bfb0e6"
+ dependencies:
+ is-descriptor "^1.0.0"
+
+define-property@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/define-property/-/define-property-2.0.2.tgz#d459689e8d654ba77e02a817f8710d702cb16e9d"
+ dependencies:
+ is-descriptor "^1.0.2"
+ isobject "^3.0.1"
+
+defined@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/defined/-/defined-1.0.0.tgz#c98d9bcef75674188e110969151199e39b1fa693"
+
+del@^3.0.0:
+ version "3.0.0"
+ resolved "http://registry.npm.taobao.org/del/download/del-3.0.0.tgz#53ecf699ffcbcb39637691ab13baf160819766e5"
+ dependencies:
+ globby "^6.1.0"
+ is-path-cwd "^1.0.0"
+ is-path-in-cwd "^1.0.0"
+ p-map "^1.1.1"
+ pify "^3.0.0"
+ rimraf "^2.2.8"
+
+delayed-stream@~1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/delayed-stream/-/delayed-stream-1.0.0.tgz#df3ae199acadfb7d440aaae0b29e2272b24ec619"
+
+delegates@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/delegates/-/delegates-1.0.0.tgz#84c6e159b81904fdca59a0ef44cd870d31250f9a"
+
+ version "1.1.1"
+ resolved "http://registry.npm.taobao.org/depd/download/depd-1.1.1.tgz#5783b4e1c459f06fa5ca27f991f3d06e7a310359"
+
+depd@~1.1.1, depd@~1.1.2:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/depd/download/depd-1.1.2.tgz#9bcd52e14c097763e749b274c4346ed2e560b5a9"
+
+des.js@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/des.js/-/des.js-1.0.0.tgz#c074d2e2aa6a8a9a07dbd61f9a15c2cd83ec8ecc"
+ dependencies:
+ inherits "^2.0.1"
+ minimalistic-assert "^1.0.0"
+
+destroy@~1.0.4:
+ version "1.0.4"
+ resolved "http://registry.npm.taobao.org/destroy/download/destroy-1.0.4.tgz#978857442c44749e4206613e37946205826abd80"
+
+detect-indent@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/detect-indent/-/detect-indent-4.0.0.tgz#f76d064352cdf43a1cb6ce619c4ee3a9475de208"
+ dependencies:
+ repeating "^2.0.0"
+
+detect-libc@^1.0.2:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/detect-libc/-/detect-libc-1.0.3.tgz#fa137c4bd698edf55cd5cd02ac559f91a4c4ba9b"
+
+detect-node@^2.0.3:
+ version "2.0.3"
+ resolved "http://registry.npm.taobao.org/detect-node/download/detect-node-2.0.3.tgz#a2033c09cc8e158d37748fbde7507832bd6ce127"
+
+diffie-hellman@^5.0.0:
+ version "5.0.2"
+ resolved "https://registry.yarnpkg.com/diffie-hellman/-/diffie-hellman-5.0.2.tgz#b5835739270cfe26acf632099fded2a07f209e5e"
+ dependencies:
+ bn.js "^4.1.0"
+ miller-rabin "^4.0.0"
+ randombytes "^2.0.0"
+
+dns-equal@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/dns-equal/download/dns-equal-1.0.0.tgz#b39e7f1da6eb0a75ba9c17324b34753c47e0654d"
+
+dns-packet@^1.3.1:
+ version "1.3.1"
+ resolved "http://registry.npm.taobao.org/dns-packet/download/dns-packet-1.3.1.tgz#12aa426981075be500b910eedcd0b47dd7deda5a"
+ dependencies:
+ ip "^1.1.0"
+ safe-buffer "^5.0.1"
+
+dns-txt@^2.0.2:
+ version "2.0.2"
+ resolved "http://registry.npm.taobao.org/dns-txt/download/dns-txt-2.0.2.tgz#b91d806f5d27188e4ab3e7d107d881a1cc4642b6"
+ dependencies:
+ buffer-indexof "^1.0.0"
+
+dom-converter@~0.1:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/dom-converter/-/dom-converter-0.1.4.tgz#a45ef5727b890c9bffe6d7c876e7b19cb0e17f3b"
+ dependencies:
+ utila "~0.3"
+
+dom-serializer@0:
+ version "0.1.0"
+ resolved "https://registry.yarnpkg.com/dom-serializer/-/dom-serializer-0.1.0.tgz#073c697546ce0780ce23be4a28e293e40bc30c82"
+ dependencies:
+ domelementtype "~1.1.1"
+ entities "~1.1.1"
+
+domain-browser@^1.1.1:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/domain-browser/-/domain-browser-1.2.0.tgz#3d31f50191a6749dd1375a7f522e823d42e54eda"
+
+domelementtype@1:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-1.3.0.tgz#b17aed82e8ab59e52dd9c19b1756e0fc187204c2"
+
+domelementtype@~1.1.1:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/domelementtype/-/domelementtype-1.1.3.tgz#bd28773e2642881aec51544924299c5cd822185b"
+
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/domhandler/-/domhandler-2.1.0.tgz#d2646f5e57f6c3bab11cf6cb05d3c0acf7412594"
+ dependencies:
+ domelementtype "1"
+
+ version "1.1.6"
+ resolved "https://registry.yarnpkg.com/domutils/-/domutils-1.1.6.tgz#bddc3de099b9a2efacc51c623f28f416ecc57485"
+ dependencies:
+ domelementtype "1"
+
+ version "1.5.1"
+ resolved "https://registry.yarnpkg.com/domutils/-/domutils-1.5.1.tgz#dcd8488a26f563d61079e48c9f7b7e32373682cf"
+ dependencies:
+ dom-serializer "0"
+ domelementtype "1"
+
+ecc-jsbn@~0.1.1:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/ecc-jsbn/-/ecc-jsbn-0.1.1.tgz#0fc73a9ed5f0d53c38193398523ef7e543777505"
+ dependencies:
+ jsbn "~0.1.0"
+
+echarts@^4.1.0:
+ version "4.1.0"
+ resolved "http://registry.npm.taobao.org/echarts/download/echarts-4.1.0.tgz#d588c95f73c1a9928b9c73d5b769751c3185bcdc"
+ dependencies:
+ zrender "4.0.4"
+
+ version "1.1.1"
+ resolved "http://registry.npm.taobao.org/ee-first/download/ee-first-1.1.1.tgz#590c61156b0ae2f4f0255732a158b266bc56b21d"
+
+electron-to-chromium@^1.2.7, electron-to-chromium@^1.3.30:
+ version "1.3.37"
+ resolved "https://registry.yarnpkg.com/electron-to-chromium/-/electron-to-chromium-1.3.37.tgz#4a92734e0044c8cf0b1553be57eae21a4c6e5fab"
+
+elliptic@^6.0.0:
+ version "6.4.0"
+ resolved "https://registry.yarnpkg.com/elliptic/-/elliptic-6.4.0.tgz#cac9af8762c85836187003c8dfe193e5e2eae5df"
+ dependencies:
+ bn.js "^4.4.0"
+ brorand "^1.0.1"
+ hash.js "^1.0.0"
+ hmac-drbg "^1.0.0"
+ inherits "^2.0.1"
+ minimalistic-assert "^1.0.0"
+ minimalistic-crypto-utils "^1.0.0"
+
+emojis-list@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/emojis-list/-/emojis-list-2.1.0.tgz#4daa4d9db00f9819880c79fa457ae5b09a1fd389"
+
+encodeurl@~1.0.2:
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/encodeurl/download/encodeurl-1.0.2.tgz#ad3ff4c86ec2d029322f5a02c3a9a606c95b3f59"
+
+encoding@^0.1.11:
+ version "0.1.12"
+ resolved "https://registry.yarnpkg.com/encoding/-/encoding-0.1.12.tgz#538b66f3ee62cd1ab51ec323829d1f9480c74beb"
+ dependencies:
+ iconv-lite "~0.4.13"
+
+enhanced-resolve@^3.4.0:
+ version "3.4.1"
+ resolved "https://registry.yarnpkg.com/enhanced-resolve/-/enhanced-resolve-3.4.1.tgz#0421e339fd71419b3da13d129b3979040230476e"
+ dependencies:
+ graceful-fs "^4.1.2"
+ memory-fs "^0.4.0"
+ object-assign "^4.0.1"
+ tapable "^0.2.7"
+
+entities@~1.1.1:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/entities/-/entities-1.1.1.tgz#6e5c2d0a5621b5dadaecef80b90edfb5cd7772f0"
+
+errno@^0.1.3:
+ version "0.1.7"
+ resolved "https://registry.yarnpkg.com/errno/-/errno-0.1.7.tgz#4684d71779ad39af177e3f007996f7c67c852618"
+ dependencies:
+ prr "~1.0.1"
+
+error-ex@^1.2.0:
+ version "1.3.1"
+ resolved "https://registry.yarnpkg.com/error-ex/-/error-ex-1.3.1.tgz#f855a86ce61adc4e8621c3cda21e7a7612c3a8dc"
+ dependencies:
+ is-arrayish "^0.2.1"
+
+es-abstract@^1.7.0:
+ version "1.10.0"
+ resolved "http://registry.npm.taobao.org/es-abstract/download/es-abstract-1.10.0.tgz#1ecb36c197842a00d8ee4c2dfd8646bb97d60864"
+ dependencies:
+ es-to-primitive "^1.1.1"
+ function-bind "^1.1.1"
+ has "^1.0.1"
+ is-callable "^1.1.3"
+ is-regex "^1.0.4"
+
+es-to-primitive@^1.1.1:
+ version "1.1.1"
+ resolved "http://registry.npm.taobao.org/es-to-primitive/download/es-to-primitive-1.1.1.tgz#45355248a88979034b6792e19bb81f2b7975dd0d"
+ dependencies:
+ is-callable "^1.1.1"
+ is-date-object "^1.0.1"
+ is-symbol "^1.0.1"
+
+es5-ext@^0.10.14, es5-ext@^0.10.35, es5-ext@^0.10.9, es5-ext@~0.10.14:
+ version "0.10.40"
+ resolved "https://registry.yarnpkg.com/es5-ext/-/es5-ext-0.10.40.tgz#ab3d2179b943008c5e9ef241beb25ef41424c774"
+ dependencies:
+ es6-iterator "~2.0.3"
+ es6-symbol "~3.1.1"
+
+es6-iterator@^2.0.1, es6-iterator@~2.0.1, es6-iterator@~2.0.3:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/es6-iterator/-/es6-iterator-2.0.3.tgz#a7de889141a05a94b0854403b2d0a0fbfa98f3b7"
+ dependencies:
+ d "1"
+ es5-ext "^0.10.35"
+ es6-symbol "^3.1.1"
+
+es6-map@^0.1.3:
+ version "0.1.5"
+ resolved "https://registry.yarnpkg.com/es6-map/-/es6-map-0.1.5.tgz#9136e0503dcc06a301690f0bb14ff4e364e949f0"
+ dependencies:
+ d "1"
+ es5-ext "~0.10.14"
+ es6-iterator "~2.0.1"
+ es6-set "~0.1.5"
+ es6-symbol "~3.1.1"
+ event-emitter "~0.3.5"
+
+es6-set@~0.1.5:
+ version "0.1.5"
+ resolved "https://registry.yarnpkg.com/es6-set/-/es6-set-0.1.5.tgz#d2b3ec5d4d800ced818db538d28974db0a73ccb1"
+ dependencies:
+ d "1"
+ es5-ext "~0.10.14"
+ es6-iterator "~2.0.1"
+ es6-symbol "3.1.1"
+ event-emitter "~0.3.5"
+
[email protected], es6-symbol@^3.1.1, es6-symbol@~3.1.1:
+ version "3.1.1"
+ resolved "https://registry.yarnpkg.com/es6-symbol/-/es6-symbol-3.1.1.tgz#bf00ef4fdab6ba1b46ecb7b629b4c7ed5715cc77"
+ dependencies:
+ d "1"
+ es5-ext "~0.10.14"
+
+es6-weak-map@^2.0.1:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/es6-weak-map/-/es6-weak-map-2.0.2.tgz#5e3ab32251ffd1538a1f8e5ffa1357772f92d96f"
+ dependencies:
+ d "1"
+ es5-ext "^0.10.14"
+ es6-iterator "^2.0.1"
+ es6-symbol "^3.1.1"
+
+escape-html@~1.0.3:
+ version "1.0.3"
+ resolved "http://registry.npm.taobao.org/escape-html/download/escape-html-1.0.3.tgz#0258eae4d3d0c0974de1c169188ef0051d1d1988"
+
+escape-string-regexp@^1.0.2, escape-string-regexp@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz#1b61c0562190a8dff6ae3bb2cf0200ca130b86d4"
+
+escope@^3.6.0:
+ version "3.6.0"
+ resolved "https://registry.yarnpkg.com/escope/-/escope-3.6.0.tgz#e01975e812781a163a6dadfdd80398dc64c889c3"
+ dependencies:
+ es6-map "^0.1.3"
+ es6-weak-map "^2.0.1"
+ esrecurse "^4.1.0"
+ estraverse "^4.1.1"
+
+esprima@^2.6.0:
+ version "2.7.3"
+ resolved "https://registry.yarnpkg.com/esprima/-/esprima-2.7.3.tgz#96e3b70d5779f6ad49cd032673d1c312767ba581"
+
+esrecurse@^4.1.0:
+ version "4.2.1"
+ resolved "https://registry.yarnpkg.com/esrecurse/-/esrecurse-4.2.1.tgz#007a3b9fdbc2b3bb87e4879ea19c92fdbd3942cf"
+ dependencies:
+ estraverse "^4.1.0"
+
+estraverse@^4.1.0, estraverse@^4.1.1:
+ version "4.2.0"
+ resolved "https://registry.yarnpkg.com/estraverse/-/estraverse-4.2.0.tgz#0dee3fed31fcd469618ce7342099fc1afa0bdb13"
+
+esutils@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/esutils/-/esutils-2.0.2.tgz#0abf4f1caa5bcb1f7a9d8acc6dea4faaa04bac9b"
+
+etag@~1.8.1:
+ version "1.8.1"
+ resolved "http://registry.npm.taobao.org/etag/download/etag-1.8.1.tgz#41ae2eeb65efa62268aebfea83ac7d79299b0887"
+
+event-emitter@~0.3.5:
+ version "0.3.5"
+ resolved "https://registry.yarnpkg.com/event-emitter/-/event-emitter-0.3.5.tgz#df8c69eef1647923c7157b9ce83840610b02cc39"
+ dependencies:
+ d "1"
+ es5-ext "~0.10.14"
+
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/eventemitter3/download/eventemitter3-1.2.0.tgz#1c86991d816ad1e504750e73874224ecf3bec508"
+
+events@^1.0.0:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/events/-/events-1.1.1.tgz#9ebdb7635ad099c70dcc4c2a1f5004288e8bd924"
+
+ version "0.1.6"
+ resolved "http://registry.npm.taobao.org/eventsource/download/eventsource-0.1.6.tgz#0acede849ed7dd1ccc32c811bb11b944d4f29232"
+ dependencies:
+ original ">=0.0.5"
+
+evp_bytestokey@^1.0.0, evp_bytestokey@^1.0.3:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz#7fcbdb198dc71959432efe13842684e0525acb02"
+ dependencies:
+ md5.js "^1.3.4"
+ safe-buffer "^5.1.1"
+
+execa@^0.7.0:
+ version "0.7.0"
+ resolved "https://registry.yarnpkg.com/execa/-/execa-0.7.0.tgz#944becd34cc41ee32a63a9faf27ad5a65fc59777"
+ dependencies:
+ cross-spawn "^5.0.1"
+ get-stream "^3.0.0"
+ is-stream "^1.1.0"
+ npm-run-path "^2.0.0"
+ p-finally "^1.0.0"
+ signal-exit "^3.0.0"
+ strip-eof "^1.0.0"
+
+expand-brackets@^0.1.4:
+ version "0.1.5"
+ resolved "http://registry.npm.taobao.org/expand-brackets/download/expand-brackets-0.1.5.tgz#df07284e342a807cd733ac5af72411e581d1177b"
+ dependencies:
+ is-posix-bracket "^0.1.0"
+
+expand-brackets@^2.1.4:
+ version "2.1.4"
+ resolved "https://registry.yarnpkg.com/expand-brackets/-/expand-brackets-2.1.4.tgz#b77735e315ce30f6b6eff0f83b04151a22449622"
+ dependencies:
+ debug "^2.3.3"
+ define-property "^0.2.5"
+ extend-shallow "^2.0.1"
+ posix-character-classes "^0.1.0"
+ regex-not "^1.0.0"
+ snapdragon "^0.8.1"
+ to-regex "^3.0.1"
+
+expand-range@^1.8.1:
+ version "1.8.2"
+ resolved "http://registry.npm.taobao.org/expand-range/download/expand-range-1.8.2.tgz#a299effd335fe2721ebae8e257ec79644fc85337"
+ dependencies:
+ fill-range "^2.1.0"
+
+express@^4.16.2:
+ version "4.16.3"
+ resolved "http://registry.npm.taobao.org/express/download/express-4.16.3.tgz#6af8a502350db3246ecc4becf6b5a34d22f7ed53"
+ dependencies:
+ accepts "~1.3.5"
+ array-flatten "1.1.1"
+ body-parser "1.18.2"
+ content-disposition "0.5.2"
+ content-type "~1.0.4"
+ cookie "0.3.1"
+ cookie-signature "1.0.6"
+ debug "2.6.9"
+ depd "~1.1.2"
+ encodeurl "~1.0.2"
+ escape-html "~1.0.3"
+ etag "~1.8.1"
+ finalhandler "1.1.1"
+ fresh "0.5.2"
+ merge-descriptors "1.0.1"
+ methods "~1.1.2"
+ on-finished "~2.3.0"
+ parseurl "~1.3.2"
+ path-to-regexp "0.1.7"
+ proxy-addr "~2.0.3"
+ qs "6.5.1"
+ range-parser "~1.2.0"
+ safe-buffer "5.1.1"
+ send "0.16.2"
+ serve-static "1.13.2"
+ setprototypeof "1.1.0"
+ statuses "~1.4.0"
+ type-is "~1.6.16"
+ utils-merge "1.0.1"
+ vary "~1.1.2"
+
+extend-shallow@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-2.0.1.tgz#51af7d614ad9a9f610ea1bafbb989d6b1c56890f"
+ dependencies:
+ is-extendable "^0.1.0"
+
+extend-shallow@^3.0.0, extend-shallow@^3.0.2:
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/extend-shallow/-/extend-shallow-3.0.2.tgz#26a71aaf073b39fb2127172746131c2704028db8"
+ dependencies:
+ assign-symbols "^1.0.0"
+ is-extendable "^1.0.1"
+
+extend@~3.0.0, extend@~3.0.1:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/extend/-/extend-3.0.1.tgz#a755ea7bc1adfcc5a31ce7e762dbaadc5e636444"
+
+extglob@^0.3.1:
+ version "0.3.2"
+ resolved "http://registry.npm.taobao.org/extglob/download/extglob-0.3.2.tgz#2e18ff3d2f49ab2765cec9023f011daa8d8349a1"
+ dependencies:
+ is-extglob "^1.0.0"
+
+extglob@^2.0.4:
+ version "2.0.4"
+ resolved "https://registry.yarnpkg.com/extglob/-/extglob-2.0.4.tgz#ad00fe4dc612a9232e8718711dc5cb5ab0285543"
+ dependencies:
+ array-unique "^0.3.2"
+ define-property "^1.0.0"
+ expand-brackets "^2.1.4"
+ extend-shallow "^2.0.1"
+ fragment-cache "^0.2.1"
+ regex-not "^1.0.0"
+ snapdragon "^0.8.1"
+ to-regex "^3.0.1"
+
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/extract-text-webpack-plugin/-/extract-text-webpack-plugin-3.0.2.tgz#5f043eaa02f9750a9258b78c0a6e0dc1408fb2f7"
+ dependencies:
+ async "^2.4.1"
+ loader-utils "^1.1.0"
+ schema-utils "^0.3.0"
+ webpack-sources "^1.0.1"
+
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.3.0.tgz#96918440e3041a7a414f8c52e3c574eb3c3e1e05"
+
+extsprintf@^1.2.0:
+ version "1.4.0"
+ resolved "https://registry.yarnpkg.com/extsprintf/-/extsprintf-1.4.0.tgz#e2689f8f356fad62cca65a3a91c5df5f9551692f"
+
+fast-deep-equal@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/fast-deep-equal/-/fast-deep-equal-1.1.0.tgz#c053477817c86b51daa853c81e059b733d023614"
+
+fast-json-stable-stringify@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/fast-json-stable-stringify/-/fast-json-stable-stringify-2.0.0.tgz#d5142c0caee6b1189f87d3a76111064f86c8bbf2"
+
+fastparse@^1.1.1:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/fastparse/-/fastparse-1.1.1.tgz#d1e2643b38a94d7583b479060e6c4affc94071f8"
+
+faye-websocket@^0.10.0:
+ version "0.10.0"
+ resolved "http://registry.npm.taobao.org/faye-websocket/download/faye-websocket-0.10.0.tgz#4e492f8d04dfb6f89003507f6edbf2d501e7c6f4"
+ dependencies:
+ websocket-driver ">=0.5.1"
+
+faye-websocket@~0.11.0:
+ version "0.11.1"
+ resolved "http://registry.npm.taobao.org/faye-websocket/download/faye-websocket-0.11.1.tgz#f0efe18c4f56e4f40afc7e06c719fd5ee6188f38"
+ dependencies:
+ websocket-driver ">=0.5.1"
+
+fbjs@^0.8.16:
+ version "0.8.16"
+ resolved "https://registry.yarnpkg.com/fbjs/-/fbjs-0.8.16.tgz#5e67432f550dc41b572bf55847b8aca64e5337db"
+ dependencies:
+ core-js "^1.0.0"
+ isomorphic-fetch "^2.1.1"
+ loose-envify "^1.0.0"
+ object-assign "^4.1.0"
+ promise "^7.1.1"
+ setimmediate "^1.0.5"
+ ua-parser-js "^0.7.9"
+
+ version "1.1.6"
+ resolved "http://registry.npm.taobao.org/file-loader/download/file-loader-1.1.6.tgz#7b9a8f2c58f00a77fddf49e940f7ac978a3ea0e8"
+ dependencies:
+ loader-utils "^1.0.2"
+ schema-utils "^0.3.0"
+
+filename-regex@^2.0.0:
+ version "2.0.1"
+ resolved "http://registry.npm.taobao.org/filename-regex/download/filename-regex-2.0.1.tgz#c1c4b9bee3e09725ddb106b75c1e301fe2f18b26"
+
+fill-range@^2.1.0:
+ version "2.2.3"
+ resolved "http://registry.npm.taobao.org/fill-range/download/fill-range-2.2.3.tgz#50b77dfd7e469bc7492470963699fe7a8485a723"
+ dependencies:
+ is-number "^2.1.0"
+ isobject "^2.0.0"
+ randomatic "^1.1.3"
+ repeat-element "^1.1.2"
+ repeat-string "^1.5.2"
+
+fill-range@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/fill-range/-/fill-range-4.0.0.tgz#d544811d428f98eb06a63dc402d2403c328c38f7"
+ dependencies:
+ extend-shallow "^2.0.1"
+ is-number "^3.0.0"
+ repeat-string "^1.6.1"
+ to-regex-range "^2.1.0"
+
+ version "1.1.1"
+ resolved "http://registry.npm.taobao.org/finalhandler/download/finalhandler-1.1.1.tgz#eebf4ed840079c83f4249038c9d703008301b105"
+ dependencies:
+ debug "2.6.9"
+ encodeurl "~1.0.2"
+ escape-html "~1.0.3"
+ on-finished "~2.3.0"
+ parseurl "~1.3.2"
+ statuses "~1.4.0"
+ unpipe "~1.0.0"
+
+find-cache-dir@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/find-cache-dir/-/find-cache-dir-1.0.0.tgz#9288e3e9e3cc3748717d39eade17cf71fc30ee6f"
+ dependencies:
+ commondir "^1.0.1"
+ make-dir "^1.0.0"
+ pkg-dir "^2.0.0"
+
+find-up@^1.0.0:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/find-up/download/find-up-1.1.2.tgz#6b2e9822b1a2ce0a60ab64d610eccad53cb24d0f"
+ dependencies:
+ path-exists "^2.0.0"
+ pinkie-promise "^2.0.0"
+
+find-up@^2.0.0, find-up@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/find-up/-/find-up-2.1.0.tgz#45d1b7e506c717ddd482775a2b77920a3c0c57a7"
+ dependencies:
+ locate-path "^2.0.0"
+
+flatten@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/flatten/-/flatten-1.0.2.tgz#dae46a9d78fbe25292258cc1e780a41d95c03782"
+
+font-awesome@^4.7.0:
+ version "4.7.0"
+ resolved "http://registry.npm.taobao.org/font-awesome/download/font-awesome-4.7.0.tgz#8fa8cf0411a1a31afd07b06d2902bb9fc815a133"
+
+for-in@^0.1.3:
+ version "0.1.8"
+ resolved "https://registry.yarnpkg.com/for-in/-/for-in-0.1.8.tgz#d8773908e31256109952b1fdb9b3fa867d2775e1"
+
+for-in@^1.0.1, for-in@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/for-in/-/for-in-1.0.2.tgz#81068d295a8142ec0ac726c6e2200c30fb6d5e80"
+
+for-own@^0.1.4:
+ version "0.1.5"
+ resolved "http://registry.npm.taobao.org/for-own/download/for-own-0.1.5.tgz#5265c681a4f294dabbf17c9509b6763aa84510ce"
+ dependencies:
+ for-in "^1.0.1"
+
+for-own@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/for-own/-/for-own-1.0.0.tgz#c63332f415cedc4b04dbfe70cf836494c53cb44b"
+ dependencies:
+ for-in "^1.0.1"
+
+foreach@^2.0.5:
+ version "2.0.5"
+ resolved "http://registry.npm.taobao.org/foreach/download/foreach-2.0.5.tgz#0bee005018aeb260d0a3af3ae658dd0136ec1b99"
+
+forever-agent@~0.6.1:
+ version "0.6.1"
+ resolved "https://registry.yarnpkg.com/forever-agent/-/forever-agent-0.6.1.tgz#fbc71f0c41adeb37f96c577ad1ed42d8fdacca91"
+
+form-data@~2.1.1:
+ version "2.1.4"
+ resolved "https://registry.yarnpkg.com/form-data/-/form-data-2.1.4.tgz#33c183acf193276ecaa98143a69e94bfee1750d1"
+ dependencies:
+ asynckit "^0.4.0"
+ combined-stream "^1.0.5"
+ mime-types "^2.1.12"
+
+form-data@~2.3.1:
+ version "2.3.2"
+ resolved "http://registry.npm.taobao.org/form-data/download/form-data-2.3.2.tgz#4970498be604c20c005d4f5c23aecd21d6b49099"
+ dependencies:
+ asynckit "^0.4.0"
+ combined-stream "1.0.6"
+ mime-types "^2.1.12"
+
+forwarded@~0.1.2:
+ version "0.1.2"
+ resolved "http://registry.npm.taobao.org/forwarded/download/forwarded-0.1.2.tgz#98c23dab1175657b8c0573e8ceccd91b0ff18c84"
+
+fragment-cache@^0.2.1:
+ version "0.2.1"
+ resolved "https://registry.yarnpkg.com/fragment-cache/-/fragment-cache-0.2.1.tgz#4290fad27f13e89be7f33799c6bc5a0abfff0d19"
+ dependencies:
+ map-cache "^0.2.2"
+
+ version "0.5.2"
+ resolved "http://registry.npm.taobao.org/fresh/download/fresh-0.5.2.tgz#3d8cadd90d976569fa835ab1f8e4b23a105605a7"
+
+fs.realpath@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/fs.realpath/-/fs.realpath-1.0.0.tgz#1504ad2523158caa40db4a2787cb01411994ea4f"
+
+fsevents@^1.0.0:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/fsevents/-/fsevents-1.1.3.tgz#11f82318f5fe7bb2cd22965a108e9306208216d8"
+ dependencies:
+ nan "^2.3.0"
+ node-pre-gyp "^0.6.39"
+
+fstream-ignore@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/fstream-ignore/-/fstream-ignore-1.0.5.tgz#9c31dae34767018fe1d249b24dada67d092da105"
+ dependencies:
+ fstream "^1.0.0"
+ inherits "2"
+ minimatch "^3.0.0"
+
+fstream@^1.0.0, fstream@^1.0.10, fstream@^1.0.2:
+ version "1.0.11"
+ resolved "https://registry.yarnpkg.com/fstream/-/fstream-1.0.11.tgz#5c1fb1f117477114f0632a0eb4b71b3cb0fd3171"
+ dependencies:
+ graceful-fs "^4.1.2"
+ inherits "~2.0.0"
+ mkdirp ">=0.5 0"
+ rimraf "2"
+
+function-bind@^1.0.2, function-bind@^1.1.1:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/function-bind/-/function-bind-1.1.1.tgz#a56899d3ea3c9bab874bb9773b7c5ede92f4895d"
+
+gauge@~2.7.3:
+ version "2.7.4"
+ resolved "https://registry.yarnpkg.com/gauge/-/gauge-2.7.4.tgz#2c03405c7538c39d7eb37b317022e325fb018bf7"
+ dependencies:
+ aproba "^1.0.3"
+ console-control-strings "^1.0.0"
+ has-unicode "^2.0.0"
+ object-assign "^4.1.0"
+ signal-exit "^3.0.0"
+ string-width "^1.0.1"
+ strip-ansi "^3.0.1"
+ wide-align "^1.1.0"
+
+gaze@^1.0.0:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/gaze/download/gaze-1.1.2.tgz#847224677adb8870d679257ed3388fdb61e40105"
+ dependencies:
+ globule "^1.0.0"
+
+generate-function@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/generate-function/download/generate-function-2.0.0.tgz#6858fe7c0969b7d4e9093337647ac79f60dfbe74"
+
+generate-object-property@^1.1.0:
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/generate-object-property/download/generate-object-property-1.2.0.tgz#9c0e1c40308ce804f4783618b937fa88f99d50d0"
+ dependencies:
+ is-property "^1.0.0"
+
+get-caller-file@^1.0.1:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/get-caller-file/-/get-caller-file-1.0.2.tgz#f702e63127e7e231c160a80c1554acb70d5047e5"
+
+get-stdin@^4.0.1:
+ version "4.0.1"
+ resolved "http://registry.npm.taobao.org/get-stdin/download/get-stdin-4.0.1.tgz#b968c6b0a04384324902e8bf1a5df32579a450fe"
+
+get-stream@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/get-stream/-/get-stream-3.0.0.tgz#8e943d1358dc37555054ecbe2edb05aa174ede14"
+
+get-value@^2.0.3, get-value@^2.0.6:
+ version "2.0.6"
+ resolved "https://registry.yarnpkg.com/get-value/-/get-value-2.0.6.tgz#dc15ca1c672387ca76bd37ac0a395ba2042a2c28"
+
+getpass@^0.1.1:
+ version "0.1.7"
+ resolved "https://registry.yarnpkg.com/getpass/-/getpass-0.1.7.tgz#5eff8e3e684d569ae4cb2b1282604e8ba62149fa"
+ dependencies:
+ assert-plus "^1.0.0"
+
+glob-base@^0.3.0:
+ version "0.3.0"
+ resolved "http://registry.npm.taobao.org/glob-base/download/glob-base-0.3.0.tgz#dbb164f6221b1c0b1ccf82aea328b497df0ea3c4"
+ dependencies:
+ glob-parent "^2.0.0"
+ is-glob "^2.0.0"
+
+glob-parent@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/glob-parent/download/glob-parent-2.0.0.tgz#81383d72db054fcccf5336daa902f182f6edbb28"
+ dependencies:
+ is-glob "^2.0.0"
+
+glob-parent@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/glob-parent/-/glob-parent-3.1.0.tgz#9e6af6299d8d3bd2bd40430832bd113df906c5ae"
+ dependencies:
+ is-glob "^3.1.0"
+ path-dirname "^1.0.0"
+
+glob@^6.0.4:
+ version "6.0.4"
+ resolved "http://registry.npm.taobao.org/glob/download/glob-6.0.4.tgz#0f08860f6a155127b2fadd4f9ce24b1aab6e4d22"
+ dependencies:
+ inflight "^1.0.4"
+ inherits "2"
+ minimatch "2 || 3"
+ once "^1.3.0"
+ path-is-absolute "^1.0.0"
+
+glob@^7.0.0, glob@^7.0.3, glob@^7.0.5, glob@~7.1.1:
+ version "7.1.2"
+ resolved "https://registry.yarnpkg.com/glob/-/glob-7.1.2.tgz#c19c9df9a028702d678612384a6552404c636d15"
+ dependencies:
+ fs.realpath "^1.0.0"
+ inflight "^1.0.4"
+ inherits "2"
+ minimatch "^3.0.4"
+ once "^1.3.0"
+ path-is-absolute "^1.0.0"
+
+globals@^9.18.0:
+ version "9.18.0"
+ resolved "https://registry.yarnpkg.com/globals/-/globals-9.18.0.tgz#aa3896b3e69b487f17e31ed2143d69a8e30c2d8a"
+
+globby@^6.1.0:
+ version "6.1.0"
+ resolved "http://registry.npm.taobao.org/globby/download/globby-6.1.0.tgz#f5a6d70e8395e21c858fb0489d64df02424d506c"
+ dependencies:
+ array-union "^1.0.1"
+ glob "^7.0.3"
+ object-assign "^4.0.1"
+ pify "^2.0.0"
+ pinkie-promise "^2.0.0"
+
+globule@^1.0.0:
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/globule/download/globule-1.2.0.tgz#1dc49c6822dd9e8a2fa00ba2a295006e8664bd09"
+ dependencies:
+ glob "~7.1.1"
+ lodash "~4.17.4"
+ minimatch "~3.0.2"
+
+graceful-fs@^4.1.2:
+ version "4.1.11"
+ resolved "https://registry.yarnpkg.com/graceful-fs/-/graceful-fs-4.1.11.tgz#0e8bdfe4d1ddb8854d64e04ea7c00e2a026e5658"
+
+handle-thing@^1.2.5:
+ version "1.2.5"
+ resolved "http://registry.npm.taobao.org/handle-thing/download/handle-thing-1.2.5.tgz#fd7aad726bf1a5fd16dfc29b2f7a6601d27139c4"
+
+har-schema@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/har-schema/-/har-schema-1.0.5.tgz#d263135f43307c02c602afc8fe95970c0151369e"
+
+har-schema@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/har-schema/download/har-schema-2.0.0.tgz#a94c2224ebcac04782a0d9035521f24735b7ec92"
+
+har-validator@~2.0.6:
+ version "2.0.6"
+ resolved "http://registry.npm.taobao.org/har-validator/download/har-validator-2.0.6.tgz#cdcbc08188265ad119b6a5a7c8ab70eecfb5d27d"
+ dependencies:
+ chalk "^1.1.1"
+ commander "^2.9.0"
+ is-my-json-valid "^2.12.4"
+ pinkie-promise "^2.0.0"
+
+har-validator@~4.2.1:
+ version "4.2.1"
+ resolved "https://registry.yarnpkg.com/har-validator/-/har-validator-4.2.1.tgz#33481d0f1bbff600dd203d75812a6a5fba002e2a"
+ dependencies:
+ ajv "^4.9.1"
+ har-schema "^1.0.5"
+
+har-validator@~5.0.3:
+ version "5.0.3"
+ resolved "http://registry.npm.taobao.org/har-validator/download/har-validator-5.0.3.tgz#ba402c266194f15956ef15e0fcf242993f6a7dfd"
+ dependencies:
+ ajv "^5.1.0"
+ har-schema "^2.0.0"
+
+has-ansi@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/has-ansi/-/has-ansi-2.0.0.tgz#34f5049ce1ecdf2b0649af3ef24e45ed35416d91"
+ dependencies:
+ ansi-regex "^2.0.0"
+
+has-flag@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-1.0.0.tgz#9d9e793165ce017a00f00418c43f942a7b1d11fa"
+
+has-flag@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-2.0.0.tgz#e8207af1cc7b30d446cc70b734b5e8be18f88d51"
+
+has-flag@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/has-flag/-/has-flag-3.0.0.tgz#b5d454dc2199ae225699f3467e5a07f3b955bafd"
+
+has-unicode@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/has-unicode/-/has-unicode-2.0.1.tgz#e0e6fe6a28cf51138855e086d1691e771de2a8b9"
+
+has-value@^0.3.1:
+ version "0.3.1"
+ resolved "https://registry.yarnpkg.com/has-value/-/has-value-0.3.1.tgz#7b1f58bada62ca827ec0a2078025654845995e1f"
+ dependencies:
+ get-value "^2.0.3"
+ has-values "^0.1.4"
+ isobject "^2.0.0"
+
+has-value@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/has-value/-/has-value-1.0.0.tgz#18b281da585b1c5c51def24c930ed29a0be6b177"
+ dependencies:
+ get-value "^2.0.6"
+ has-values "^1.0.0"
+ isobject "^3.0.0"
+
+has-values@^0.1.4:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/has-values/-/has-values-0.1.4.tgz#6d61de95d91dfca9b9a02089ad384bff8f62b771"
+
+has-values@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/has-values/-/has-values-1.0.0.tgz#95b0b63fec2146619a6fe57fe75628d5a39efe4f"
+ dependencies:
+ is-number "^3.0.0"
+ kind-of "^4.0.0"
+
+has@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/has/-/has-1.0.1.tgz#8461733f538b0837c9361e39a9ab9e9704dc2f28"
+ dependencies:
+ function-bind "^1.0.2"
+
+hash-base@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-2.0.2.tgz#66ea1d856db4e8a5470cadf6fce23ae5244ef2e1"
+ dependencies:
+ inherits "^2.0.1"
+
+hash-base@^3.0.0:
+ version "3.0.4"
+ resolved "https://registry.yarnpkg.com/hash-base/-/hash-base-3.0.4.tgz#5fc8686847ecd73499403319a6b0a3f3f6ae4918"
+ dependencies:
+ inherits "^2.0.1"
+ safe-buffer "^5.0.1"
+
+hash.js@^1.0.0, hash.js@^1.0.3:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/hash.js/-/hash.js-1.1.3.tgz#340dedbe6290187151c1ea1d777a3448935df846"
+ dependencies:
+ inherits "^2.0.3"
+ minimalistic-assert "^1.0.0"
+
[email protected], hawk@~3.1.3:
+ version "3.1.3"
+ resolved "https://registry.yarnpkg.com/hawk/-/hawk-3.1.3.tgz#078444bd7c1640b0fe540d2c9b73d59678e8e1c4"
+ dependencies:
+ boom "2.x.x"
+ cryptiles "2.x.x"
+ hoek "2.x.x"
+ sntp "1.x.x"
+
+hawk@~6.0.2:
+ version "6.0.2"
+ resolved "http://registry.npm.taobao.org/hawk/download/hawk-6.0.2.tgz#af4d914eb065f9b5ce4d9d11c1cb2126eecc3038"
+ dependencies:
+ boom "4.x.x"
+ cryptiles "3.x.x"
+ hoek "4.x.x"
+ sntp "2.x.x"
+
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/he/-/he-1.1.1.tgz#93410fd21b009735151f8868c2f271f3427e23fd"
+
+history@^4.7.2:
+ version "4.7.2"
+ resolved "http://registry.npm.taobao.org/history/download/history-4.7.2.tgz#22b5c7f31633c5b8021c7f4a8a954ac139ee8d5b"
+ dependencies:
+ invariant "^2.2.1"
+ loose-envify "^1.2.0"
+ resolve-pathname "^2.2.0"
+ value-equal "^0.4.0"
+ warning "^3.0.0"
+
+hmac-drbg@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/hmac-drbg/-/hmac-drbg-1.0.1.tgz#d2745701025a6c775a6c545793ed502fc0c649a1"
+ dependencies:
+ hash.js "^1.0.3"
+ minimalistic-assert "^1.0.0"
+ minimalistic-crypto-utils "^1.0.1"
+
+ version "2.16.3"
+ resolved "https://registry.yarnpkg.com/hoek/-/hoek-2.16.3.tgz#20bb7403d3cea398e91dc4710a8ff1b8274a25ed"
+
+ version "4.2.1"
+ resolved "http://registry.npm.taobao.org/hoek/download/hoek-4.2.1.tgz#9634502aa12c445dd5a7c5734b572bb8738aacbb"
+
+hoist-non-react-statics@^2.3.0:
+ version "2.5.0"
+ resolved "http://registry.npm.taobao.org/hoist-non-react-statics/download/hoist-non-react-statics-2.5.0.tgz#d2ca2dfc19c5a91c5a6615ce8e564ef0347e2a40"
+
+home-or-tmp@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/home-or-tmp/-/home-or-tmp-2.0.0.tgz#e36c3f2d2cae7d746a857e38d18d5f32a7882db8"
+ dependencies:
+ os-homedir "^1.0.0"
+ os-tmpdir "^1.0.1"
+
+hosted-git-info@^2.1.4:
+ version "2.6.0"
+ resolved "https://registry.yarnpkg.com/hosted-git-info/-/hosted-git-info-2.6.0.tgz#23235b29ab230c576aab0d4f13fc046b0b038222"
+
+hpack.js@^2.1.6:
+ version "2.1.6"
+ resolved "http://registry.npm.taobao.org/hpack.js/download/hpack.js-2.1.6.tgz#87774c0949e513f42e84575b3c45681fade2a0b2"
+ dependencies:
+ inherits "^2.0.1"
+ obuf "^1.0.0"
+ readable-stream "^2.0.1"
+ wbuf "^1.1.0"
+
+html-comment-regex@^1.1.0:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/html-comment-regex/-/html-comment-regex-1.1.1.tgz#668b93776eaae55ebde8f3ad464b307a4963625e"
+
+html-entities@^1.2.0:
+ version "1.2.1"
+ resolved "http://registry.npm.taobao.org/html-entities/download/html-entities-1.2.1.tgz#0df29351f0721163515dfb9e5543e5f6eed5162f"
+
+html-minifier@^3.2.3:
+ version "3.5.10"
+ resolved "https://registry.yarnpkg.com/html-minifier/-/html-minifier-3.5.10.tgz#8522c772c388db81aa5c26f62033302d906ea1c7"
+ dependencies:
+ camel-case "3.0.x"
+ clean-css "4.1.x"
+ commander "2.14.x"
+ he "1.1.x"
+ ncname "1.0.x"
+ param-case "2.1.x"
+ relateurl "0.2.x"
+ uglify-js "3.3.x"
+
+ version "2.30.1"
+ resolved "https://registry.yarnpkg.com/html-webpack-plugin/-/html-webpack-plugin-2.30.1.tgz#7f9c421b7ea91ec460f56527d78df484ee7537d5"
+ dependencies:
+ bluebird "^3.4.7"
+ html-minifier "^3.2.3"
+ loader-utils "^0.2.16"
+ lodash "^4.17.3"
+ pretty-error "^2.0.2"
+ toposort "^1.0.0"
+
+htmlparser2@~3.3.0:
+ version "3.3.0"
+ resolved "https://registry.yarnpkg.com/htmlparser2/-/htmlparser2-3.3.0.tgz#cc70d05a59f6542e43f0e685c982e14c924a9efe"
+ dependencies:
+ domelementtype "1"
+ domhandler "2.1"
+ domutils "1.1"
+ readable-stream "1.0"
+
+http-deceiver@^1.2.7:
+ version "1.2.7"
+ resolved "http://registry.npm.taobao.org/http-deceiver/download/http-deceiver-1.2.7.tgz#fa7168944ab9a519d337cb0bec7284dc3e723d87"
+
[email protected], http-errors@~1.6.2:
+ version "1.6.2"
+ resolved "http://registry.npm.taobao.org/http-errors/download/http-errors-1.6.2.tgz#0a002cc85707192a7e7946ceedc11155f60ec736"
+ dependencies:
+ depd "1.1.1"
+ inherits "2.0.3"
+ setprototypeof "1.0.3"
+ statuses ">= 1.3.1 < 2"
+
+http-parser-js@>=0.4.0:
+ version "0.4.11"
+ resolved "http://registry.npm.taobao.org/http-parser-js/download/http-parser-js-0.4.11.tgz#5b720849c650903c27e521633d94696ee95f3529"
+
+http-proxy-middleware@~0.17.4:
+ version "0.17.4"
+ resolved "http://registry.npm.taobao.org/http-proxy-middleware/download/http-proxy-middleware-0.17.4.tgz#642e8848851d66f09d4f124912846dbaeb41b833"
+ dependencies:
+ http-proxy "^1.16.2"
+ is-glob "^3.1.0"
+ lodash "^4.17.2"
+ micromatch "^2.3.11"
+
+http-proxy@^1.16.2:
+ version "1.16.2"
+ resolved "http://registry.npm.taobao.org/http-proxy/download/http-proxy-1.16.2.tgz#06dff292952bf64dbe8471fa9df73066d4f37742"
+ dependencies:
+ eventemitter3 "1.x.x"
+ requires-port "1.x.x"
+
+http-signature@~1.1.0:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/http-signature/-/http-signature-1.1.1.tgz#df72e267066cd0ac67fb76adf8e134a8fbcf91bf"
+ dependencies:
+ assert-plus "^0.2.0"
+ jsprim "^1.2.2"
+ sshpk "^1.7.0"
+
+http-signature@~1.2.0:
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/http-signature/download/http-signature-1.2.0.tgz#9aecd925114772f3d95b65a60abb8f7c18fbace1"
+ dependencies:
+ assert-plus "^1.0.0"
+ jsprim "^1.2.2"
+ sshpk "^1.7.0"
+
+https-browserify@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/https-browserify/-/https-browserify-1.0.0.tgz#ec06c10e0a34c0f2faf199f7fd7fc78fffd03c73"
+
[email protected], iconv-lite@~0.4.13:
+ version "0.4.19"
+ resolved "https://registry.yarnpkg.com/iconv-lite/-/iconv-lite-0.4.19.tgz#f7468f60135f5e5dad3399c0a81be9a1603a082b"
+
+icss-replace-symbols@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/icss-replace-symbols/-/icss-replace-symbols-1.1.0.tgz#06ea6f83679a7749e386cfe1fe812ae5db223ded"
+
+icss-utils@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/icss-utils/-/icss-utils-2.1.0.tgz#83f0a0ec378bf3246178b6c2ad9136f135b1c962"
+ dependencies:
+ postcss "^6.0.1"
+
+ieee754@^1.1.4:
+ version "1.1.8"
+ resolved "https://registry.yarnpkg.com/ieee754/-/ieee754-1.1.8.tgz#be33d40ac10ef1926701f6f08a2d86fbfd1ad3e4"
+
+import-local@^0.1.1:
+ version "0.1.1"
+ resolved "http://registry.npm.taobao.org/import-local/download/import-local-0.1.1.tgz#b1179572aacdc11c6a91009fb430dbcab5f668a8"
+ dependencies:
+ pkg-dir "^2.0.0"
+ resolve-cwd "^2.0.0"
+
+in-publish@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/in-publish/download/in-publish-2.0.0.tgz#e20ff5e3a2afc2690320b6dc552682a9c7fadf51"
+
+indent-string@^2.1.0:
+ version "2.1.0"
+ resolved "http://registry.npm.taobao.org/indent-string/download/indent-string-2.1.0.tgz#8e2d48348742121b4a8218b7a137e9a52049dc80"
+ dependencies:
+ repeating "^2.0.0"
+
+indexes-of@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/indexes-of/-/indexes-of-1.0.1.tgz#f30f716c8e2bd346c7b67d3df3915566a7c05607"
+
+ version "0.0.1"
+ resolved "https://registry.yarnpkg.com/indexof/-/indexof-0.0.1.tgz#82dc336d232b9062179d05ab3293a66059fd435d"
+
+inflight@^1.0.4:
+ version "1.0.6"
+ resolved "https://registry.yarnpkg.com/inflight/-/inflight-1.0.6.tgz#49bd6331d7d02d0c09bc910a1075ba8165b56df9"
+ dependencies:
+ once "^1.3.0"
+ wrappy "1"
+
+inherits@2, [email protected], inherits@^2.0.1, inherits@^2.0.3, inherits@~2.0.0, inherits@~2.0.1, inherits@~2.0.3:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.3.tgz#633c2c83e3da42a502f52466022480f4208261de"
+
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/inherits/-/inherits-2.0.1.tgz#b17d08d326b4423e568eff719f91b0b1cbdf69f1"
+
+ini@~1.3.0:
+ version "1.3.5"
+ resolved "https://registry.yarnpkg.com/ini/-/ini-1.3.5.tgz#eee25f56db1c9ec6085e0c22778083f596abf927"
+
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/internal-ip/download/internal-ip-1.2.0.tgz#ae9fbf93b984878785d50a8de1b356956058cf5c"
+ dependencies:
+ meow "^3.3.0"
+
+interpret@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/interpret/-/interpret-1.1.0.tgz#7ed1b1410c6a0e0f78cf95d3b8440c63f78b8614"
+
+invariant@^2.2.1:
+ version "2.2.4"
+ resolved "http://registry.npm.taobao.org/invariant/download/invariant-2.2.4.tgz#610f3c92c9359ce1db616e538008d23ff35158e6"
+ dependencies:
+ loose-envify "^1.0.0"
+
+invariant@^2.2.2:
+ version "2.2.3"
+ resolved "https://registry.yarnpkg.com/invariant/-/invariant-2.2.3.tgz#1a827dfde7dcbd7c323f0ca826be8fa7c5e9d688"
+ dependencies:
+ loose-envify "^1.0.0"
+
+invert-kv@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/invert-kv/-/invert-kv-1.0.0.tgz#104a8e4aaca6d3d8cd157a8ef8bfab2d7a3ffdb6"
+
+ip@^1.1.0, ip@^1.1.5:
+ version "1.1.5"
+ resolved "http://registry.npm.taobao.org/ip/download/ip-1.1.5.tgz#bdded70114290828c0a039e72ef25f5aaec4354a"
+
+ version "1.6.0"
+ resolved "http://registry.npm.taobao.org/ipaddr.js/download/ipaddr.js-1.6.0.tgz#e3fa357b773da619f26e95f049d055c72796f86b"
+
+is-absolute-url@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/is-absolute-url/-/is-absolute-url-2.1.0.tgz#50530dfb84fcc9aa7dbe7852e83a37b93b9f2aa6"
+
+is-accessor-descriptor@^0.1.6:
+ version "0.1.6"
+ resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz#a9e12cb3ae8d876727eeef3843f8a0897b5c98d6"
+ dependencies:
+ kind-of "^3.0.2"
+
+is-accessor-descriptor@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz#169c2f6d3df1f992618072365c9b0ea1f6878656"
+ dependencies:
+ kind-of "^6.0.0"
+
+is-arrayish@^0.2.1:
+ version "0.2.1"
+ resolved "https://registry.yarnpkg.com/is-arrayish/-/is-arrayish-0.2.1.tgz#77c99840527aa8ecb1a8ba697b80645a7a926a9d"
+
+is-binary-path@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/is-binary-path/-/is-binary-path-1.0.1.tgz#75f16642b480f187a711c814161fd3a4a7655898"
+ dependencies:
+ binary-extensions "^1.0.0"
+
+is-buffer@^1.0.2, is-buffer@^1.1.5:
+ version "1.1.6"
+ resolved "https://registry.yarnpkg.com/is-buffer/-/is-buffer-1.1.6.tgz#efaa2ea9daa0d7ab2ea13a97b2b8ad51fefbe8be"
+
+is-builtin-module@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/is-builtin-module/-/is-builtin-module-1.0.0.tgz#540572d34f7ac3119f8f76c30cbc1b1e037affbe"
+ dependencies:
+ builtin-modules "^1.0.0"
+
+is-callable@^1.1.1, is-callable@^1.1.3:
+ version "1.1.3"
+ resolved "http://registry.npm.taobao.org/is-callable/download/is-callable-1.1.3.tgz#86eb75392805ddc33af71c92a0eedf74ee7604b2"
+
+is-data-descriptor@^0.1.4:
+ version "0.1.4"
+ resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz#0b5ee648388e2c860282e793f1856fec3f301b56"
+ dependencies:
+ kind-of "^3.0.2"
+
+is-data-descriptor@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz#d84876321d0e7add03990406abbbbd36ba9268c7"
+ dependencies:
+ kind-of "^6.0.0"
+
+is-date-object@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/is-date-object/download/is-date-object-1.0.1.tgz#9aa20eb6aeebbff77fbd33e74ca01b33581d3a16"
+
+is-descriptor@^0.1.0:
+ version "0.1.6"
+ resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-0.1.6.tgz#366d8240dde487ca51823b1ab9f07a10a78251ca"
+ dependencies:
+ is-accessor-descriptor "^0.1.6"
+ is-data-descriptor "^0.1.4"
+ kind-of "^5.0.0"
+
+is-descriptor@^1.0.0, is-descriptor@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/is-descriptor/-/is-descriptor-1.0.2.tgz#3b159746a66604b04f8c81524ba365c5f14d86ec"
+ dependencies:
+ is-accessor-descriptor "^1.0.0"
+ is-data-descriptor "^1.0.0"
+ kind-of "^6.0.2"
+
+is-dotfile@^1.0.0:
+ version "1.0.3"
+ resolved "http://registry.npm.taobao.org/is-dotfile/download/is-dotfile-1.0.3.tgz#a6a2f32ffd2dfb04f5ca25ecd0f6b83cf798a1e1"
+
+is-equal-shallow@^0.1.3:
+ version "0.1.3"
+ resolved "http://registry.npm.taobao.org/is-equal-shallow/download/is-equal-shallow-0.1.3.tgz#2238098fc221de0bcfa5d9eac4c45d638aa1c534"
+ dependencies:
+ is-primitive "^2.0.0"
+
+is-extendable@^0.1.0, is-extendable@^0.1.1:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-0.1.1.tgz#62b110e289a471418e3ec36a617d472e301dfc89"
+
+is-extendable@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/is-extendable/-/is-extendable-1.0.1.tgz#a7470f9e426733d81bd81e1155264e3a3507cab4"
+ dependencies:
+ is-plain-object "^2.0.4"
+
+is-extglob@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/is-extglob/download/is-extglob-1.0.0.tgz#ac468177c4943405a092fc8f29760c6ffc6206c0"
+
+is-extglob@^2.1.0, is-extglob@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/is-extglob/-/is-extglob-2.1.1.tgz#a88c02535791f02ed37c76a1b9ea9773c833f8c2"
+
+is-finite@^1.0.0:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/is-finite/-/is-finite-1.0.2.tgz#cc6677695602be550ef11e8b4aa6305342b6d0aa"
+ dependencies:
+ number-is-nan "^1.0.0"
+
+is-fullwidth-code-point@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz#ef9e31386f031a7f0d643af82fde50c457ef00cb"
+ dependencies:
+ number-is-nan "^1.0.0"
+
+is-fullwidth-code-point@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz#a3b30a5c4f199183167aaab93beefae3ddfb654f"
+
+is-glob@^2.0.0, is-glob@^2.0.1:
+ version "2.0.1"
+ resolved "http://registry.npm.taobao.org/is-glob/download/is-glob-2.0.1.tgz#d096f926a3ded5600f3fdfd91198cb0888c2d863"
+ dependencies:
+ is-extglob "^1.0.0"
+
+is-glob@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-3.1.0.tgz#7ba5ae24217804ac70707b96922567486cc3e84a"
+ dependencies:
+ is-extglob "^2.1.0"
+
+is-glob@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/is-glob/-/is-glob-4.0.0.tgz#9521c76845cc2610a85203ddf080a958c2ffabc0"
+ dependencies:
+ is-extglob "^2.1.1"
+
+is-my-ip-valid@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/is-my-ip-valid/download/is-my-ip-valid-1.0.0.tgz#7b351b8e8edd4d3995d4d066680e664d94696824"
+
+is-my-json-valid@^2.12.4:
+ version "2.17.2"
+ resolved "http://registry.npm.taobao.org/is-my-json-valid/download/is-my-json-valid-2.17.2.tgz#6b2103a288e94ef3de5cf15d29dd85fc4b78d65c"
+ dependencies:
+ generate-function "^2.0.0"
+ generate-object-property "^1.1.0"
+ is-my-ip-valid "^1.0.0"
+ jsonpointer "^4.0.0"
+ xtend "^4.0.0"
+
+is-number@^2.1.0:
+ version "2.1.0"
+ resolved "http://registry.npm.taobao.org/is-number/download/is-number-2.1.0.tgz#01fcbbb393463a548f2f466cce16dece49db908f"
+ dependencies:
+ kind-of "^3.0.2"
+
+is-number@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/is-number/-/is-number-3.0.0.tgz#24fd6201a4782cf50561c810276afc7d12d71195"
+ dependencies:
+ kind-of "^3.0.2"
+
+is-number@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/is-number/-/is-number-4.0.0.tgz#0026e37f5454d73e356dfe6564699867c6a7f0ff"
+
+is-odd@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/is-odd/-/is-odd-2.0.0.tgz#7646624671fd7ea558ccd9a2795182f2958f1b24"
+ dependencies:
+ is-number "^4.0.0"
+
+is-path-cwd@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/is-path-cwd/download/is-path-cwd-1.0.0.tgz#d225ec23132e89edd38fda767472e62e65f1106d"
+
+is-path-in-cwd@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/is-path-in-cwd/download/is-path-in-cwd-1.0.0.tgz#6477582b8214d602346094567003be8a9eac04dc"
+ dependencies:
+ is-path-inside "^1.0.0"
+
+is-path-inside@^1.0.0:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/is-path-inside/download/is-path-inside-1.0.1.tgz#8ef5b7de50437a3fdca6b4e865ef7aa55cb48036"
+ dependencies:
+ path-is-inside "^1.0.1"
+
+is-plain-obj@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/is-plain-obj/-/is-plain-obj-1.1.0.tgz#71a50c8429dfca773c92a390a4a03b39fcd51d3e"
+
+is-plain-object@^2.0.1, is-plain-object@^2.0.3, is-plain-object@^2.0.4:
+ version "2.0.4"
+ resolved "https://registry.yarnpkg.com/is-plain-object/-/is-plain-object-2.0.4.tgz#2c163b3fafb1b606d9d17928f05c2a1c38e07677"
+ dependencies:
+ isobject "^3.0.1"
+
+is-posix-bracket@^0.1.0:
+ version "0.1.1"
+ resolved "http://registry.npm.taobao.org/is-posix-bracket/download/is-posix-bracket-0.1.1.tgz#3334dc79774368e92f016e6fbc0a88f5cd6e6bc4"
+
+is-primitive@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/is-primitive/download/is-primitive-2.0.0.tgz#207bab91638499c07b2adf240a41a87210034575"
+
+is-property@^1.0.0:
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/is-property/download/is-property-1.0.2.tgz#57fe1c4e48474edd65b09911f26b1cd4095dda84"
+
+is-regex@^1.0.4:
+ version "1.0.4"
+ resolved "http://registry.npm.taobao.org/is-regex/download/is-regex-1.0.4.tgz#5517489b547091b0930e095654ced25ee97e9491"
+ dependencies:
+ has "^1.0.1"
+
+is-stream@^1.0.1, is-stream@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/is-stream/-/is-stream-1.1.0.tgz#12d4a3dd4e68e0b79ceb8dbc84173ae80d91ca44"
+
+is-svg@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/is-svg/-/is-svg-2.1.0.tgz#cf61090da0d9efbcab8722deba6f032208dbb0e9"
+ dependencies:
+ html-comment-regex "^1.1.0"
+
+is-symbol@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/is-symbol/download/is-symbol-1.0.1.tgz#3cc59f00025194b6ab2e38dbae6689256b660572"
+
+is-typedarray@~1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/is-typedarray/-/is-typedarray-1.0.0.tgz#e479c80858df0c1b11ddda6940f96011fcda4a9a"
+
+is-utf8@^0.2.0:
+ version "0.2.1"
+ resolved "http://registry.npm.taobao.org/is-utf8/download/is-utf8-0.2.1.tgz#4b0da1442104d1b336340e80797e865cf39f7d72"
+
+is-windows@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/is-windows/-/is-windows-1.0.2.tgz#d1850eb9791ecd18e6182ce12a30f396634bb19d"
+
+is-wsl@^1.1.0:
+ version "1.1.0"
+ resolved "http://registry.npm.taobao.org/is-wsl/download/is-wsl-1.1.0.tgz#1f16e4aa22b04d1336b66188a66af3c600c3a66d"
+
+ version "0.0.1"
+ resolved "https://registry.yarnpkg.com/isarray/-/isarray-0.0.1.tgz#8a18acfca9a8f4177e09abfc6038939b05d1eedf"
+
[email protected], isarray@^1.0.0, isarray@~1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/isarray/-/isarray-1.0.0.tgz#bb935d48582cba168c06834957a54a3e07124f11"
+
+isexe@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/isexe/-/isexe-2.0.0.tgz#e8fbf374dc556ff8947a10dcb0572d633f2cfa10"
+
+isobject@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/isobject/-/isobject-2.1.0.tgz#f065561096a3f1da2ef46272f815c840d87e0c89"
+ dependencies:
+ isarray "1.0.0"
+
+isobject@^3.0.0, isobject@^3.0.1:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/isobject/-/isobject-3.0.1.tgz#4e431e92b11a9731636aa1f9c8d1ccbcfdab78df"
+
+isomorphic-fetch@^2.1.1:
+ version "2.2.1"
+ resolved "https://registry.yarnpkg.com/isomorphic-fetch/-/isomorphic-fetch-2.2.1.tgz#611ae1acf14f5e81f729507472819fe9733558a9"
+ dependencies:
+ node-fetch "^1.0.1"
+ whatwg-fetch ">=0.10.0"
+
+isstream@~0.1.2:
+ version "0.1.2"
+ resolved "https://registry.yarnpkg.com/isstream/-/isstream-0.1.2.tgz#47e63f7af55afa6f92e1500e690eb8b8529c099a"
+
+js-base64@^2.1.8, js-base64@^2.1.9:
+ version "2.4.3"
+ resolved "https://registry.yarnpkg.com/js-base64/-/js-base64-2.4.3.tgz#2e545ec2b0f2957f41356510205214e98fad6582"
+
+js-tokens@^3.0.0, js-tokens@^3.0.2:
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/js-tokens/-/js-tokens-3.0.2.tgz#9866df395102130e38f7f996bceb65443209c25b"
+
+js-yaml@~3.7.0:
+ version "3.7.0"
+ resolved "https://registry.yarnpkg.com/js-yaml/-/js-yaml-3.7.0.tgz#5c967ddd837a9bfdca5f2de84253abe8a1c03b80"
+ dependencies:
+ argparse "^1.0.7"
+ esprima "^2.6.0"
+
+jsbn@~0.1.0:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/jsbn/-/jsbn-0.1.1.tgz#a5e654c2e5a2deb5f201d96cefbca80c0ef2f513"
+
+jsesc@^1.3.0:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-1.3.0.tgz#46c3fec8c1892b12b0833db9bc7622176dbab34b"
+
+jsesc@~0.5.0:
+ version "0.5.0"
+ resolved "https://registry.yarnpkg.com/jsesc/-/jsesc-0.5.0.tgz#e7dee66e35d6fc16f710fe91d5cf69f70f08911d"
+
+json-loader@^0.5.4:
+ version "0.5.7"
+ resolved "https://registry.yarnpkg.com/json-loader/-/json-loader-0.5.7.tgz#dca14a70235ff82f0ac9a3abeb60d337a365185d"
+
+json-schema-traverse@^0.3.0:
+ version "0.3.1"
+ resolved "https://registry.yarnpkg.com/json-schema-traverse/-/json-schema-traverse-0.3.1.tgz#349a6d44c53a51de89b40805c5d5e59b417d3340"
+
+ version "0.2.3"
+ resolved "https://registry.yarnpkg.com/json-schema/-/json-schema-0.2.3.tgz#b480c892e59a2f05954ce727bd3f2a4e882f9e13"
+
+json-stable-stringify@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz#9a759d39c5f2ff503fd5300646ed445f88c4f9af"
+ dependencies:
+ jsonify "~0.0.0"
+
+json-stringify-safe@~5.0.1:
+ version "5.0.1"
+ resolved "https://registry.yarnpkg.com/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz#1296a2d58fd45f19a0f6ce01d65701e2c735b6eb"
+
+json3@^3.3.2:
+ version "3.3.2"
+ resolved "http://registry.npm.taobao.org/json3/download/json3-3.3.2.tgz#3c0434743df93e2f5c42aee7b19bcb483575f4e1"
+
+json5@^0.5.0, json5@^0.5.1:
+ version "0.5.1"
+ resolved "https://registry.yarnpkg.com/json5/-/json5-0.5.1.tgz#1eade7acc012034ad84e2396767ead9fa5495821"
+
+jsonify@~0.0.0:
+ version "0.0.0"
+ resolved "https://registry.yarnpkg.com/jsonify/-/jsonify-0.0.0.tgz#2c74b6ee41d93ca51b7b5aaee8f503631d252a73"
+
+jsonpointer@^4.0.0:
+ version "4.0.1"
+ resolved "http://registry.npm.taobao.org/jsonpointer/download/jsonpointer-4.0.1.tgz#4fd92cb34e0e9db3c89c8622ecf51f9b978c6cb9"
+
+jsprim@^1.2.2:
+ version "1.4.1"
+ resolved "https://registry.yarnpkg.com/jsprim/-/jsprim-1.4.1.tgz#313e66bc1e5cc06e438bc1b7499c2e5c56acb6a2"
+ dependencies:
+ assert-plus "1.0.0"
+ extsprintf "1.3.0"
+ json-schema "0.2.3"
+ verror "1.10.0"
+
+keyboard-key@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/keyboard-key/download/keyboard-key-1.0.1.tgz#a946294fe59ad5431c63a3ea269f023e51fac6aa"
+
+killable@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/killable/download/killable-1.0.0.tgz#da8b84bd47de5395878f95d64d02f2449fe05e6b"
+
+kind-of@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-2.0.1.tgz#018ec7a4ce7e3a86cb9141be519d24c8faa981b5"
+ dependencies:
+ is-buffer "^1.0.2"
+
+kind-of@^3.0.2, kind-of@^3.0.3, kind-of@^3.2.0, kind-of@^3.2.2:
+ version "3.2.2"
+ resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-3.2.2.tgz#31ea21a734bab9bbb0f32466d893aea51e4a3c64"
+ dependencies:
+ is-buffer "^1.1.5"
+
+kind-of@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-4.0.0.tgz#20813df3d712928b207378691a45066fae72dd57"
+ dependencies:
+ is-buffer "^1.1.5"
+
+kind-of@^5.0.0:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-5.1.0.tgz#729c91e2d857b7a419a1f9aa65685c4c33f5845d"
+
+kind-of@^6.0.0, kind-of@^6.0.2:
+ version "6.0.2"
+ resolved "https://registry.yarnpkg.com/kind-of/-/kind-of-6.0.2.tgz#01146b36a6218e64e58f3a8d66de5d7fc6f6d051"
+
+lazy-cache@^0.2.3:
+ version "0.2.7"
+ resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-0.2.7.tgz#7feddf2dcb6edb77d11ef1d117ab5ffdf0ab1b65"
+
+lazy-cache@^1.0.3:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/lazy-cache/-/lazy-cache-1.0.4.tgz#a1d78fc3a50474cb80845d3b3b6e1da49a446e8e"
+
+lcid@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/lcid/-/lcid-1.0.0.tgz#308accafa0bc483a3867b4b6f2b9506251d1b835"
+ dependencies:
+ invert-kv "^1.0.0"
+
+load-json-file@^1.0.0:
+ version "1.1.0"
+ resolved "http://registry.npm.taobao.org/load-json-file/download/load-json-file-1.1.0.tgz#956905708d58b4bab4c2261b04f59f31c99374c0"
+ dependencies:
+ graceful-fs "^4.1.2"
+ parse-json "^2.2.0"
+ pify "^2.0.0"
+ pinkie-promise "^2.0.0"
+ strip-bom "^2.0.0"
+
+load-json-file@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/load-json-file/-/load-json-file-2.0.0.tgz#7947e42149af80d696cbf797bcaabcfe1fe29ca8"
+ dependencies:
+ graceful-fs "^4.1.2"
+ parse-json "^2.2.0"
+ pify "^2.0.0"
+ strip-bom "^3.0.0"
+
+loader-runner@^2.3.0:
+ version "2.3.0"
+ resolved "https://registry.yarnpkg.com/loader-runner/-/loader-runner-2.3.0.tgz#f482aea82d543e07921700d5a46ef26fdac6b8a2"
+
+loader-utils@^0.2.16:
+ version "0.2.17"
+ resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-0.2.17.tgz#f86e6374d43205a6e6c60e9196f17c0299bfb348"
+ dependencies:
+ big.js "^3.1.3"
+ emojis-list "^2.0.0"
+ json5 "^0.5.0"
+ object-assign "^4.0.1"
+
+loader-utils@^1.0.1, loader-utils@^1.0.2, loader-utils@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/loader-utils/-/loader-utils-1.1.0.tgz#c98aef488bcceda2ffb5e2de646d6a754429f5cd"
+ dependencies:
+ big.js "^3.1.3"
+ emojis-list "^2.0.0"
+ json5 "^0.5.0"
+
+locate-path@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/locate-path/-/locate-path-2.0.0.tgz#2b568b265eec944c6d9c0de9c3dbbbca0354cd8e"
+ dependencies:
+ p-locate "^2.0.0"
+ path-exists "^3.0.0"
+
+lodash.assign@^4.2.0:
+ version "4.2.0"
+ resolved "http://registry.npm.taobao.org/lodash.assign/download/lodash.assign-4.2.0.tgz#0d99f3ccd7a6d261d19bdaeb9245005d285808e7"
+
+lodash.camelcase@^4.3.0:
+ version "4.3.0"
+ resolved "https://registry.yarnpkg.com/lodash.camelcase/-/lodash.camelcase-4.3.0.tgz#b28aa6288a2b9fc651035c7711f65ab6190331a6"
+
+lodash.clonedeep@^4.3.2:
+ version "4.5.0"
+ resolved "http://registry.npm.taobao.org/lodash.clonedeep/download/lodash.clonedeep-4.5.0.tgz#e23f3f9c4f8fbdde872529c1071857a086e5ccef"
+
+lodash.memoize@^4.1.2:
+ version "4.1.2"
+ resolved "https://registry.yarnpkg.com/lodash.memoize/-/lodash.memoize-4.1.2.tgz#bcc6c49a42a2840ed997f323eada5ecd182e0bfe"
+
+lodash.mergewith@^4.6.0:
+ version "4.6.1"
+ resolved "http://registry.npm.taobao.org/lodash.mergewith/download/lodash.mergewith-4.6.1.tgz#639057e726c3afbdb3e7d42741caa8d6e4335927"
+
+lodash.tail@^4.1.1:
+ version "4.1.1"
+ resolved "https://registry.yarnpkg.com/lodash.tail/-/lodash.tail-4.1.1.tgz#d2333a36d9e7717c8ad2f7cacafec7c32b444664"
+
+lodash.uniq@^4.5.0:
+ version "4.5.0"
+ resolved "https://registry.yarnpkg.com/lodash.uniq/-/lodash.uniq-4.5.0.tgz#d0225373aeb652adc1bc82e4945339a842754773"
+
+lodash@^4.0.0, lodash@^4.14.0, lodash@^4.17.2, lodash@^4.17.3, lodash@^4.17.4, lodash@~4.17.4:
+ version "4.17.5"
+ resolved "https://registry.yarnpkg.com/lodash/-/lodash-4.17.5.tgz#99a92d65c0272debe8c96b6057bc8fbfa3bed511"
+
+lodash@^4.17.10:
+ version "4.17.10"
+ resolved "http://registry.npm.taobao.org/lodash/download/lodash-4.17.10.tgz#1b7793cf7259ea38fb3661d4d38b3260af8ae4e7"
+
+loglevel@^1.4.1:
+ version "1.6.1"
+ resolved "http://registry.npm.taobao.org/loglevel/download/loglevel-1.6.1.tgz#e0fc95133b6ef276cdc8887cdaf24aa6f156f8fa"
+
+longest@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/longest/-/longest-1.0.1.tgz#30a0b2da38f73770e8294a0d22e6625ed77d0097"
+
+loose-envify@^1.0.0, loose-envify@^1.1.0, loose-envify@^1.2.0, loose-envify@^1.3.1:
+ version "1.3.1"
+ resolved "https://registry.yarnpkg.com/loose-envify/-/loose-envify-1.3.1.tgz#d1a8ad33fa9ce0e713d65fdd0ac8b748d478c848"
+ dependencies:
+ js-tokens "^3.0.0"
+
+loud-rejection@^1.0.0:
+ version "1.6.0"
+ resolved "http://registry.npm.taobao.org/loud-rejection/download/loud-rejection-1.6.0.tgz#5b46f80147edee578870f086d04821cf998e551f"
+ dependencies:
+ currently-unhandled "^0.4.1"
+ signal-exit "^3.0.0"
+
+lower-case@^1.1.1:
+ version "1.1.4"
+ resolved "https://registry.yarnpkg.com/lower-case/-/lower-case-1.1.4.tgz#9a2cabd1b9e8e0ae993a4bf7d5875c39c42e8eac"
+
+lru-cache@^4.0.1:
+ version "4.1.2"
+ resolved "https://registry.yarnpkg.com/lru-cache/-/lru-cache-4.1.2.tgz#45234b2e6e2f2b33da125624c4664929a0224c3f"
+ dependencies:
+ pseudomap "^1.0.2"
+ yallist "^2.1.2"
+
+macaddress@^0.2.8:
+ version "0.2.8"
+ resolved "https://registry.yarnpkg.com/macaddress/-/macaddress-0.2.8.tgz#5904dc537c39ec6dbefeae902327135fa8511f12"
+
+make-dir@^1.0.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/make-dir/-/make-dir-1.2.0.tgz#6d6a49eead4aae296c53bbf3a1a008bd6c89469b"
+ dependencies:
+ pify "^3.0.0"
+
+map-cache@^0.2.2:
+ version "0.2.2"
+ resolved "https://registry.yarnpkg.com/map-cache/-/map-cache-0.2.2.tgz#c32abd0bd6525d9b051645bb4f26ac5dc98a0dbf"
+
+map-obj@^1.0.0, map-obj@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/map-obj/download/map-obj-1.0.1.tgz#d933ceb9205d82bdcf4886f6742bdc2b4dea146d"
+
+map-visit@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/map-visit/-/map-visit-1.0.0.tgz#ecdca8f13144e660f1b5bd41f12f3479d98dfb8f"
+ dependencies:
+ object-visit "^1.0.0"
+
+math-expression-evaluator@^1.2.14:
+ version "1.2.17"
+ resolved "https://registry.yarnpkg.com/math-expression-evaluator/-/math-expression-evaluator-1.2.17.tgz#de819fdbcd84dccd8fae59c6aeb79615b9d266ac"
+
+md5.js@^1.3.4:
+ version "1.3.4"
+ resolved "https://registry.yarnpkg.com/md5.js/-/md5.js-1.3.4.tgz#e9bdbde94a20a5ac18b04340fc5764d5b09d901d"
+ dependencies:
+ hash-base "^3.0.0"
+ inherits "^2.0.1"
+
+ version "0.3.0"
+ resolved "http://registry.npm.taobao.org/media-typer/download/media-typer-0.3.0.tgz#8710d7af0aa626f8fffa1ce00168545263255748"
+
+mem@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/mem/-/mem-1.1.0.tgz#5edd52b485ca1d900fe64895505399a0dfa45f76"
+ dependencies:
+ mimic-fn "^1.0.0"
+
+memory-fs@^0.4.0, memory-fs@~0.4.1:
+ version "0.4.1"
+ resolved "https://registry.yarnpkg.com/memory-fs/-/memory-fs-0.4.1.tgz#3a9a20b8462523e447cfbc7e8bb80ed667bfc552"
+ dependencies:
+ errno "^0.1.3"
+ readable-stream "^2.0.1"
+
+meow@^3.3.0, meow@^3.7.0:
+ version "3.7.0"
+ resolved "http://registry.npm.taobao.org/meow/download/meow-3.7.0.tgz#72cb668b425228290abbfa856892587308a801fb"
+ dependencies:
+ camelcase-keys "^2.0.0"
+ decamelize "^1.1.2"
+ loud-rejection "^1.0.0"
+ map-obj "^1.0.1"
+ minimist "^1.1.3"
+ normalize-package-data "^2.3.4"
+ object-assign "^4.0.1"
+ read-pkg-up "^1.0.1"
+ redent "^1.0.0"
+ trim-newlines "^1.0.0"
+
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/merge-descriptors/download/merge-descriptors-1.0.1.tgz#b00aaa556dd8b44568150ec9d1b953f3f90cbb61"
+
+methods@~1.1.2:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/methods/download/methods-1.1.2.tgz#5529a4d67654134edcc5266656835b0f851afcee"
+
+micromatch@^2.1.5, micromatch@^2.3.11:
+ version "2.3.11"
+ resolved "http://registry.npm.taobao.org/micromatch/download/micromatch-2.3.11.tgz#86677c97d1720b363431d04d0d15293bd38c1565"
+ dependencies:
+ arr-diff "^2.0.0"
+ array-unique "^0.2.1"
+ braces "^1.8.2"
+ expand-brackets "^0.1.4"
+ extglob "^0.3.1"
+ filename-regex "^2.0.0"
+ is-extglob "^1.0.0"
+ is-glob "^2.0.1"
+ kind-of "^3.0.2"
+ normalize-path "^2.0.1"
+ object.omit "^2.0.0"
+ parse-glob "^3.0.4"
+ regex-cache "^0.4.2"
+
+micromatch@^3.1.4:
+ version "3.1.9"
+ resolved "https://registry.yarnpkg.com/micromatch/-/micromatch-3.1.9.tgz#15dc93175ae39e52e93087847096effc73efcf89"
+ dependencies:
+ arr-diff "^4.0.0"
+ array-unique "^0.3.2"
+ braces "^2.3.1"
+ define-property "^2.0.2"
+ extend-shallow "^3.0.2"
+ extglob "^2.0.4"
+ fragment-cache "^0.2.1"
+ kind-of "^6.0.2"
+ nanomatch "^1.2.9"
+ object.pick "^1.3.0"
+ regex-not "^1.0.0"
+ snapdragon "^0.8.1"
+ to-regex "^3.0.1"
+
+miller-rabin@^4.0.0:
+ version "4.0.1"
+ resolved "https://registry.yarnpkg.com/miller-rabin/-/miller-rabin-4.0.1.tgz#f080351c865b0dc562a8462966daa53543c78a4d"
+ dependencies:
+ bn.js "^4.0.0"
+ brorand "^1.0.1"
+
+"mime-db@>= 1.33.0 < 2", mime-db@~1.33.0:
+ version "1.33.0"
+ resolved "https://registry.yarnpkg.com/mime-db/-/mime-db-1.33.0.tgz#a3492050a5cb9b63450541e39d9788d2272783db"
+
+mime-types@^2.1.12, mime-types@~2.1.17, mime-types@~2.1.18, mime-types@~2.1.7:
+ version "2.1.18"
+ resolved "https://registry.yarnpkg.com/mime-types/-/mime-types-2.1.18.tgz#6f323f60a83d11146f831ff11fd66e2fe5503bb8"
+ dependencies:
+ mime-db "~1.33.0"
+
+ version "1.4.1"
+ resolved "http://registry.npm.taobao.org/mime/download/mime-1.4.1.tgz#121f9ebc49e3766f311a76e1fa1c8003c4b03aa6"
+
+mime@^1.4.1, mime@^1.5.0:
+ version "1.6.0"
+ resolved "http://registry.npm.taobao.org/mime/download/mime-1.6.0.tgz#32cd9e5c64553bd58d19a568af452acff04981b1"
+
+mimic-fn@^1.0.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/mimic-fn/-/mimic-fn-1.2.0.tgz#820c86a39334640e99516928bd03fca88057d022"
+
+minimalistic-assert@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/minimalistic-assert/-/minimalistic-assert-1.0.0.tgz#702be2dda6b37f4836bcb3f5db56641b64a1d3d3"
+
+minimalistic-crypto-utils@^1.0.0, minimalistic-crypto-utils@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz#f6c00c1c0b082246e5c4d99dfb8c7c083b2b582a"
+
+"minimatch@2 || 3", minimatch@^3.0.0, minimatch@^3.0.2, minimatch@^3.0.4, minimatch@~3.0.2:
+ version "3.0.4"
+ resolved "https://registry.yarnpkg.com/minimatch/-/minimatch-3.0.4.tgz#5166e286457f03306064be5497e8dbb0c3d32083"
+ dependencies:
+ brace-expansion "^1.1.7"
+
+ version "0.0.8"
+ resolved "https://registry.yarnpkg.com/minimist/-/minimist-0.0.8.tgz#857fcabfc3397d2625b8228262e86aa7a011b05d"
+
+minimist@^1.1.3, minimist@^1.2.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/minimist/-/minimist-1.2.0.tgz#a35008b20f41383eec1fb914f4cd5df79a264284"
+
+mixin-deep@^1.2.0:
+ version "1.3.1"
+ resolved "https://registry.yarnpkg.com/mixin-deep/-/mixin-deep-1.3.1.tgz#a49e7268dce1a0d9698e45326c5626df3543d0fe"
+ dependencies:
+ for-in "^1.0.2"
+ is-extendable "^1.0.1"
+
+mixin-object@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/mixin-object/-/mixin-object-2.0.1.tgz#4fb949441dab182540f1fe035ba60e1947a5e57e"
+ dependencies:
+ for-in "^0.1.3"
+ is-extendable "^0.1.1"
+
[email protected], "mkdirp@>=0.5 0", mkdirp@^0.5.0, mkdirp@^0.5.1, mkdirp@~0.5.0, mkdirp@~0.5.1:
+ version "0.5.1"
+ resolved "https://registry.yarnpkg.com/mkdirp/-/mkdirp-0.5.1.tgz#30057438eac6cf7f8c4767f38648d6697d75c903"
+ dependencies:
+ minimist "0.0.8"
+
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/ms/-/ms-2.0.0.tgz#5608aeadfc00be6c2901df5f9861788de0d597c8"
+
+multicast-dns-service-types@^1.1.0:
+ version "1.1.0"
+ resolved "http://registry.npm.taobao.org/multicast-dns-service-types/download/multicast-dns-service-types-1.1.0.tgz#899f11d9686e5e05cb91b35d5f0e63b773cfc901"
+
+multicast-dns@^6.0.1:
+ version "6.2.3"
+ resolved "http://registry.npm.taobao.org/multicast-dns/download/multicast-dns-6.2.3.tgz#a0ec7bd9055c4282f790c3c82f4e28db3b31b229"
+ dependencies:
+ dns-packet "^1.3.1"
+ thunky "^1.0.2"
+
+nan@^2.3.0, nan@^2.3.2:
+ version "2.9.2"
+ resolved "https://registry.yarnpkg.com/nan/-/nan-2.9.2.tgz#f564d75f5f8f36a6d9456cca7a6c4fe488ab7866"
+
+nanomatch@^1.2.9:
+ version "1.2.9"
+ resolved "https://registry.yarnpkg.com/nanomatch/-/nanomatch-1.2.9.tgz#879f7150cb2dab7a471259066c104eee6e0fa7c2"
+ dependencies:
+ arr-diff "^4.0.0"
+ array-unique "^0.3.2"
+ define-property "^2.0.2"
+ extend-shallow "^3.0.2"
+ fragment-cache "^0.2.1"
+ is-odd "^2.0.0"
+ is-windows "^1.0.2"
+ kind-of "^6.0.2"
+ object.pick "^1.3.0"
+ regex-not "^1.0.0"
+ snapdragon "^0.8.1"
+ to-regex "^3.0.1"
+
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/ncname/-/ncname-1.0.0.tgz#5b57ad18b1ca092864ef62b0b1ed8194f383b71c"
+ dependencies:
+ xml-char-classes "^1.0.0"
+
+ version "0.6.1"
+ resolved "http://registry.npm.taobao.org/negotiator/download/negotiator-0.6.1.tgz#2b327184e8992101177b28563fb5e7102acd0ca9"
+
+neo-async@^2.5.0:
+ version "2.5.0"
+ resolved "https://registry.yarnpkg.com/neo-async/-/neo-async-2.5.0.tgz#76b1c823130cca26acfbaccc8fbaf0a2fa33b18f"
+
+no-case@^2.2.0:
+ version "2.3.2"
+ resolved "https://registry.yarnpkg.com/no-case/-/no-case-2.3.2.tgz#60b813396be39b3f1288a4c1ed5d1e7d28b464ac"
+ dependencies:
+ lower-case "^1.1.1"
+
+node-fetch@^1.0.1:
+ version "1.7.3"
+ resolved "https://registry.yarnpkg.com/node-fetch/-/node-fetch-1.7.3.tgz#980f6f72d85211a5347c6b2bc18c5b84c3eb47ef"
+ dependencies:
+ encoding "^0.1.11"
+ is-stream "^1.0.1"
+
+ version "0.7.1"
+ resolved "http://registry.npm.taobao.org/node-forge/download/node-forge-0.7.1.tgz#9da611ea08982f4b94206b3beb4cc9665f20c300"
+
+node-gyp@^3.3.1:
+ version "3.6.2"
+ resolved "http://registry.npm.taobao.org/node-gyp/download/node-gyp-3.6.2.tgz#9bfbe54562286284838e750eac05295853fa1c60"
+ dependencies:
+ fstream "^1.0.0"
+ glob "^7.0.3"
+ graceful-fs "^4.1.2"
+ minimatch "^3.0.2"
+ mkdirp "^0.5.0"
+ nopt "2 || 3"
+ npmlog "0 || 1 || 2 || 3 || 4"
+ osenv "0"
+ request "2"
+ rimraf "2"
+ semver "~5.3.0"
+ tar "^2.0.0"
+ which "1"
+
+node-libs-browser@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/node-libs-browser/-/node-libs-browser-2.1.0.tgz#5f94263d404f6e44767d726901fff05478d600df"
+ dependencies:
+ assert "^1.1.1"
+ browserify-zlib "^0.2.0"
+ buffer "^4.3.0"
+ console-browserify "^1.1.0"
+ constants-browserify "^1.0.0"
+ crypto-browserify "^3.11.0"
+ domain-browser "^1.1.1"
+ events "^1.0.0"
+ https-browserify "^1.0.0"
+ os-browserify "^0.3.0"
+ path-browserify "0.0.0"
+ process "^0.11.10"
+ punycode "^1.2.4"
+ querystring-es3 "^0.2.0"
+ readable-stream "^2.3.3"
+ stream-browserify "^2.0.1"
+ stream-http "^2.7.2"
+ string_decoder "^1.0.0"
+ timers-browserify "^2.0.4"
+ tty-browserify "0.0.0"
+ url "^0.11.0"
+ util "^0.10.3"
+ vm-browserify "0.0.4"
+
+node-pre-gyp@^0.6.39:
+ version "0.6.39"
+ resolved "https://registry.yarnpkg.com/node-pre-gyp/-/node-pre-gyp-0.6.39.tgz#c00e96860b23c0e1420ac7befc5044e1d78d8649"
+ dependencies:
+ detect-libc "^1.0.2"
+ hawk "3.1.3"
+ mkdirp "^0.5.1"
+ nopt "^4.0.1"
+ npmlog "^4.0.2"
+ rc "^1.1.7"
+ request "2.81.0"
+ rimraf "^2.6.1"
+ semver "^5.3.0"
+ tar "^2.2.1"
+ tar-pack "^3.4.0"
+
+ version "4.7.2"
+ resolved "http://registry.npm.taobao.org/node-sass/download/node-sass-4.7.2.tgz#9366778ba1469eb01438a9e8592f4262bcb6794e"
+ dependencies:
+ async-foreach "^0.1.3"
+ chalk "^1.1.1"
+ cross-spawn "^3.0.0"
+ gaze "^1.0.0"
+ get-stdin "^4.0.1"
+ glob "^7.0.3"
+ in-publish "^2.0.0"
+ lodash.assign "^4.2.0"
+ lodash.clonedeep "^4.3.2"
+ lodash.mergewith "^4.6.0"
+ meow "^3.7.0"
+ mkdirp "^0.5.1"
+ nan "^2.3.2"
+ node-gyp "^3.3.1"
+ npmlog "^4.0.0"
+ request "~2.79.0"
+ sass-graph "^2.2.4"
+ stdout-stream "^1.4.0"
+ "true-case-path" "^1.0.2"
+
+"nopt@2 || 3":
+ version "3.0.6"
+ resolved "http://registry.npm.taobao.org/nopt/download/nopt-3.0.6.tgz#c6465dbf08abcd4db359317f79ac68a646b28ff9"
+ dependencies:
+ abbrev "1"
+
+nopt@^4.0.1:
+ version "4.0.1"
+ resolved "https://registry.yarnpkg.com/nopt/-/nopt-4.0.1.tgz#d0d4685afd5415193c8c7505602d0d17cd64474d"
+ dependencies:
+ abbrev "1"
+ osenv "^0.1.4"
+
+normalize-package-data@^2.3.2, normalize-package-data@^2.3.4:
+ version "2.4.0"
+ resolved "https://registry.yarnpkg.com/normalize-package-data/-/normalize-package-data-2.4.0.tgz#12f95a307d58352075a04907b84ac8be98ac012f"
+ dependencies:
+ hosted-git-info "^2.1.4"
+ is-builtin-module "^1.0.0"
+ semver "2 || 3 || 4 || 5"
+ validate-npm-package-license "^3.0.1"
+
+normalize-path@^2.0.0, normalize-path@^2.0.1, normalize-path@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/normalize-path/-/normalize-path-2.1.1.tgz#1ab28b556e198363a8c1a6f7e6fa20137fe6aed9"
+ dependencies:
+ remove-trailing-separator "^1.0.1"
+
+normalize-range@^0.1.2:
+ version "0.1.2"
+ resolved "https://registry.yarnpkg.com/normalize-range/-/normalize-range-0.1.2.tgz#2d10c06bdfd312ea9777695a4d28439456b75942"
+
+normalize-url@^1.4.0:
+ version "1.9.1"
+ resolved "https://registry.yarnpkg.com/normalize-url/-/normalize-url-1.9.1.tgz#2cc0d66b31ea23036458436e3620d85954c66c3c"
+ dependencies:
+ object-assign "^4.0.1"
+ prepend-http "^1.0.0"
+ query-string "^4.1.0"
+ sort-keys "^1.0.0"
+
+npm-run-path@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/npm-run-path/-/npm-run-path-2.0.2.tgz#35a9232dfa35d7067b4cb2ddf2357b1871536c5f"
+ dependencies:
+ path-key "^2.0.0"
+
+"npmlog@0 || 1 || 2 || 3 || 4", npmlog@^4.0.0, npmlog@^4.0.2:
+ version "4.1.2"
+ resolved "https://registry.yarnpkg.com/npmlog/-/npmlog-4.1.2.tgz#08a7f2a8bf734604779a9efa4ad5cc717abb954b"
+ dependencies:
+ are-we-there-yet "~1.1.2"
+ console-control-strings "~1.1.0"
+ gauge "~2.7.3"
+ set-blocking "~2.0.0"
+
+nth-check@~1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/nth-check/-/nth-check-1.0.1.tgz#9929acdf628fc2c41098deab82ac580cf149aae4"
+ dependencies:
+ boolbase "~1.0.0"
+
+num2fraction@^1.2.2:
+ version "1.2.2"
+ resolved "https://registry.yarnpkg.com/num2fraction/-/num2fraction-1.2.2.tgz#6f682b6a027a4e9ddfa4564cd2589d1d4e669ede"
+
+number-is-nan@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/number-is-nan/-/number-is-nan-1.0.1.tgz#097b602b53422a522c1afb8790318336941a011d"
+
+oauth-sign@~0.8.1, oauth-sign@~0.8.2:
+ version "0.8.2"
+ resolved "https://registry.yarnpkg.com/oauth-sign/-/oauth-sign-0.8.2.tgz#46a6ab7f0aead8deae9ec0565780b7d4efeb9d43"
+
+object-assign@^4.0.1, object-assign@^4.1.0, object-assign@^4.1.1:
+ version "4.1.1"
+ resolved "https://registry.yarnpkg.com/object-assign/-/object-assign-4.1.1.tgz#2109adc7965887cfc05cbbd442cac8bfbb360863"
+
+object-copy@^0.1.0:
+ version "0.1.0"
+ resolved "https://registry.yarnpkg.com/object-copy/-/object-copy-0.1.0.tgz#7e7d858b781bd7c991a41ba975ed3812754e998c"
+ dependencies:
+ copy-descriptor "^0.1.0"
+ define-property "^0.2.5"
+ kind-of "^3.0.3"
+
+object-keys@^1.0.8:
+ version "1.0.11"
+ resolved "http://registry.npm.taobao.org/object-keys/download/object-keys-1.0.11.tgz#c54601778ad560f1142ce0e01bcca8b56d13426d"
+
+object-visit@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/object-visit/-/object-visit-1.0.1.tgz#f79c4493af0c5377b59fe39d395e41042dd045bb"
+ dependencies:
+ isobject "^3.0.0"
+
+object.omit@^2.0.0:
+ version "2.0.1"
+ resolved "http://registry.npm.taobao.org/object.omit/download/object.omit-2.0.1.tgz#1a9c744829f39dbb858c76ca3579ae2a54ebd1fa"
+ dependencies:
+ for-own "^0.1.4"
+ is-extendable "^0.1.1"
+
+object.pick@^1.3.0:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/object.pick/-/object.pick-1.3.0.tgz#87a10ac4c1694bd2e1cbf53591a66141fb5dd747"
+ dependencies:
+ isobject "^3.0.1"
+
+obuf@^1.0.0, obuf@^1.1.1:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/obuf/download/obuf-1.1.2.tgz#09bea3343d41859ebd446292d11c9d4db619084e"
+
+on-finished@~2.3.0:
+ version "2.3.0"
+ resolved "http://registry.npm.taobao.org/on-finished/download/on-finished-2.3.0.tgz#20f1336481b083cd75337992a16971aa2d906947"
+ dependencies:
+ ee-first "1.1.1"
+
+on-headers@~1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/on-headers/download/on-headers-1.0.1.tgz#928f5d0f470d49342651ea6794b0857c100693f7"
+
+once@^1.3.0, once@^1.3.3:
+ version "1.4.0"
+ resolved "https://registry.yarnpkg.com/once/-/once-1.4.0.tgz#583b1aa775961d4b113ac17d9c50baef9dd76bd1"
+ dependencies:
+ wrappy "1"
+
+opn@^5.1.0:
+ version "5.2.0"
+ resolved "http://registry.npm.taobao.org/opn/download/opn-5.2.0.tgz#71fdf934d6827d676cecbea1531f95d354641225"
+ dependencies:
+ is-wsl "^1.1.0"
+
+original@>=0.0.5:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/original/download/original-1.0.0.tgz#9147f93fa1696d04be61e01bd50baeaca656bd3b"
+ dependencies:
+ url-parse "1.0.x"
+
+os-browserify@^0.3.0:
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/os-browserify/-/os-browserify-0.3.0.tgz#854373c7f5c2315914fc9bfc6bd8238fdda1ec27"
+
+os-homedir@^1.0.0:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/os-homedir/-/os-homedir-1.0.2.tgz#ffbc4988336e0e833de0c168c7ef152121aa7fb3"
+
+os-locale@^1.4.0:
+ version "1.4.0"
+ resolved "http://registry.npm.taobao.org/os-locale/download/os-locale-1.4.0.tgz#20f9f17ae29ed345e8bde583b13d2009803c14d9"
+ dependencies:
+ lcid "^1.0.0"
+
+os-locale@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/os-locale/-/os-locale-2.1.0.tgz#42bc2900a6b5b8bd17376c8e882b65afccf24bf2"
+ dependencies:
+ execa "^0.7.0"
+ lcid "^1.0.0"
+ mem "^1.1.0"
+
+os-tmpdir@^1.0.0, os-tmpdir@^1.0.1:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/os-tmpdir/-/os-tmpdir-1.0.2.tgz#bbe67406c79aa85c5cfec766fe5734555dfa1274"
+
+osenv@0, osenv@^0.1.4:
+ version "0.1.5"
+ resolved "https://registry.yarnpkg.com/osenv/-/osenv-0.1.5.tgz#85cdfafaeb28e8677f416e287592b5f3f49ea410"
+ dependencies:
+ os-homedir "^1.0.0"
+ os-tmpdir "^1.0.0"
+
+p-finally@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/p-finally/-/p-finally-1.0.0.tgz#3fbcfb15b899a44123b34b6dcc18b724336a2cae"
+
+p-limit@^1.1.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/p-limit/-/p-limit-1.2.0.tgz#0e92b6bedcb59f022c13d0f1949dc82d15909f1c"
+ dependencies:
+ p-try "^1.0.0"
+
+p-locate@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/p-locate/-/p-locate-2.0.0.tgz#20a0103b222a70c8fd39cc2e580680f3dde5ec43"
+ dependencies:
+ p-limit "^1.1.0"
+
+p-map@^1.1.1:
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/p-map/download/p-map-1.2.0.tgz#e4e94f311eabbc8633a1e79908165fca26241b6b"
+
+p-try@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/p-try/-/p-try-1.0.0.tgz#cbc79cdbaf8fd4228e13f621f2b1a237c1b207b3"
+
+pako@~1.0.5:
+ version "1.0.6"
+ resolved "https://registry.yarnpkg.com/pako/-/pako-1.0.6.tgz#0101211baa70c4bca4a0f63f2206e97b7dfaf258"
+
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/param-case/-/param-case-2.1.1.tgz#df94fd8cf6531ecf75e6bef9a0858fbc72be2247"
+ dependencies:
+ no-case "^2.2.0"
+
+parse-asn1@^5.0.0:
+ version "5.1.0"
+ resolved "https://registry.yarnpkg.com/parse-asn1/-/parse-asn1-5.1.0.tgz#37c4f9b7ed3ab65c74817b5f2480937fbf97c712"
+ dependencies:
+ asn1.js "^4.0.0"
+ browserify-aes "^1.0.0"
+ create-hash "^1.1.0"
+ evp_bytestokey "^1.0.0"
+ pbkdf2 "^3.0.3"
+
+parse-glob@^3.0.4:
+ version "3.0.4"
+ resolved "http://registry.npm.taobao.org/parse-glob/download/parse-glob-3.0.4.tgz#b2c376cfb11f35513badd173ef0bb6e3a388391c"
+ dependencies:
+ glob-base "^0.3.0"
+ is-dotfile "^1.0.0"
+ is-extglob "^1.0.0"
+ is-glob "^2.0.0"
+
+parse-json@^2.2.0:
+ version "2.2.0"
+ resolved "https://registry.yarnpkg.com/parse-json/-/parse-json-2.2.0.tgz#f480f40434ef80741f8469099f8dea18f55a4dc9"
+ dependencies:
+ error-ex "^1.2.0"
+
+parseurl@~1.3.2:
+ version "1.3.2"
+ resolved "http://registry.npm.taobao.org/parseurl/download/parseurl-1.3.2.tgz#fc289d4ed8993119460c156253262cdc8de65bf3"
+
+pascalcase@^0.1.1:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/pascalcase/-/pascalcase-0.1.1.tgz#b363e55e8006ca6fe21784d2db22bd15d7917f14"
+
+ version "0.0.0"
+ resolved "https://registry.yarnpkg.com/path-browserify/-/path-browserify-0.0.0.tgz#a0b870729aae214005b7d5032ec2cbbb0fb4451a"
+
+path-dirname@^1.0.0:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/path-dirname/-/path-dirname-1.0.2.tgz#cc33d24d525e099a5388c0336c6e32b9160609e0"
+
+path-exists@^2.0.0:
+ version "2.1.0"
+ resolved "http://registry.npm.taobao.org/path-exists/download/path-exists-2.1.0.tgz#0feb6c64f0fc518d9a754dd5efb62c7022761f4b"
+ dependencies:
+ pinkie-promise "^2.0.0"
+
+path-exists@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/path-exists/-/path-exists-3.0.0.tgz#ce0ebeaa5f78cb18925ea7d810d7b59b010fd515"
+
+path-is-absolute@^1.0.0, path-is-absolute@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/path-is-absolute/-/path-is-absolute-1.0.1.tgz#174b9268735534ffbc7ace6bf53a5a9e1b5c5f5f"
+
+path-is-inside@^1.0.1:
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/path-is-inside/download/path-is-inside-1.0.2.tgz#365417dede44430d1c11af61027facf074bdfc53"
+
+path-key@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/path-key/-/path-key-2.0.1.tgz#411cadb574c5a140d3a4b1910d40d80cc9f40b40"
+
+ version "0.1.7"
+ resolved "http://registry.npm.taobao.org/path-to-regexp/download/path-to-regexp-0.1.7.tgz#df604178005f522f15eb4490e7247a1bfaa67f8c"
+
+path-to-regexp@^1.7.0:
+ version "1.7.0"
+ resolved "http://registry.npm.taobao.org/path-to-regexp/download/path-to-regexp-1.7.0.tgz#59fde0f435badacba103a84e9d3bc64e96b9937d"
+ dependencies:
+ isarray "0.0.1"
+
+path-type@^1.0.0:
+ version "1.1.0"
+ resolved "http://registry.npm.taobao.org/path-type/download/path-type-1.1.0.tgz#59c44f7ee491da704da415da5a4070ba4f8fe441"
+ dependencies:
+ graceful-fs "^4.1.2"
+ pify "^2.0.0"
+ pinkie-promise "^2.0.0"
+
+path-type@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/path-type/-/path-type-2.0.0.tgz#f012ccb8415b7096fc2daa1054c3d72389594c73"
+ dependencies:
+ pify "^2.0.0"
+
+pbkdf2@^3.0.3:
+ version "3.0.14"
+ resolved "https://registry.yarnpkg.com/pbkdf2/-/pbkdf2-3.0.14.tgz#a35e13c64799b06ce15320f459c230e68e73bade"
+ dependencies:
+ create-hash "^1.1.2"
+ create-hmac "^1.1.4"
+ ripemd160 "^2.0.1"
+ safe-buffer "^5.0.1"
+ sha.js "^2.4.8"
+
+performance-now@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/performance-now/-/performance-now-0.2.0.tgz#33ef30c5c77d4ea21c5a53869d91b56d8f2555e5"
+
+performance-now@^2.1.0:
+ version "2.1.0"
+ resolved "http://registry.npm.taobao.org/performance-now/download/performance-now-2.1.0.tgz#6309f4e0e5fa913ec1c69307ae364b4b377c9e7b"
+
+pify@^2.0.0:
+ version "2.3.0"
+ resolved "https://registry.yarnpkg.com/pify/-/pify-2.3.0.tgz#ed141a6ac043a849ea588498e7dca8b15330e90c"
+
+pify@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/pify/-/pify-3.0.0.tgz#e5a4acd2c101fdf3d9a4d07f0dbc4db49dd28176"
+
+pinkie-promise@^2.0.0:
+ version "2.0.1"
+ resolved "http://registry.npm.taobao.org/pinkie-promise/download/pinkie-promise-2.0.1.tgz#2135d6dfa7a358c069ac9b178776288228450ffa"
+ dependencies:
+ pinkie "^2.0.0"
+
+pinkie@^2.0.0:
+ version "2.0.4"
+ resolved "http://registry.npm.taobao.org/pinkie/download/pinkie-2.0.4.tgz#72556b80cfa0d48a974e80e77248e80ed4f7f870"
+
+pkg-dir@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/pkg-dir/-/pkg-dir-2.0.0.tgz#f6d5d1109e19d63edf428e0bd57e12777615334b"
+ dependencies:
+ find-up "^2.1.0"
+
+portfinder@^1.0.9:
+ version "1.0.13"
+ resolved "http://registry.npm.taobao.org/portfinder/download/portfinder-1.0.13.tgz#bb32ecd87c27104ae6ee44b5a3ccbf0ebb1aede9"
+ dependencies:
+ async "^1.5.2"
+ debug "^2.2.0"
+ mkdirp "0.5.x"
+
+posix-character-classes@^0.1.0:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/posix-character-classes/-/posix-character-classes-0.1.1.tgz#01eac0fe3b5af71a2a6c02feabb8c1fef7e00eab"
+
+postcss-calc@^5.2.0:
+ version "5.3.1"
+ resolved "https://registry.yarnpkg.com/postcss-calc/-/postcss-calc-5.3.1.tgz#77bae7ca928ad85716e2fda42f261bf7c1d65b5e"
+ dependencies:
+ postcss "^5.0.2"
+ postcss-message-helpers "^2.0.0"
+ reduce-css-calc "^1.2.6"
+
+postcss-colormin@^2.1.8:
+ version "2.2.2"
+ resolved "https://registry.yarnpkg.com/postcss-colormin/-/postcss-colormin-2.2.2.tgz#6631417d5f0e909a3d7ec26b24c8a8d1e4f96e4b"
+ dependencies:
+ colormin "^1.0.5"
+ postcss "^5.0.13"
+ postcss-value-parser "^3.2.3"
+
+postcss-convert-values@^2.3.4:
+ version "2.6.1"
+ resolved "https://registry.yarnpkg.com/postcss-convert-values/-/postcss-convert-values-2.6.1.tgz#bbd8593c5c1fd2e3d1c322bb925dcae8dae4d62d"
+ dependencies:
+ postcss "^5.0.11"
+ postcss-value-parser "^3.1.2"
+
+postcss-discard-comments@^2.0.4:
+ version "2.0.4"
+ resolved "https://registry.yarnpkg.com/postcss-discard-comments/-/postcss-discard-comments-2.0.4.tgz#befe89fafd5b3dace5ccce51b76b81514be00e3d"
+ dependencies:
+ postcss "^5.0.14"
+
+postcss-discard-duplicates@^2.0.1:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/postcss-discard-duplicates/-/postcss-discard-duplicates-2.1.0.tgz#b9abf27b88ac188158a5eb12abcae20263b91932"
+ dependencies:
+ postcss "^5.0.4"
+
+postcss-discard-empty@^2.0.1:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/postcss-discard-empty/-/postcss-discard-empty-2.1.0.tgz#d2b4bd9d5ced5ebd8dcade7640c7d7cd7f4f92b5"
+ dependencies:
+ postcss "^5.0.14"
+
+postcss-discard-overridden@^0.1.1:
+ version "0.1.1"
+ resolved "https://registry.yarnpkg.com/postcss-discard-overridden/-/postcss-discard-overridden-0.1.1.tgz#8b1eaf554f686fb288cd874c55667b0aa3668d58"
+ dependencies:
+ postcss "^5.0.16"
+
+postcss-discard-unused@^2.2.1:
+ version "2.2.3"
+ resolved "https://registry.yarnpkg.com/postcss-discard-unused/-/postcss-discard-unused-2.2.3.tgz#bce30b2cc591ffc634322b5fb3464b6d934f4433"
+ dependencies:
+ postcss "^5.0.14"
+ uniqs "^2.0.0"
+
+postcss-filter-plugins@^2.0.0:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/postcss-filter-plugins/-/postcss-filter-plugins-2.0.2.tgz#6d85862534d735ac420e4a85806e1f5d4286d84c"
+ dependencies:
+ postcss "^5.0.4"
+ uniqid "^4.0.0"
+
+postcss-merge-idents@^2.1.5:
+ version "2.1.7"
+ resolved "https://registry.yarnpkg.com/postcss-merge-idents/-/postcss-merge-idents-2.1.7.tgz#4c5530313c08e1d5b3bbf3d2bbc747e278eea270"
+ dependencies:
+ has "^1.0.1"
+ postcss "^5.0.10"
+ postcss-value-parser "^3.1.1"
+
+postcss-merge-longhand@^2.0.1:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/postcss-merge-longhand/-/postcss-merge-longhand-2.0.2.tgz#23d90cd127b0a77994915332739034a1a4f3d658"
+ dependencies:
+ postcss "^5.0.4"
+
+postcss-merge-rules@^2.0.3:
+ version "2.1.2"
+ resolved "https://registry.yarnpkg.com/postcss-merge-rules/-/postcss-merge-rules-2.1.2.tgz#d1df5dfaa7b1acc3be553f0e9e10e87c61b5f721"
+ dependencies:
+ browserslist "^1.5.2"
+ caniuse-api "^1.5.2"
+ postcss "^5.0.4"
+ postcss-selector-parser "^2.2.2"
+ vendors "^1.0.0"
+
+postcss-message-helpers@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/postcss-message-helpers/-/postcss-message-helpers-2.0.0.tgz#a4f2f4fab6e4fe002f0aed000478cdf52f9ba60e"
+
+postcss-minify-font-values@^1.0.2:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/postcss-minify-font-values/-/postcss-minify-font-values-1.0.5.tgz#4b58edb56641eba7c8474ab3526cafd7bbdecb69"
+ dependencies:
+ object-assign "^4.0.1"
+ postcss "^5.0.4"
+ postcss-value-parser "^3.0.2"
+
+postcss-minify-gradients@^1.0.1:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/postcss-minify-gradients/-/postcss-minify-gradients-1.0.5.tgz#5dbda11373703f83cfb4a3ea3881d8d75ff5e6e1"
+ dependencies:
+ postcss "^5.0.12"
+ postcss-value-parser "^3.3.0"
+
+postcss-minify-params@^1.0.4:
+ version "1.2.2"
+ resolved "https://registry.yarnpkg.com/postcss-minify-params/-/postcss-minify-params-1.2.2.tgz#ad2ce071373b943b3d930a3fa59a358c28d6f1f3"
+ dependencies:
+ alphanum-sort "^1.0.1"
+ postcss "^5.0.2"
+ postcss-value-parser "^3.0.2"
+ uniqs "^2.0.0"
+
+postcss-minify-selectors@^2.0.4:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/postcss-minify-selectors/-/postcss-minify-selectors-2.1.1.tgz#b2c6a98c0072cf91b932d1a496508114311735bf"
+ dependencies:
+ alphanum-sort "^1.0.2"
+ has "^1.0.1"
+ postcss "^5.0.14"
+ postcss-selector-parser "^2.0.0"
+
+postcss-modules-extract-imports@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/postcss-modules-extract-imports/-/postcss-modules-extract-imports-1.1.0.tgz#b614c9720be6816eaee35fb3a5faa1dba6a05ddb"
+ dependencies:
+ postcss "^6.0.1"
+
+postcss-modules-local-by-default@^1.2.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/postcss-modules-local-by-default/-/postcss-modules-local-by-default-1.2.0.tgz#f7d80c398c5a393fa7964466bd19500a7d61c069"
+ dependencies:
+ css-selector-tokenizer "^0.7.0"
+ postcss "^6.0.1"
+
+postcss-modules-scope@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/postcss-modules-scope/-/postcss-modules-scope-1.1.0.tgz#d6ea64994c79f97b62a72b426fbe6056a194bb90"
+ dependencies:
+ css-selector-tokenizer "^0.7.0"
+ postcss "^6.0.1"
+
+postcss-modules-values@^1.3.0:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/postcss-modules-values/-/postcss-modules-values-1.3.0.tgz#ecffa9d7e192518389f42ad0e83f72aec456ea20"
+ dependencies:
+ icss-replace-symbols "^1.1.0"
+ postcss "^6.0.1"
+
+postcss-normalize-charset@^1.1.0:
+ version "1.1.1"
+ resolved "https://registry.yarnpkg.com/postcss-normalize-charset/-/postcss-normalize-charset-1.1.1.tgz#ef9ee71212d7fe759c78ed162f61ed62b5cb93f1"
+ dependencies:
+ postcss "^5.0.5"
+
+postcss-normalize-url@^3.0.7:
+ version "3.0.8"
+ resolved "https://registry.yarnpkg.com/postcss-normalize-url/-/postcss-normalize-url-3.0.8.tgz#108f74b3f2fcdaf891a2ffa3ea4592279fc78222"
+ dependencies:
+ is-absolute-url "^2.0.0"
+ normalize-url "^1.4.0"
+ postcss "^5.0.14"
+ postcss-value-parser "^3.2.3"
+
+postcss-ordered-values@^2.1.0:
+ version "2.2.3"
+ resolved "https://registry.yarnpkg.com/postcss-ordered-values/-/postcss-ordered-values-2.2.3.tgz#eec6c2a67b6c412a8db2042e77fe8da43f95c11d"
+ dependencies:
+ postcss "^5.0.4"
+ postcss-value-parser "^3.0.1"
+
+postcss-reduce-idents@^2.2.2:
+ version "2.4.0"
+ resolved "https://registry.yarnpkg.com/postcss-reduce-idents/-/postcss-reduce-idents-2.4.0.tgz#c2c6d20cc958284f6abfbe63f7609bf409059ad3"
+ dependencies:
+ postcss "^5.0.4"
+ postcss-value-parser "^3.0.2"
+
+postcss-reduce-initial@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/postcss-reduce-initial/-/postcss-reduce-initial-1.0.1.tgz#68f80695f045d08263a879ad240df8dd64f644ea"
+ dependencies:
+ postcss "^5.0.4"
+
+postcss-reduce-transforms@^1.0.3:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/postcss-reduce-transforms/-/postcss-reduce-transforms-1.0.4.tgz#ff76f4d8212437b31c298a42d2e1444025771ae1"
+ dependencies:
+ has "^1.0.1"
+ postcss "^5.0.8"
+ postcss-value-parser "^3.0.1"
+
+postcss-selector-parser@^2.0.0, postcss-selector-parser@^2.2.2:
+ version "2.2.3"
+ resolved "https://registry.yarnpkg.com/postcss-selector-parser/-/postcss-selector-parser-2.2.3.tgz#f9437788606c3c9acee16ffe8d8b16297f27bb90"
+ dependencies:
+ flatten "^1.0.2"
+ indexes-of "^1.0.1"
+ uniq "^1.0.1"
+
+postcss-svgo@^2.1.1:
+ version "2.1.6"
+ resolved "https://registry.yarnpkg.com/postcss-svgo/-/postcss-svgo-2.1.6.tgz#b6df18aa613b666e133f08adb5219c2684ac108d"
+ dependencies:
+ is-svg "^2.0.0"
+ postcss "^5.0.14"
+ postcss-value-parser "^3.2.3"
+ svgo "^0.7.0"
+
+postcss-unique-selectors@^2.0.2:
+ version "2.0.2"
+ resolved "https://registry.yarnpkg.com/postcss-unique-selectors/-/postcss-unique-selectors-2.0.2.tgz#981d57d29ddcb33e7b1dfe1fd43b8649f933ca1d"
+ dependencies:
+ alphanum-sort "^1.0.1"
+ postcss "^5.0.4"
+ uniqs "^2.0.0"
+
+postcss-value-parser@^3.0.1, postcss-value-parser@^3.0.2, postcss-value-parser@^3.1.1, postcss-value-parser@^3.1.2, postcss-value-parser@^3.2.3, postcss-value-parser@^3.3.0:
+ version "3.3.0"
+ resolved "https://registry.yarnpkg.com/postcss-value-parser/-/postcss-value-parser-3.3.0.tgz#87f38f9f18f774a4ab4c8a232f5c5ce8872a9d15"
+
+postcss-zindex@^2.0.1:
+ version "2.2.0"
+ resolved "https://registry.yarnpkg.com/postcss-zindex/-/postcss-zindex-2.2.0.tgz#d2109ddc055b91af67fc4cb3b025946639d2af22"
+ dependencies:
+ has "^1.0.1"
+ postcss "^5.0.4"
+ uniqs "^2.0.0"
+
+postcss@^5.0.10, postcss@^5.0.11, postcss@^5.0.12, postcss@^5.0.13, postcss@^5.0.14, postcss@^5.0.16, postcss@^5.0.2, postcss@^5.0.4, postcss@^5.0.5, postcss@^5.0.6, postcss@^5.0.8, postcss@^5.2.16:
+ version "5.2.18"
+ resolved "https://registry.yarnpkg.com/postcss/-/postcss-5.2.18.tgz#badfa1497d46244f6390f58b319830d9107853c5"
+ dependencies:
+ chalk "^1.1.3"
+ js-base64 "^2.1.9"
+ source-map "^0.5.6"
+ supports-color "^3.2.3"
+
+postcss@^6.0.1:
+ version "6.0.19"
+ resolved "https://registry.yarnpkg.com/postcss/-/postcss-6.0.19.tgz#76a78386f670b9d9494a655bf23ac012effd1555"
+ dependencies:
+ chalk "^2.3.1"
+ source-map "^0.6.1"
+ supports-color "^5.2.0"
+
+prepend-http@^1.0.0:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/prepend-http/-/prepend-http-1.0.4.tgz#d4f4562b0ce3696e41ac52d0e002e57a635dc6dc"
+
+preserve@^0.2.0:
+ version "0.2.0"
+ resolved "http://registry.npm.taobao.org/preserve/download/preserve-0.2.0.tgz#815ed1f6ebc65926f865b310c0713bcb3315ce4b"
+
+pretty-error@^2.0.2:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/pretty-error/-/pretty-error-2.1.1.tgz#5f4f87c8f91e5ae3f3ba87ab4cf5e03b1a17f1a3"
+ dependencies:
+ renderkid "^2.0.1"
+ utila "~0.4"
+
+private@^0.1.6, private@^0.1.7:
+ version "0.1.8"
+ resolved "https://registry.yarnpkg.com/private/-/private-0.1.8.tgz#2381edb3689f7a53d653190060fcf822d2f368ff"
+
+process-nextick-args@~2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/process-nextick-args/-/process-nextick-args-2.0.0.tgz#a37d732f4271b4ab1ad070d35508e8290788ffaa"
+
+process@^0.11.10:
+ version "0.11.10"
+ resolved "https://registry.yarnpkg.com/process/-/process-0.11.10.tgz#7332300e840161bda3e69a1d1d91a7d4bc16f182"
+
+promise@^7.1.1:
+ version "7.3.1"
+ resolved "https://registry.yarnpkg.com/promise/-/promise-7.3.1.tgz#064b72602b18f90f29192b8b1bc418ffd1ebd3bf"
+ dependencies:
+ asap "~2.0.3"
+
+prop-types@^15.5.10, prop-types@^15.5.4, prop-types@^15.5.7, prop-types@^15.5.8, prop-types@^15.6.0, prop-types@^15.6.1:
+ version "15.6.1"
+ resolved "https://registry.yarnpkg.com/prop-types/-/prop-types-15.6.1.tgz#36644453564255ddda391191fb3a125cbdf654ca"
+ dependencies:
+ fbjs "^0.8.16"
+ loose-envify "^1.3.1"
+ object-assign "^4.1.1"
+
+proxy-addr@~2.0.3:
+ version "2.0.3"
+ resolved "http://registry.npm.taobao.org/proxy-addr/download/proxy-addr-2.0.3.tgz#355f262505a621646b3130a728eb647e22055341"
+ dependencies:
+ forwarded "~0.1.2"
+ ipaddr.js "1.6.0"
+
+prr@~1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/prr/-/prr-1.0.1.tgz#d3fc114ba06995a45ec6893f484ceb1d78f5f476"
+
+pseudomap@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/pseudomap/-/pseudomap-1.0.2.tgz#f052a28da70e618917ef0a8ac34c1ae5a68286b3"
+
+public-encrypt@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/public-encrypt/-/public-encrypt-4.0.0.tgz#39f699f3a46560dd5ebacbca693caf7c65c18cc6"
+ dependencies:
+ bn.js "^4.1.0"
+ browserify-rsa "^4.0.0"
+ create-hash "^1.1.0"
+ parse-asn1 "^5.0.0"
+ randombytes "^2.0.1"
+
+ version "1.3.2"
+ resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.3.2.tgz#9653a036fb7c1ee42342f2325cceefea3926c48d"
+
+punycode@^1.2.4, punycode@^1.4.1:
+ version "1.4.1"
+ resolved "https://registry.yarnpkg.com/punycode/-/punycode-1.4.1.tgz#c0d5a63b2718800ad8e1eb0fa5269c84dd41845e"
+
+q@^1.1.2:
+ version "1.5.1"
+ resolved "https://registry.yarnpkg.com/q/-/q-1.5.1.tgz#7e32f75b41381291d04611f1bf14109ac00651d7"
+
[email protected], qs@~6.5.1:
+ version "6.5.1"
+ resolved "http://registry.npm.taobao.org/qs/download/qs-6.5.1.tgz#349cdf6eef89ec45c12d7d5eb3fc0c870343a6d8"
+
+qs@~6.3.0:
+ version "6.3.2"
+ resolved "http://registry.npm.taobao.org/qs/download/qs-6.3.2.tgz#e75bd5f6e268122a2a0e0bda630b2550c166502c"
+
+qs@~6.4.0:
+ version "6.4.0"
+ resolved "https://registry.yarnpkg.com/qs/-/qs-6.4.0.tgz#13e26d28ad6b0ffaa91312cd3bf708ed351e7233"
+
+query-string@^4.1.0:
+ version "4.3.4"
+ resolved "https://registry.yarnpkg.com/query-string/-/query-string-4.3.4.tgz#bbb693b9ca915c232515b228b1a02b609043dbeb"
+ dependencies:
+ object-assign "^4.1.0"
+ strict-uri-encode "^1.0.0"
+
+querystring-es3@^0.2.0:
+ version "0.2.1"
+ resolved "https://registry.yarnpkg.com/querystring-es3/-/querystring-es3-0.2.1.tgz#9ec61f79049875707d69414596fd907a4d711e73"
+
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/querystring/-/querystring-0.2.0.tgz#b209849203bb25df820da756e747005878521620"
+
+ version "0.0.4"
+ resolved "http://registry.npm.taobao.org/querystringify/download/querystringify-0.0.4.tgz#0cf7f84f9463ff0ae51c4c4b142d95be37724d9c"
+
+querystringify@~1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/querystringify/download/querystringify-1.0.0.tgz#6286242112c5b712fa654e526652bf6a13ff05cb"
+
+raf@^3.1.0:
+ version "3.4.0"
+ resolved "http://registry.npm.taobao.org/raf/download/raf-3.4.0.tgz#a28876881b4bc2ca9117d4138163ddb80f781575"
+ dependencies:
+ performance-now "^2.1.0"
+
+randomatic@^1.1.3:
+ version "1.1.7"
+ resolved "http://registry.npm.taobao.org/randomatic/download/randomatic-1.1.7.tgz#c7abe9cc8b87c0baa876b19fde83fd464797e38c"
+ dependencies:
+ is-number "^3.0.0"
+ kind-of "^4.0.0"
+
+randombytes@^2.0.0, randombytes@^2.0.1, randombytes@^2.0.5:
+ version "2.0.6"
+ resolved "https://registry.yarnpkg.com/randombytes/-/randombytes-2.0.6.tgz#d302c522948588848a8d300c932b44c24231da80"
+ dependencies:
+ safe-buffer "^5.1.0"
+
+randomfill@^1.0.3:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/randomfill/-/randomfill-1.0.4.tgz#c92196fc86ab42be983f1bf31778224931d61458"
+ dependencies:
+ randombytes "^2.0.5"
+ safe-buffer "^5.1.0"
+
+range-parser@^1.0.3, range-parser@~1.2.0:
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/range-parser/download/range-parser-1.2.0.tgz#f49be6b487894ddc40dcc94a322f611092e00d5e"
+
+ version "2.3.2"
+ resolved "http://registry.npm.taobao.org/raw-body/download/raw-body-2.3.2.tgz#bcd60c77d3eb93cde0050295c3f379389bc88f89"
+ dependencies:
+ bytes "3.0.0"
+ http-errors "1.6.2"
+ iconv-lite "0.4.19"
+ unpipe "1.0.0"
+
+rc-pagination@^1.16.3:
+ version "1.16.3"
+ resolved "http://registry.npm.taobao.org/rc-pagination/download/rc-pagination-1.16.3.tgz#2d3780a129c290c2e2e85a71b6723a8301484c2e"
+ dependencies:
+ babel-runtime "6.x"
+ prop-types "^15.5.7"
+
+rc@^1.1.7:
+ version "1.2.6"
+ resolved "https://registry.yarnpkg.com/rc/-/rc-1.2.6.tgz#eb18989c6d4f4f162c399f79ddd29f3835568092"
+ dependencies:
+ deep-extend "~0.4.0"
+ ini "~1.3.0"
+ minimist "^1.2.0"
+ strip-json-comments "~2.0.1"
+
+ version "16.2.0"
+ resolved "https://registry.yarnpkg.com/react-dom/-/react-dom-16.2.0.tgz#69003178601c0ca19b709b33a83369fe6124c044"
+ dependencies:
+ fbjs "^0.8.16"
+ loose-envify "^1.1.0"
+ object-assign "^4.1.1"
+ prop-types "^15.6.0"
+
+react-motion@^0.5.0:
+ version "0.5.2"
+ resolved "http://registry.npm.taobao.org/react-motion/download/react-motion-0.5.2.tgz#0dd3a69e411316567927917c6626551ba0607316"
+ dependencies:
+ performance-now "^0.2.0"
+ prop-types "^15.5.8"
+ raf "^3.1.0"
+
[email protected], react-router-dom@^4.1.1:
+ version "4.2.2"
+ resolved "http://registry.npm.taobao.org/react-router-dom/download/react-router-dom-4.2.2.tgz#c8a81df3adc58bba8a76782e946cbd4eae649b8d"
+ dependencies:
+ history "^4.7.2"
+ invariant "^2.2.2"
+ loose-envify "^1.3.1"
+ prop-types "^15.5.4"
+ react-router "^4.2.0"
+ warning "^3.0.0"
+
+react-router-transition@^1.2.1:
+ version "1.2.1"
+ resolved "http://registry.npm.taobao.org/react-router-transition/download/react-router-transition-1.2.1.tgz#167702d122ca6de339cdd005b95d74707e1c7e77"
+ dependencies:
+ prop-types "^15.5.10"
+ react-motion "^0.5.0"
+ react-router-dom "^4.1.1"
+
+react-router@^4.2.0:
+ version "4.2.0"
+ resolved "http://registry.npm.taobao.org/react-router/download/react-router-4.2.0.tgz#61f7b3e3770daeb24062dae3eedef1b054155986"
+ dependencies:
+ history "^4.7.2"
+ hoist-non-react-statics "^2.3.0"
+ invariant "^2.2.2"
+ loose-envify "^1.3.1"
+ path-to-regexp "^1.7.0"
+ prop-types "^15.5.4"
+ warning "^3.0.0"
+
+react-table@^6.8.6:
+ version "6.8.6"
+ resolved "http://registry.npm.taobao.org/react-table/download/react-table-6.8.6.tgz#a0ad8b4839319052d5befc012603fb161e52ede3"
+ dependencies:
+ classnames "^2.2.5"
+
+ version "16.2.0"
+ resolved "https://registry.yarnpkg.com/react/-/react-16.2.0.tgz#a31bd2dab89bff65d42134fa187f24d054c273ba"
+ dependencies:
+ fbjs "^0.8.16"
+ loose-envify "^1.1.0"
+ object-assign "^4.1.1"
+ prop-types "^15.6.0"
+
+read-pkg-up@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/read-pkg-up/download/read-pkg-up-1.0.1.tgz#9d63c13276c065918d57f002a57f40a1b643fb02"
+ dependencies:
+ find-up "^1.0.0"
+ read-pkg "^1.0.0"
+
+read-pkg-up@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/read-pkg-up/-/read-pkg-up-2.0.0.tgz#6b72a8048984e0c41e79510fd5e9fa99b3b549be"
+ dependencies:
+ find-up "^2.0.0"
+ read-pkg "^2.0.0"
+
+read-pkg@^1.0.0:
+ version "1.1.0"
+ resolved "http://registry.npm.taobao.org/read-pkg/download/read-pkg-1.1.0.tgz#f5ffaa5ecd29cb31c0474bca7d756b6bb29e3f28"
+ dependencies:
+ load-json-file "^1.0.0"
+ normalize-package-data "^2.3.2"
+ path-type "^1.0.0"
+
+read-pkg@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/read-pkg/-/read-pkg-2.0.0.tgz#8ef1c0623c6a6db0dc6713c4bfac46332b2368f8"
+ dependencies:
+ load-json-file "^2.0.0"
+ normalize-package-data "^2.3.2"
+ path-type "^2.0.0"
+
+ version "1.0.34"
+ resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-1.0.34.tgz#125820e34bc842d2f2aaafafe4c2916ee32c157c"
+ dependencies:
+ core-util-is "~1.0.0"
+ inherits "~2.0.1"
+ isarray "0.0.1"
+ string_decoder "~0.10.x"
+
+readable-stream@^2.0.1, readable-stream@^2.0.2, readable-stream@^2.0.6, readable-stream@^2.1.4, readable-stream@^2.2.9, readable-stream@^2.3.3:
+ version "2.3.5"
+ resolved "https://registry.yarnpkg.com/readable-stream/-/readable-stream-2.3.5.tgz#b4f85003a938cbb6ecbce2a124fb1012bd1a838d"
+ dependencies:
+ core-util-is "~1.0.0"
+ inherits "~2.0.3"
+ isarray "~1.0.0"
+ process-nextick-args "~2.0.0"
+ safe-buffer "~5.1.1"
+ string_decoder "~1.0.3"
+ util-deprecate "~1.0.1"
+
+readdirp@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/readdirp/-/readdirp-2.1.0.tgz#4ed0ad060df3073300c48440373f72d1cc642d78"
+ dependencies:
+ graceful-fs "^4.1.2"
+ minimatch "^3.0.2"
+ readable-stream "^2.0.2"
+ set-immediate-shim "^1.0.1"
+
+redent@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/redent/download/redent-1.0.0.tgz#cf916ab1fd5f1f16dfb20822dd6ec7f730c2afde"
+ dependencies:
+ indent-string "^2.1.0"
+ strip-indent "^1.0.1"
+
+reduce-css-calc@^1.2.6:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/reduce-css-calc/-/reduce-css-calc-1.3.0.tgz#747c914e049614a4c9cfbba629871ad1d2927716"
+ dependencies:
+ balanced-match "^0.4.2"
+ math-expression-evaluator "^1.2.14"
+ reduce-function-call "^1.0.1"
+
+reduce-function-call@^1.0.1:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/reduce-function-call/-/reduce-function-call-1.0.2.tgz#5a200bf92e0e37751752fe45b0ab330fd4b6be99"
+ dependencies:
+ balanced-match "^0.4.2"
+
+regenerate@^1.2.1:
+ version "1.3.3"
+ resolved "https://registry.yarnpkg.com/regenerate/-/regenerate-1.3.3.tgz#0c336d3980553d755c39b586ae3b20aa49c82b7f"
+
+regenerator-runtime@^0.11.0, regenerator-runtime@^0.11.1:
+ version "0.11.1"
+ resolved "https://registry.yarnpkg.com/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz#be05ad7f9bf7d22e056f9726cee5017fbf19e2e9"
+
+regenerator-transform@^0.10.0:
+ version "0.10.1"
+ resolved "https://registry.yarnpkg.com/regenerator-transform/-/regenerator-transform-0.10.1.tgz#1e4996837231da8b7f3cf4114d71b5691a0680dd"
+ dependencies:
+ babel-runtime "^6.18.0"
+ babel-types "^6.19.0"
+ private "^0.1.6"
+
+regex-cache@^0.4.2:
+ version "0.4.4"
+ resolved "http://registry.npm.taobao.org/regex-cache/download/regex-cache-0.4.4.tgz#75bdc58a2a1496cec48a12835bc54c8d562336dd"
+ dependencies:
+ is-equal-shallow "^0.1.3"
+
+regex-not@^1.0.0, regex-not@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/regex-not/-/regex-not-1.0.2.tgz#1f4ece27e00b0b65e0247a6810e6a85d83a5752c"
+ dependencies:
+ extend-shallow "^3.0.2"
+ safe-regex "^1.1.0"
+
+regexpu-core@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-1.0.0.tgz#86a763f58ee4d7c2f6b102e4764050de7ed90c6b"
+ dependencies:
+ regenerate "^1.2.1"
+ regjsgen "^0.2.0"
+ regjsparser "^0.1.4"
+
+regexpu-core@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/regexpu-core/-/regexpu-core-2.0.0.tgz#49d038837b8dcf8bfa5b9a42139938e6ea2ae240"
+ dependencies:
+ regenerate "^1.2.1"
+ regjsgen "^0.2.0"
+ regjsparser "^0.1.4"
+
+regjsgen@^0.2.0:
+ version "0.2.0"
+ resolved "https://registry.yarnpkg.com/regjsgen/-/regjsgen-0.2.0.tgz#6c016adeac554f75823fe37ac05b92d5a4edb1f7"
+
+regjsparser@^0.1.4:
+ version "0.1.5"
+ resolved "https://registry.yarnpkg.com/regjsparser/-/regjsparser-0.1.5.tgz#7ee8f84dc6fa792d3fd0ae228d24bd949ead205c"
+ dependencies:
+ jsesc "~0.5.0"
+
+ version "0.2.7"
+ resolved "https://registry.yarnpkg.com/relateurl/-/relateurl-0.2.7.tgz#54dbf377e51440aca90a4cd274600d3ff2d888a9"
+
+remove-trailing-separator@^1.0.1:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz#c24bce2a283adad5bc3f58e0d48249b92379d8ef"
+
+renderkid@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/renderkid/-/renderkid-2.0.1.tgz#898cabfc8bede4b7b91135a3ffd323e58c0db319"
+ dependencies:
+ css-select "^1.1.0"
+ dom-converter "~0.1"
+ htmlparser2 "~3.3.0"
+ strip-ansi "^3.0.0"
+ utila "~0.3"
+
+repeat-element@^1.1.2:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/repeat-element/-/repeat-element-1.1.2.tgz#ef089a178d1483baae4d93eb98b4f9e4e11d990a"
+
+repeat-string@^1.5.2, repeat-string@^1.6.1:
+ version "1.6.1"
+ resolved "https://registry.yarnpkg.com/repeat-string/-/repeat-string-1.6.1.tgz#8dcae470e1c88abc2d600fff4a776286da75e637"
+
+repeating@^2.0.0:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/repeating/-/repeating-2.0.1.tgz#5214c53a926d3552707527fbab415dbc08d06dda"
+ dependencies:
+ is-finite "^1.0.0"
+
+request@2:
+ version "2.85.0"
+ resolved "http://registry.npm.taobao.org/request/download/request-2.85.0.tgz#5a03615a47c61420b3eb99b7dba204f83603e1fa"
+ dependencies:
+ aws-sign2 "~0.7.0"
+ aws4 "^1.6.0"
+ caseless "~0.12.0"
+ combined-stream "~1.0.5"
+ extend "~3.0.1"
+ forever-agent "~0.6.1"
+ form-data "~2.3.1"
+ har-validator "~5.0.3"
+ hawk "~6.0.2"
+ http-signature "~1.2.0"
+ is-typedarray "~1.0.0"
+ isstream "~0.1.2"
+ json-stringify-safe "~5.0.1"
+ mime-types "~2.1.17"
+ oauth-sign "~0.8.2"
+ performance-now "^2.1.0"
+ qs "~6.5.1"
+ safe-buffer "^5.1.1"
+ stringstream "~0.0.5"
+ tough-cookie "~2.3.3"
+ tunnel-agent "^0.6.0"
+ uuid "^3.1.0"
+
+ version "2.81.0"
+ resolved "https://registry.yarnpkg.com/request/-/request-2.81.0.tgz#c6928946a0e06c5f8d6f8a9333469ffda46298a0"
+ dependencies:
+ aws-sign2 "~0.6.0"
+ aws4 "^1.2.1"
+ caseless "~0.12.0"
+ combined-stream "~1.0.5"
+ extend "~3.0.0"
+ forever-agent "~0.6.1"
+ form-data "~2.1.1"
+ har-validator "~4.2.1"
+ hawk "~3.1.3"
+ http-signature "~1.1.0"
+ is-typedarray "~1.0.0"
+ isstream "~0.1.2"
+ json-stringify-safe "~5.0.1"
+ mime-types "~2.1.7"
+ oauth-sign "~0.8.1"
+ performance-now "^0.2.0"
+ qs "~6.4.0"
+ safe-buffer "^5.0.1"
+ stringstream "~0.0.4"
+ tough-cookie "~2.3.0"
+ tunnel-agent "^0.6.0"
+ uuid "^3.0.0"
+
+request@~2.79.0:
+ version "2.79.0"
+ resolved "http://registry.npm.taobao.org/request/download/request-2.79.0.tgz#4dfe5bf6be8b8cdc37fcf93e04b65577722710de"
+ dependencies:
+ aws-sign2 "~0.6.0"
+ aws4 "^1.2.1"
+ caseless "~0.11.0"
+ combined-stream "~1.0.5"
+ extend "~3.0.0"
+ forever-agent "~0.6.1"
+ form-data "~2.1.1"
+ har-validator "~2.0.6"
+ hawk "~3.1.3"
+ http-signature "~1.1.0"
+ is-typedarray "~1.0.0"
+ isstream "~0.1.2"
+ json-stringify-safe "~5.0.1"
+ mime-types "~2.1.7"
+ oauth-sign "~0.8.1"
+ qs "~6.3.0"
+ stringstream "~0.0.4"
+ tough-cookie "~2.3.0"
+ tunnel-agent "~0.4.1"
+ uuid "^3.0.0"
+
+require-directory@^2.1.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/require-directory/-/require-directory-2.1.1.tgz#8c64ad5fd30dab1c976e2344ffe7f792a6a6df42"
+
+require-main-filename@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/require-main-filename/-/require-main-filename-1.0.1.tgz#97f717b69d48784f5f526a6c5aa8ffdda055a4d1"
+
[email protected], [email protected], requires-port@~1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/requires-port/download/requires-port-1.0.0.tgz#925d2601d39ac485e091cf0da5c6e694dc3dcaff"
+
+resolve-cwd@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/resolve-cwd/download/resolve-cwd-2.0.0.tgz#00a9f7387556e27038eae232caa372a6a59b665a"
+ dependencies:
+ resolve-from "^3.0.0"
+
+resolve-from@^3.0.0:
+ version "3.0.0"
+ resolved "http://registry.npm.taobao.org/resolve-from/download/resolve-from-3.0.0.tgz#b22c7af7d9d6881bc8b6e653335eebcb0a188748"
+
+resolve-pathname@^2.2.0:
+ version "2.2.0"
+ resolved "http://registry.npm.taobao.org/resolve-pathname/download/resolve-pathname-2.2.0.tgz#7e9ae21ed815fd63ab189adeee64dc831eefa879"
+
+resolve-url@^0.2.1:
+ version "0.2.1"
+ resolved "https://registry.yarnpkg.com/resolve-url/-/resolve-url-0.2.1.tgz#2c637fe77c893afd2a663fe21aa9080068e2052a"
+
+ret@~0.1.10:
+ version "0.1.15"
+ resolved "https://registry.yarnpkg.com/ret/-/ret-0.1.15.tgz#b8a4825d5bdb1fc3f6f53c2bc33f81388681c7bc"
+
+right-align@^0.1.1:
+ version "0.1.3"
+ resolved "https://registry.yarnpkg.com/right-align/-/right-align-0.1.3.tgz#61339b722fe6a3515689210d24e14c96148613ef"
+ dependencies:
+ align-text "^0.1.1"
+
+rimraf@2, rimraf@^2.2.8, rimraf@^2.5.1, rimraf@^2.6.1:
+ version "2.6.2"
+ resolved "https://registry.yarnpkg.com/rimraf/-/rimraf-2.6.2.tgz#2ed8150d24a16ea8651e6d6ef0f47c4158ce7a36"
+ dependencies:
+ glob "^7.0.5"
+
+ripemd160@^2.0.0, ripemd160@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/ripemd160/-/ripemd160-2.0.1.tgz#0f4584295c53a3628af7e6d79aca21ce57d1c6e7"
+ dependencies:
+ hash-base "^2.0.0"
+ inherits "^2.0.1"
+
[email protected], safe-buffer@^5.0.1, safe-buffer@^5.1.0, safe-buffer@^5.1.1, safe-buffer@~5.1.0, safe-buffer@~5.1.1:
+ version "5.1.1"
+ resolved "https://registry.yarnpkg.com/safe-buffer/-/safe-buffer-5.1.1.tgz#893312af69b2123def71f57889001671eeb2c853"
+
+safe-regex@^1.1.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/safe-regex/-/safe-regex-1.1.0.tgz#40a3669f3b077d1e943d44629e157dd48023bf2e"
+ dependencies:
+ ret "~0.1.10"
+
+sass-graph@^2.2.4:
+ version "2.2.4"
+ resolved "http://registry.npm.taobao.org/sass-graph/download/sass-graph-2.2.4.tgz#13fbd63cd1caf0908b9fd93476ad43a51d1e0b49"
+ dependencies:
+ glob "^7.0.0"
+ lodash "^4.0.0"
+ scss-tokenizer "^0.2.3"
+ yargs "^7.0.0"
+
+ version "6.0.6"
+ resolved "https://registry.yarnpkg.com/sass-loader/-/sass-loader-6.0.6.tgz#e9d5e6c1f155faa32a4b26d7a9b7107c225e40f9"
+ dependencies:
+ async "^2.1.5"
+ clone-deep "^0.3.0"
+ loader-utils "^1.0.1"
+ lodash.tail "^4.1.1"
+ pify "^3.0.0"
+
+sax@~1.2.1:
+ version "1.2.4"
+ resolved "https://registry.yarnpkg.com/sax/-/sax-1.2.4.tgz#2816234e2378bddc4e5354fab5caa895df7100d9"
+
+schema-utils@^0.3.0:
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/schema-utils/-/schema-utils-0.3.0.tgz#f5877222ce3e931edae039f17eb3716e7137f8cf"
+ dependencies:
+ ajv "^5.0.0"
+
+scss-tokenizer@^0.2.3:
+ version "0.2.3"
+ resolved "http://registry.npm.taobao.org/scss-tokenizer/download/scss-tokenizer-0.2.3.tgz#8eb06db9a9723333824d3f5530641149847ce5d1"
+ dependencies:
+ js-base64 "^2.1.8"
+ source-map "^0.4.2"
+
+select-hose@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/select-hose/download/select-hose-2.0.0.tgz#625d8658f865af43ec962bfc376a37359a4994ca"
+
+selfsigned@^1.9.1:
+ version "1.10.2"
+ resolved "http://registry.npm.taobao.org/selfsigned/download/selfsigned-1.10.2.tgz#b4449580d99929b65b10a48389301a6592088758"
+ dependencies:
+ node-forge "0.7.1"
+
+semantic-ui-react@^0.80.2:
+ version "0.80.2"
+ resolved "http://registry.npm.taobao.org/semantic-ui-react/download/semantic-ui-react-0.80.2.tgz#a584f6dc485b0617438adc4baf6d1858e54bb930"
+ dependencies:
+ "@babel/runtime" "^7.0.0-beta.48"
+ classnames "^2.2.5"
+ fbjs "^0.8.16"
+ keyboard-key "^1.0.1"
+ lodash "^4.17.10"
+ prop-types "^15.6.1"
+
+"semver@2 || 3 || 4 || 5", semver@^5.3.0:
+ version "5.5.0"
+ resolved "https://registry.yarnpkg.com/semver/-/semver-5.5.0.tgz#dc4bbc7a6ca9d916dee5d43516f0092b58f7b8ab"
+
+semver@~5.3.0:
+ version "5.3.0"
+ resolved "http://registry.npm.taobao.org/semver/download/semver-5.3.0.tgz#9b2ce5d3de02d17c6012ad326aa6b4d0cf54f94f"
+
+ version "0.16.2"
+ resolved "http://registry.npm.taobao.org/send/download/send-0.16.2.tgz#6ecca1e0f8c156d141597559848df64730a6bbc1"
+ dependencies:
+ debug "2.6.9"
+ depd "~1.1.2"
+ destroy "~1.0.4"
+ encodeurl "~1.0.2"
+ escape-html "~1.0.3"
+ etag "~1.8.1"
+ fresh "0.5.2"
+ http-errors "~1.6.2"
+ mime "1.4.1"
+ ms "2.0.0"
+ on-finished "~2.3.0"
+ range-parser "~1.2.0"
+ statuses "~1.4.0"
+
+serve-index@^1.7.2:
+ version "1.9.1"
+ resolved "http://registry.npm.taobao.org/serve-index/download/serve-index-1.9.1.tgz#d3768d69b1e7d82e5ce050fff5b453bea12a9239"
+ dependencies:
+ accepts "~1.3.4"
+ batch "0.6.1"
+ debug "2.6.9"
+ escape-html "~1.0.3"
+ http-errors "~1.6.2"
+ mime-types "~2.1.17"
+ parseurl "~1.3.2"
+
+ version "1.13.2"
+ resolved "http://registry.npm.taobao.org/serve-static/download/serve-static-1.13.2.tgz#095e8472fd5b46237db50ce486a43f4b86c6cec1"
+ dependencies:
+ encodeurl "~1.0.2"
+ escape-html "~1.0.3"
+ parseurl "~1.3.2"
+ send "0.16.2"
+
+set-blocking@^2.0.0, set-blocking@~2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/set-blocking/-/set-blocking-2.0.0.tgz#045f9782d011ae9a6803ddd382b24392b3d890f7"
+
+set-immediate-shim@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/set-immediate-shim/-/set-immediate-shim-1.0.1.tgz#4b2b1b27eb808a9f8dcc481a58e5e56f599f3f61"
+
+set-value@^0.4.3:
+ version "0.4.3"
+ resolved "https://registry.yarnpkg.com/set-value/-/set-value-0.4.3.tgz#7db08f9d3d22dc7f78e53af3c3bf4666ecdfccf1"
+ dependencies:
+ extend-shallow "^2.0.1"
+ is-extendable "^0.1.1"
+ is-plain-object "^2.0.1"
+ to-object-path "^0.3.0"
+
+set-value@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/set-value/-/set-value-2.0.0.tgz#71ae4a88f0feefbbf52d1ea604f3fb315ebb6274"
+ dependencies:
+ extend-shallow "^2.0.1"
+ is-extendable "^0.1.1"
+ is-plain-object "^2.0.3"
+ split-string "^3.0.1"
+
+setimmediate@^1.0.4, setimmediate@^1.0.5:
+ version "1.0.5"
+ resolved "https://registry.yarnpkg.com/setimmediate/-/setimmediate-1.0.5.tgz#290cbb232e306942d7d7ea9b83732ab7856f8285"
+
+ version "1.0.3"
+ resolved "http://registry.npm.taobao.org/setprototypeof/download/setprototypeof-1.0.3.tgz#66567e37043eeb4f04d91bd658c0cbefb55b8e04"
+
+ version "1.1.0"
+ resolved "http://registry.npm.taobao.org/setprototypeof/download/setprototypeof-1.1.0.tgz#d0bd85536887b6fe7c0d818cb962d9d91c54e656"
+
+sha.js@^2.4.0, sha.js@^2.4.8:
+ version "2.4.10"
+ resolved "https://registry.yarnpkg.com/sha.js/-/sha.js-2.4.10.tgz#b1fde5cd7d11a5626638a07c604ab909cfa31f9b"
+ dependencies:
+ inherits "^2.0.1"
+ safe-buffer "^5.0.1"
+
+shallow-clone@^0.1.2:
+ version "0.1.2"
+ resolved "https://registry.yarnpkg.com/shallow-clone/-/shallow-clone-0.1.2.tgz#5909e874ba77106d73ac414cfec1ffca87d97060"
+ dependencies:
+ is-extendable "^0.1.1"
+ kind-of "^2.0.1"
+ lazy-cache "^0.2.3"
+ mixin-object "^2.0.1"
+
+shebang-command@^1.2.0:
+ version "1.2.0"
+ resolved "https://registry.yarnpkg.com/shebang-command/-/shebang-command-1.2.0.tgz#44aac65b695b03398968c39f363fee5deafdf1ea"
+ dependencies:
+ shebang-regex "^1.0.0"
+
+shebang-regex@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/shebang-regex/-/shebang-regex-1.0.0.tgz#da42f49740c0b42db2ca9728571cb190c98efea3"
+
+signal-exit@^3.0.0:
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/signal-exit/-/signal-exit-3.0.2.tgz#b5fdc08f1287ea1178628e415e25132b73646c6d"
+
+slash@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/slash/-/slash-1.0.0.tgz#c41f2f6c39fc16d1cd17ad4b5d896114ae470d55"
+
+snapdragon-node@^2.0.1:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/snapdragon-node/-/snapdragon-node-2.1.1.tgz#6c175f86ff14bdb0724563e8f3c1b021a286853b"
+ dependencies:
+ define-property "^1.0.0"
+ isobject "^3.0.0"
+ snapdragon-util "^3.0.1"
+
+snapdragon-util@^3.0.1:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/snapdragon-util/-/snapdragon-util-3.0.1.tgz#f956479486f2acd79700693f6f7b805e45ab56e2"
+ dependencies:
+ kind-of "^3.2.0"
+
+snapdragon@^0.8.1:
+ version "0.8.2"
+ resolved "https://registry.yarnpkg.com/snapdragon/-/snapdragon-0.8.2.tgz#64922e7c565b0e14204ba1aa7d6964278d25182d"
+ dependencies:
+ base "^0.11.1"
+ debug "^2.2.0"
+ define-property "^0.2.5"
+ extend-shallow "^2.0.1"
+ map-cache "^0.2.2"
+ source-map "^0.5.6"
+ source-map-resolve "^0.5.0"
+ use "^3.1.0"
+
+ version "1.0.9"
+ resolved "https://registry.yarnpkg.com/sntp/-/sntp-1.0.9.tgz#6541184cc90aeea6c6e7b35e2659082443c66198"
+ dependencies:
+ hoek "2.x.x"
+
+ version "2.1.0"
+ resolved "http://registry.npm.taobao.org/sntp/download/sntp-2.1.0.tgz#2c6cec14fedc2222739caf9b5c3d85d1cc5a2cc8"
+ dependencies:
+ hoek "4.x.x"
+
+ version "1.1.4"
+ resolved "http://registry.npm.taobao.org/sockjs-client/download/sockjs-client-1.1.4.tgz#5babe386b775e4cf14e7520911452654016c8b12"
+ dependencies:
+ debug "^2.6.6"
+ eventsource "0.1.6"
+ faye-websocket "~0.11.0"
+ inherits "^2.0.1"
+ json3 "^3.3.2"
+ url-parse "^1.1.8"
+
+ version "0.3.18"
+ resolved "http://registry.npm.taobao.org/sockjs/download/sockjs-0.3.18.tgz#d9b289316ca7df77595ef299e075f0f937eb4207"
+ dependencies:
+ faye-websocket "^0.10.0"
+ uuid "^2.0.2"
+
+sort-keys@^1.0.0:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/sort-keys/-/sort-keys-1.1.2.tgz#441b6d4d346798f1b4e49e8920adfba0e543f9ad"
+ dependencies:
+ is-plain-obj "^1.0.0"
+
+source-list-map@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/source-list-map/-/source-list-map-2.0.0.tgz#aaa47403f7b245a92fbc97ea08f250d6087ed085"
+
+source-map-resolve@^0.5.0:
+ version "0.5.1"
+ resolved "https://registry.yarnpkg.com/source-map-resolve/-/source-map-resolve-0.5.1.tgz#7ad0f593f2281598e854df80f19aae4b92d7a11a"
+ dependencies:
+ atob "^2.0.0"
+ decode-uri-component "^0.2.0"
+ resolve-url "^0.2.1"
+ source-map-url "^0.4.0"
+ urix "^0.1.0"
+
+source-map-support@^0.4.15:
+ version "0.4.18"
+ resolved "https://registry.yarnpkg.com/source-map-support/-/source-map-support-0.4.18.tgz#0286a6de8be42641338594e97ccea75f0a2c585f"
+ dependencies:
+ source-map "^0.5.6"
+
+source-map-url@^0.4.0:
+ version "0.4.0"
+ resolved "https://registry.yarnpkg.com/source-map-url/-/source-map-url-0.4.0.tgz#3e935d7ddd73631b97659956d55128e87b5084a3"
+
[email protected], source-map@^0.5.3, source-map@^0.5.6, source-map@^0.5.7, source-map@~0.5.1:
+ version "0.5.7"
+ resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.5.7.tgz#8a039d2d1021d22d1ea14c80d8ea468ba2ef3fcc"
+
+source-map@^0.4.2:
+ version "0.4.4"
+ resolved "http://registry.npm.taobao.org/source-map/download/source-map-0.4.4.tgz#eba4f5da9c0dc999de68032d8b4f76173652036b"
+ dependencies:
+ amdefine ">=0.0.4"
+
+source-map@^0.6.1, source-map@~0.6.1:
+ version "0.6.1"
+ resolved "https://registry.yarnpkg.com/source-map/-/source-map-0.6.1.tgz#74722af32e9614e9c287a8d0bbde48b5e2f1a263"
+
+spdx-correct@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/spdx-correct/-/spdx-correct-3.0.0.tgz#05a5b4d7153a195bc92c3c425b69f3b2a9524c82"
+ dependencies:
+ spdx-expression-parse "^3.0.0"
+ spdx-license-ids "^3.0.0"
+
+spdx-exceptions@^2.1.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/spdx-exceptions/-/spdx-exceptions-2.1.0.tgz#2c7ae61056c714a5b9b9b2b2af7d311ef5c78fe9"
+
+spdx-expression-parse@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz#99e119b7a5da00e05491c9fa338b7904823b41d0"
+ dependencies:
+ spdx-exceptions "^2.1.0"
+ spdx-license-ids "^3.0.0"
+
+spdx-license-ids@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/spdx-license-ids/-/spdx-license-ids-3.0.0.tgz#7a7cd28470cc6d3a1cfe6d66886f6bc430d3ac87"
+
+spdy-transport@^2.0.18:
+ version "2.0.20"
+ resolved "http://registry.npm.taobao.org/spdy-transport/download/spdy-transport-2.0.20.tgz#735e72054c486b2354fe89e702256004a39ace4d"
+ dependencies:
+ debug "^2.6.8"
+ detect-node "^2.0.3"
+ hpack.js "^2.1.6"
+ obuf "^1.1.1"
+ readable-stream "^2.2.9"
+ safe-buffer "^5.0.1"
+ wbuf "^1.7.2"
+
+spdy@^3.4.1:
+ version "3.4.7"
+ resolved "http://registry.npm.taobao.org/spdy/download/spdy-3.4.7.tgz#42ff41ece5cc0f99a3a6c28aabb73f5c3b03acbc"
+ dependencies:
+ debug "^2.6.8"
+ handle-thing "^1.2.5"
+ http-deceiver "^1.2.7"
+ safe-buffer "^5.0.1"
+ select-hose "^2.0.0"
+ spdy-transport "^2.0.18"
+
+split-string@^3.0.1, split-string@^3.0.2:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/split-string/-/split-string-3.1.0.tgz#7cb09dda3a86585705c64b39a6466038682e8fe2"
+ dependencies:
+ extend-shallow "^3.0.0"
+
+sprintf-js@~1.0.2:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/sprintf-js/-/sprintf-js-1.0.3.tgz#04e6926f662895354f3dd015203633b857297e2c"
+
+sshpk@^1.7.0:
+ version "1.14.1"
+ resolved "https://registry.yarnpkg.com/sshpk/-/sshpk-1.14.1.tgz#130f5975eddad963f1d56f92b9ac6c51fa9f83eb"
+ dependencies:
+ asn1 "~0.2.3"
+ assert-plus "^1.0.0"
+ dashdash "^1.12.0"
+ getpass "^0.1.1"
+ optionalDependencies:
+ bcrypt-pbkdf "^1.0.0"
+ ecc-jsbn "~0.1.1"
+ jsbn "~0.1.0"
+ tweetnacl "~0.14.0"
+
+static-extend@^0.1.1:
+ version "0.1.2"
+ resolved "https://registry.yarnpkg.com/static-extend/-/static-extend-0.1.2.tgz#60809c39cbff55337226fd5e0b520f341f1fb5c6"
+ dependencies:
+ define-property "^0.2.5"
+ object-copy "^0.1.0"
+
+"statuses@>= 1.3.1 < 2", statuses@~1.4.0:
+ version "1.4.0"
+ resolved "http://registry.npm.taobao.org/statuses/download/statuses-1.4.0.tgz#bb73d446da2796106efcc1b601a253d6c46bd087"
+
+stdout-stream@^1.4.0:
+ version "1.4.0"
+ resolved "http://registry.npm.taobao.org/stdout-stream/download/stdout-stream-1.4.0.tgz#a2c7c8587e54d9427ea9edb3ac3f2cd522df378b"
+ dependencies:
+ readable-stream "^2.0.1"
+
+stream-browserify@^2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/stream-browserify/-/stream-browserify-2.0.1.tgz#66266ee5f9bdb9940a4e4514cafb43bb71e5c9db"
+ dependencies:
+ inherits "~2.0.1"
+ readable-stream "^2.0.2"
+
+stream-http@^2.7.2:
+ version "2.8.0"
+ resolved "https://registry.yarnpkg.com/stream-http/-/stream-http-2.8.0.tgz#fd86546dac9b1c91aff8fc5d287b98fafb41bc10"
+ dependencies:
+ builtin-status-codes "^3.0.0"
+ inherits "^2.0.1"
+ readable-stream "^2.3.3"
+ to-arraybuffer "^1.0.0"
+ xtend "^4.0.0"
+
+strict-uri-encode@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz#279b225df1d582b1f54e65addd4352e18faa0713"
+
+string-width@^1.0.1, string-width@^1.0.2:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/string-width/-/string-width-1.0.2.tgz#118bdf5b8cdc51a2a7e70d211e07e2b0b9b107d3"
+ dependencies:
+ code-point-at "^1.0.0"
+ is-fullwidth-code-point "^1.0.0"
+ strip-ansi "^3.0.0"
+
+string-width@^2.0.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/string-width/-/string-width-2.1.1.tgz#ab93f27a8dc13d28cac815c462143a6d9012ae9e"
+ dependencies:
+ is-fullwidth-code-point "^2.0.0"
+ strip-ansi "^4.0.0"
+
+string_decoder@^1.0.0:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.1.0.tgz#384f322ee8a848e500effde99901bba849c5d403"
+ dependencies:
+ safe-buffer "~5.1.0"
+
+string_decoder@~0.10.x:
+ version "0.10.31"
+ resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-0.10.31.tgz#62e203bc41766c6c28c9fc84301dab1c5310fa94"
+
+string_decoder@~1.0.3:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/string_decoder/-/string_decoder-1.0.3.tgz#0fc67d7c141825de94282dd536bec6b9bce860ab"
+ dependencies:
+ safe-buffer "~5.1.0"
+
+stringstream@~0.0.4, stringstream@~0.0.5:
+ version "0.0.5"
+ resolved "https://registry.yarnpkg.com/stringstream/-/stringstream-0.0.5.tgz#4e484cd4de5a0bbbee18e46307710a8a81621878"
+
+strip-ansi@^3.0.0, strip-ansi@^3.0.1:
+ version "3.0.1"
+ resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-3.0.1.tgz#6a385fb8853d952d5ff05d0e8aaf94278dc63dcf"
+ dependencies:
+ ansi-regex "^2.0.0"
+
+strip-ansi@^4.0.0:
+ version "4.0.0"
+ resolved "https://registry.yarnpkg.com/strip-ansi/-/strip-ansi-4.0.0.tgz#a8479022eb1ac368a871389b635262c505ee368f"
+ dependencies:
+ ansi-regex "^3.0.0"
+
+strip-bom@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/strip-bom/download/strip-bom-2.0.0.tgz#6219a85616520491f35788bdbf1447a99c7e6b0e"
+ dependencies:
+ is-utf8 "^0.2.0"
+
+strip-bom@^3.0.0:
+ version "3.0.0"
+ resolved "https://registry.yarnpkg.com/strip-bom/-/strip-bom-3.0.0.tgz#2334c18e9c759f7bdd56fdef7e9ae3d588e68ed3"
+
+strip-eof@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/strip-eof/-/strip-eof-1.0.0.tgz#bb43ff5598a6eb05d89b59fcd129c983313606bf"
+
+strip-indent@^1.0.1:
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/strip-indent/download/strip-indent-1.0.1.tgz#0c7962a6adefa7bbd4ac366460a638552ae1a0a2"
+ dependencies:
+ get-stdin "^4.0.1"
+
+strip-json-comments@~2.0.1:
+ version "2.0.1"
+ resolved "https://registry.yarnpkg.com/strip-json-comments/-/strip-json-comments-2.0.1.tgz#3c531942e908c2697c0ec344858c286c7ca0a60a"
+
+ version "0.19.1"
+ resolved "https://registry.yarnpkg.com/style-loader/-/style-loader-0.19.1.tgz#591ffc80bcefe268b77c5d9ebc0505d772619f85"
+ dependencies:
+ loader-utils "^1.0.2"
+ schema-utils "^0.3.0"
+
+supports-color@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-2.0.0.tgz#535d045ce6b6363fa40117084629995e9df324c7"
+
+supports-color@^3.2.3:
+ version "3.2.3"
+ resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-3.2.3.tgz#65ac0504b3954171d8a64946b2ae3cbb8a5f54f6"
+ dependencies:
+ has-flag "^1.0.0"
+
+supports-color@^4.2.1:
+ version "4.5.0"
+ resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-4.5.0.tgz#be7a0de484dec5c5cddf8b3d59125044912f635b"
+ dependencies:
+ has-flag "^2.0.0"
+
+supports-color@^5.2.0, supports-color@^5.3.0:
+ version "5.3.0"
+ resolved "https://registry.yarnpkg.com/supports-color/-/supports-color-5.3.0.tgz#5b24ac15db80fa927cf5227a4a33fd3c4c7676c0"
+ dependencies:
+ has-flag "^3.0.0"
+
+svgo@^0.7.0:
+ version "0.7.2"
+ resolved "https://registry.yarnpkg.com/svgo/-/svgo-0.7.2.tgz#9f5772413952135c6fefbf40afe6a4faa88b4bb5"
+ dependencies:
+ coa "~1.0.1"
+ colors "~1.1.2"
+ csso "~2.3.1"
+ js-yaml "~3.7.0"
+ mkdirp "~0.5.1"
+ sax "~1.2.1"
+ whet.extend "~0.9.9"
+
+tapable@^0.2.7:
+ version "0.2.8"
+ resolved "https://registry.yarnpkg.com/tapable/-/tapable-0.2.8.tgz#99372a5c999bf2df160afc0d74bed4f47948cd22"
+
+tar-pack@^3.4.0:
+ version "3.4.1"
+ resolved "https://registry.yarnpkg.com/tar-pack/-/tar-pack-3.4.1.tgz#e1dbc03a9b9d3ba07e896ad027317eb679a10a1f"
+ dependencies:
+ debug "^2.2.0"
+ fstream "^1.0.10"
+ fstream-ignore "^1.0.5"
+ once "^1.3.3"
+ readable-stream "^2.1.4"
+ rimraf "^2.5.1"
+ tar "^2.2.1"
+ uid-number "^0.0.6"
+
+tar@^2.0.0, tar@^2.2.1:
+ version "2.2.1"
+ resolved "https://registry.yarnpkg.com/tar/-/tar-2.2.1.tgz#8e4d2a256c0e2185c6b18ad694aec968b83cb1d1"
+ dependencies:
+ block-stream "*"
+ fstream "^1.0.2"
+ inherits "2"
+
+thunky@^1.0.2:
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/thunky/download/thunky-1.0.2.tgz#a862e018e3fb1ea2ec3fce5d55605cf57f247371"
+
+time-stamp@^2.0.0:
+ version "2.0.0"
+ resolved "http://registry.npm.taobao.org/time-stamp/download/time-stamp-2.0.0.tgz#95c6a44530e15ba8d6f4a3ecb8c3a3fac46da357"
+
+timers-browserify@^2.0.4:
+ version "2.0.6"
+ resolved "https://registry.yarnpkg.com/timers-browserify/-/timers-browserify-2.0.6.tgz#241e76927d9ca05f4d959819022f5b3664b64bae"
+ dependencies:
+ setimmediate "^1.0.4"
+
+to-arraybuffer@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz#7d229b1fcc637e466ca081180836a7aabff83f43"
+
+to-fast-properties@^1.0.3:
+ version "1.0.3"
+ resolved "https://registry.yarnpkg.com/to-fast-properties/-/to-fast-properties-1.0.3.tgz#b83571fa4d8c25b82e231b06e3a3055de4ca1a47"
+
+to-object-path@^0.3.0:
+ version "0.3.0"
+ resolved "https://registry.yarnpkg.com/to-object-path/-/to-object-path-0.3.0.tgz#297588b7b0e7e0ac08e04e672f85c1f4999e17af"
+ dependencies:
+ kind-of "^3.0.2"
+
+to-regex-range@^2.1.0:
+ version "2.1.1"
+ resolved "https://registry.yarnpkg.com/to-regex-range/-/to-regex-range-2.1.1.tgz#7c80c17b9dfebe599e27367e0d4dd5590141db38"
+ dependencies:
+ is-number "^3.0.0"
+ repeat-string "^1.6.1"
+
+to-regex@^3.0.1:
+ version "3.0.2"
+ resolved "https://registry.yarnpkg.com/to-regex/-/to-regex-3.0.2.tgz#13cfdd9b336552f30b51f33a8ae1b42a7a7599ce"
+ dependencies:
+ define-property "^2.0.2"
+ extend-shallow "^3.0.2"
+ regex-not "^1.0.2"
+ safe-regex "^1.1.0"
+
+toposort@^1.0.0:
+ version "1.0.6"
+ resolved "https://registry.yarnpkg.com/toposort/-/toposort-1.0.6.tgz#c31748e55d210effc00fdcdc7d6e68d7d7bb9cec"
+
+tough-cookie@~2.3.0, tough-cookie@~2.3.3:
+ version "2.3.4"
+ resolved "https://registry.yarnpkg.com/tough-cookie/-/tough-cookie-2.3.4.tgz#ec60cee38ac675063ffc97a5c18970578ee83655"
+ dependencies:
+ punycode "^1.4.1"
+
+trim-newlines@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/trim-newlines/download/trim-newlines-1.0.0.tgz#5887966bb582a4503a41eb524f7d35011815a613"
+
+trim-right@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/trim-right/-/trim-right-1.0.1.tgz#cb2e1203067e0c8de1f614094b9fe45704ea6003"
+
+"true-case-path@^1.0.2":
+ version "1.0.2"
+ resolved "http://registry.npm.taobao.org/true-case-path/download/true-case-path-1.0.2.tgz#7ec91130924766c7f573be3020c34f8fdfd00d62"
+ dependencies:
+ glob "^6.0.4"
+
+ version "0.0.0"
+ resolved "https://registry.yarnpkg.com/tty-browserify/-/tty-browserify-0.0.0.tgz#a157ba402da24e9bf957f9aa69d524eed42901a6"
+
+tunnel-agent@^0.6.0:
+ version "0.6.0"
+ resolved "https://registry.yarnpkg.com/tunnel-agent/-/tunnel-agent-0.6.0.tgz#27a5dea06b36b04a0a9966774b290868f0fc40fd"
+ dependencies:
+ safe-buffer "^5.0.1"
+
+tunnel-agent@~0.4.1:
+ version "0.4.3"
+ resolved "http://registry.npm.taobao.org/tunnel-agent/download/tunnel-agent-0.4.3.tgz#6373db76909fe570e08d73583365ed828a74eeeb"
+
+tweetnacl@^0.14.3, tweetnacl@~0.14.0:
+ version "0.14.5"
+ resolved "https://registry.yarnpkg.com/tweetnacl/-/tweetnacl-0.14.5.tgz#5ae68177f192d4456269d108afa93ff8743f4f64"
+
+type-is@~1.6.15, type-is@~1.6.16:
+ version "1.6.16"
+ resolved "http://registry.npm.taobao.org/type-is/download/type-is-1.6.16.tgz#f89ce341541c672b25ee7ae3c73dee3b2be50194"
+ dependencies:
+ media-typer "0.3.0"
+ mime-types "~2.1.18"
+
+ua-parser-js@^0.7.9:
+ version "0.7.17"
+ resolved "https://registry.yarnpkg.com/ua-parser-js/-/ua-parser-js-0.7.17.tgz#e9ec5f9498b9ec910e7ae3ac626a805c4d09ecac"
+
+ version "3.3.14"
+ resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-3.3.14.tgz#d3d84d18722ff342fa96029cca71c67367700079"
+ dependencies:
+ commander "~2.14.1"
+ source-map "~0.6.1"
+
+uglify-js@^2.8.29:
+ version "2.8.29"
+ resolved "https://registry.yarnpkg.com/uglify-js/-/uglify-js-2.8.29.tgz#29c5733148057bb4e1f75df35b7a9cb72e6a59dd"
+ dependencies:
+ source-map "~0.5.1"
+ yargs "~3.10.0"
+ optionalDependencies:
+ uglify-to-browserify "~1.0.0"
+
+uglify-to-browserify@~1.0.0:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/uglify-to-browserify/-/uglify-to-browserify-1.0.2.tgz#6e0924d6bda6b5afe349e39a6d632850a0f882b7"
+
+uglifyjs-webpack-plugin@^0.4.6:
+ version "0.4.6"
+ resolved "https://registry.yarnpkg.com/uglifyjs-webpack-plugin/-/uglifyjs-webpack-plugin-0.4.6.tgz#b951f4abb6bd617e66f63eb891498e391763e309"
+ dependencies:
+ source-map "^0.5.6"
+ uglify-js "^2.8.29"
+ webpack-sources "^1.0.1"
+
+uid-number@^0.0.6:
+ version "0.0.6"
+ resolved "https://registry.yarnpkg.com/uid-number/-/uid-number-0.0.6.tgz#0ea10e8035e8eb5b8e4449f06da1c730663baa81"
+
+union-value@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/union-value/-/union-value-1.0.0.tgz#5c71c34cb5bad5dcebe3ea0cd08207ba5aa1aea4"
+ dependencies:
+ arr-union "^3.1.0"
+ get-value "^2.0.6"
+ is-extendable "^0.1.1"
+ set-value "^0.4.3"
+
+uniq@^1.0.1:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/uniq/-/uniq-1.0.1.tgz#b31c5ae8254844a3a8281541ce2b04b865a734ff"
+
+uniqid@^4.0.0:
+ version "4.1.1"
+ resolved "https://registry.yarnpkg.com/uniqid/-/uniqid-4.1.1.tgz#89220ddf6b751ae52b5f72484863528596bb84c1"
+ dependencies:
+ macaddress "^0.2.8"
+
+uniqs@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/uniqs/-/uniqs-2.0.0.tgz#ffede4b36b25290696e6e165d4a59edb998e6b02"
+
[email protected], unpipe@~1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/unpipe/download/unpipe-1.0.0.tgz#b2bf4ee8514aae6165b4817829d21b2ef49904ec"
+
+unset-value@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/unset-value/-/unset-value-1.0.0.tgz#8376873f7d2335179ffb1e6fc3a8ed0dfc8ab559"
+ dependencies:
+ has-value "^0.3.1"
+ isobject "^3.0.0"
+
+upath@^1.0.0:
+ version "1.0.4"
+ resolved "https://registry.yarnpkg.com/upath/-/upath-1.0.4.tgz#ee2321ba0a786c50973db043a50b7bcba822361d"
+
+upper-case@^1.1.1:
+ version "1.1.3"
+ resolved "https://registry.yarnpkg.com/upper-case/-/upper-case-1.1.3.tgz#f6b4501c2ec4cdd26ba78be7222961de77621598"
+
+urix@^0.1.0:
+ version "0.1.0"
+ resolved "https://registry.yarnpkg.com/urix/-/urix-0.1.0.tgz#da937f7a62e21fec1fd18d49b35c2935067a6c72"
+
+ version "0.6.2"
+ resolved "http://registry.npm.taobao.org/url-loader/download/url-loader-0.6.2.tgz#a007a7109620e9d988d14bce677a1decb9a993f7"
+ dependencies:
+ loader-utils "^1.0.2"
+ mime "^1.4.1"
+ schema-utils "^0.3.0"
+
+ version "1.0.5"
+ resolved "http://registry.npm.taobao.org/url-parse/download/url-parse-1.0.5.tgz#0854860422afdcfefeb6c965c662d4800169927b"
+ dependencies:
+ querystringify "0.0.x"
+ requires-port "1.0.x"
+
+url-parse@^1.1.8:
+ version "1.2.0"
+ resolved "http://registry.npm.taobao.org/url-parse/download/url-parse-1.2.0.tgz#3a19e8aaa6d023ddd27dcc44cb4fc8f7fec23986"
+ dependencies:
+ querystringify "~1.0.0"
+ requires-port "~1.0.0"
+
+url@^0.11.0:
+ version "0.11.0"
+ resolved "https://registry.yarnpkg.com/url/-/url-0.11.0.tgz#3838e97cfc60521eb73c525a8e55bfdd9e2e28f1"
+ dependencies:
+ punycode "1.3.2"
+ querystring "0.2.0"
+
+use@^3.1.0:
+ version "3.1.0"
+ resolved "https://registry.yarnpkg.com/use/-/use-3.1.0.tgz#14716bf03fdfefd03040aef58d8b4b85f3a7c544"
+ dependencies:
+ kind-of "^6.0.2"
+
+util-deprecate@~1.0.1:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/util-deprecate/-/util-deprecate-1.0.2.tgz#450d4dc9fa70de732762fbd2d4a28981419a0ccf"
+
[email protected], util@^0.10.3:
+ version "0.10.3"
+ resolved "https://registry.yarnpkg.com/util/-/util-0.10.3.tgz#7afb1afe50805246489e3db7fe0ed379336ac0f9"
+ dependencies:
+ inherits "2.0.1"
+
+utila@~0.3:
+ version "0.3.3"
+ resolved "https://registry.yarnpkg.com/utila/-/utila-0.3.3.tgz#d7e8e7d7e309107092b05f8d9688824d633a4226"
+
+utila@~0.4:
+ version "0.4.0"
+ resolved "https://registry.yarnpkg.com/utila/-/utila-0.4.0.tgz#8a16a05d445657a3aea5eecc5b12a4fa5379772c"
+
+ version "1.0.1"
+ resolved "http://registry.npm.taobao.org/utils-merge/download/utils-merge-1.0.1.tgz#9f95710f50a267947b2ccc124741c1028427e713"
+
+uuid@^2.0.2:
+ version "2.0.3"
+ resolved "http://registry.npm.taobao.org/uuid/download/uuid-2.0.3.tgz#67e2e863797215530dff318e5bf9dcebfd47b21a"
+
+uuid@^3.0.0, uuid@^3.1.0:
+ version "3.2.1"
+ resolved "https://registry.yarnpkg.com/uuid/-/uuid-3.2.1.tgz#12c528bb9d58d0b9265d9a2f6f0fe8be17ff1f14"
+
+validate-npm-package-license@^3.0.1:
+ version "3.0.3"
+ resolved "https://registry.yarnpkg.com/validate-npm-package-license/-/validate-npm-package-license-3.0.3.tgz#81643bcbef1bdfecd4623793dc4648948ba98338"
+ dependencies:
+ spdx-correct "^3.0.0"
+ spdx-expression-parse "^3.0.0"
+
+value-equal@^0.4.0:
+ version "0.4.0"
+ resolved "http://registry.npm.taobao.org/value-equal/download/value-equal-0.4.0.tgz#c5bdd2f54ee093c04839d71ce2e4758a6890abc7"
+
+vary@~1.1.2:
+ version "1.1.2"
+ resolved "http://registry.npm.taobao.org/vary/download/vary-1.1.2.tgz#2299f02c6ded30d4a5961b0b9f74524a18f634fc"
+
+vendors@^1.0.0:
+ version "1.0.1"
+ resolved "https://registry.yarnpkg.com/vendors/-/vendors-1.0.1.tgz#37ad73c8ee417fb3d580e785312307d274847f22"
+
+ version "1.10.0"
+ resolved "https://registry.yarnpkg.com/verror/-/verror-1.10.0.tgz#3a105ca17053af55d6e270c1f8288682e18da400"
+ dependencies:
+ assert-plus "^1.0.0"
+ core-util-is "1.0.2"
+ extsprintf "^1.2.0"
+
+ version "0.0.4"
+ resolved "https://registry.yarnpkg.com/vm-browserify/-/vm-browserify-0.0.4.tgz#5d7ea45bbef9e4a6ff65f95438e0a87c357d5a73"
+ dependencies:
+ indexof "0.0.1"
+
+warning@^3.0.0:
+ version "3.0.0"
+ resolved "http://registry.npm.taobao.org/warning/download/warning-3.0.0.tgz#32e5377cb572de4ab04753bdf8821c01ed605b7c"
+ dependencies:
+ loose-envify "^1.0.0"
+
+watchpack@^1.4.0:
+ version "1.5.0"
+ resolved "https://registry.yarnpkg.com/watchpack/-/watchpack-1.5.0.tgz#231e783af830a22f8966f65c4c4bacc814072eed"
+ dependencies:
+ chokidar "^2.0.2"
+ graceful-fs "^4.1.2"
+ neo-async "^2.5.0"
+
+wbuf@^1.1.0, wbuf@^1.7.2:
+ version "1.7.3"
+ resolved "http://registry.npm.taobao.org/wbuf/download/wbuf-1.7.3.tgz#c1d8d149316d3ea852848895cb6a0bfe887b87df"
+ dependencies:
+ minimalistic-assert "^1.0.0"
+
+webpack-dev-middleware@^1.11.0:
+ version "1.12.2"
+ resolved "http://registry.npm.taobao.org/webpack-dev-middleware/download/webpack-dev-middleware-1.12.2.tgz#f8fc1120ce3b4fc5680ceecb43d777966b21105e"
+ dependencies:
+ memory-fs "~0.4.1"
+ mime "^1.5.0"
+ path-is-absolute "^1.0.0"
+ range-parser "^1.0.3"
+ time-stamp "^2.0.0"
+
+ version "2.9.7"
+ resolved "http://registry.npm.taobao.org/webpack-dev-server/download/webpack-dev-server-2.9.7.tgz#100ad6a14775478924d417ca6dcfb9d52a98faed"
+ dependencies:
+ ansi-html "0.0.7"
+ array-includes "^3.0.3"
+ bonjour "^3.5.0"
+ chokidar "^1.6.0"
+ compression "^1.5.2"
+ connect-history-api-fallback "^1.3.0"
+ debug "^3.1.0"
+ del "^3.0.0"
+ express "^4.16.2"
+ html-entities "^1.2.0"
+ http-proxy-middleware "~0.17.4"
+ import-local "^0.1.1"
+ internal-ip "1.2.0"
+ ip "^1.1.5"
+ killable "^1.0.0"
+ loglevel "^1.4.1"
+ opn "^5.1.0"
+ portfinder "^1.0.9"
+ selfsigned "^1.9.1"
+ serve-index "^1.7.2"
+ sockjs "0.3.18"
+ sockjs-client "1.1.4"
+ spdy "^3.4.1"
+ strip-ansi "^3.0.1"
+ supports-color "^4.2.1"
+ webpack-dev-middleware "^1.11.0"
+ yargs "^6.6.0"
+
+webpack-sources@^1.0.1:
+ version "1.1.0"
+ resolved "https://registry.yarnpkg.com/webpack-sources/-/webpack-sources-1.1.0.tgz#a101ebae59d6507354d71d8013950a3a8b7a5a54"
+ dependencies:
+ source-list-map "^2.0.0"
+ source-map "~0.6.1"
+
+ version "3.10.0"
+ resolved "https://registry.yarnpkg.com/webpack/-/webpack-3.10.0.tgz#5291b875078cf2abf42bdd23afe3f8f96c17d725"
+ dependencies:
+ acorn "^5.0.0"
+ acorn-dynamic-import "^2.0.0"
+ ajv "^5.1.5"
+ ajv-keywords "^2.0.0"
+ async "^2.1.2"
+ enhanced-resolve "^3.4.0"
+ escope "^3.6.0"
+ interpret "^1.0.0"
+ json-loader "^0.5.4"
+ json5 "^0.5.1"
+ loader-runner "^2.3.0"
+ loader-utils "^1.1.0"
+ memory-fs "~0.4.1"
+ mkdirp "~0.5.0"
+ node-libs-browser "^2.0.0"
+ source-map "^0.5.3"
+ supports-color "^4.2.1"
+ tapable "^0.2.7"
+ uglifyjs-webpack-plugin "^0.4.6"
+ watchpack "^1.4.0"
+ webpack-sources "^1.0.1"
+ yargs "^8.0.2"
+
+websocket-driver@>=0.5.1:
+ version "0.7.0"
+ resolved "http://registry.npm.taobao.org/websocket-driver/download/websocket-driver-0.7.0.tgz#0caf9d2d755d93aee049d4bdd0d3fe2cca2a24eb"
+ dependencies:
+ http-parser-js ">=0.4.0"
+ websocket-extensions ">=0.1.1"
+
+websocket-extensions@>=0.1.1:
+ version "0.1.3"
+ resolved "http://registry.npm.taobao.org/websocket-extensions/download/websocket-extensions-0.1.3.tgz#5d2ff22977003ec687a4b87073dfbbac146ccf29"
+
+whatwg-fetch@>=0.10.0:
+ version "2.0.3"
+ resolved "https://registry.yarnpkg.com/whatwg-fetch/-/whatwg-fetch-2.0.3.tgz#9c84ec2dcf68187ff00bc64e1274b442176e1c84"
+
+whet.extend@~0.9.9:
+ version "0.9.9"
+ resolved "https://registry.yarnpkg.com/whet.extend/-/whet.extend-0.9.9.tgz#f877d5bf648c97e5aa542fadc16d6a259b9c11a1"
+
+which-module@^1.0.0:
+ version "1.0.0"
+ resolved "http://registry.npm.taobao.org/which-module/download/which-module-1.0.0.tgz#bba63ca861948994ff307736089e3b96026c2a4f"
+
+which-module@^2.0.0:
+ version "2.0.0"
+ resolved "https://registry.yarnpkg.com/which-module/-/which-module-2.0.0.tgz#d9ef07dce77b9902b8a3a8fa4b31c3e3f7e6e87a"
+
+which@1, which@^1.2.9:
+ version "1.3.0"
+ resolved "https://registry.yarnpkg.com/which/-/which-1.3.0.tgz#ff04bdfc010ee547d780bec38e1ac1c2777d253a"
+ dependencies:
+ isexe "^2.0.0"
+
+wide-align@^1.1.0:
+ version "1.1.2"
+ resolved "https://registry.yarnpkg.com/wide-align/-/wide-align-1.1.2.tgz#571e0f1b0604636ebc0dfc21b0339bbe31341710"
+ dependencies:
+ string-width "^1.0.2"
+
+ version "0.1.0"
+ resolved "https://registry.yarnpkg.com/window-size/-/window-size-0.1.0.tgz#5438cd2ea93b202efa3a19fe8887aee7c94f9c9d"
+
+ version "0.0.2"
+ resolved "https://registry.yarnpkg.com/wordwrap/-/wordwrap-0.0.2.tgz#b79669bb42ecb409f83d583cad52ca17eaa1643f"
+
+wrap-ansi@^2.0.0:
+ version "2.1.0"
+ resolved "https://registry.yarnpkg.com/wrap-ansi/-/wrap-ansi-2.1.0.tgz#d8fc3d284dd05794fe84973caecdd1cf824fdd85"
+ dependencies:
+ string-width "^1.0.1"
+ strip-ansi "^3.0.1"
+
+wrappy@1:
+ version "1.0.2"
+ resolved "https://registry.yarnpkg.com/wrappy/-/wrappy-1.0.2.tgz#b5243d8f3ec1aa35f1364605bc0d1036e30ab69f"
+
+xml-char-classes@^1.0.0:
+ version "1.0.0"
+ resolved "https://registry.yarnpkg.com/xml-char-classes/-/xml-char-classes-1.0.0.tgz#64657848a20ffc5df583a42ad8a277b4512bbc4d"
+
+xtend@^4.0.0:
+ version "4.0.1"
+ resolved "https://registry.yarnpkg.com/xtend/-/xtend-4.0.1.tgz#a5c6d532be656e23db820efb943a1f04998d63af"
+
+y18n@^3.2.1:
+ version "3.2.1"
+ resolved "https://registry.yarnpkg.com/y18n/-/y18n-3.2.1.tgz#6d15fba884c08679c0d77e88e7759e811e07fa41"
+
+yallist@^2.1.2:
+ version "2.1.2"
+ resolved "https://registry.yarnpkg.com/yallist/-/yallist-2.1.2.tgz#1c11f9218f076089a47dd512f93c6699a6a81d52"
+
+yargs-parser@^4.2.0:
+ version "4.2.1"
+ resolved "http://registry.npm.taobao.org/yargs-parser/download/yargs-parser-4.2.1.tgz#29cceac0dc4f03c6c87b4a9f217dd18c9f74871c"
+ dependencies:
+ camelcase "^3.0.0"
+
+yargs-parser@^5.0.0:
+ version "5.0.0"
+ resolved "http://registry.npm.taobao.org/yargs-parser/download/yargs-parser-5.0.0.tgz#275ecf0d7ffe05c77e64e7c86e4cd94bf0e1228a"
+ dependencies:
+ camelcase "^3.0.0"
+
+yargs-parser@^7.0.0:
+ version "7.0.0"
+ resolved "https://registry.yarnpkg.com/yargs-parser/-/yargs-parser-7.0.0.tgz#8d0ac42f16ea55debd332caf4c4038b3e3f5dfd9"
+ dependencies:
+ camelcase "^4.1.0"
+
+yargs@^6.6.0:
+ version "6.6.0"
+ resolved "http://registry.npm.taobao.org/yargs/download/yargs-6.6.0.tgz#782ec21ef403345f830a808ca3d513af56065208"
+ dependencies:
+ camelcase "^3.0.0"
+ cliui "^3.2.0"
+ decamelize "^1.1.1"
+ get-caller-file "^1.0.1"
+ os-locale "^1.4.0"
+ read-pkg-up "^1.0.1"
+ require-directory "^2.1.1"
+ require-main-filename "^1.0.1"
+ set-blocking "^2.0.0"
+ string-width "^1.0.2"
+ which-module "^1.0.0"
+ y18n "^3.2.1"
+ yargs-parser "^4.2.0"
+
+yargs@^7.0.0:
+ version "7.1.0"
+ resolved "http://registry.npm.taobao.org/yargs/download/yargs-7.1.0.tgz#6ba318eb16961727f5d284f8ea003e8d6154d0c8"
+ dependencies:
+ camelcase "^3.0.0"
+ cliui "^3.2.0"
+ decamelize "^1.1.1"
+ get-caller-file "^1.0.1"
+ os-locale "^1.4.0"
+ read-pkg-up "^1.0.1"
+ require-directory "^2.1.1"
+ require-main-filename "^1.0.1"
+ set-blocking "^2.0.0"
+ string-width "^1.0.2"
+ which-module "^1.0.0"
+ y18n "^3.2.1"
+ yargs-parser "^5.0.0"
+
+yargs@^8.0.2:
+ version "8.0.2"
+ resolved "https://registry.yarnpkg.com/yargs/-/yargs-8.0.2.tgz#6299a9055b1cefc969ff7e79c1d918dceb22c360"
+ dependencies:
+ camelcase "^4.1.0"
+ cliui "^3.2.0"
+ decamelize "^1.1.1"
+ get-caller-file "^1.0.1"
+ os-locale "^2.0.0"
+ read-pkg-up "^2.0.0"
+ require-directory "^2.1.1"
+ require-main-filename "^1.0.1"
+ set-blocking "^2.0.0"
+ string-width "^2.0.0"
+ which-module "^2.0.0"
+ y18n "^3.2.1"
+ yargs-parser "^7.0.0"
+
+yargs@~3.10.0:
+ version "3.10.0"
+ resolved "https://registry.yarnpkg.com/yargs/-/yargs-3.10.0.tgz#f7ee7bd857dd7c1d2d38c0e74efbd681d1431fd1"
+ dependencies:
+ camelcase "^1.0.2"
+ cliui "^2.1.0"
+ decamelize "^1.0.0"
+ window-size "0.1.0"
+
+ version "4.0.4"
+ resolved "http://registry.npm.taobao.org/zrender/download/zrender-4.0.4.tgz#910e60d888f00c9599073f23758dd23345fe48fd"
diff --git a/web/apps/__init__.py b/web/apps/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/apps/__init__.py
diff --git a/web/apps/test_records/__init__.py b/web/apps/test_records/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/apps/test_records/__init__.py
diff --git a/web/apps/test_records/admin.py b/web/apps/test_records/admin.py
new file mode 100644
index 0000000..edd0260
--- /dev/null
+++ b/web/apps/test_records/admin.py
@@ -0,0 +1,16 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.contrib import admin
+
+# Register your models here.
+from django.contrib import admin
+from .models import TestRecord, TestBranch
+
+class TestRecordAdmin(admin.ModelAdmin):
+ list_display = ('id', 'branch', 'uuid', 'test_machine')
+ list_filter = ('branch',)
+
+admin.site.register(TestRecord, TestRecordAdmin)
+
+admin.site.register(TestBranch) \ No newline at end of file
diff --git a/web/apps/test_records/apps.py b/web/apps/test_records/apps.py
new file mode 100644
index 0000000..fb49fc9
--- /dev/null
+++ b/web/apps/test_records/apps.py
@@ -0,0 +1,8 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.apps import AppConfig
+
+
+class TestsConfig(AppConfig):
+ name = 'test_records'
diff --git a/web/apps/test_records/auth.py b/web/apps/test_records/auth.py
new file mode 100644
index 0000000..cbdf452
--- /dev/null
+++ b/web/apps/test_records/auth.py
@@ -0,0 +1,39 @@
+# -*- coding: utf-8 -*-
+from rest_framework.authtoken.views import ObtainAuthToken
+from rest_framework.authtoken.models import Token
+from rest_framework.response import Response
+from rest_framework.authtoken.serializers import AuthTokenSerializer
+from rest_framework.schemas import ManualSchema
+import coreapi
+import coreschema
+from .models import UserMachine
+
+
+class MachineAuthToken(ObtainAuthToken):
+ # super.schema
+ # super.schema = ManualSchema(
+ # fields=[
+ # coreapi.Field(
+ # name="machine",
+ # required=True,
+ # location='form',
+ # schema=coreschema.String(
+ # title="MachineSNS",
+ # description="Valid MachineSNS for authentication",
+ # ),
+ # ),
+ # ],
+ # encoding="application/json",
+ # )
+
+ def post(self, request, *args, **kwargs):
+ print(self.schema)
+ serializer = self.serializer_class(data=request.data,
+ context={'request': request})
+ serializer.is_valid(raise_exception=True)
+ UserMachine = serializer.validated_data['UserMachine']
+ token, created = Token.objects.get_or_create(UserMachine=UserMachine)
+ return Response({
+ 'token': token.key,
+ 'machine_id': UserMachine,
+ })
diff --git a/web/apps/test_records/exception.py b/web/apps/test_records/exception.py
new file mode 100644
index 0000000..ed9b861
--- /dev/null
+++ b/web/apps/test_records/exception.py
@@ -0,0 +1,4 @@
+# -*- coding: utf-8 -*-
+class TestDataUploadError(RuntimeError):
+ def __init__(self, arg):
+ self.args = arg \ No newline at end of file
diff --git a/web/apps/test_records/filters.py b/web/apps/test_records/filters.py
new file mode 100644
index 0000000..3c3b8fb
--- /dev/null
+++ b/web/apps/test_records/filters.py
@@ -0,0 +1,17 @@
+
+# -*- coding: utf-8 -*-
+import django_filters
+from django.db.models import Q
+
+from test_records.models import TestRecord
+
+
+class TestRecordListFilter(django_filters.rest_framework.FilterSet):
+ """
+ TestRecordListFilter
+ """
+ date = django_filters.DateTimeFilter(name='add_time',lookup_expr='gt')
+ branch = django_filters.CharFilter(name='branch__branch_name')
+ class Meta:
+ model = TestRecord
+ fields = ['date', 'branch'] \ No newline at end of file
diff --git a/web/apps/test_records/models.py b/web/apps/test_records/models.py
new file mode 100644
index 0000000..f2dc376
--- /dev/null
+++ b/web/apps/test_records/models.py
@@ -0,0 +1,269 @@
+from datetime import datetime
+from django.utils import timezone
+from django.db import models
+
+# Create your models here.
+from users.models import UserMachine
+
+
+class TestBranch(models.Model):
+ """
+ test brand
+ """
+ branch_name = models.CharField(max_length=128, unique=True,verbose_name="branch name", help_text="branch name")
+ branch_order = models.IntegerField(default=5,verbose_name=" branch order", help_text="order in all the branch")
+ is_show = models.BooleanField(verbose_name="branch isshow", default=True, help_text="branch isshow")
+ is_accept = models.BooleanField(verbose_name="branch weather accept accept new reports", default=True, help_text="branch weather accept new reports")
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="branch added time",
+ help_text="branch added time")
+
+ class Meta:
+ verbose_name = "test branch"
+ verbose_name_plural = "test branch"
+
+ def __str__(self):
+ return self.branch_name
+
+
+class TestCategory(models.Model):
+ """
+ tests category
+ """
+ cate_name = models.CharField(max_length=64, verbose_name="cate name", help_text="cate name")
+ cate_sn = models.CharField(max_length=32, unique=True, verbose_name="cate sn", help_text="cate sn")
+ # cate_parent = models.ForeignKey("self", verbose_name="parent category", related_name="sub_cat", help_text="parent category")
+ cate_order = models.IntegerField(verbose_name="cate order", help_text="order in the current level")
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="add time", help_text="category added time")
+
+ class Meta:
+ verbose_name = "tests category"
+ verbose_name_plural = "tests category"
+
+ def __str__(self):
+ return self.cate_name
+
+
+class PGInfo(models.Model):
+ """
+ pg info
+
+ "settings": {
+ "checkpoint_timeout": "15min",
+ "log_temp_files": "32",
+ "work_mem": "64MB",
+ "log_line_prefix": "%n %t ",
+ "shared_buffers": "1GB",
+ "log_autovacuum_min_duration": "0",
+ "checkpoint_completion_target": "0.9",
+ "maintenance_work_mem": "128MB",
+ "log_checkpoints": "on",
+ "max_wal_size": "4GB",
+ "min_wal_size": "2GB"
+ }
+ """
+ checkpoint_timeout =models.IntegerField(verbose_name="checkpoint_timeout", help_text="checkpoint_timeout")
+ log_temp_files = models.IntegerField(verbose_name="log_temp_files", help_text="log_temp_files")
+ work_mem = models.IntegerField(verbose_name="work_mem", help_text="work_mem")
+ log_line_prefix = models.CharField(max_length=64,verbose_name="checkpoint_timeout", help_text="checkpoint_timeout")
+ shared_buffers = models.IntegerField(verbose_name="shared_buffers", help_text="shared_buffers")
+ log_autovacuum_min_duration =models.IntegerField(verbose_name="log_autovacuum_min_duration", help_text="log_autovacuum_min_duration")
+
+
+ checkpoint_completion_target =models.DecimalField(max_digits=8, decimal_places=4,verbose_name="checkpoint_completion_target", help_text="checkpoint_completion_target")
+ maintenance_work_mem = models.IntegerField(verbose_name="maintenance_work_mem", help_text="maintenance_work_mem")
+
+ SWITCH_CHOICE = (
+ (1, 'on'),
+ (2, 'off')
+ )
+ log_checkpoints = models.IntegerField(choices=SWITCH_CHOICE,verbose_name="log_checkpoints", help_text="log_checkpoints")
+ max_wal_size =models.IntegerField(verbose_name="max_wal_size", help_text="max_wal_size")
+ min_wal_size =models.IntegerField(verbose_name="min_wal_size", help_text="min_wal_size")
+
+ # pg_branch = models.ForeignKey(TestBranch, verbose_name="pg branch", help_text="pg branch")
+
+ class Meta:
+ verbose_name = "pg info"
+ verbose_name_plural = "pg info"
+
+
+class MetaInfo(models.Model):
+ """
+ meta info
+ """
+ date = models.DateTimeField(verbose_name="date", help_text="date")
+ uname = models.TextField(verbose_name="uname", help_text="uname")
+ benchmark = models.TextField(verbose_name="benchmark", help_text="benchmark")
+ name = models.TextField(verbose_name="name", help_text="name")
+
+ class Meta:
+ verbose_name = "meta info"
+ verbose_name_plural = "meta info"
+
+
+class LinuxInfo(models.Model):
+ """
+ linux info
+ """
+ mounts = models.TextField(verbose_name="mounts", help_text="mounts")
+ cpuinfo = models.TextField(verbose_name="cpuinfo", help_text="cpuinfo")
+ sysctl = models.TextField(verbose_name="sysctl", help_text="sysctl")
+ meminfo = models.TextField(verbose_name="meminfo", help_text="meminfo")
+
+ class Meta:
+ verbose_name = "linux info"
+ verbose_name_plural = "linux info"
+
+ def __str__(self):
+ return self.mounts
+
+
+class TestRecord(models.Model):
+ """
+ test record
+ """
+ branch = models.ForeignKey(TestBranch, verbose_name="pg branch", help_text="pg branch")
+ test_machine = models.ForeignKey(UserMachine, verbose_name="test owner",
+ help_text="person who add this test item")
+ pg_info = models.ForeignKey(PGInfo, verbose_name="pg info", help_text="pg info")
+ meta_info = models.ForeignKey(MetaInfo, verbose_name="meta info", help_text="meta info")
+ linux_info = models.ForeignKey(LinuxInfo, verbose_name="linux info", help_text="linux info")
+ test_desc = models.TextField(verbose_name="test desc", help_text="test desc")
+ # test_branch_id = models.ForeignKey(TestBranch, verbose_name="test category", help_text="test category")
+ meta_time = models.DateTimeField(default=timezone.now, verbose_name="meta time")
+ hash = models.CharField(unique=True, default='', max_length=128, verbose_name="record hash",
+ help_text="record hash")
+ uuid = models.CharField(unique=True, default='', max_length=64, verbose_name="record uuid", help_text="record uuid")
+ commit = models.CharField(max_length=64, verbose_name="record commit", help_text="record commit")
+
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="test added time")
+
+ class Meta:
+ verbose_name = "tests"
+ verbose_name_plural = "tests"
+
+
+# class AbstractTestDataSet(models.Model):
+# prev = models.ForeignKey('self',blank=True, null=True, related_name='none')
+# class Meta:
+# abstract = True
+
+class TestDataSet(models.Model):
+ test_record = models.ForeignKey(TestRecord, verbose_name="test record id", help_text="test record id")
+ test_cate = models.ForeignKey(TestCategory, verbose_name="test cate id", help_text="test cate id")
+ clients = models.IntegerField(verbose_name="clients", help_text="clients of the test dataset")
+ scale = models.IntegerField(verbose_name="scale", help_text="scale of the test dataset")
+ std = models.DecimalField(max_digits=18, decimal_places=8, verbose_name="std", help_text="std of the test dataset")
+ metric = models.DecimalField(max_digits=18, decimal_places=8, verbose_name="metric",
+ help_text="metric of the test dataset")
+ median = models.DecimalField(max_digits=18, decimal_places=8, verbose_name="median",
+ help_text="median of the test dataset")
+
+ STATUS_CHOICE = (
+ (-1, 'none'),
+ (1, 'improved'),
+ (2, 'quo'),
+ (3, 'regressive'),
+ )
+ status = models.IntegerField(choices=STATUS_CHOICE, verbose_name="status", help_text="status of this dataset")
+ percentage = models.DecimalField(max_digits=8, decimal_places=4, verbose_name="percentage",
+ help_text="percentage compared to previous dataset")
+
+ prev = models.ForeignKey('self', blank=True, null=True, related_name='prev1',
+ verbose_name="previous test dataset id", help_text="previous test dataset id")
+ # prev = models.ForeignKey('self',verbose_name="previous test dataset id", help_text="previous test dataset id")
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="test dataset time")
+
+ class Meta:
+ verbose_name = "test dataset"
+ verbose_name_plural = "test dataset"
+
+
+from django.db.models.signals import pre_save
+from django.dispatch import receiver
+
+
+@receiver(pre_save, sender=TestDataSet)
+def calc_status(sender, instance, **kwargs):
+ print('dataset:' + str(instance.id) + " prev:" + str(instance.prev) + " will be save ")
+
+ # record_id = instance.test_record.id
+ machine_id = instance.test_record.test_machine_id
+ add_time = instance.test_record.add_time
+ branch = instance.test_record.branch
+ prevRecord = TestRecord.objects.order_by('-add_time').filter(test_machine_id=machine_id,branch=branch,
+ add_time__lt=add_time).first()
+ if (prevRecord == None):
+ print("prev record not found")
+ return
+ # print("previd is: " + str(prevRecord.id))
+ prevTestDataSet = TestDataSet.objects.filter(test_record_id=prevRecord.id, scale=instance.scale,
+ clients=instance.clients, test_cate_id=instance.test_cate_id).first()
+
+ if (prevTestDataSet == None):
+ # print("prev dataset not found")
+ return
+
+ # print("prev dataset is: " + str(prevTestDataSet.id))
+
+ percentage = (instance.metric - prevTestDataSet.metric) / prevTestDataSet.metric
+ # print('instance.metric is:' + str(instance.metric))
+ # print('prevTestDataSet.metric is:' + str(prevTestDataSet.metric))
+ # print('percentage is:' + str(percentage))
+ status = 0
+ if (percentage >= 0.05):
+ status = 1
+ elif (percentage <= -0.05):
+ status = 3
+ else:
+ status = 2
+
+ instance.percentage = percentage
+ instance.status = status
+ instance.prev_id = prevTestDataSet.id
+
+ return
+
+
+class TestResult(models.Model):
+ """
+ test result sample:
+
+ "latency": -1,
+ "scale": "10",
+ "end": 1526184453.133798,
+ "clients": "2",
+ "start": 1526184333.102856,
+ "run": 0,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "369.666116",
+ "read-only": false
+
+ """
+
+ test_dataset = models.ForeignKey(TestDataSet, verbose_name="test dataset id", help_text="test dataset id")
+ # test_cate = models.ForeignKey(TestCategory, verbose_name="test category", help_text="test category")
+ latency = models.IntegerField(verbose_name="latency", help_text="latency of the test result")
+ scale = models.IntegerField(verbose_name="scale", help_text="scale of the test result")
+ end = models.DecimalField(max_digits=16, decimal_places=6, verbose_name="end",
+ help_text="endtime of the test result")
+ clients = models.IntegerField(verbose_name="clients", help_text="clients of the test result")
+ start = models.DecimalField(max_digits=16, decimal_places=6, verbose_name="start",
+ help_text="starttime of the test result")
+ tps = models.DecimalField(default=0, max_digits=18, decimal_places=6, verbose_name="tps",
+ help_text="tps of the test result")
+ run = models.IntegerField(verbose_name="run", help_text="run number")
+ threads = models.IntegerField(verbose_name="threads", help_text="threads of the test result")
+
+ MODE_CHOICE = (
+ (1, 'simple'),
+ (2, 'other'),
+ )
+ mode = models.IntegerField(choices=MODE_CHOICE, verbose_name="mode", help_text="test mode")
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="test result added time")
+
+ class Meta:
+ verbose_name = "test result"
+ verbose_name_plural = "test result"
diff --git a/web/apps/test_records/serializer.py b/web/apps/test_records/serializer.py
new file mode 100644
index 0000000..5decb02
--- /dev/null
+++ b/web/apps/test_records/serializer.py
@@ -0,0 +1,472 @@
+from rest_framework import serializers
+
+from pgperffarm.settings import DB_ENUM
+from test_records.models import TestRecord, TestResult, PGInfo, LinuxInfo, MetaInfo, TestDataSet, TestCategory, \
+ TestBranch
+from users.serializer import UserMachineSerializer
+from users.models import UserMachine
+from django.db.models import Count
+
+
+class TestBranchSerializer(serializers.ModelSerializer):
+ '''
+ use TestBranchSerializer
+ '''
+
+ class Meta:
+ model = TestBranch
+ fields = ('branch_name', 'id')
+
+
+class TestCategorySerializer(serializers.ModelSerializer):
+ '''
+ use TestCategorySerializer
+ '''
+
+ class Meta:
+ model = TestCategory
+ fields = ('cate_name', 'cate_sn')
+
+
+class CreatePGInfoSerializer(serializers.ModelSerializer):
+ '''
+ use CreatePGInfoSerializer
+ '''
+
+ class Meta:
+ model = PGInfo
+ fields = "__all__"
+
+
+class PGInfoSerializer(serializers.ModelSerializer):
+ '''
+ use PGInfoSerializer
+ "settings": {
+ "checkpoint_timeout": "15min",
+ "log_temp_files": "32",
+ "work_mem": "64MB",
+ "log_line_prefix": "%n %t ",
+ "shared_buffers": "1GB",
+ "log_autovacuum_min_duration": "0",
+ "checkpoint_completion_target": "0.9",
+ "maintenance_work_mem": "128MB",
+ "log_checkpoints": "on",
+ "max_wal_size": "4GB",
+ "min_wal_size": "2GB"
+ }
+ '''
+ checkpoint_timeout = serializers.SerializerMethodField()
+ work_mem = serializers.SerializerMethodField()
+ shared_buffers = serializers.SerializerMethodField()
+ maintenance_work_mem = serializers.SerializerMethodField()
+ max_wal_size = serializers.SerializerMethodField()
+ min_wal_size = serializers.SerializerMethodField()
+ log_checkpoints = serializers.SerializerMethodField()
+
+ class Meta:
+ model = PGInfo
+ fields = ('checkpoint_timeout', 'log_temp_files', 'work_mem', 'log_line_prefix', 'shared_buffers',
+ 'log_autovacuum_min_duration', 'checkpoint_completion_target', 'maintenance_work_mem',
+ 'log_checkpoints', 'max_wal_size', 'min_wal_size')
+
+ def get_log_checkpoints(self, obj):
+ new_dict = {v: k for k, v in DB_ENUM["general_switch"].items()}
+ return new_dict[obj.log_checkpoints]
+
+ def get_checkpoint_timeout(self, obj):
+ return obj.checkpoint_timeout.__str__() + 'min'
+
+ def get_work_mem(self, obj):
+ return obj.work_mem.__str__() + 'MB'
+
+ def get_shared_buffers(self, obj):
+ return obj.shared_buffers.__str__() + 'GB'
+
+ def get_maintenance_work_mem(self, obj):
+ return obj.maintenance_work_mem.__str__() + 'MB'
+
+ def get_max_wal_size(self, obj):
+ return obj.max_wal_size.__str__() + 'GB'
+
+ def get_min_wal_size(self, obj):
+ return obj.min_wal_size.__str__() + 'GB'
+
+
+class HardwareInfoDetailSerializer(serializers.ModelSerializer):
+ '''
+ use HardwareInfoDetailSerializer
+ '''
+
+ class Meta:
+ model = LinuxInfo
+ fields = ('cpuinfo', 'meminfo')
+
+
+class LinuxInfoDetailSerializer(serializers.ModelSerializer):
+ '''
+ use LinuxInfoDetailSerializer
+ '''
+
+ class Meta:
+ model = LinuxInfo
+ fields = ('mounts', 'sysctl')
+
+
+class LinuxInfoSerializer(serializers.ModelSerializer):
+ '''
+ use LinuxInfoSerializer
+ '''
+
+ class Meta:
+ model = LinuxInfo
+ fields = ('mounts', 'cpuinfo', 'sysctl', 'meminfo')
+
+
+class MetaInfoDetailSerializer(serializers.ModelSerializer):
+ '''
+ use MetaInfoSerializer
+ '''
+
+ class Meta:
+ model = MetaInfo
+ fields = ('uname',)
+
+
+class MetaInfoSerializer(serializers.ModelSerializer):
+ '''
+ use MetaInfoSerializer
+ '''
+
+ class Meta:
+ model = MetaInfo
+ fields = ('date', 'uname', 'benchmark', 'name')
+
+
+class CreateTestResultSerializer(serializers.ModelSerializer):
+ '''
+ use CreateTestResultSerializer
+ '''
+
+ class Meta:
+ model = TestResult
+ fields = "__all__"
+
+
+class TestResultSerializer(serializers.ModelSerializer):
+ '''
+ use TestResultSerializer
+ '''
+ mode = serializers.SerializerMethodField()
+
+ class Meta:
+ model = TestResult
+ fields = "__all__"
+
+ def get_mode(self, obj):
+ new_dict = {v: k for k, v in DB_ENUM["mode"].items()}
+ return new_dict[obj.mode]
+
+
+class CreateTestRecordSerializer(serializers.ModelSerializer):
+ '''
+ create ModelSerializer
+ '''
+
+ # pg_info =PGInfoSerializer()
+ # linux_info = LinuxInfoSerializer()
+ # meta_info = MetaInfoSerializer()
+
+ class Meta:
+ model = TestRecord
+ fields = "__all__"
+
+
+class CreateTestDateSetSerializer(serializers.ModelSerializer):
+ '''
+ create TestDateSetSerializer
+ 'test_record': testRecordRet.id,
+ 'clients': client_num,
+ 'scale': scale,
+ 'std': dataset['std'],
+ 'metric': dataset['metric'],
+ 'median': dataset['median'],
+ 'test_cate': test_cate.id,
+ # status,percentage calc by tarr
+ 'status': -1,
+ 'percentage': 0.0,
+ '''
+
+ class Meta:
+ model = TestDataSet
+ fields = "__all__"
+
+
+class TestStatusRecordListSerializer(serializers.ModelSerializer):
+ '''
+ use ModelSerializer
+ '''
+ pg_info = PGInfoSerializer()
+ linux_info = LinuxInfoSerializer()
+ meta_info = MetaInfoSerializer()
+ branch = serializers.SerializerMethodField()
+ trend = serializers.SerializerMethodField()
+ machine_info = serializers.SerializerMethodField()
+
+ # client_max_num = serializers.SerializerMethodField()
+ class Meta:
+ model = TestRecord
+ fields = ('uuid', 'add_time', 'machine_info', 'pg_info', 'branch', 'trend', 'linux_info', 'meta_info')
+
+ def get_branch(self, obj):
+ branch = TestBranch.objects.filter(id=obj.branch.id).first()
+
+ serializer = TestBranchSerializer(branch)
+ return serializer.data["branch_name"]
+
+ def get_trend(self, obj):
+ dataset_list = TestDataSet.objects.filter(test_record_id=obj.id).values_list('status').annotate(Count('id'))
+ data_list_count = TestDataSet.objects.filter(test_record_id=obj.id).count()
+
+ trend = {}
+ trend['improved'] = 0
+ trend['quo'] = 0
+ trend['regressive'] = 0
+ trend['none'] = 0
+ trend['is_first'] = False
+ for i in dataset_list:
+ if i[0] == DB_ENUM['status']['improved']:
+ trend['improved'] += i[1]
+ elif i[0] == DB_ENUM['status']['quo']:
+ trend['quo'] += i[1]
+ elif i[0] == DB_ENUM['status']['regressive']:
+ trend['regressive'] += i[1]
+ elif i[0] == DB_ENUM['status']['none']:
+ trend['none'] += i[1]
+
+ if (data_list_count == trend['none']):
+ trend['is_first'] = True
+
+ print str(data_list_count)
+ return trend
+
+ def get_machine_info(self, obj):
+ machine_data = UserMachine.objects.filter(id=obj.test_machine_id)
+
+ machine_info_serializer = UserMachineSerializer(machine_data, many=True)
+ return machine_info_serializer.data
+
+ # def get_client_max_num(self, obj):
+ # ro_client_num = TestResult.objects.filter(Q(test_record_id=obj.id ) ,test_cate_id=1).order_by('clients').distinct('clients').count()
+ # rw_client_num = TestResult.objects.filter(Q(test_record_id=obj.id ) ,test_cate_id=2).order_by('clients').distinct('clients').count()
+ # return max(ro_client_num,rw_client_num)
+
+
+class TestRecordListSerializer(serializers.ModelSerializer):
+ '''
+ use ModelSerializer
+ '''
+ # pg_info = PGInfoSerializer()
+ linux_info = LinuxInfoSerializer()
+ meta_info = MetaInfoSerializer()
+ branch = serializers.SerializerMethodField()
+ trend = serializers.SerializerMethodField()
+ machine_info = serializers.SerializerMethodField()
+
+ # client_max_num = serializers.SerializerMethodField()
+ class Meta:
+ model = TestRecord
+ fields = ('uuid', 'add_time', 'machine_info', 'branch', 'trend', 'linux_info', 'meta_info', 'commit')
+
+ def get_branch(self, obj):
+ branch = TestBranch.objects.filter(id=obj.branch.id).first()
+
+ serializer = TestBranchSerializer(branch)
+ return serializer.data["branch_name"]
+
+ def get_trend(self, obj):
+ dataset_list = TestDataSet.objects.filter(test_record_id=obj.id).values_list('status').annotate(Count('id'))
+ data_list_count = TestDataSet.objects.filter(test_record_id=obj.id).count()
+
+ trend = {}
+ trend['improved'] = 0
+ trend['quo'] = 0
+ trend['regressive'] = 0
+ trend['none'] = 0
+ trend['is_first'] = False
+ for i in dataset_list:
+ if i[0] == DB_ENUM['status']['improved']:
+ trend['improved'] += i[1]
+ elif i[0] == DB_ENUM['status']['quo']:
+ trend['quo'] += i[1]
+ elif i[0] == DB_ENUM['status']['regressive']:
+ trend['regressive'] += i[1]
+ elif i[0] == DB_ENUM['status']['none']:
+ trend['none'] += i[1]
+
+ if (data_list_count == trend['none']):
+ trend['is_first'] = True
+
+ print str(data_list_count)
+ return trend
+
+ def get_machine_info(self, obj):
+ machine_data = UserMachine.objects.filter(id=obj.test_machine_id).get()
+
+ machine_info_serializer = UserMachineSerializer(machine_data)
+ return machine_info_serializer.data
+
+ # def get_client_max_num(self, obj):
+ # ro_client_num = TestResult.objects.filter(Q(test_record_id=obj.id ) ,test_cate_id=1).order_by('clients').distinct('clients').count()
+ # rw_client_num = TestResult.objects.filter(Q(test_record_id=obj.id ) ,test_cate_id=2).order_by('clients').distinct('clients').count()
+ # return max(ro_client_num,rw_client_num)
+
+
+class TestDataSetDetailSerializer(serializers.ModelSerializer):
+ results = serializers.SerializerMethodField()
+
+ class Meta:
+ model = TestDataSet
+ fields = "__all__"
+
+ def get_results(self, obj):
+ all_data = TestResult.objects.filter(test_dataset=obj.id)
+
+ serializer = TestResultSerializer(all_data, many=True)
+ return serializer.data
+
+
+class TestRecordDetailSerializer(serializers.ModelSerializer):
+ '''
+ use ModelSerializer
+ '''
+ branch = serializers.SerializerMethodField()
+ date = serializers.SerializerMethodField()
+ pg_info = PGInfoSerializer()
+ linux_info = LinuxInfoDetailSerializer()
+ test_machine = UserMachineSerializer()
+ hardware_info = serializers.SerializerMethodField()
+ meta_info = MetaInfoDetailSerializer()
+ dataset_info = serializers.SerializerMethodField()
+
+ prev = serializers.SerializerMethodField()
+ class Meta:
+ model = TestRecord
+ fields = (
+ 'branch', 'date', 'uuid', 'pg_info', 'linux_info', 'hardware_info', 'meta_info', 'dataset_info',
+ 'test_desc', 'meta_time', 'test_machine', 'commit', 'prev')
+
+ def get_prev(self, obj):
+ target = TestDataSet.objects.filter(test_record_id=obj.id).first()
+ serializer = TestDataSetDetailSerializer(target)
+ prev = serializer.data["prev"]
+ target = TestDataSet.objects.filter(id=prev).first()
+ serializer = TestDataSetDetailSerializer(target)
+ record_id = serializer.data["test_record"]
+
+ target_record= TestRecord.objects.filter(id=record_id).first()
+ serializer = TestRecordDetailSerializer(target_record)
+ return serializer.data["uuid"]
+
+ def get_branch(self, obj):
+ branch = TestBranch.objects.filter(id=obj.branch_id).first()
+
+ serializer = TestBranchSerializer(branch)
+ return serializer.data["branch_name"]
+
+ def get_date(self, obj):
+ target_meta_info = MetaInfo.objects.filter(id=obj.meta_info.id).first()
+
+ return target_meta_info.date
+
+ def get_hardware_info(self, obj):
+ target_data = LinuxInfo.objects.filter(id=obj.linux_info.id).first()
+
+ hardware_info_serializer = HardwareInfoDetailSerializer(target_data)
+ return hardware_info_serializer.data
+
+ def get_dataset_info(self, obj):
+ dataset_list = TestDataSet.objects.filter(test_record_id=obj.id).values_list('test_cate_id').annotate(
+ Count('id'))
+ # print(dataset_list)
+
+ dataset = {}
+ # < QuerySet[(1, 3), (2, 3)] >
+
+ for cate_item in dataset_list:
+
+ cate_info = TestCategory.objects.filter(id=cate_item[0]).first()
+ cate_info_serializer = TestCategorySerializer(cate_info)
+ cate_sn = cate_info_serializer.data["cate_sn"]
+ dataset[cate_sn] = {}
+
+ dataset_scale_list = TestDataSet.objects.filter(test_record_id=obj.id, test_cate=cate_item[0]).values_list(
+ 'scale').annotate(Count('id'))
+ # print(dataset_scale_list) # <QuerySet [(10, 2), (20, 1)]>
+ for scale_item in dataset_scale_list:
+ dataset[cate_sn][scale_item[0]] = {}
+
+ dataset_client_list = TestDataSet.objects.filter(test_record_id=obj.id,
+ test_cate=cate_item[0],
+ scale=scale_item[0]).values_list(
+ 'clients').annotate(Count('id'))
+ # print(dataset_client_list) # <QuerySet [(1, 1), (2, 1), (4, 1)]>
+ for client_item in dataset_client_list:
+ dataset[cate_sn][scale_item[0]][client_item[0]] = []
+ target_dataset = TestDataSet.objects.filter(test_record_id=obj.id, test_cate=cate_item[0],
+ scale=scale_item[0], clients=client_item[0])
+
+ dataset_serializer = TestDataSetDetailSerializer(target_dataset, many=True)
+ dataset[cate_sn][scale_item[0]][client_item[0]] = dataset_serializer.data
+
+ return dataset
+
+
+class MachineHistoryRecordSerializer(serializers.ModelSerializer):
+ '''
+ use MachineHistoryRecordSerializer
+ '''
+ machine_info = serializers.SerializerMethodField()
+ reports = serializers.SerializerMethodField()
+ branches = serializers.SerializerMethodField()
+
+ class Meta:
+ model = UserMachine
+ fields = ('machine_info', 'reports', 'branches')
+
+ def get_reports(self, obj):
+ target_records = TestRecord.objects.filter(test_machine_id=obj.id).values_list(
+ 'branch').annotate(Count('id'))
+ # print(target_records) # <QuerySet [(2, 2), (1, 3)]>
+ ret = []
+ for branch_item in target_records:
+ item = {}
+ item['branch'] = branch_item[0]
+
+ records = TestRecord.objects.filter(test_machine_id=obj.id, branch_id=branch_item[0])
+
+ serializer = TestRecordListSerializer(records, many=True)
+ item['records'] = serializer.data
+ ret.append(item)
+ return ret
+
+ def get_machine_info(self, obj):
+ target_machine = UserMachine.objects.filter(id=obj.id).first()
+ serializer = UserMachineSerializer(target_machine)
+
+ return serializer.data
+
+ def get_branches(self, obj):
+ target_records = TestRecord.objects.filter(test_machine_id=obj.id).values_list(
+ 'branch').annotate(Count('id'))
+
+ ret = []
+ for branch_item in target_records:
+ item = {}
+ item['value'] = branch_item[0]
+
+ branch = TestBranch.objects.filter(id=branch_item[0]).first()
+ serializer = TestBranchSerializer(branch)
+ item['branch'] = serializer.data["branch_name"]
+ ret.append(item)
+
+ return ret
diff --git a/web/apps/test_records/tests.py b/web/apps/test_records/tests.py
new file mode 100644
index 0000000..5982e6b
--- /dev/null
+++ b/web/apps/test_records/tests.py
@@ -0,0 +1,6 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/web/apps/test_records/view_base.py b/web/apps/test_records/view_base.py
new file mode 100644
index 0000000..401add2
--- /dev/null
+++ b/web/apps/test_records/view_base.py
@@ -0,0 +1,28 @@
+# -*- coding: utf-8 -*-
+from django.views.generic.base import View
+
+class TestListView(View):
+ def get(self, request):
+ '''
+ status page
+ :param request:
+ :return:
+ '''
+ json_list = []
+ # testRecords = TestRecord.objects.all();
+ testRecords = [1,2]
+
+ from django.forms.models import model_to_dict
+ # for record in testRecords:
+ # json_dict = {}
+ # json_dict = model_to_dict(record)
+ #
+ # json_list.append(json_dict)
+
+ import json
+ from django.core import serializers
+ json_data = serializers.serialize('json', testRecords)
+ json_data = json.loads(json_data)
+ from django.http import HttpResponse, JsonResponse
+
+ return JsonResponse(json_data, safe=False) \ No newline at end of file
diff --git a/web/apps/test_records/views.py b/web/apps/test_records/views.py
new file mode 100644
index 0000000..d09484b
--- /dev/null
+++ b/web/apps/test_records/views.py
@@ -0,0 +1,264 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+import django_filters
+import shortuuid
+
+from django.contrib.auth.hashers import make_password
+from rest_framework.pagination import PageNumberPagination
+
+from exception import TestDataUploadError
+from test_records.filters import TestRecordListFilter
+from models import UserMachine, TestCategory, TestBranch
+from pgperffarm.settings import DB_ENUM
+from user_operation.views import UserMachinePermission
+from .serializer import MachineHistoryRecordSerializer, TestStatusRecordListSerializer, TestBranchSerializer, \
+ CreateTestResultSerializer, CreatePGInfoSerializer
+from .serializer import TestRecordListSerializer, TestRecordDetailSerializer, LinuxInfoSerializer, MetaInfoSerializer, \
+ PGInfoSerializer, CreateTestRecordSerializer, CreateTestDateSetSerializer, TestResultSerializer
+
+from rest_framework.decorators import api_view, permission_classes
+from rest_framework.response import Response
+from rest_framework import mixins
+from rest_framework import status
+
+from rest_framework import viewsets
+from .models import TestRecord
+import json
+
+
+class StandardResultsSetPagination(PageNumberPagination):
+ page_size = 20
+ page_size_query_param = 'page_size'
+ max_page_size = 100
+
+class BigResultsSetPagination(PageNumberPagination):
+ page_size = 1000
+ page_size_query_param = 'page_size'
+
+class TestBranchListViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
+ """
+ List test records
+ """
+
+ queryset = TestBranch.objects.all().order_by('branch_order','add_time')
+ serializer_class = TestBranchSerializer
+ pagination_class = BigResultsSetPagination
+
+class TestRecordListViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
+ """
+ List test records
+ """
+
+ queryset = TestRecord.objects.all().order_by('add_time')
+ serializer_class = TestRecordListSerializer
+ pagination_class = StandardResultsSetPagination
+ filter_backends = (django_filters.rest_framework.DjangoFilterBackend,)
+ filter_class = TestRecordListFilter
+
+class TestRecordListByBranchViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
+ """
+ List test records (/status)
+ """
+
+ queryset = TestRecord.objects.order_by('test_machine__alias__name','-add_time').distinct('test_machine__alias__name').all()
+ serializer_class = TestRecordListSerializer
+ pagination_class = StandardResultsSetPagination
+ filter_backends = (django_filters.rest_framework.DjangoFilterBackend,)
+ filter_class = TestRecordListFilter
+
+# @api_view(['GET'])
+# def GetStatusRecordList(request, format=None):
+# """
+# List lastest test records involve all branches
+# """
+#
+# queryset = TestBranch.objects.all().order_by('branch_order').values_list('id','branch_name').annotate(num_records=Count('testrecord')).filter(num_records__gt=0)
+# # print queryset # <QuerySet [(1, u'HEAD', 3), (2, u'10_STABLE', 2)]>
+#
+# ret = {'branch_num':queryset.__len__(),'result':[]}
+# for branch_item in queryset:
+#
+# target_record = TestRecord.objects.filter(branch_id=branch_item[0]).order_by('test_machine_id','-add_time').distinct('test_machine_id').all()
+# # print target_record # <QuerySet [(1, u'HEAD', 3), (2, u'10_STABLE', 2)]>
+# data = TestRecordListSerializer(target_record,many=True)
+# obj = {'branch':branch_item[1],'data':data.data}
+# ret["result"].append(obj)
+# # msg = 'ok!'
+# return Response(ret, status=status.HTTP_201_CREATED)
+
+
+class TestRecordDetailViewSet(mixins.RetrieveModelMixin, viewsets.GenericViewSet):
+ """
+ detail test records
+ """
+ lookup_field = 'uuid'
+ queryset = TestRecord.objects.all().order_by('add_time')
+ serializer_class = TestRecordDetailSerializer
+ # pagination_class = StandardResultsSetPagination
+
+class MachineHistoryRecordViewSet( mixins.RetrieveModelMixin, viewsets.GenericViewSet):
+ """
+ machine info page
+ """
+ lookup_field = 'machine_sn'
+ queryset = UserMachine.objects.all().order_by('add_time')
+ serializer_class = MachineHistoryRecordSerializer
+ # pagination_class = StandardResultsSetPagination
+
+@api_view(['POST'])
+@permission_classes((UserMachinePermission, ))
+def TestRecordCreate(request, format=None):
+ """
+ Receive data from client
+ """
+ print(request.__str__())
+ data = request.data
+
+ print type(data[0])
+ json_data = json.dumps(data[0], encoding="UTF-8", ensure_ascii=False)
+ json_data = json.loads(json_data, encoding="UTF-8")
+ # obj = data[0].pgbench
+ # jsLoads = json.loads(data[0])
+
+ from django.db import transaction
+
+ try:
+ # todo get machine by token
+ secret = request.META.get("HTTP_AUTHORIZATION")
+ ret = UserMachine.objects.filter(machine_secret=secret, state=1).get()
+ test_machine = ret.id
+ if test_machine <= 0:
+ raise TestDataUploadError("The machine is unavailable.")
+
+ record_hash = make_password(str(json_data), 'pg_perf_farm')
+ # print(record_hash.__len__()) 77
+ r = TestRecord.objects.filter(hash=record_hash).count()
+ if r != 0:
+ raise TestDataUploadError("The same record already exists, please do not submit it twice.")
+
+ with transaction.atomic():
+
+ linux_data = json_data['linux']
+ linuxInfo = LinuxInfoSerializer(data=linux_data)
+ linuxInfoRet = None
+ if linuxInfo.is_valid():
+ linuxInfoRet = linuxInfo.save()
+ else:
+ msg = 'linuxInfo invalid'
+ raise TestDataUploadError(msg)
+
+ meta_data = json_data['meta']
+ metaInfo = MetaInfoSerializer(data=meta_data)
+ metaInfoRet = None
+ if metaInfo.is_valid():
+ metaInfoRet = metaInfo.save()
+ else:
+ msg = 'metaInfo invalid'
+ raise TestDataUploadError(msg)
+
+ pg_data = json_data['postgres']
+ branch_str = pg_data['branch']
+ if(branch_str == 'master'):
+ branch_str = 'HEAD'
+
+ branch = TestBranch.objects.filter(branch_name__iexact=branch_str,is_accept=True).get()
+ if not branch:
+ raise TestDataUploadError('The branch name is unavailable.')
+
+ commit = pg_data['commit']
+ pg_settings = pg_data['settings']
+ filtered=['checkpoint_timeout','work_mem','shared_buffers','maintenance_work_mem','max_wal_size','min_wal_size']
+ for item in filtered:
+ pg_settings[item] = pg_settings[item].encode('utf-8')
+ pg_settings[item] = filter(str.isdigit, pg_settings[item])
+
+ pg_settings['log_checkpoints'] = DB_ENUM['general_switch'][pg_settings['log_checkpoints']]
+ pgInfo = CreatePGInfoSerializer(data=pg_settings)
+ pgInfoRet = None
+ if pgInfo.is_valid():
+ pgInfoRet = pgInfo.save()
+ else:
+ msg = pgInfo.errors
+ raise TestDataUploadError(msg)
+
+ test_record_data = {
+ 'pg_info': pgInfoRet.id,
+ 'linux_info': linuxInfoRet.id,
+ 'meta_info': metaInfoRet.id,
+ 'test_machine': test_machine,
+ 'test_desc': 'here is desc',
+ 'meta_time': metaInfoRet.date,
+ 'hash': record_hash,
+ 'commit': commit,
+ 'branch':branch.id,
+ 'uuid': shortuuid.uuid()
+ }
+ testRecord = CreateTestRecordSerializer(data=test_record_data)
+ testRecordRet = None
+ if testRecord.is_valid():
+ testRecordRet = testRecord.save()
+ else:
+ msg = 'testRecord invalid'
+ print(testRecord.errors)
+ raise TestDataUploadError(msg)
+
+ pgbench = json_data['pgbench']
+ # print(type(ro))
+ ro = pgbench['ro']
+ for tag, tag_list in pgbench.iteritems():
+ test_cate = TestCategory.objects.get(cate_sn=tag)
+ if not test_cate:
+ continue
+ else:
+ print test_cate.cate_name
+ for scale, dataset_list in tag_list.iteritems():
+ print "ro[%s]=" % scale, dataset_list
+ for client_num, dataset in dataset_list.iteritems():
+ print 'std is:' + str(dataset['std'])
+
+ test_dataset_data = {
+ 'test_record': testRecordRet.id,
+ 'clients': client_num,
+ 'scale': scale,
+ 'std': dataset['std'],
+ 'metric': dataset['metric'],
+ 'median': dataset['median'],
+ 'test_cate': test_cate.id,
+ # status,percentage will calc by receiver
+ 'status': -1,
+ 'percentage': 0.0,
+ }
+ testDateSet = CreateTestDateSetSerializer(data=test_dataset_data)
+ testDateSetRet = None
+ if testDateSet.is_valid():
+ print 'dataset valid'
+ testDateSetRet = testDateSet.save()
+ else:
+ # print(testDateSet.errors)
+ msg = 'testDateSet invalid'
+ raise TestDataUploadError(msg)
+
+ test_result_list = dataset['results']
+ for test_result in test_result_list:
+ test_result_data = test_result
+ test_result_data['test_dataset'] = testDateSetRet.id
+ test_result_data['mode'] = DB_ENUM['mode'][test_result_data['mode']]
+ testResult = CreateTestResultSerializer(data=test_result_data)
+
+ testResultRet = None
+ if testResult.is_valid():
+ print 'testResult valid'
+ testResultRet = testResult.save()
+ else:
+ # print(testResult.error_messages)
+ msg = testResult.error_messages
+ raise TestDataUploadError(msg)
+
+ except Exception as e:
+ msg = 'upload error:' + e.__str__()
+ # todo add log
+ return Response(msg, status=status.HTTP_202_ACCEPTED)
+
+ msg = 'upload success!'
+ return Response(msg, status=status.HTTP_201_CREATED)
diff --git a/web/apps/user_operation/__init__.py b/web/apps/user_operation/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/apps/user_operation/__init__.py
diff --git a/web/apps/user_operation/admin.py b/web/apps/user_operation/admin.py
new file mode 100644
index 0000000..13be29d
--- /dev/null
+++ b/web/apps/user_operation/admin.py
@@ -0,0 +1,6 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.contrib import admin
+
+# Register your models here.
diff --git a/web/apps/user_operation/apps.py b/web/apps/user_operation/apps.py
new file mode 100644
index 0000000..ff65d1a
--- /dev/null
+++ b/web/apps/user_operation/apps.py
@@ -0,0 +1,8 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.apps import AppConfig
+
+
+class UserOperationConfig(AppConfig):
+ name = 'user_operation'
diff --git a/web/apps/user_operation/filters.py b/web/apps/user_operation/filters.py
new file mode 100644
index 0000000..d429d96
--- /dev/null
+++ b/web/apps/user_operation/filters.py
@@ -0,0 +1,31 @@
+
+# -*- coding: utf-8 -*-
+import django_filters
+from django.db.models import Q
+
+from models import UserMachine
+from test_records.models import TestRecord
+
+
+class MachineRecordListFilter(django_filters.rest_framework.FilterSet):
+ """
+ TestRecordListFilter
+ """
+ branch__id = django_filters.NumberFilter()
+ test_machine__machine_sn = django_filters.CharFilter()
+
+ class Meta:
+ model = TestRecord
+ fields = ['branch__id', 'test_machine__machine_sn']
+
+
+class UserMachineListFilter(django_filters.rest_framework.FilterSet):
+ """
+ UserMachineListFilter
+ """
+
+ # machine_owner__username = django_filters.CharFilter()
+
+ class Meta:
+ model = UserMachine
+ fields = ['machine_owner__username', ] \ No newline at end of file
diff --git a/web/apps/user_operation/models.py b/web/apps/user_operation/models.py
new file mode 100644
index 0000000..804118a
--- /dev/null
+++ b/web/apps/user_operation/models.py
@@ -0,0 +1,5 @@
+from datetime import datetime
+from django.db import models
+
+from users.models import UserMachine
+# Create your models here. \ No newline at end of file
diff --git a/web/apps/user_operation/serializer.py b/web/apps/user_operation/serializer.py
new file mode 100644
index 0000000..1a18f32
--- /dev/null
+++ b/web/apps/user_operation/serializer.py
@@ -0,0 +1,116 @@
+from django.db.models import Count
+from rest_framework import serializers
+
+from pgperffarm.settings import DB_ENUM,AVATAR_URL
+from test_records.serializer import TestRecordListSerializer
+from users.serializer import AliasSerializer, UserMachineSerializer
+from test_records.models import TestRecord
+from users.models import UserMachine, Alias, UserProfile
+import hashlib
+
+
+class UserPortalInfoSerializer(serializers.ModelSerializer):
+ involved = serializers.SerializerMethodField()
+ reports = serializers.SerializerMethodField()
+ machines = serializers.SerializerMethodField()
+ avatar = serializers.SerializerMethodField()
+ date_joined = serializers.SerializerMethodField()
+
+ class Meta:
+ model = UserProfile
+ fields = ('email', 'involved', 'reports', 'date_joined', 'machines', 'avatar')
+
+ def date_joined(self, obj):
+ return obj.date_joined.strftime('%Y')
+
+ def get_avatar(self, obj):
+ email = obj.email
+ avatar = AVATAR_URL + hashlib.md5(email).hexdigest()
+ return avatar
+
+ def get_machines(self, obj):
+ '''
+ machines num
+ '''
+
+ return UserMachine.objects.filter(machine_owner_id=obj.id).count()
+
+ def get_reports(self, obj):
+ '''
+ reports num
+ '''
+ machine_dict = []
+ target_machines = UserMachine.objects.filter(machine_owner_id=obj.id)
+ serializer = UserMachineSerializer(target_machines, many=True)
+ # print(serializer.data)
+ for item in serializer.data:
+ machine_dict.append(item['machine_sn'])
+
+ reports = TestRecord.objects.filter(test_machine__machine_sn__in=machine_dict).count()
+
+ return reports
+
+ def get_involved(self, obj):
+ '''
+ reports, machines, branches
+ '''
+ machine_dict = []
+ target_machines = UserMachine.objects.filter(machine_owner_id=obj.id)
+ serializer = UserMachineSerializer(target_machines, many=True)
+ # print(serializer.data)
+ for item in serializer.data:
+ machine_dict.append(item['machine_sn'])
+
+ reports = TestRecord.objects.filter(test_machine__machine_sn__in=machine_dict).values_list('branch__branch_name').annotate(Count('id'))
+ return reports.count()
+
+class CreateUserMachineSerializer(serializers.ModelSerializer):
+ class Meta:
+ model = UserMachine
+ fields = "__all__"
+
+class UserMachineManageSerializer(serializers.ModelSerializer):
+ '''
+ use UserMachineSerializer
+ '''
+
+ alias = serializers.SerializerMethodField()
+ reports = serializers.SerializerMethodField()
+ lastest = serializers.SerializerMethodField()
+ state = serializers.SerializerMethodField()
+
+ class Meta:
+ model = UserMachine
+ fields = (
+ 'alias', 'machine_sn', 'os_name', 'os_version', 'comp_name', 'comp_version', 'reports', 'state', 'lastest',
+ 'state', 'add_time')
+
+ def get_state(self, obj):
+ state_code = obj.state
+ new_dict = {v: k for k, v in DB_ENUM["machine_state"].items()}
+ return new_dict[state_code]
+
+ def get_alias(self, obj):
+ target_alias = Alias.objects.filter(id=obj.alias_id).first()
+
+ serializer = AliasSerializer(target_alias)
+ return serializer.data['name']
+
+ def get_reports(self, obj):
+ reports_num = TestRecord.objects.filter(test_machine_id=obj.id).count()
+ return reports_num
+
+ def get_lastest(self, obj):
+ record_branch_list = TestRecord.objects.filter(test_machine_id=obj.id).values_list(
+ 'branch').annotate(Count('id'))
+ # < QuerySet[(1, 4), (2, 5)] >
+ ret = []
+ for branch_item in record_branch_list:
+ # branch_name = branch_item[0]
+
+ target_record = TestRecord.objects.filter(test_machine_id=obj.id, branch=branch_item[0]).first()
+ serializer = TestRecordListSerializer(target_record)
+
+ ret.append(serializer.data)
+
+ return ret
diff --git a/web/apps/user_operation/tests.py b/web/apps/user_operation/tests.py
new file mode 100644
index 0000000..5982e6b
--- /dev/null
+++ b/web/apps/user_operation/tests.py
@@ -0,0 +1,6 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/web/apps/user_operation/views.py b/web/apps/user_operation/views.py
new file mode 100644
index 0000000..e7641cf
--- /dev/null
+++ b/web/apps/user_operation/views.py
@@ -0,0 +1,110 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+import django_filters
+from rest_framework import mixins, viewsets, permissions
+
+from rest_framework import authentication
+from rest_framework.pagination import PageNumberPagination
+from rest_framework_jwt.authentication import JSONWebTokenAuthentication
+
+from filters import MachineRecordListFilter, UserMachineListFilter
+from test_records.models import TestRecord
+from users.models import UserMachine, UserProfile
+from users.serializer import CreateUserProfileSerializer
+from serializer import UserMachineManageSerializer, UserPortalInfoSerializer, TestRecordListSerializer, \
+ UserMachineSerializer, CreateUserMachineSerializer
+from rest_framework.response import Response
+from rest_framework import status
+
+class StandardResultsSetPagination(PageNumberPagination):
+ page_size = 20
+ page_size_query_param = 'page_size'
+ max_page_size = 100
+
+class MiddleResultsSetPagination(PageNumberPagination):
+ page_size = 40
+ page_size_query_param = 'page_size'
+ max_page_size = 100
+
+
+class UserMachineRecordByBranchListViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
+ """
+ List machine records by branch
+ """
+
+ queryset = TestRecord.objects.all().order_by('-add_time')
+ serializer_class = TestRecordListSerializer
+ pagination_class = StandardResultsSetPagination
+ filter_backends = (django_filters.rest_framework.DjangoFilterBackend,)
+ filter_class = MachineRecordListFilter
+
+class UserMachineListViewSet(mixins.ListModelMixin, mixins.CreateModelMixin, viewsets.GenericViewSet):
+ """
+ List test records
+ """
+ authentication_classes = (JSONWebTokenAuthentication, authentication.SessionAuthentication )
+ permission_classes = (permissions.IsAuthenticated, )
+ queryset = UserMachine.objects.all().order_by('add_time')
+ serializer_class = UserMachineManageSerializer
+ pagination_class = MiddleResultsSetPagination
+ filter_backends = (django_filters.rest_framework.DjangoFilterBackend,)
+ filter_class = UserMachineListFilter
+
+ def post(self, request, *args, **kwargs):
+ return self.create(request, *args, **kwargs)
+
+ def create(self, request, *args, **kwargs):
+ data = {}
+ data['os_name'] = request.data['os_name']
+ data['os_version'] = request.data['os_version']
+ data['comp_name'] = request.data['comp_name']
+ data['comp_version'] = request.data['comp_version']
+
+ username = request.data['machine_owner']
+ user = UserProfile.objects.filter(username=username).filter().first()
+ user_serializer = CreateUserProfileSerializer(user)
+
+ data['machine_owner'] = user_serializer.data['id']
+
+ serializer = CreateUserMachineSerializer(data=data)
+ serializer.is_valid(raise_exception=True)
+ machine = self.perform_create(serializer)
+
+ headers = self.get_success_headers(serializer.data)
+
+ return Response('success', status=status.HTTP_201_CREATED, headers=headers)
+
+ def perform_create(self, serializer):
+ return serializer.save()
+
+
+class PublicMachineListViewSet(mixins.ListModelMixin, viewsets.GenericViewSet):
+ """
+ List all machines
+ """
+ queryset = UserMachine.objects.all().order_by('add_time')
+ serializer_class = UserMachineManageSerializer
+ pagination_class = MiddleResultsSetPagination
+
+class UserPortalInfoViewSet(mixins.RetrieveModelMixin, viewsets.GenericViewSet):
+ """
+ user info
+ """
+ # authentication_classes = (JSONWebTokenAuthentication, authentication.SessionAuthentication )
+ # permission_classes = (permissions.IsAuthenticated, )
+ lookup_field = 'username'
+ queryset = UserProfile.objects.all()
+ serializer_class = UserPortalInfoSerializer
+
+class UserMachinePermission(permissions.BasePermission):
+ """
+ Machine upload permission check
+ """
+
+ def has_permission(self, request, view):
+ secret = request.META.get("HTTP_AUTHORIZATION")
+ # print(secret)
+ # alias = request.data.alias
+ ret = UserMachine.objects.filter(machine_secret=secret, state=1).exists()
+ return ret
diff --git a/web/apps/users/__init__.py b/web/apps/users/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/apps/users/__init__.py
diff --git a/web/apps/users/admin.py b/web/apps/users/admin.py
new file mode 100644
index 0000000..2c31eef
--- /dev/null
+++ b/web/apps/users/admin.py
@@ -0,0 +1,92 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.contrib import admin
+from asynchronous_send_mail import send_mail
+from django.conf import settings
+# Register your models here.
+from serializer import UserMachineSerializer
+from .models import UserMachine, UserProfile
+
+class UserProfileAdmin(admin.ModelAdmin):
+ list_display = ('id', 'username', 'email', 'is_active', 'last_login', )
+ list_filter = ('is_active',)
+
+
+admin.site.register(UserProfile, UserProfileAdmin)
+
+class UserMachineAdmin(admin.ModelAdmin):
+ list_display = ('id', 'alias', 'state', 'machine_sn', 'machine_secret', )
+ list_filter = ('state',)
+ actions = ['approve_machine','only_approve']
+
+ def approve_machine(self, request, queryset):
+
+ total = 0
+ error = 0
+ success = 0
+ for machine in queryset:
+
+ ret = machine.approve_machine()
+ # ret = {"is_success": True, "alias": self.alias.name, "secret": self.machine_secret, "system": system, "compiler":compiler,"email":user_email}
+
+ if ret['is_success']:
+ success += 1
+ # send email to notice user
+ content = "Greetings,\n\
+\
+The machine you have applied for has been approved.\n\
+Here is the information about it: \n \
+\n \
+alias: %s\n \
+secret: %s\n \
+system: %s\n \
+compiler: %s\n \
+\n \
+Regards,\n \
+PG PERF FARM" % (ret['alias'], ret['secret'], ret['system'], ret['compiler'])
+
+ send_mail('[PG PERF FARM<test mail>]Machine Approval Notice', content, settings.EMAIL_HOST_USER, [ret['email']],
+ fail_silently=False)
+
+ else:
+ error += 1
+
+ total += 1
+
+ # rows_updated = queryset.update(state=1)
+ # message_bit = "%s machine(s)" % rows_updated
+ self.message_user(request,
+ "Total: %s ,Success: %s ,Error: %s. Please make sure there are enough unused aliases." % (
+ total, success, error))
+
+ approve_machine.short_description = u'Approve Machine(Modify the state to active, generate machine_sn, machine_secret and assign an alias)'
+
+ def only_approve(self, request, queryset):
+
+ total = 0
+ error = 0
+ success = 0
+ for machine in queryset:
+
+ ret = machine.approve_machine()
+ # ret = {"is_success": True, "alias": self.alias.name, "secret": self.machine_secret, "system": system, "compiler":compiler,"email":user_email}
+
+ if ret['is_success']:
+ success += 1
+ else:
+ error += 1
+
+ total += 1
+
+ # rows_updated = queryset.update(state=1)
+ # message_bit = "%s machine(s)" % rows_updated
+ self.message_user(request,
+ "Total: %s ,Success: %s ,Error: %s. Please make sure there are enough unused aliases." % (
+ total, success, error))
+ only_approve.short_description = u'Approve Machine(with send emails)'
+
+admin.site.register(UserMachine, UserMachineAdmin)
+
+
+
diff --git a/web/apps/users/apps.py b/web/apps/users/apps.py
new file mode 100644
index 0000000..2519897
--- /dev/null
+++ b/web/apps/users/apps.py
@@ -0,0 +1,8 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.apps import AppConfig
+
+
+class UsersConfig(AppConfig):
+ name = 'users'
diff --git a/web/apps/users/jwt_handler.py b/web/apps/users/jwt_handler.py
new file mode 100644
index 0000000..7dfdb94
--- /dev/null
+++ b/web/apps/users/jwt_handler.py
@@ -0,0 +1,9 @@
+from serializer import JWTUserProfileSerializer
+
+# user jwt handler
+def jwt_response_payload_handler(token, user=None, request=None):
+ return {
+ 'token': token,
+ 'username': JWTUserProfileSerializer(user).data['username'],
+ 'status': 1
+ } \ No newline at end of file
diff --git a/web/apps/users/models.py b/web/apps/users/models.py
new file mode 100644
index 0000000..6db5ace
--- /dev/null
+++ b/web/apps/users/models.py
@@ -0,0 +1,100 @@
+from datetime import datetime
+from django.utils.timezone import utc
+import shortuuid
+
+import hashlib
+from django.contrib.auth.hashers import make_password
+from django.utils import timezone
+from django.db import models
+from django.contrib.auth.models import AbstractUser
+
+
+# Create your models here.
+# from .serializer import JWTUserProfileSerializer
+
+
+class UserProfile(AbstractUser):
+ """
+ user
+ """
+
+ # first_name = None
+ # last_name = None
+ username = models.CharField(max_length=64, unique=True, verbose_name="username")
+ # user_email = models.EmailField(max_length=256, verbose_name="email")
+ # add_time = models.DateTimeField(default=datetime.now, verbose_name="user added time")
+
+ class Meta:
+ verbose_name = "user"
+ verbose_name_plural = "user"
+
+ def __str__(self):
+ return self.user_name
+
+class Alias(models.Model):
+ name = models.CharField(max_length=32, unique=True, verbose_name="alias name")
+ is_used = models.BooleanField(default=False,verbose_name="is_used")
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="add time", help_text="category added time")
+
+ def __str__(self):
+ return self.name
+class UserMachine(models.Model):
+ """
+ user machine
+ """
+ machine_sn = models.CharField(max_length=16, blank=True, default='',verbose_name="machine sn")
+ machine_secret = models.CharField(max_length=32, blank=True, default='', verbose_name="machine secret")
+ machine_owner = models.ForeignKey(UserProfile)
+ alias = models.OneToOneField(Alias,blank=True, null=True, verbose_name="alias", help_text="alias")
+ os_name = models.CharField(max_length=32, verbose_name="operation system name")
+ os_version = models.CharField(max_length=32, verbose_name="operation system version")
+ comp_name = models.CharField(max_length=32, verbose_name="compiler name")
+ comp_version = models.CharField(max_length=32, verbose_name="compiler version")
+ add_time = models.DateTimeField(default=timezone.now, verbose_name="machine added time")
+
+ STATE_CHOICE = (
+ (-1, 'prohibited'),
+ (0, 'pending'),
+ (1, 'active'),
+
+ )
+ state = models.IntegerField(choices=STATE_CHOICE, default=0,verbose_name="state", help_text="machine state")
+
+ class Meta:
+ verbose_name = "user machines"
+ verbose_name_plural = "user machines"
+
+ def __str__(self):
+ return self.alias.__str__() + ' (' + self.os_name + ' ' + self.os_version + '' + self.comp_name + ' ' + self.comp_version + ')'
+
+ def approve_machine(self):
+ "Approve Machine(Modify the state to active, generate machine_sn, machine_secret, and assign an alias)"
+ alias = Alias.objects.filter(is_used=False).order_by('?').first()
+ if not alias:
+ return {"is_success": False, "alias": '', "secret": '', "email":''}
+ from django.db import transaction
+ with transaction.atomic():
+ alias.is_used=True
+ alias.save()
+
+ self.alias = alias
+ self.state = 1
+ if not self.machine_sn:
+ self.machine_sn = shortuuid.ShortUUID().random(length=16)
+
+ if not self.machine_secret:
+ machine_str = self.alias.name + self.os_name + self.os_version + self.comp_name + self.comp_version + self.machine_sn
+
+ m = hashlib.md5()
+ m.update(make_password(str(machine_str), 'pg_perf_farm'))
+ self.machine_secret = m.hexdigest()
+
+ self.save()
+
+
+ # serializer = JWTUserProfileSerializer(user)
+ print(self.machine_owner.email)
+ user_email = self.machine_owner.email
+ system = self.os_name + ' ' + self.os_version
+ compiler = self.comp_name + ' ' + self.comp_version
+ return {"is_success": True, "alias": self.alias.name, "secret": self.machine_secret, "system": system, "compiler":compiler,"email":user_email} \ No newline at end of file
diff --git a/web/apps/users/serializer.py b/web/apps/users/serializer.py
new file mode 100644
index 0000000..e1ba40a
--- /dev/null
+++ b/web/apps/users/serializer.py
@@ -0,0 +1,63 @@
+from rest_framework import serializers
+
+from pgperffarm.settings import AVATAR_URL
+from test_records.models import TestRecord
+from users.models import UserMachine, Alias, UserProfile
+import hashlib
+
+class AliasSerializer(serializers.ModelSerializer):
+ '''
+ use TestResultSerializer
+ '''
+
+ class Meta:
+ model = Alias
+ fields = ('name', )
+
+class CreateUserProfileSerializer(serializers.ModelSerializer):
+ '''
+ use CreateUserProfileSerializer
+ '''
+ class Meta:
+ model = UserProfile
+ fields = "__all__"
+
+class UserMachineSerializer(serializers.ModelSerializer):
+ '''
+ use UserMachineSerializer
+ '''
+
+ alias = serializers.SerializerMethodField()
+ reports = serializers.SerializerMethodField()
+ owner = serializers.SerializerMethodField()
+ avatar = serializers.SerializerMethodField()
+ class Meta:
+ model = UserMachine
+ fields = ('alias', 'os_name', 'os_version', 'comp_name', 'comp_version', 'reports', 'owner' , 'avatar', 'machine_sn')
+
+ def get_alias(self, obj):
+ target_alias = Alias.objects.filter(id=obj.alias_id).first()
+
+ serializer = AliasSerializer(target_alias)
+ return serializer.data['name']
+
+ def get_reports(self, obj):
+ reports_num = TestRecord.objects.filter(test_machine_id=obj.id).count()
+ return reports_num
+
+ def get_owner(self, obj):
+ target_owner = UserProfile.objects.filter(id=obj.machine_owner_id).first()
+ serializer = JWTUserProfileSerializer(target_owner)
+ return serializer.data
+
+ def get_avatar(self, obj):
+ target_owner = UserProfile.objects.filter(id=obj.machine_owner_id).values('email').first()
+
+
+ avatar = AVATAR_URL + hashlib.md5(target_owner['email']).hexdigest()
+ return avatar
+
+class JWTUserProfileSerializer(serializers.ModelSerializer):
+ class Meta:
+ model = UserProfile
+ fields = ('username', 'email') \ No newline at end of file
diff --git a/web/apps/users/tests.py b/web/apps/users/tests.py
new file mode 100644
index 0000000..5982e6b
--- /dev/null
+++ b/web/apps/users/tests.py
@@ -0,0 +1,6 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.test import TestCase
+
+# Create your tests here.
diff --git a/web/apps/users/views.py b/web/apps/users/views.py
new file mode 100644
index 0000000..5a4457f
--- /dev/null
+++ b/web/apps/users/views.py
@@ -0,0 +1,29 @@
+# -*- coding: utf-8 -*-
+from __future__ import unicode_literals
+
+from django.contrib.auth.backends import ModelBackend
+from django.db.models import Q
+
+# Create your views here.
+from rest_framework import permissions
+
+from .models import UserProfile, UserMachine
+
+
+class CustomBackend(ModelBackend):
+ """
+ custom user auth
+ """
+ # todo use auth.py
+ def authenticate(self, username=None, password=None, **kwargs):
+ try:
+ user = UserProfile.objects.get(Q(username=username))
+ if user.check_password(password):
+ return user
+
+
+ except Exception as e:
+ return None
+
+
+
diff --git a/web/apps/util/__init__.py b/web/apps/util/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/apps/util/__init__.py
diff --git a/web/apps/util/common.py b/web/apps/util/common.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/apps/util/common.py
diff --git a/web/apps/util/exception_handler.py b/web/apps/util/exception_handler.py
new file mode 100644
index 0000000..a58227a
--- /dev/null
+++ b/web/apps/util/exception_handler.py
@@ -0,0 +1,16 @@
+from rest_framework.views import exception_handler
+
+
+def custom_exception_handler(exc, context):
+ # Call REST framework's default exception handler first,
+ # to get the standard error response.
+ response = exception_handler(exc, context)
+
+ # Now add the HTTP status code to the response.
+ if response is not None:
+ response.data['code'] = response.status_code
+ response.data['desc'] = response.data['detail']
+ # response.data['data'] = None #
+ del response.data['detail'] # delete detail field
+
+ return response
diff --git a/web/apps/util/response.py b/web/apps/util/response.py
new file mode 100644
index 0000000..c47f41b
--- /dev/null
+++ b/web/apps/util/response.py
@@ -0,0 +1,38 @@
+from django.utils import six
+from rest_framework.response import Response
+from rest_framework.serializers import Serializer
+
+class PGJsonResponse(Response):
+ """
+ An HttpResponse that allows its data to be rendered into
+ arbitrary media types.
+ """
+
+ def __init__(self, data=None, code=None, desc=None,
+ status=None,
+ template_name=None, headers=None,
+ exception=False, content_type=None):
+ """
+ Alters the init arguments slightly.
+ For example, drop 'template_name', and instead use 'data'.
+ Setting 'renderer' and 'media_type' will typically be deferred,
+ For example being set automatically by the `APIView`.
+ """
+ super(Response, self).__init__(None, status=status)
+
+ if isinstance(data, Serializer):
+ msg = (
+ 'You passed a Serializer instance as data, but '
+ 'probably meant to pass serialized `.data` or '
+ '`.error`. representation.'
+ )
+ raise AssertionError(msg)
+
+ self.data = {"code": code, "desc": desc, "data": data}
+ self.template_name = template_name
+ self.exception = exception
+ self.content_type = content_type
+
+ if headers:
+ for name, value in six.iteritems(headers):
+ self[name] = value \ No newline at end of file
diff --git a/web/db_tools/data/__init__.py b/web/db_tools/data/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/db_tools/data/__init__.py
diff --git a/web/db_tools/data/alias_data.py b/web/db_tools/data/alias_data.py
new file mode 100644
index 0000000..5f4d11b
--- /dev/null
+++ b/web/db_tools/data/alias_data.py
@@ -0,0 +1,74 @@
+row_data = [
+ {
+ 'name': 'Avocado',
+ 'is_used': False
+ },
+ {
+ 'name': 'Cabbage',
+ 'is_used': False
+ },
+ {
+ 'name': 'Cucumber',
+ 'is_used': False
+ },
+ {
+ 'name': 'Celery',
+ 'is_used': False
+ },
+ {
+ 'name': 'Celtuce',
+ 'is_used': False
+ },
+ {
+ 'name': 'Chaya',
+ 'is_used': False
+ },
+ {
+ 'name': 'Chicory',
+ 'is_used': False
+ },
+ {
+ 'name': 'Cress',
+ 'is_used': False
+ },
+ {
+ 'name': 'Dandelion',
+ 'is_used': False
+ },
+ {
+ 'name': 'Eggplant',
+ 'is_used': False
+ },
+ {
+ 'name': 'Fiddlehead',
+ 'is_used': False
+ },
+ {
+ 'name': 'Grape',
+ 'is_used': False
+ },
+ {
+ 'name': 'Luffa',
+ 'is_used': False
+ },
+ {
+ 'name': 'Kale',
+ 'is_used': False
+ },
+ {
+ 'name': 'Kale',
+ 'is_used': False
+ },
+ {
+ 'name': 'Pepper',
+ 'is_used': False
+ },
+ {
+ 'name': 'Sorrel',
+ 'is_used': False
+ },
+ {
+ 'name': 'Squash',
+ 'is_used': False
+ },
+]
diff --git a/web/db_tools/data/branch_data.py b/web/db_tools/data/branch_data.py
new file mode 100644
index 0000000..f908c74
--- /dev/null
+++ b/web/db_tools/data/branch_data.py
@@ -0,0 +1,33 @@
+row_data = [
+ {
+ 'branch_name': 'HEAD',
+ },
+ {
+ 'branch_name': 'REL_9_0_STABLE',
+ },
+ {
+ 'branch_name': 'REL_9_1_STABLE',
+ },
+ {
+ 'branch_name': 'REL_9_2_STABLE',
+ },
+ {
+ 'branch_name': 'REL_9_3_STABLE',
+ },
+ {
+ 'branch_name': 'REL_9_4_STABLE',
+ },
+ {
+ 'branch_name': 'REL_9_5_STABLE',
+ },
+ {
+ 'branch_name': 'REL_9_6_STABLE',
+ },
+ {
+ 'branch_name': 'REL_10_STABLE',
+ },
+ {
+ 'branch_name': 'REL_11_STABLE',
+ },
+
+]
diff --git a/web/db_tools/data/category_data.py b/web/db_tools/data/category_data.py
new file mode 100644
index 0000000..46a4e82
--- /dev/null
+++ b/web/db_tools/data/category_data.py
@@ -0,0 +1,12 @@
+row_data = [
+ {
+ 'cate_name': 'read only',
+ 'cate_order': 1,
+ 'cate_sn': 'ro'
+ },
+ {
+ 'cate_name': 'read write',
+ 'cate_order': 2,
+ 'cate_sn': 'rw',
+ },
+] \ No newline at end of file
diff --git a/web/db_tools/data/machine_data.py b/web/db_tools/data/machine_data.py
new file mode 100644
index 0000000..1661661
--- /dev/null
+++ b/web/db_tools/data/machine_data.py
@@ -0,0 +1,12 @@
+row_data = [
+ {
+ 'machine_sn': '123456',
+ 'machine_secret': '123456',
+ 'alias': 1,
+ 'os_name': 'Ubuntu',
+ 'os_version': 16,
+ 'comp_name': 'x86',
+ 'comp_version':'64',
+ 'machine_owner_id':1
+ },
+]
diff --git a/web/db_tools/data/user_data.py b/web/db_tools/data/user_data.py
new file mode 100644
index 0000000..aa4f3f6
--- /dev/null
+++ b/web/db_tools/data/user_data.py
@@ -0,0 +1,14 @@
+row_data = [
+ {
+ 'password': '123456',
+ 'is_superuser': False,
+ 'username': 'maleic',
+ 'first_name': 'Maleic',
+ 'last_name': 'Acid',
+ 'date_joined': '2018-06-14 21:34:51+08',
+ 'email': '[email protected]',
+ 'is_staff': False,
+ 'is_active': True,
+ 'last_login': '2018-06-14 21:34:51+08',
+ },
+] \ No newline at end of file
diff --git a/web/db_tools/import_alias_data.py b/web/db_tools/import_alias_data.py
new file mode 100644
index 0000000..8f9902a
--- /dev/null
+++ b/web/db_tools/import_alias_data.py
@@ -0,0 +1,22 @@
+import sys
+import os
+from path import PORJECT_PATH
+# Use django's model independently
+pwd = os.path.dirname(os.path.realpath(__file__))
+sys.path.append(pwd)
+path = PORJECT_PATH # path = 'D:\GitSpace\pgperffarm\web\pgperffarm'
+sys.path.append(path)
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
+
+# Initialize django
+import django
+django.setup()
+
+from users.models import Alias
+from data.alias_data import row_data
+
+for alias_item in row_data:
+ alias = Alias()
+ alias.name = alias_item["name"]
+ alias.is_used = alias_item["is_used"]
+ alias.save() \ No newline at end of file
diff --git a/web/db_tools/import_branch_data.py b/web/db_tools/import_branch_data.py
new file mode 100644
index 0000000..c736cad
--- /dev/null
+++ b/web/db_tools/import_branch_data.py
@@ -0,0 +1,23 @@
+import sys
+import os
+from path import PORJECT_PATH
+# Use django's model independently
+pwd = os.path.dirname(os.path.realpath(__file__))
+sys.path.append(pwd)
+path = PORJECT_PATH
+sys.path.append(path)
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
+
+# Initialize django
+import django
+django.setup()
+
+from test_records.models import TestBranch
+from data.branch_data import row_data
+
+for branch_item in row_data:
+ branch = TestBranch()
+ branch.branch_name = branch_item["branch_name"]
+ # branch.is_accept = True
+ # branch.is_show = True
+ branch.save() \ No newline at end of file
diff --git a/web/db_tools/import_category_data.py b/web/db_tools/import_category_data.py
new file mode 100644
index 0000000..09e7146
--- /dev/null
+++ b/web/db_tools/import_category_data.py
@@ -0,0 +1,24 @@
+import sys
+import os
+from path import PORJECT_PATH
+# Use django's model independently
+pwd = os.path.dirname(os.path.realpath(__file__))
+sys.path.append(pwd+ "../")
+path = PORJECT_PATH
+sys.path.append(path)
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
+
+# Initialize django
+import django
+django.setup()
+
+from test_records.models import TestCategory
+from data.category_data import row_data
+from django.contrib.auth.hashers import make_password
+
+for test_cate in row_data:
+ cate = TestCategory()
+ cate.cate_name = test_cate["cate_name"]
+ cate.cate_order = test_cate["cate_order"]
+ cate.cate_sn = test_cate["cate_sn"]
+ cate.save() \ No newline at end of file
diff --git a/web/db_tools/import_machine_data.py b/web/db_tools/import_machine_data.py
new file mode 100644
index 0000000..2f4e425
--- /dev/null
+++ b/web/db_tools/import_machine_data.py
@@ -0,0 +1,33 @@
+import sys
+import os
+from path import PORJECT_PATH
+# Use django's model independently
+pwd = os.path.dirname(os.path.realpath(__file__))
+sys.path.append(pwd+ "../")
+path = PORJECT_PATH
+sys.path.append(path)
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
+
+# Initialize django
+import django
+django.setup()
+
+from apps.user_operation.models import UserMachine
+# cannot use 'apps.users.models'
+from users.models import Alias
+from data.machine_data import row_data
+from django.contrib.auth.hashers import make_password
+
+for machine_item in row_data:
+ machine = UserMachine()
+
+ machine.machine_sn = machine_item["machine_sn"]
+ machine.machine_secret = machine_item["machine_secret"]
+ machine.alias = Alias.objects.get(id=machine_item["alias"])
+ machine.os_name = machine_item["os_name"]
+ machine.os_version = machine_item["os_version"]
+ machine.comp_name = machine_item["comp_name"]
+ machine.comp_version = machine_item["comp_version"]
+ machine.machine_owner_id = machine_item["machine_owner_id"]
+
+ machine.save() \ No newline at end of file
diff --git a/web/db_tools/import_user_data.py b/web/db_tools/import_user_data.py
new file mode 100644
index 0000000..799e5f9
--- /dev/null
+++ b/web/db_tools/import_user_data.py
@@ -0,0 +1,28 @@
+import sys
+import os
+from pgperffarm.settings import PORJECT_PATH
+# Use django's model independently
+pwd = os.path.dirname(os.path.realpath(__file__))
+sys.path.append(pwd+ "../")
+path = PORJECT_PATH
+sys.path.append(path)
+os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")
+
+# Initialize django
+import django
+django.setup()
+
+from users.models import UserProfile
+from data.user_data import row_data
+from django.contrib.auth.hashers import make_password
+
+for user_deatil in row_data:
+ users = UserProfile()
+ users.password = make_password(user_deatil["password"])
+ users.is_superuser = user_deatil["is_superuser"]
+ users.username = user_deatil["username"]
+ users.email = user_deatil["email"]
+ users.is_staff = user_deatil["is_staff"]
+ users.is_active = user_deatil["is_active"]
+
+ users.save() \ No newline at end of file
diff --git a/web/db_tools/path.py b/web/db_tools/path.py
new file mode 100644
index 0000000..984eaee
--- /dev/null
+++ b/web/db_tools/path.py
@@ -0,0 +1 @@
+PORJECT_PATH = 'D:\GitSpace\pgperffarm\web\pgperffarm'# 'D:\GitSpace\pgperffarm\web\pgperffarm' '/var/www/web/pgperffarm'
diff --git a/web/extra_apps/__init__.py b/web/extra_apps/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/extra_apps/__init__.py
diff --git a/web/extra_apps/asynchronous_send_mail/__init__.py b/web/extra_apps/asynchronous_send_mail/__init__.py
new file mode 100644
index 0000000..fb85442
--- /dev/null
+++ b/web/extra_apps/asynchronous_send_mail/__init__.py
@@ -0,0 +1,24 @@
+from django.core.mail import send_mail as core_send_mail
+from django.core.mail import EmailMultiAlternatives
+import threading
+
+class EmailThread(threading.Thread):
+ def __init__(self, subject, body, from_email, recipient_list, fail_silently, html):
+ self.subject = subject
+ self.body = body
+ self.recipient_list = recipient_list
+ self.from_email = from_email
+ self.fail_silently = fail_silently
+ self.html = html
+ threading.Thread.__init__(self)
+
+ def run (self):
+ msg = EmailMultiAlternatives(self.subject, self.body, self.from_email, self.recipient_list)
+ if self.html:
+ msg.attach_alternative(self.html, "text/html")
+ msg.send(self.fail_silently)
+
+def send_mail(subject, body, from_email, recipient_list, fail_silently=False, html=None, *args, **kwargs):
+ EmailThread(subject, body, from_email, recipient_list, fail_silently, html).start()
+
+
diff --git a/web/extra_apps/asynchronous_send_mail/models.py b/web/extra_apps/asynchronous_send_mail/models.py
new file mode 100644
index 0000000..71a8362
--- /dev/null
+++ b/web/extra_apps/asynchronous_send_mail/models.py
@@ -0,0 +1,3 @@
+from django.db import models
+
+# Create your models here.
diff --git a/web/extra_apps/asynchronous_send_mail/tests.py b/web/extra_apps/asynchronous_send_mail/tests.py
new file mode 100644
index 0000000..2247054
--- /dev/null
+++ b/web/extra_apps/asynchronous_send_mail/tests.py
@@ -0,0 +1,23 @@
+"""
+This file demonstrates two different styles of tests (one doctest and one
+unittest). These will both pass when you run "manage.py test".
+
+Replace these with more appropriate tests for your application.
+"""
+
+from django.test import TestCase
+
+class SimpleTest(TestCase):
+ def test_basic_addition(self):
+ """
+ Tests that 1 + 1 always equals 2.
+ """
+ self.failUnlessEqual(1 + 1, 2)
+
+__test__ = {"doctest": """
+Another way to test that 1 + 1 is equal to 2.
+
+>>> 1 + 1 == 2
+True
+"""}
+
diff --git a/web/extra_apps/asynchronous_send_mail/views.py b/web/extra_apps/asynchronous_send_mail/views.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/extra_apps/asynchronous_send_mail/views.py
diff --git a/web/extra_apps/pg_auth/__init__.py b/web/extra_apps/pg_auth/__init__.py
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/extra_apps/pg_auth/__init__.py
diff --git a/web/pgperffarm/auth.py b/web/extra_apps/pg_auth/auth.py
index b1d74b7..c60728e 100644
--- a/web/pgperffarm/auth.py
+++ b/web/extra_apps/pg_auth/auth.py
@@ -19,7 +19,8 @@
#
from django.http import HttpResponse, HttpResponseRedirect
-from django.contrib.auth.models import User
+# from django.contrib.auth.models import User
+from users.models import UserProfile as User
from django.contrib.auth.backends import ModelBackend
from django.contrib.auth import login as django_login
from django.contrib.auth import logout as django_logout
diff --git a/web/git b/web/git
new file mode 100644
index 0000000..e69de29
--- /dev/null
+++ b/web/git
diff --git a/web/manage.py b/web/manage.py
index 75b91ab..75b91ab 100755..100644
--- a/web/manage.py
+++ b/web/manage.py
diff --git a/web/pgperffarm/settings.py b/web/pgperffarm/settings.py
index 38fdf8a..52c1987 100644
--- a/web/pgperffarm/settings.py
+++ b/web/pgperffarm/settings.py
@@ -1,5 +1,7 @@
# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
+import datetime
import os
+import sys
# Load local settings overrides
from settings_local import *
@@ -16,8 +18,11 @@ For the full list of settings and their values, see
https://docs.djangoproject.com/en/1.8/ref/settings/
"""
+# Build paths inside the project like this: os.path.join(BASE_DIR, ...)
BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))
-
+sys.path.insert(0, BASE_DIR)
+sys.path.insert(0, os.path.join(BASE_DIR, 'apps'))
+sys.path.insert(0, os.path.join(BASE_DIR, 'extra_apps'))
# Quick-start development settings - unsuitable for production
# See https://docs.djangoproject.com/en/1.8/howto/deployment/checklist/
@@ -30,20 +35,29 @@ DEBUG = True
ALLOWED_HOSTS = []
-
# Application definition
INSTALLED_APPS = (
'django.contrib.admin',
+ 'corsheaders',
'django.contrib.auth',
'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.messages',
'django.contrib.staticfiles',
'django_gravatar',
+ 'rest_framework',
+ 'rest_framework.authtoken',
+ 'django_filters',
+ 'users',
+ 'test_records',
+ 'crispy_forms',
+ 'user_operation',
+ 'asynchronous_send_mail'
)
MIDDLEWARE_CLASSES = (
+ 'corsheaders.middleware.CorsMiddleware',
'django.contrib.sessions.middleware.SessionMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
@@ -72,18 +86,28 @@ TEMPLATES = [
},
]
-WSGI_APPLICATION = 'pgperffarm.wsgi.application'
+# PASSWORD_HASHERS = (
+# 'django.contrib.auth.hashers.MD5PasswordHasher',
+# 'django.contrib.auth.hashers.PBKDF2PasswordHasher',
+# 'django.contrib.auth.hashers.PBKDF2SHA1PasswordHasher',
+# 'django.contrib.auth.hashers.BCryptSHA256PasswordHasher',
+# 'django.contrib.auth.hashers.BCryptPasswordHasher',
+# 'django.contrib.auth.hashers.SHA1PasswordHasher',
+#
+# 'django.contrib.auth.hashers.CryptPasswordHasher',
+# )
+WSGI_APPLICATION = 'pgperffarm.wsgi.application'
# Database
# https://docs.djangoproject.com/en/1.8/ref/settings/#databases
-DATABASES = {
- 'default': {
- 'ENGINE': 'django.db.backends.sqlite3',
- 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
- }
-}
+# DATABASES = {
+# 'default': {
+# 'ENGINE': 'django.db.backends.sqlite3',
+# 'NAME': os.path.join(BASE_DIR, 'db.sqlite3'),
+# }
+# }
# Internationalization
@@ -99,7 +123,6 @@ USE_L10N = True
USE_TZ = True
-
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.8/howto/static-files/
@@ -110,5 +133,97 @@ STATICFILES_DIRS = [
]
AUTHENTICATION_BACKENDS = (
- 'pgperffarm.auth.AuthBackend',
+ 'users.views.CustomBackend',
)
+AUTH_USER_MODEL = 'users.UserProfile'
+
+REST_FRAMEWORK = {
+
+ # 'DEFAULT_PERMISSION_CLASSES': (
+ # 'rest_framework.permissions.IsAuthenticated',
+ # ),
+
+ # 'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',),
+ # 'EXCEPTION_HANDLER': (
+ # 'dataAPI.common.api_exception.custom_exception_handler'
+ # ),
+ 'DEFAULT_AUTHENTICATION_CLASSES': (
+ 'rest_framework_jwt.authentication.JSONWebTokenAuthentication',
+ 'rest_framework.authentication.BasicAuthentication',
+ 'rest_framework.authentication.SessionAuthentication',
+ # 'rest_framework.authentication.TokenAuthentication',
+ ),
+ 'DEFAULT_PAGINATION_CLASS': 'rest_framework.pagination.LimitOffsetPagination',
+ 'PAGE_SIZE': 20
+}
+
+AVATAR_URL = 'http://s.gravatar.com/avatar/'
+DB_ENUM = {
+ "general_switch": {
+ "on": 1,
+ "off": 2
+ },
+ "mode": {
+ "simple": 1,
+ "other": 2
+ },
+ "machine_state": {
+ "prohibited": -1,
+ "pending": 0,
+ "active": 1,
+ },
+ "status": {
+ "none": -1,
+ "improved": 1,
+ "quo": 2,
+ "regressive": 3
+ }
+}
+
+APPEND_SLAS = False
+
+CORS_ALLOW_CREDENTIALS = True
+CORS_ORIGIN_ALLOW_ALL = True
+CORS_ORIGIN_WHITELIST = (
+ '*'
+)
+
+CORS_ALLOW_METHODS = (
+ 'DELETE',
+ 'GET',
+ 'OPTIONS',
+ 'PATCH',
+ 'POST',
+ 'PUT',
+ 'VIEW',
+)
+
+CORS_ALLOW_HEADERS = (
+ 'XMLHttpRequest',
+ 'X_FILENAME',
+ 'accept-encoding',
+ 'authorization',
+ 'content-type',
+ 'dnt',
+ 'origin',
+ 'user-agent',
+ 'x-csrftoken',
+ 'x-requested-with',
+ 'Pragma',
+)
+ALLOWED_HOSTS = ['*']
+
+JWT_AUTH = {
+ 'JWT_RESPONSE_PAYLOAD_HANDLER':
+ 'users.jwt_handler.jwt_response_payload_handler',
+ 'JWT_EXPIRATION_DELTA': datetime.timedelta(seconds=7200),
+ 'JWT_AUTH_HEADER_PREFIX': 'Token',
+}
+
+EMAIL_BACKEND = 'django.core.mail.backends.smtp.EmailBackend'
+EMAIL_USE_SSL = True
+EMAIL_HOST = 'smtp.163.com'
+EMAIL_PORT = 465
+# EMAIL_HOST_USER = ''
+# EMAIL_HOST_PASSWORD = '' # individual password
+DEFAULT_FROM_EMAIL = EMAIL_HOST_USER
diff --git a/web/pgperffarm/settings_local.py.in b/web/pgperffarm/settings_local.py.in
index 39618d4..26d1559 100644
--- a/web/pgperffarm/settings_local.py.in
+++ b/web/pgperffarm/settings_local.py.in
@@ -11,4 +11,11 @@ DATABASES={
}
PGAUTH_REDIRECT=''
-PGAUTH_KEY='' \ No newline at end of file
+PGAUTH_KEY=''
+
+PORJECT_PATH = '/var/www/web/pgperffarm' # 'D:\GitSpace\pgperffarm\web\pgperffarm'
+PGAUTH_REDIRECT=''
+PGAUTH_KEY=''
+
+EMAIL_HOST_USER = ''
+EMAIL_HOST_PASSWORD = '' # individual smtp password \ No newline at end of file
diff --git a/web/pgperffarm/urls.py b/web/pgperffarm/urls.py
index 3b439eb..cf0ec7b 100644
--- a/web/pgperffarm/urls.py
+++ b/web/pgperffarm/urls.py
@@ -14,26 +14,71 @@ Including another URLconf
"""
from django.conf.urls import include, url
from django.contrib import admin
-from django.views.generic.base import RedirectView
+from rest_framework_jwt.views import obtain_jwt_token
+
+from rest_framework.authtoken import views
+from rest_framework.documentation import include_docs_urls
+from rest_framework.routers import DefaultRouter
+from test_records.views import TestRecordListViewSet, TestRecordCreate, TestRecordDetailViewSet, \
+ MachineHistoryRecordViewSet, TestBranchListViewSet, TestRecordListByBranchViewSet
+from test_records.auth import MachineAuthToken
+# from test_records.view_base import TestListView
+
+# config test record url
+# test_record_list = TestRecordListViewSet.as_view({
+# 'get': 'list',
+# 'post': 'create'
+# })
+from user_operation.views import UserMachineListViewSet, UserPortalInfoViewSet, UserMachineRecordByBranchListViewSet, \
+ PublicMachineListViewSet
+
+router = DefaultRouter()
+router.register(r'records', TestRecordListViewSet, base_name="records")
+router.register(r'machines', PublicMachineListViewSet, base_name="machines")
+router.register(r'branches', TestBranchListViewSet, base_name="branches")
+router.register(r'records-by-branch', TestRecordListByBranchViewSet, base_name="records-by-branch")
+# router.register(r'status-records', TestStatusRecordListViewSet, base_name="status-records")
+router.register(r'detail', TestRecordDetailViewSet, base_name="detail")
+router.register(r'machine-records', MachineHistoryRecordViewSet, base_name="machine-records")
+router.register(r'machine-records-by-branch', UserMachineRecordByBranchListViewSet, base_name="machine-records-by-branch")
+
+# user's machine manage list
+router.register(r'my-machine', UserMachineListViewSet, base_name="my-machine")
+# get userinfo on portal page
+router.register(r'user-portal', UserPortalInfoViewSet, base_name="user-portal")
urlpatterns = [
+ url(r'^perf_farm_admin/', admin.site.urls),
+ # url(r'^admin/', include(admin.site.urls)),
+ url(r'^api-auth/', include('rest_framework.urls')),
+
+
+ url(r'^api-token-auth/', views.obtain_auth_token),
+
+ # user login(jwt auth)
+ url(r'^login/', obtain_jwt_token),
+
+ url(r'^machine-token-auth/', MachineAuthToken.as_view()),
+ url(r'^', include(router.urls)),
+
+ url(r'upload/$', TestRecordCreate, name='test-upload'),
+
+ url(r'docs/', include_docs_urls(title='pgperffarm')),
# Static pages
- url(r'^$', 'pgperffarm.views.index', name='index'),
- url(r'^/licence$', 'pgperffarm.views.licence', name='licence'),
- url(r'^/ppolicy$', 'pgperffarm.views.ppolicy', name='ppolicy'),
-
- # Auth system integration
- url(r'^(?:account/)?login/?$', 'pgperffarm.auth.login'),
- url(r'^(?:account/)?logout/?$', 'pgperffarm.auth.logout'),
- url(r'^auth_receive/$', 'pgperffarm.auth.auth_receive'),
-
- # Admin site
- url(r'^admin/', include(admin.site.urls)),
-
- # This should not happen in production - serve with lightty!
- url(r'^static/(.*)$', 'django.views.static.serve', {
- 'document_root': '/static',
- }),
- url(r'^favicon\.ico$', RedirectView.as_view(url='/static/favicon.ico',
- permanent=True))
-]
+ # url(r'^$', 'pgperffarm.views.index', name='index'),
+ # url(r'^/licence$', 'pgperffarm.views.licence', name='licence'),
+ # url(r'^/ppolicy$', 'pgperffarm.views.ppolicy', name='ppolicy'),
+ #
+ # # Auth system integration
+ # url(r'^(?:account/)?login/?$', 'pgperffarm.auth.login'),
+ # url(r'^(?:account/)?logout/?$', 'pgperffarm.auth.logout'),
+ # url(r'^auth_receive/$', 'pgperffarm.auth.auth_receive'),
+ #
+ # # Admin site
+ # url(r'^admin/', include(admin.site.urls)),
+ #
+ # # This should not happen in production - serve with lightty!
+ # url(r'^static/(.*)$', 'django.views.static.serve', {
+ # 'document_root': '/static',
+ # }),
+] \ No newline at end of file
diff --git a/web/pgperffarm/view_base.py b/web/pgperffarm/view_base.py
new file mode 100644
index 0000000..91e1808
--- /dev/null
+++ b/web/pgperffarm/view_base.py
@@ -0,0 +1,22 @@
+"""Views for the core PGPerfFarm app"""
+
+from django.shortcuts import render_to_response
+from django.template import RequestContext
+
+import datetime
+
+
+# Handle the static pages
+def index(request):
+ return render_to_response('index.html',
+ context_instance=RequestContext(request))
+
+
+def licence(request):
+ return render_to_response('licence.html',
+ context_instance=RequestContext(request))
+
+
+def ppolicy(request):
+ return render_to_response('ppolicy.html',
+ context_instance=RequestContext(request))
diff --git a/web/requirements.txt b/web/requirements.txt
index eb3458b..9b8d591 100644
--- a/web/requirements.txt
+++ b/web/requirements.txt
@@ -1,4 +1,44 @@
-Django==1.8.11
+certifi==2018.4.16
+chardet==3.0.4
+codegen==1.0
+coreapi==2.3.3
+coreschema==0.0.4
+data==0.4
+decorator==4.3.0
+diff-match-patch==20121119
+Django==1.11.10
+django-cors-headers==2.2.0
+django-crispy-forms==1.7.2
+django-filter==1.1.0
+django-formtools==2.1
django-gravatar2==1.4.0
-psycopg2==2.6.1
+django-import-export==1.0.1
+django-reversion==3.0.0
+djangorestframework==3.8.1
+djangorestframework-jwt==1.11.0
+et-xmlfile==1.0.1
+funcsigs==1.0.2
+future==0.16.0
+httplib2==0.9.2
+idna==2.6
+itypes==1.1.0
+jdcal==1.4
+Jinja2==2.10
+Markdown==2.6.11
+MarkupSafe==1.0
+odfpy==1.3.6
+openpyxl==2.5.4
+psycopg2==2.7.4
pycrypto==2.6.1
+PyJWT==1.6.4
+pytz==2018.3
+PyYAML==3.13
+requests==2.18.4
+shortuuid==0.5.0
+six==1.11.0
+tablib==0.12.1
+unicodecsv==0.14.1
+uritemplate==3.0.0
+urllib3==1.22
+xlrd==1.1.0
+xlwt==1.3.0
diff --git a/web/requirements.txt.bak b/web/requirements.txt.bak
new file mode 100644
index 0000000..2456e78
--- /dev/null
+++ b/web/requirements.txt.bak
@@ -0,0 +1,28 @@
+certifi==2018.4.16
+chardet==3.0.4
+codegen==1.0
+coreapi==2.3.3
+coreschema==0.0.4
+data==0.4
+decorator==4.3.0
+Django==1.11.10
+django-cors-headers==2.2.0
+django-crispy-forms==1.7.2
+django-filter==1.1.0
+django-formtools==2.1
+django-gravatar2==1.4.0
+djangorestframework==3.8.1
+funcsigs==1.0.2
+idna==2.6
+itypes==1.1.0
+Jinja2==2.10
+Markdown==2.6.11
+MarkupSafe==1.0
+psycopg2==2.7.4
+pycrypto==2.6.1
+pytz==2018.3
+requests==2.18.4
+shortuuid==0.5.0
+six==1.11.0
+uritemplate==3.0.0
+urllib3==1.22
diff --git a/web/results.json b/web/results.json
new file mode 100644
index 0000000..e189d89
--- /dev/null
+++ b/web/results.json
@@ -0,0 +1,229 @@
+{
+ "pgbench": {
+ "ro": {
+ "10": {
+ "1": {
+ "std": 397.30643899999995,
+ "metric": 11892.645435,
+ "median": 11892.645435,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744130.123901,
+ "clients": "1",
+ "start": 1527744010.089376,
+ "run": 0,
+ "threads": "1",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "11495.338996",
+ "read-only": true
+ },
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744497.961157,
+ "clients": "1",
+ "start": 1527744377.72603,
+ "run": 1,
+ "threads": "1",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "12289.951874",
+ "read-only": true
+ }
+ ]
+ },
+ "2": {
+ "std": 252.71243850000064,
+ "metric": 28953.186513499997,
+ "median": 28953.186513499997,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744255.57636,
+ "clients": "2",
+ "start": 1527744135.356979,
+ "run": 0,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "28700.474075",
+ "read-only": true
+ },
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744619.115272,
+ "clients": "2",
+ "start": 1527744499.091329,
+ "run": 1,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "29205.898952",
+ "read-only": true
+ }
+ ]
+ },
+ "4": {
+ "std": 285.0294699999995,
+ "metric": 28795.454019999997,
+ "median": 28795.454019999997,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744376.71256,
+ "clients": "4",
+ "start": 1527744256.687497,
+ "run": 0,
+ "threads": "4",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "28510.424550",
+ "read-only": true
+ },
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744741.561973,
+ "clients": "4",
+ "start": 1527744621.429693,
+ "run": 1,
+ "threads": "4",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "29080.483490",
+ "read-only": true
+ }
+ ]
+ }
+ }
+ },
+ "rw": {
+ "10": {
+ "1": {
+ "std": 86.91589850000001,
+ "metric": 150.6329775,
+ "median": 150.6329775,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744864.061863,
+ "clients": "1",
+ "start": 1527744742.776619,
+ "run": 0,
+ "threads": "1",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "63.717079",
+ "read-only": false
+ },
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527745241.364349,
+ "clients": "1",
+ "start": 1527745121.106113,
+ "run": 1,
+ "threads": "1",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "237.548876",
+ "read-only": false
+ }
+ ]
+ },
+ "2": {
+ "std": 4.182392499999992,
+ "metric": 280.8884175,
+ "median": 280.8884175,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527744991.386044,
+ "clients": "2",
+ "start": 1527744869.496062,
+ "run": 0,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "276.706025",
+ "read-only": false
+ },
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527745365.458378,
+ "clients": "2",
+ "start": 1527745245.387941,
+ "run": 1,
+ "threads": "2",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "285.070810",
+ "read-only": false
+ }
+ ]
+ },
+ "4": {
+ "std": 15.571989000000002,
+ "metric": 399.858649,
+ "median": 399.858649,
+ "results": [
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527745117.188537,
+ "clients": "4",
+ "start": 1527744997.01389,
+ "run": 0,
+ "threads": "4",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "384.286660",
+ "read-only": false
+ },
+ {
+ "latency": -1,
+ "scale": "10",
+ "end": 1527745489.95213,
+ "clients": "4",
+ "start": 1527745369.876761,
+ "run": 1,
+ "threads": "4",
+ "mode": "simple",
+ "duration": "120",
+ "tps": "415.430638",
+ "read-only": false
+ }
+ ]
+ }
+ }
+ }
+ },
+ "postgres": {},
+ "results": {
+ "init": 9.83613395690918,
+ "runs": [],
+ "warmup": null
+ },
+ "collectd": {},
+ "meta": {
+ "date": "2018-05-31 05:44:54.000000+00",
+ "uname": "Linux postgresql-gsoc1 4.9.0-6-powerpc64le #1 SMP Debian 4.9.88-1+deb9u1 (2018-05-07) ppc64le GNU/Linux\n",
+ "benchmark": "pgbench",
+ "name": "pgbench-basic"
+ },
+ "linux": {
+ "mounts": "sysfs /sys sysfs rw,nosuid,nodev,noexec,relatime 0 0\nproc /proc proc rw,nosuid,nodev,noexec,relatime 0 0\nudev /dev devtmpfs rw,nosuid,relatime,size=2076864k,nr_inodes=32451,mode=755 0 0\ndevpts /dev/pts devpts rw,nosuid,noexec,relatime,gid=5,mode=620,ptmxmode=000 0 0\ntmpfs /run tmpfs rw,nosuid,noexec,relatime,size=417600k,mode=755 0 0\n/dev/sda2 / ext4 rw,relatime,errors=remount-ro,data=ordered 0 0\nsecurityfs /sys/kernel/security securityfs rw,nosuid,nodev,noexec,relatime 0 0\ntmpfs /dev/shm tmpfs rw,nosuid,nodev 0 0\ntmpfs /run/lock tmpfs rw,nosuid,nodev,noexec,relatime,size=5120k 0 0\ntmpfs /sys/fs/cgroup tmpfs ro,nosuid,nodev,noexec,mode=755 0 0\ncgroup /sys/fs/cgroup/systemd cgroup rw,nosuid,nodev,noexec,relatime,xattr,release_agent=/lib/systemd/systemd-cgroups-agent,name=systemd 0 0\ncgroup /sys/fs/cgroup/memory cgroup rw,nosuid,nodev,noexec,relatime,memory 0 0\ncgroup /sys/fs/cgroup/cpu,cpuacct cgroup rw,nosuid,nodev,noexec,relatime,cpu,cpuacct 0 0\ncgroup /sys/fs/cgroup/cpuset cgroup rw,nosuid,nodev,noexec,relatime,cpuset 0 0\ncgroup /sys/fs/cgroup/net_cls,net_prio cgroup rw,nosuid,nodev,noexec,relatime,net_cls,net_prio 0 0\ncgroup /sys/fs/cgroup/pids cgroup rw,nosuid,nodev,noexec,relatime,pids 0 0\ncgroup /sys/fs/cgroup/perf_event cgroup rw,nosuid,nodev,noexec,relatime,perf_event 0 0\ncgroup /sys/fs/cgroup/freezer cgroup rw,nosuid,nodev,noexec,relatime,freezer 0 0\ncgroup /sys/fs/cgroup/devices cgroup rw,nosuid,nodev,noexec,relatime,devices 0 0\ncgroup /sys/fs/cgroup/blkio cgroup rw,nosuid,nodev,noexec,relatime,blkio 0 0\nsystemd-1 /proc/sys/fs/binfmt_misc autofs rw,relatime,fd=29,pgrp=1,timeout=0,minproto=5,maxproto=5,direct,pipe_ino=8487 0 0\nmqueue /dev/mqueue mqueue rw,relatime 0 0\ndebugfs /sys/kernel/debug debugfs rw,relatime 0 0\nbinfmt_misc /proc/sys/fs/binfmt_misc binfmt_misc rw,relatime 0 0\ntmpfs /run/user/1001 tmpfs rw,nosuid,nodev,relatime,size=417536k,mode=700,uid=1001,gid=1001 0 0\n",
+ "cpuinfo": "processor\t: 0\ncpu\t\t: POWER8 (architected), altivec supported\nclock\t\t: 3425.000000MHz\nrevision\t: 2.1 (pvr 004b 0201)\n\nprocessor\t: 1\ncpu\t\t: POWER8 (architected), altivec supported\nclock\t\t: 3425.000000MHz\nrevision\t: 2.1 (pvr 004b 0201)\n\ntimebase\t: 512000000\nplatform\t: pSeries\nmodel\t\t: IBM pSeries (emulated by qemu)\nmachine\t\t: CHRP IBM pSeries (emulated by qemu)\n",
+ "sysctl": "debug.exception-trace = 1\ndev.mac_hid.mouse_button2_keycode = 97\ndev.mac_hid.mouse_button3_keycode = 100\ndev.mac_hid.mouse_button_emulation = 0\ndev.scsi.logging_level = 0\nfs.aio-max-nr = 65536\nfs.aio-nr = 0\nfs.binfmt_misc.status = enabled\nfs.dentry-state = 55628\t46232\t45\t0\t0\t0\nfs.dir-notify-enable = 1\nfs.epoll.max_user_watches = 850657\nfs.file-max = 414118\nfs.file-nr = 736\t0\t414118\nfs.inode-nr = 39189\t291\nfs.inode-state = 39189\t291\t0\t0\t0\t0\t0\nfs.inotify.max_queued_events = 16384\nfs.inotify.max_user_instances = 128\nfs.inotify.max_user_watches = 8192\nfs.lease-break-time = 45\nfs.leases-enable = 1\nfs.mount-max = 100000\nfs.mqueue.msg_default = 10\nfs.mqueue.msg_max = 10\nfs.mqueue.msgsize_default = 8192\nfs.mqueue.msgsize_max = 8192\nfs.mqueue.queues_max = 256\nfs.nr_open = 1048576\nfs.overflowgid = 65534\nfs.overflowuid = 65534\nfs.pipe-max-size = 1048576\nfs.pipe-user-pages-hard = 0\nfs.pipe-user-pages-soft = 16384\nsysctl: permission denied on key 'fs.protected_hardlinks'\nsysctl: permission denied on key 'fs.protected_symlinks'\nfs.quota.allocated_dquots = 0\nfs.quota.cache_hits = 0\nfs.quota.drops = 0\nfs.quota.free_dquots = 0\nfs.quota.lookups = 0\nfs.quota.reads = 0\nfs.quota.syncs = 0\nfs.quota.warnings = 1\nfs.quota.writes = 0\nfs.suid_dumpable = 0\nkernel.acct = 4\t2\t30\nkernel.auto_msgmni = 0\nsysctl: permission denied on key 'kernel.cad_pid'\nkernel.cap_last_cap = 37\nkernel.core_pattern = core\nkernel.core_pipe_limit = 0\nkernel.core_uses_pid = 0\nkernel.ctrl-alt-del = 0\nkernel.dmesg_restrict = 1\nkernel.domainname = (none)\nkernel.ftrace_dump_on_oops = 0\nkernel.ftrace_enabled = 1\nkernel.hardlockup_all_cpu_backtrace = 0\nkernel.hardlockup_panic = 0\nkernel.hostname = postgresql-gsoc1\nkernel.hung_task_check_count = 4194304\nkernel.hung_task_panic = 0\nkernel.hung_task_timeout_secs = 120\nkernel.hung_task_warnings = 10\nkernel.kexec_load_disabled = 0\nkernel.keys.gc_delay = 300\nkernel.keys.maxbytes = 20000\nkernel.keys.maxkeys = 200\nkernel.keys.root_maxbytes = 25000000\nkernel.keys.root_maxkeys = 1000000\nkernel.kptr_restrict = 0\nkernel.max_lock_depth = 1024\nkernel.modprobe = /sbin/modprobe\nkernel.modules_disabled = 0\nkernel.msg_next_id = -1\nkernel.msgmax = 8192\nkernel.msgmnb = 16384\nkernel.msgmni = 32000\nkernel.ngroups_max = 65536\nkernel.nmi_watchdog = 0\nkernel.ns_last_pid = 16106\nkernel.numa_balancing = 0\nkernel.numa_balancing_scan_delay_ms = 1000\nkernel.numa_balancing_scan_period_max_ms = 60000\nkernel.numa_balancing_scan_period_min_ms = 1000\nkernel.numa_balancing_scan_size_mb = 256\nkernel.osrelease = 4.9.0-6-powerpc64le\nkernel.ostype = Linux\nkernel.overflowgid = 65534\nkernel.overflowuid = 65534\nkernel.panic = 0\nkernel.panic_on_oops = 0\nkernel.panic_on_rcu_stall = 0\nkernel.panic_on_warn = 0\nkernel.perf_cpu_time_max_percent = 25\nkernel.perf_event_max_contexts_per_stack = 8\nkernel.perf_event_max_sample_rate = 100000\nkernel.perf_event_max_stack = 127\nkernel.perf_event_mlock_kb = 576\nkernel.perf_event_paranoid = 3\nkernel.pid_max = 32768\nkernel.poweroff_cmd = /sbin/poweroff\nkernel.powersave-nap = 0\nkernel.print-fatal-signals = 0\nkernel.printk = 4\t4\t1\t7\nkernel.printk_delay = 0\nkernel.printk_devkmsg = ratelimit\nkernel.printk_ratelimit = 5\nkernel.printk_ratelimit_burst = 10\nkernel.pty.max = 4096\nkernel.pty.nr = 1\nkernel.pty.reserve = 1024\nkernel.random.boot_id = abb03e17-7d5d-4d71-9e9e-cecfaee3e67a\nkernel.random.entropy_avail = 3789\nkernel.random.poolsize = 4096\nkernel.random.read_wakeup_threshold = 64\nkernel.random.urandom_min_reseed_secs = 60\nkernel.random.uuid = 9f0d7b0c-86e2-46fe-9865-58bf6598b6c6\nkernel.random.write_wakeup_threshold = 896\nkernel.randomize_va_space = 2\nkernel.real-root-dev = 0\nkernel.sched_autogroup_enabled = 0\nkernel.sched_cfs_bandwidth_slice_us = 5000\nkernel.sched_child_runs_first = 0\nkernel.sched_domain.cpu0.domain0.busy_factor = 32\nkernel.sched_domain.cpu0.domain0.busy_idx = 2\nkernel.sched_domain.cpu0.domain0.cache_nice_tries = 1\nkernel.sched_domain.cpu0.domain0.flags = 4143\nkernel.sched_domain.cpu0.domain0.forkexec_idx = 0\nkernel.sched_domain.cpu0.domain0.idle_idx = 1\nkernel.sched_domain.cpu0.domain0.imbalance_pct = 125\nkernel.sched_domain.cpu0.domain0.max_interval = 4\nkernel.sched_domain.cpu0.domain0.max_newidle_lb_cost = 42755\nkernel.sched_domain.cpu0.domain0.min_interval = 2\nkernel.sched_domain.cpu0.domain0.name = DIE\nkernel.sched_domain.cpu0.domain0.newidle_idx = 0\nkernel.sched_domain.cpu0.domain0.wake_idx = 0\nkernel.sched_domain.cpu1.domain0.busy_factor = 32\nkernel.sched_domain.cpu1.domain0.busy_idx = 2\nkernel.sched_domain.cpu1.domain0.cache_nice_tries = 1\nkernel.sched_domain.cpu1.domain0.flags = 4143\nkernel.sched_domain.cpu1.domain0.forkexec_idx = 0\nkernel.sched_domain.cpu1.domain0.idle_idx = 1\nkernel.sched_domain.cpu1.domain0.imbalance_pct = 125\nkernel.sched_domain.cpu1.domain0.max_interval = 4\nkernel.sched_domain.cpu1.domain0.max_newidle_lb_cost = 56605\nkernel.sched_domain.cpu1.domain0.min_interval = 2\nkernel.sched_domain.cpu1.domain0.name = DIE\nkernel.sched_domain.cpu1.domain0.newidle_idx = 0\nkernel.sched_domain.cpu1.domain0.wake_idx = 0\nkernel.sched_latency_ns = 12000000\nkernel.sched_migration_cost_ns = 500000\nkernel.sched_min_granularity_ns = 1500000\nkernel.sched_nr_migrate = 32\nkernel.sched_rr_timeslice_ms = 25\nkernel.sched_rt_period_us = 1000000\nkernel.sched_rt_runtime_us = 950000\nkernel.sched_schedstats = 0\nkernel.sched_shares_window_ns = 10000000\nkernel.sched_time_avg_ms = 1000\nkernel.sched_tunable_scaling = 1\nkernel.sched_wakeup_granularity_ns = 2000000\nkernel.sem = 32000\t1024000000\t500\t32000\nkernel.sem_next_id = -1\nkernel.shm_next_id = -1\nkernel.shm_rmid_forced = 0\nkernel.shmall = 18446744073692774399\nkernel.shmmax = 18446744073692774399\nkernel.shmmni = 4096\nkernel.soft_watchdog = 1\nkernel.softlockup_all_cpu_backtrace = 0\nkernel.softlockup_panic = 0\nkernel.stack_tracer_enabled = 0\nkernel.sysctl_writes_strict = 1\nkernel.sysrq = 438\nkernel.tainted = 0\nkernel.threads-max = 32451\nkernel.timer_migration = 1\nkernel.traceoff_on_warning = 0\nkernel.tracepoint_printk = 0\nkernel.unprivileged_bpf_disabled = 0\nkernel.unprivileged_userns_clone = 0\nsysctl: permission denied on key 'kernel.usermodehelper.bset'\nsysctl: permission denied on key 'kernel.usermodehelper.inheritable'\nkernel.version = #1 SMP Debian 4.9.88-1+deb9u1 (2018-05-07)\nkernel.watchdog = 1\nkernel.watchdog_cpumask = 0-1\nkernel.watchdog_thresh = 10\nkernel.yama.ptrace_scope = 0\nnet.core.bpf_jit_enable = 0\nsysctl: permission denied on key 'net.core.bpf_jit_harden'\nnet.core.busy_poll = 0\nnet.core.busy_read = 0\nnet.core.default_qdisc = pfifo_fast\nnet.core.dev_weight = 64\nnet.core.flow_limit_cpu_bitmap = 0\nnet.core.flow_limit_table_len = 4096\nnet.core.max_skb_frags = 16\nnet.core.message_burst = 10\nnet.core.message_cost = 5\nnet.core.netdev_budget = 300\nnet.core.netdev_max_backlog = 1000\nnet.core.netdev_rss_key = 00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00:00\nnet.core.netdev_tstamp_prequeue = 1\nnet.core.optmem_max = 20480\nnet.core.rmem_default = 229376\nnet.core.rmem_max = 229376\nnet.core.rps_sock_flow_entries = 0\nnet.core.somaxconn = 128\nnet.core.tstamp_allow_data = 1\nnet.core.warnings = 0\nnet.core.wmem_default = 229376\nnet.core.wmem_max = 229376\nnet.core.xfrm_acq_expires = 30\nnet.core.xfrm_aevent_etime = 10\nnet.core.xfrm_aevent_rseqth = 2\nnet.core.xfrm_larval_drop = 1\nnet.ipv4.conf.all.accept_local = 0\nnet.ipv4.conf.all.accept_redirects = 1\nnet.ipv4.conf.all.accept_source_route = 0\nnet.ipv4.conf.all.arp_accept = 0\nnet.ipv4.conf.all.arp_announce = 0\nnet.ipv4.conf.all.arp_filter = 0\nnet.ipv4.conf.all.arp_ignore = 0\nnet.ipv4.conf.all.arp_notify = 0\nnet.ipv4.conf.all.bootp_relay = 0\nnet.ipv4.conf.all.disable_policy = 0\nnet.ipv4.conf.all.disable_xfrm = 0\nnet.ipv4.conf.all.drop_gratuitous_arp = 0\nnet.ipv4.conf.all.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.all.force_igmp_version = 0\nnet.ipv4.conf.all.forwarding = 0\nnet.ipv4.conf.all.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.all.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.all.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.all.log_martians = 0\nnet.ipv4.conf.all.mc_forwarding = 0\nnet.ipv4.conf.all.medium_id = 0\nnet.ipv4.conf.all.promote_secondaries = 0\nnet.ipv4.conf.all.proxy_arp = 0\nnet.ipv4.conf.all.proxy_arp_pvlan = 0\nnet.ipv4.conf.all.route_localnet = 0\nnet.ipv4.conf.all.rp_filter = 0\nnet.ipv4.conf.all.secure_redirects = 1\nnet.ipv4.conf.all.send_redirects = 1\nnet.ipv4.conf.all.shared_media = 1\nnet.ipv4.conf.all.src_valid_mark = 0\nnet.ipv4.conf.all.tag = 0\nnet.ipv4.conf.default.accept_local = 0\nnet.ipv4.conf.default.accept_redirects = 1\nnet.ipv4.conf.default.accept_source_route = 1\nnet.ipv4.conf.default.arp_accept = 0\nnet.ipv4.conf.default.arp_announce = 0\nnet.ipv4.conf.default.arp_filter = 0\nnet.ipv4.conf.default.arp_ignore = 0\nnet.ipv4.conf.default.arp_notify = 0\nnet.ipv4.conf.default.bootp_relay = 0\nnet.ipv4.conf.default.disable_policy = 0\nnet.ipv4.conf.default.disable_xfrm = 0\nnet.ipv4.conf.default.drop_gratuitous_arp = 0\nnet.ipv4.conf.default.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.default.force_igmp_version = 0\nnet.ipv4.conf.default.forwarding = 0\nnet.ipv4.conf.default.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.default.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.default.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.default.log_martians = 0\nnet.ipv4.conf.default.mc_forwarding = 0\nnet.ipv4.conf.default.medium_id = 0\nnet.ipv4.conf.default.promote_secondaries = 0\nnet.ipv4.conf.default.proxy_arp = 0\nnet.ipv4.conf.default.proxy_arp_pvlan = 0\nnet.ipv4.conf.default.route_localnet = 0\nnet.ipv4.conf.default.rp_filter = 0\nnet.ipv4.conf.default.secure_redirects = 1\nnet.ipv4.conf.default.send_redirects = 1\nnet.ipv4.conf.default.shared_media = 1\nnet.ipv4.conf.default.src_valid_mark = 0\nnet.ipv4.conf.default.tag = 0\nnet.ipv4.conf.eth0.accept_local = 0\nnet.ipv4.conf.eth0.accept_redirects = 1\nnet.ipv4.conf.eth0.accept_source_route = 1\nnet.ipv4.conf.eth0.arp_accept = 0\nnet.ipv4.conf.eth0.arp_announce = 0\nnet.ipv4.conf.eth0.arp_filter = 0\nnet.ipv4.conf.eth0.arp_ignore = 0\nnet.ipv4.conf.eth0.arp_notify = 0\nnet.ipv4.conf.eth0.bootp_relay = 0\nnet.ipv4.conf.eth0.disable_policy = 0\nnet.ipv4.conf.eth0.disable_xfrm = 0\nnet.ipv4.conf.eth0.drop_gratuitous_arp = 0\nnet.ipv4.conf.eth0.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.eth0.force_igmp_version = 0\nnet.ipv4.conf.eth0.forwarding = 0\nnet.ipv4.conf.eth0.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.eth0.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.eth0.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.eth0.log_martians = 0\nnet.ipv4.conf.eth0.mc_forwarding = 0\nnet.ipv4.conf.eth0.medium_id = 0\nnet.ipv4.conf.eth0.promote_secondaries = 0\nnet.ipv4.conf.eth0.proxy_arp = 0\nnet.ipv4.conf.eth0.proxy_arp_pvlan = 0\nnet.ipv4.conf.eth0.route_localnet = 0\nnet.ipv4.conf.eth0.rp_filter = 0\nnet.ipv4.conf.eth0.secure_redirects = 1\nnet.ipv4.conf.eth0.send_redirects = 1\nnet.ipv4.conf.eth0.shared_media = 1\nnet.ipv4.conf.eth0.src_valid_mark = 0\nnet.ipv4.conf.eth0.tag = 0\nnet.ipv4.conf.lo.accept_local = 0\nnet.ipv4.conf.lo.accept_redirects = 1\nnet.ipv4.conf.lo.accept_source_route = 1\nnet.ipv4.conf.lo.arp_accept = 0\nnet.ipv4.conf.lo.arp_announce = 0\nnet.ipv4.conf.lo.arp_filter = 0\nnet.ipv4.conf.lo.arp_ignore = 0\nnet.ipv4.conf.lo.arp_notify = 0\nnet.ipv4.conf.lo.bootp_relay = 0\nnet.ipv4.conf.lo.disable_policy = 1\nnet.ipv4.conf.lo.disable_xfrm = 1\nnet.ipv4.conf.lo.drop_gratuitous_arp = 0\nnet.ipv4.conf.lo.drop_unicast_in_l2_multicast = 0\nnet.ipv4.conf.lo.force_igmp_version = 0\nnet.ipv4.conf.lo.forwarding = 0\nnet.ipv4.conf.lo.igmpv2_unsolicited_report_interval = 10000\nnet.ipv4.conf.lo.igmpv3_unsolicited_report_interval = 1000\nnet.ipv4.conf.lo.ignore_routes_with_linkdown = 0\nnet.ipv4.conf.lo.log_martians = 0\nnet.ipv4.conf.lo.mc_forwarding = 0\nnet.ipv4.conf.lo.medium_id = 0\nnet.ipv4.conf.lo.promote_secondaries = 0\nnet.ipv4.conf.lo.proxy_arp = 0\nnet.ipv4.conf.lo.proxy_arp_pvlan = 0\nnet.ipv4.conf.lo.route_localnet = 0\nnet.ipv4.conf.lo.rp_filter = 0\nnet.ipv4.conf.lo.secure_redirects = 1\nnet.ipv4.conf.lo.send_redirects = 1\nnet.ipv4.conf.lo.shared_media = 1\nnet.ipv4.conf.lo.src_valid_mark = 0\nnet.ipv4.conf.lo.tag = 0\nnet.ipv4.fib_multipath_use_neigh = 0\nnet.ipv4.fwmark_reflect = 0\nnet.ipv4.icmp_echo_ignore_all = 0\nnet.ipv4.icmp_echo_ignore_broadcasts = 1\nnet.ipv4.icmp_errors_use_inbound_ifaddr = 0\nnet.ipv4.icmp_ignore_bogus_error_responses = 1\nnet.ipv4.icmp_msgs_burst = 50\nnet.ipv4.icmp_msgs_per_sec = 1000\nnet.ipv4.icmp_ratelimit = 1000\nnet.ipv4.icmp_ratemask = 6168\nnet.ipv4.igmp_link_local_mcast_reports = 1\nnet.ipv4.igmp_max_memberships = 20\nnet.ipv4.igmp_max_msf = 10\nnet.ipv4.igmp_qrv = 2\nnet.ipv4.inet_peer_maxttl = 600\nnet.ipv4.inet_peer_minttl = 120\nnet.ipv4.inet_peer_threshold = 65664\nnet.ipv4.ip_default_ttl = 64\nnet.ipv4.ip_dynaddr = 0\nnet.ipv4.ip_early_demux = 1\nnet.ipv4.ip_forward = 0\nnet.ipv4.ip_forward_use_pmtu = 0\nnet.ipv4.ip_local_port_range = 32768\t60999\nnet.ipv4.ip_local_reserved_ports = \nnet.ipv4.ip_no_pmtu_disc = 0\nnet.ipv4.ip_nonlocal_bind = 0\nnet.ipv4.ipfrag_high_thresh = 4194304\nnet.ipv4.ipfrag_low_thresh = 3145728\nnet.ipv4.ipfrag_max_dist = 64\nnet.ipv4.ipfrag_secret_interval = 0\nnet.ipv4.ipfrag_time = 30\nnet.ipv4.neigh.default.anycast_delay = 100\nnet.ipv4.neigh.default.app_solicit = 0\nnet.ipv4.neigh.default.base_reachable_time_ms = 30000\nnet.ipv4.neigh.default.delay_first_probe_time = 5\nnet.ipv4.neigh.default.gc_interval = 30\nnet.ipv4.neigh.default.gc_stale_time = 60\nnet.ipv4.neigh.default.gc_thresh1 = 128\nnet.ipv4.neigh.default.gc_thresh2 = 512\nnet.ipv4.neigh.default.gc_thresh3 = 1024\nnet.ipv4.neigh.default.locktime = 100\nnet.ipv4.neigh.default.mcast_resolicit = 0\nnet.ipv4.neigh.default.mcast_solicit = 3\nnet.ipv4.neigh.default.proxy_delay = 80\nnet.ipv4.neigh.default.proxy_qlen = 64\nnet.ipv4.neigh.default.retrans_time_ms = 1000\nnet.ipv4.neigh.default.ucast_solicit = 3\nnet.ipv4.neigh.default.unres_qlen = 30\nnet.ipv4.neigh.default.unres_qlen_bytes = 65536\nnet.ipv4.neigh.eth0.anycast_delay = 100\nnet.ipv4.neigh.eth0.app_solicit = 0\nnet.ipv4.neigh.eth0.base_reachable_time_ms = 30000\nnet.ipv4.neigh.eth0.delay_first_probe_time = 5\nnet.ipv4.neigh.eth0.gc_stale_time = 60\nnet.ipv4.neigh.eth0.locktime = 100\nnet.ipv4.neigh.eth0.mcast_resolicit = 0\nnet.ipv4.neigh.eth0.mcast_solicit = 3\nnet.ipv4.neigh.eth0.proxy_delay = 80\nnet.ipv4.neigh.eth0.proxy_qlen = 64\nnet.ipv4.neigh.eth0.retrans_time_ms = 1000\nnet.ipv4.neigh.eth0.ucast_solicit = 3\nnet.ipv4.neigh.eth0.unres_qlen = 30\nnet.ipv4.neigh.eth0.unres_qlen_bytes = 65536\nnet.ipv4.neigh.lo.anycast_delay = 100\nnet.ipv4.neigh.lo.app_solicit = 0\nnet.ipv4.neigh.lo.base_reachable_time_ms = 30000\nnet.ipv4.neigh.lo.delay_first_probe_time = 5\nnet.ipv4.neigh.lo.gc_stale_time = 60\nnet.ipv4.neigh.lo.locktime = 100\nnet.ipv4.neigh.lo.mcast_resolicit = 0\nnet.ipv4.neigh.lo.mcast_solicit = 3\nnet.ipv4.neigh.lo.proxy_delay = 80\nnet.ipv4.neigh.lo.proxy_qlen = 64\nnet.ipv4.neigh.lo.retrans_time_ms = 1000\nnet.ipv4.neigh.lo.ucast_solicit = 3\nnet.ipv4.neigh.lo.unres_qlen = 30\nnet.ipv4.neigh.lo.unres_qlen_bytes = 65536\nnet.ipv4.ping_group_range = 1\t0\nnet.ipv4.route.error_burst = 1250\nnet.ipv4.route.error_cost = 250\nnet.ipv4.route.gc_elasticity = 8\nnet.ipv4.route.gc_interval = 60\nnet.ipv4.route.gc_min_interval = 0\nnet.ipv4.route.gc_min_interval_ms = 500\nnet.ipv4.route.gc_thresh = -1\nnet.ipv4.route.gc_timeout = 300\nnet.ipv4.route.max_size = 2147483647\nnet.ipv4.route.min_adv_mss = 256\nnet.ipv4.route.min_pmtu = 552\nnet.ipv4.route.mtu_expires = 600\nnet.ipv4.route.redirect_load = 5\nnet.ipv4.route.redirect_number = 9\nnet.ipv4.route.redirect_silence = 5120\nnet.ipv4.tcp_abort_on_overflow = 0\nnet.ipv4.tcp_adv_win_scale = 1\nnet.ipv4.tcp_allowed_congestion_control = cubic reno\nnet.ipv4.tcp_app_win = 31\nnet.ipv4.tcp_autocorking = 1\nnet.ipv4.tcp_available_congestion_control = cubic reno\nnet.ipv4.tcp_base_mss = 1024\nnet.ipv4.tcp_challenge_ack_limit = 1000\nnet.ipv4.tcp_congestion_control = cubic\nnet.ipv4.tcp_dsack = 1\nnet.ipv4.tcp_early_retrans = 3\nnet.ipv4.tcp_ecn = 2\nnet.ipv4.tcp_ecn_fallback = 1\nnet.ipv4.tcp_fack = 1\nnet.ipv4.tcp_fastopen = 1\nsysctl: permission denied on key 'net.ipv4.tcp_fastopen_key'\nnet.ipv4.tcp_fin_timeout = 60\nnet.ipv4.tcp_frto = 2\nnet.ipv4.tcp_fwmark_accept = 0\nnet.ipv4.tcp_invalid_ratelimit = 500\nnet.ipv4.tcp_keepalive_intvl = 75\nnet.ipv4.tcp_keepalive_probes = 9\nnet.ipv4.tcp_keepalive_time = 7200\nnet.ipv4.tcp_l3mdev_accept = 0\nnet.ipv4.tcp_limit_output_bytes = 262144\nnet.ipv4.tcp_low_latency = 0\nnet.ipv4.tcp_max_orphans = 16384\nnet.ipv4.tcp_max_reordering = 300\nnet.ipv4.tcp_max_syn_backlog = 128\nnet.ipv4.tcp_max_tw_buckets = 16384\nnet.ipv4.tcp_mem = 3030\t4041\t6060\nnet.ipv4.tcp_min_rtt_wlen = 300\nnet.ipv4.tcp_min_tso_segs = 2\nnet.ipv4.tcp_moderate_rcvbuf = 1\nnet.ipv4.tcp_mtu_probing = 0\nnet.ipv4.tcp_no_metrics_save = 0\nnet.ipv4.tcp_notsent_lowat = 4294967295\nnet.ipv4.tcp_orphan_retries = 0\nnet.ipv4.tcp_pacing_ca_ratio = 120\nnet.ipv4.tcp_pacing_ss_ratio = 200\nnet.ipv4.tcp_probe_interval = 600\nnet.ipv4.tcp_probe_threshold = 8\nnet.ipv4.tcp_recovery = 1\nnet.ipv4.tcp_reordering = 3\nnet.ipv4.tcp_retrans_collapse = 1\nnet.ipv4.tcp_retries1 = 3\nnet.ipv4.tcp_retries2 = 15\nnet.ipv4.tcp_rfc1337 = 0\nnet.ipv4.tcp_rmem = 65536\t87380\t6291456\nnet.ipv4.tcp_sack = 1\nnet.ipv4.tcp_slow_start_after_idle = 1\nnet.ipv4.tcp_stdurg = 0\nnet.ipv4.tcp_syn_retries = 6\nnet.ipv4.tcp_synack_retries = 5\nnet.ipv4.tcp_syncookies = 1\nnet.ipv4.tcp_thin_dupack = 0\nnet.ipv4.tcp_thin_linear_timeouts = 0\nnet.ipv4.tcp_timestamps = 1\nnet.ipv4.tcp_tso_win_divisor = 3\nnet.ipv4.tcp_tw_recycle = 0\nnet.ipv4.tcp_tw_reuse = 0\nnet.ipv4.tcp_window_scaling = 1\nnet.ipv4.tcp_wmem = 65536\t16384\t4194304\nnet.ipv4.tcp_workaround_signed_windows = 0\nnet.ipv4.udp_mem = 6060\t8082\t12120\nnet.ipv4.udp_rmem_min = 65536\nnet.ipv4.udp_wmem_min = 65536\nnet.ipv4.xfrm4_gc_thresh = 2147483647\nnet.ipv6.anycast_src_echo_reply = 0\nnet.ipv6.auto_flowlabels = 1\nnet.ipv6.bindv6only = 0\nnet.ipv6.conf.all.accept_dad = 1\nnet.ipv6.conf.all.accept_ra = 1\nnet.ipv6.conf.all.accept_ra_defrtr = 1\nnet.ipv6.conf.all.accept_ra_from_local = 0\nnet.ipv6.conf.all.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.all.accept_ra_mtu = 1\nnet.ipv6.conf.all.accept_ra_pinfo = 1\nnet.ipv6.conf.all.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.all.accept_ra_rtr_pref = 1\nnet.ipv6.conf.all.accept_redirects = 1\nnet.ipv6.conf.all.accept_source_route = 0\nnet.ipv6.conf.all.autoconf = 1\nnet.ipv6.conf.all.dad_transmits = 1\nnet.ipv6.conf.all.disable_ipv6 = 0\nnet.ipv6.conf.all.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.all.drop_unsolicited_na = 0\nnet.ipv6.conf.all.force_mld_version = 0\nnet.ipv6.conf.all.force_tllao = 0\nnet.ipv6.conf.all.forwarding = 0\nnet.ipv6.conf.all.hop_limit = 64\nnet.ipv6.conf.all.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.all.keep_addr_on_down = 0\nnet.ipv6.conf.all.max_addresses = 16\nnet.ipv6.conf.all.max_desync_factor = 600\nnet.ipv6.conf.all.mc_forwarding = 0\nnet.ipv6.conf.all.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.all.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.all.mtu = 1280\nnet.ipv6.conf.all.ndisc_notify = 0\nnet.ipv6.conf.all.optimistic_dad = 0\nnet.ipv6.conf.all.proxy_ndp = 0\nnet.ipv6.conf.all.regen_max_retry = 3\nnet.ipv6.conf.all.router_probe_interval = 60\nnet.ipv6.conf.all.router_solicitation_delay = 1\nnet.ipv6.conf.all.router_solicitation_interval = 4\nnet.ipv6.conf.all.router_solicitation_max_interval = 3600\nnet.ipv6.conf.all.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.all.stable_secret'\nnet.ipv6.conf.all.suppress_frag_ndisc = 1\nnet.ipv6.conf.all.temp_prefered_lft = 86400\nnet.ipv6.conf.all.temp_valid_lft = 604800\nnet.ipv6.conf.all.use_oif_addrs_only = 0\nnet.ipv6.conf.all.use_optimistic = 0\nnet.ipv6.conf.all.use_tempaddr = 0\nnet.ipv6.conf.default.accept_dad = 1\nnet.ipv6.conf.default.accept_ra = 1\nnet.ipv6.conf.default.accept_ra_defrtr = 1\nnet.ipv6.conf.default.accept_ra_from_local = 0\nnet.ipv6.conf.default.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.default.accept_ra_mtu = 1\nnet.ipv6.conf.default.accept_ra_pinfo = 1\nnet.ipv6.conf.default.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.default.accept_ra_rtr_pref = 1\nnet.ipv6.conf.default.accept_redirects = 1\nnet.ipv6.conf.default.accept_source_route = 0\nnet.ipv6.conf.default.autoconf = 1\nnet.ipv6.conf.default.dad_transmits = 1\nnet.ipv6.conf.default.disable_ipv6 = 0\nnet.ipv6.conf.default.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.default.drop_unsolicited_na = 0\nnet.ipv6.conf.default.force_mld_version = 0\nnet.ipv6.conf.default.force_tllao = 0\nnet.ipv6.conf.default.forwarding = 0\nnet.ipv6.conf.default.hop_limit = 64\nnet.ipv6.conf.default.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.default.keep_addr_on_down = 0\nnet.ipv6.conf.default.max_addresses = 16\nnet.ipv6.conf.default.max_desync_factor = 600\nnet.ipv6.conf.default.mc_forwarding = 0\nnet.ipv6.conf.default.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.default.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.default.mtu = 1280\nnet.ipv6.conf.default.ndisc_notify = 0\nnet.ipv6.conf.default.optimistic_dad = 0\nnet.ipv6.conf.default.proxy_ndp = 0\nnet.ipv6.conf.default.regen_max_retry = 3\nnet.ipv6.conf.default.router_probe_interval = 60\nnet.ipv6.conf.default.router_solicitation_delay = 1\nnet.ipv6.conf.default.router_solicitation_interval = 4\nnet.ipv6.conf.default.router_solicitation_max_interval = 3600\nnet.ipv6.conf.default.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.default.stable_secret'\nnet.ipv6.conf.default.suppress_frag_ndisc = 1\nnet.ipv6.conf.default.temp_prefered_lft = 86400\nnet.ipv6.conf.default.temp_valid_lft = 604800\nnet.ipv6.conf.default.use_oif_addrs_only = 0\nnet.ipv6.conf.default.use_optimistic = 0\nnet.ipv6.conf.default.use_tempaddr = 0\nnet.ipv6.conf.eth0.accept_dad = 1\nnet.ipv6.conf.eth0.accept_ra = 1\nnet.ipv6.conf.eth0.accept_ra_defrtr = 1\nnet.ipv6.conf.eth0.accept_ra_from_local = 0\nnet.ipv6.conf.eth0.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.eth0.accept_ra_mtu = 1\nnet.ipv6.conf.eth0.accept_ra_pinfo = 1\nnet.ipv6.conf.eth0.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.eth0.accept_ra_rtr_pref = 1\nnet.ipv6.conf.eth0.accept_redirects = 1\nnet.ipv6.conf.eth0.accept_source_route = 0\nnet.ipv6.conf.eth0.autoconf = 1\nnet.ipv6.conf.eth0.dad_transmits = 1\nnet.ipv6.conf.eth0.disable_ipv6 = 0\nnet.ipv6.conf.eth0.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.eth0.drop_unsolicited_na = 0\nnet.ipv6.conf.eth0.force_mld_version = 0\nnet.ipv6.conf.eth0.force_tllao = 0\nnet.ipv6.conf.eth0.forwarding = 0\nnet.ipv6.conf.eth0.hop_limit = 64\nnet.ipv6.conf.eth0.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.eth0.keep_addr_on_down = 0\nnet.ipv6.conf.eth0.max_addresses = 16\nnet.ipv6.conf.eth0.max_desync_factor = 600\nnet.ipv6.conf.eth0.mc_forwarding = 0\nnet.ipv6.conf.eth0.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.eth0.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.eth0.mtu = 1500\nnet.ipv6.conf.eth0.ndisc_notify = 0\nnet.ipv6.conf.eth0.optimistic_dad = 0\nnet.ipv6.conf.eth0.proxy_ndp = 0\nnet.ipv6.conf.eth0.regen_max_retry = 3\nnet.ipv6.conf.eth0.router_probe_interval = 60\nnet.ipv6.conf.eth0.router_solicitation_delay = 1\nnet.ipv6.conf.eth0.router_solicitation_interval = 4\nnet.ipv6.conf.eth0.router_solicitation_max_interval = 3600\nnet.ipv6.conf.eth0.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.eth0.stable_secret'\nnet.ipv6.conf.eth0.suppress_frag_ndisc = 1\nnet.ipv6.conf.eth0.temp_prefered_lft = 86400\nnet.ipv6.conf.eth0.temp_valid_lft = 604800\nnet.ipv6.conf.eth0.use_oif_addrs_only = 0\nnet.ipv6.conf.eth0.use_optimistic = 0\nnet.ipv6.conf.eth0.use_tempaddr = 0\nnet.ipv6.conf.lo.accept_dad = -1\nnet.ipv6.conf.lo.accept_ra = 1\nnet.ipv6.conf.lo.accept_ra_defrtr = 1\nnet.ipv6.conf.lo.accept_ra_from_local = 0\nnet.ipv6.conf.lo.accept_ra_min_hop_limit = 1\nnet.ipv6.conf.lo.accept_ra_mtu = 1\nnet.ipv6.conf.lo.accept_ra_pinfo = 1\nnet.ipv6.conf.lo.accept_ra_rt_info_max_plen = 0\nnet.ipv6.conf.lo.accept_ra_rtr_pref = 1\nnet.ipv6.conf.lo.accept_redirects = 1\nnet.ipv6.conf.lo.accept_source_route = 0\nnet.ipv6.conf.lo.autoconf = 1\nnet.ipv6.conf.lo.dad_transmits = 1\nnet.ipv6.conf.lo.disable_ipv6 = 0\nnet.ipv6.conf.lo.drop_unicast_in_l2_multicast = 0\nnet.ipv6.conf.lo.drop_unsolicited_na = 0\nnet.ipv6.conf.lo.force_mld_version = 0\nnet.ipv6.conf.lo.force_tllao = 0\nnet.ipv6.conf.lo.forwarding = 0\nnet.ipv6.conf.lo.hop_limit = 64\nnet.ipv6.conf.lo.ignore_routes_with_linkdown = 0\nnet.ipv6.conf.lo.keep_addr_on_down = 0\nnet.ipv6.conf.lo.max_addresses = 16\nnet.ipv6.conf.lo.max_desync_factor = 600\nnet.ipv6.conf.lo.mc_forwarding = 0\nnet.ipv6.conf.lo.mldv1_unsolicited_report_interval = 10000\nnet.ipv6.conf.lo.mldv2_unsolicited_report_interval = 1000\nnet.ipv6.conf.lo.mtu = 65536\nnet.ipv6.conf.lo.ndisc_notify = 0\nnet.ipv6.conf.lo.optimistic_dad = 0\nnet.ipv6.conf.lo.proxy_ndp = 0\nnet.ipv6.conf.lo.regen_max_retry = 3\nnet.ipv6.conf.lo.router_probe_interval = 60\nnet.ipv6.conf.lo.router_solicitation_delay = 1\nnet.ipv6.conf.lo.router_solicitation_interval = 4\nnet.ipv6.conf.lo.router_solicitation_max_interval = 3600\nnet.ipv6.conf.lo.router_solicitations = -1\nsysctl: permission denied on key 'net.ipv6.conf.lo.stable_secret'\nnet.ipv6.conf.lo.suppress_frag_ndisc = 1\nnet.ipv6.conf.lo.temp_prefered_lft = 86400\nnet.ipv6.conf.lo.temp_valid_lft = 604800\nnet.ipv6.conf.lo.use_oif_addrs_only = 0\nnet.ipv6.conf.lo.use_optimistic = 0\nnet.ipv6.conf.lo.use_tempaddr = -1\nnet.ipv6.flowlabel_consistency = 1\nnet.ipv6.flowlabel_state_ranges = 0\nnet.ipv6.fwmark_reflect = 0\nnet.ipv6.icmp.ratelimit = 1000\nnet.ipv6.idgen_delay = 1\nnet.ipv6.idgen_retries = 3\nnet.ipv6.ip6frag_high_thresh = 4194304\nnet.ipv6.ip6frag_low_thresh = 3145728\nnet.ipv6.ip6frag_secret_interval = 0\nnet.ipv6.ip6frag_time = 60\nnet.ipv6.ip_nonlocal_bind = 0\nnet.ipv6.mld_max_msf = 64\nnet.ipv6.mld_qrv = 2\nnet.ipv6.neigh.default.anycast_delay = 100\nnet.ipv6.neigh.default.app_solicit = 0\nnet.ipv6.neigh.default.base_reachable_time_ms = 30000\nnet.ipv6.neigh.default.delay_first_probe_time = 5\nnet.ipv6.neigh.default.gc_interval = 30\nnet.ipv6.neigh.default.gc_stale_time = 60\nnet.ipv6.neigh.default.gc_thresh1 = 128\nnet.ipv6.neigh.default.gc_thresh2 = 512\nnet.ipv6.neigh.default.gc_thresh3 = 1024\nnet.ipv6.neigh.default.locktime = 0\nnet.ipv6.neigh.default.mcast_resolicit = 0\nnet.ipv6.neigh.default.mcast_solicit = 3\nnet.ipv6.neigh.default.proxy_delay = 80\nnet.ipv6.neigh.default.proxy_qlen = 64\nnet.ipv6.neigh.default.retrans_time_ms = 1000\nnet.ipv6.neigh.default.ucast_solicit = 3\nnet.ipv6.neigh.default.unres_qlen = 30\nnet.ipv6.neigh.default.unres_qlen_bytes = 65536\nnet.ipv6.neigh.eth0.anycast_delay = 100\nnet.ipv6.neigh.eth0.app_solicit = 0\nnet.ipv6.neigh.eth0.base_reachable_time_ms = 30000\nnet.ipv6.neigh.eth0.delay_first_probe_time = 5\nnet.ipv6.neigh.eth0.gc_stale_time = 60\nnet.ipv6.neigh.eth0.locktime = 0\nnet.ipv6.neigh.eth0.mcast_resolicit = 0\nnet.ipv6.neigh.eth0.mcast_solicit = 3\nnet.ipv6.neigh.eth0.proxy_delay = 80\nnet.ipv6.neigh.eth0.proxy_qlen = 64\nnet.ipv6.neigh.eth0.retrans_time_ms = 1000\nnet.ipv6.neigh.eth0.ucast_solicit = 3\nnet.ipv6.neigh.eth0.unres_qlen = 30\nnet.ipv6.neigh.eth0.unres_qlen_bytes = 65536\nnet.ipv6.neigh.lo.anycast_delay = 100\nnet.ipv6.neigh.lo.app_solicit = 0\nnet.ipv6.neigh.lo.base_reachable_time_ms = 30000\nnet.ipv6.neigh.lo.delay_first_probe_time = 5\nnet.ipv6.neigh.lo.gc_stale_time = 60\nnet.ipv6.neigh.lo.locktime = 0\nnet.ipv6.neigh.lo.mcast_resolicit = 0\nnet.ipv6.neigh.lo.mcast_solicit = 3\nnet.ipv6.neigh.lo.proxy_delay = 80\nnet.ipv6.neigh.lo.proxy_qlen = 64\nnet.ipv6.neigh.lo.retrans_time_ms = 1000\nnet.ipv6.neigh.lo.ucast_solicit = 3\nnet.ipv6.neigh.lo.unres_qlen = 30\nnet.ipv6.neigh.lo.unres_qlen_bytes = 65536\nnet.ipv6.route.gc_elasticity = 9\nnet.ipv6.route.gc_interval = 30\nnet.ipv6.route.gc_min_interval = 0\nnet.ipv6.route.gc_min_interval_ms = 500\nnet.ipv6.route.gc_thresh = 1024\nnet.ipv6.route.gc_timeout = 60\nnet.ipv6.route.max_size = 4096\nnet.ipv6.route.min_adv_mss = 1220\nnet.ipv6.route.mtu_expires = 600\nnet.ipv6.xfrm6_gc_thresh = 2147483647\nnet.netfilter.nf_log.0 = NONE\nnet.netfilter.nf_log.1 = NONE\nnet.netfilter.nf_log.10 = NONE\nnet.netfilter.nf_log.11 = NONE\nnet.netfilter.nf_log.12 = NONE\nnet.netfilter.nf_log.2 = NONE\nnet.netfilter.nf_log.3 = NONE\nnet.netfilter.nf_log.4 = NONE\nnet.netfilter.nf_log.5 = NONE\nnet.netfilter.nf_log.6 = NONE\nnet.netfilter.nf_log.7 = NONE\nnet.netfilter.nf_log.8 = NONE\nnet.netfilter.nf_log.9 = NONE\nnet.unix.max_dgram_qlen = 512\nuser.max_cgroup_namespaces = 16225\nuser.max_ipc_namespaces = 16225\nuser.max_mnt_namespaces = 16225\nuser.max_net_namespaces = 16225\nuser.max_pid_namespaces = 16225\nuser.max_user_namespaces = 16225\nuser.max_uts_namespaces = 16225\nvm.admin_reserve_kbytes = 8192\nvm.block_dump = 0\nvm.compact_unevictable_allowed = 1\nvm.dirty_background_bytes = 0\nvm.dirty_background_ratio = 10\nvm.dirty_bytes = 0\nvm.dirty_expire_centisecs = 3000\nvm.dirty_ratio = 20\nvm.dirty_writeback_centisecs = 500\nvm.dirtytime_expire_seconds = 43200\nvm.drop_caches = 0\nvm.extfrag_threshold = 500\nvm.hugepages_treat_as_movable = 0\nvm.hugetlb_shm_group = 0\nvm.laptop_mode = 0\nvm.legacy_va_layout = 0\nvm.lowmem_reserve_ratio = 256\t256\t32\nvm.max_map_count = 65530\nvm.memory_failure_early_kill = 0\nvm.memory_failure_recovery = 1\nvm.min_free_kbytes = 8152\nvm.min_slab_ratio = 5\nvm.min_unmapped_ratio = 1\nvm.mmap_min_addr = 4096\nsysctl: reading key \"vm.nr_hugepages\"\nsysctl: reading key \"vm.nr_hugepages_mempolicy\"\nsysctl: reading key \"vm.nr_overcommit_hugepages\"\nvm.nr_pdflush_threads = 0\nvm.numa_zonelist_order = default\nvm.oom_dump_tasks = 1\nvm.oom_kill_allocating_task = 0\nvm.overcommit_kbytes = 0\nvm.overcommit_memory = 0\nvm.overcommit_ratio = 50\nvm.page-cluster = 3\nvm.panic_on_oom = 0\nvm.percpu_pagelist_fraction = 0\nvm.stat_interval = 1\nsysctl: permission denied on key 'vm.stat_refresh'\nvm.swappiness = 60\nvm.user_reserve_kbytes = 129404\nvm.vfs_cache_pressure = 100\nvm.watermark_scale_factor = 10\nvm.zone_reclaim_mode = 0\n",
+ "meminfo": "MemTotal: 4175424 kB\nMemFree: 2699840 kB\nMemAvailable: 3898816 kB\nBuffers: 107968 kB\nCached: 1146688 kB\nSwapCached: 0 kB\nActive: 764288 kB\nInactive: 587008 kB\nActive(anon): 100800 kB\nInactive(anon): 76928 kB\nActive(file): 663488 kB\nInactive(file): 510080 kB\nUnevictable: 0 kB\nMlocked: 0 kB\nSwapTotal: 0 kB\nSwapFree: 0 kB\nDirty: 1856 kB\nWriteback: 0 kB\nAnonPages: 95744 kB\nMapped: 45248 kB\nShmem: 81152 kB\nSlab: 97792 kB\nSReclaimable: 66176 kB\nSUnreclaim: 31616 kB\nKernelStack: 1488 kB\nPageTables: 2048 kB\nNFS_Unstable: 0 kB\nBounce: 0 kB\nWritebackTmp: 0 kB\nCommitLimit: 2087680 kB\nCommitted_AS: 416448 kB\nVmallocTotal: 8589934592 kB\nVmallocUsed: 0 kB\nVmallocChunk: 0 kB\nHardwareCorrupted: 0 kB\nAnonHugePages: 0 kB\nShmemHugePages: 0 kB\nShmemPmdMapped: 0 kB\nCmaTotal: 0 kB\nCmaFree: 0 kB\n"
+ }
+} \ No newline at end of file
diff --git a/web/static/js/plugins.js b/web/static/js/plugins.js
index 728680b..728680b 100755..100644
--- a/web/static/js/plugins.js
+++ b/web/static/js/plugins.js
diff --git a/web/templates/admin/login.html b/web/templates/admin/login.html
deleted file mode 100644
index e9e7257..0000000
--- a/web/templates/admin/login.html
+++ /dev/null
@@ -1,11 +0,0 @@
-<html>
-<head>
-<meta http-equiv="refresh" content="0;url={% url 'pgperffarm.auth.login' %}/?next=/admin/"></meta>
-</head>
-<body>
-<h1>Redirect</h1>
-<p>
-Redirect <a href="{% url 'pgperffarm.auth.login' %}/?next=/admin/">here</a>
-</p>
-</body>
-</html> \ No newline at end of file
diff --git a/web/templates/admin_bak/login.html b/web/templates/admin_bak/login.html
new file mode 100644
index 0000000..224d856
--- /dev/null
+++ b/web/templates/admin_bak/login.html
@@ -0,0 +1,11 @@
+<html>
+<head>
+<meta http-equiv="refresh" content="0;url={% url 'login' %}/?next=/admin/"></meta>
+</head>
+<body>
+<h1>Redirect</h1>
+<p>
+Redirect <a href="{% url login' %}/?next=/admin/">here</a>
+</p>
+</body>
+</html> \ No newline at end of file
diff --git a/web/uwsgi.ini b/web/uwsgi.ini
new file mode 100644
index 0000000..8155200
--- /dev/null
+++ b/web/uwsgi.ini
@@ -0,0 +1,23 @@
+[uwsgi]
+# Django-related settings
+# socket=/opt/proj/script/uwsgi.sock
+
+# the base directory (full path)
+chdir = /var/www/web
+
+# Django s wsgi file
+module = pgperffarm.wsgi
+
+# process-related settings
+# master
+master = true
+
+# maximum number of worker processes
+processes = 4
+
+# ... with appropriate permissions - may be needed
+# chmod-socket = 664
+# clear environment on exit
+vacuum = true
+http=0.0.0.0:8080
+# pythonpath = /home/debian/env/pg_perf_farm2/lib/python2.7/site-packages \ No newline at end of file