diff options
author | Mark Wong | 2018-08-12 00:30:39 +0000 |
---|---|---|
committer | Mark Wong | 2018-08-12 00:30:39 +0000 |
commit | 85e3150fd9cd9c25ce11f27028e1a760e812f875 (patch) | |
tree | a6f42ed6db43388d72f54b7fba059cb925f5296e | |
parent | 611e28c6a76b0c43def17fc2cefffbe2c4ea2357 (diff) | |
parent | 5136593f9f895942175d65d6f44595f4afc080a9 (diff) |
Merge branch 'master' of https://github.com/PGPerfFarm/pgperffarm
142 files changed, 13657 insertions, 66 deletions
@@ -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 @@ -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. @@ -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> Your Info + </h3> + <span className="panel-report-num"> + 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 Binary files differnew file mode 100644 index 0000000..0103459 --- /dev/null +++ b/front-end/src/image/client-icon/1.png diff --git a/front-end/src/image/client-icon/2.png b/front-end/src/image/client-icon/2.png Binary files differnew file mode 100644 index 0000000..daa4f06 --- /dev/null +++ b/front-end/src/image/client-icon/2.png diff --git a/front-end/src/image/client-icon/4.png b/front-end/src/image/client-icon/4.png Binary files differnew file mode 100644 index 0000000..b7d7463 --- /dev/null +++ b/front-end/src/image/client-icon/4.png diff --git a/front-end/src/image/client-icon/5.png b/front-end/src/image/client-icon/5.png Binary files differnew file mode 100644 index 0000000..2779f13 --- /dev/null +++ b/front-end/src/image/client-icon/5.png diff --git a/front-end/src/image/fonteditor.ttf b/front-end/src/image/fonteditor.ttf Binary files differnew file mode 100644 index 0000000..07a9a1d --- /dev/null +++ b/front-end/src/image/fonteditor.ttf diff --git a/front-end/src/image/slonik.png b/front-end/src/image/slonik.png Binary files differnew file mode 100644 index 0000000..bb300aa --- /dev/null +++ b/front-end/src/image/slonik.png 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> Shortcuts + </h3> + </div> + <div className="list-group"> + <Link target='_blank' to="farmerApply/" className="list-group-item"> + <i className="fa fa-globe fa-fw"></i> Add a New Mchine + </Link> + <a onClick={() => {this.onLogout()}} className="list-group-item"> + <i className="fa fa-arrow-left fa-fw"></i> 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> Shortcuts + </h3> + </div> + <div className="list-group"> + <Link target='_blank' to="farmerApply/" className="list-group-item"> + <i className="fa fa-globe fa-fw"></i> Add a New Mchine + </Link> + + <a onClick={() => {this.onLogout()}} className="list-group-item"> + <i className="fa fa-arrow-left fa-fw"></i> 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¶m1=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/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 |