Consolidating BUILD files for clarity and ease of maintenance.

- module definitions extracted to modules.bzl
- all packaging done from top BUILD file
- removed all BUILD files from under tools tree

Change-Id: I0f45eb77c809c48d1446ce86f62be6f5baf40ded
diff --git a/BUILD b/BUILD
index c4daba4..7c76da0 100644
--- a/BUILD
+++ b/BUILD
@@ -1,319 +1,84 @@
-UTILS = [
-    "//utils/osgiwrap:osgi-jar",
-    "//utils/osgi:onlab-osgi",
-    "//utils/junit:onlab-junit",
-    "//utils/misc:onlab-misc",
-    "//utils/rest:onlab-rest",
-    #"//tools/build/conf:onos-build-conf",
-]
-
-API = [
-    "//core/api:onos-api",
-    "//incubator/api:onos-incubator-api",
-]
-
-CORE = UTILS + API + [
-    "//core/net:onos-core-net",
-    "//core/common:onos-core-common",
-    #"//core/store/primitives:onos-core-primitives",
-    "//core/store/serializers:onos-core-serializers",
-    "//core/store/dist:onos-core-dist",
-    "//core/security:onos-security",
-    "//core/store/persistence:onos-core-persistence",
-    "//incubator/net:onos-incubator-net",
-    "//incubator/store:onos-incubator-store",
-    "//incubator/rpc:onos-incubator-rpc",
-    "//cli:onos-cli",
-    "//protocols/rest/api:onos-protocols-rest-api",
-    "//protocols/rest/ctl:onos-protocols-rest-ctl",
-    #"//protocols/bgp/bgpio:onos-protocols-bgp-bgpio",
-    #"//protocols/bgp/api:onos-protocols-bgp-api",
-    #"//protocols/bgp/ctl:onos-protocols-bgp-ctl",
-    "//protocols/netconf/api:onos-protocols-netconf-api",
-    "//protocols/netconf/ctl:onos-protocols-netconf-ctl",
-    "//protocols/openflow/api:onos-protocols-openflow-api",
-    "//protocols/openflow/ctl:onos-protocols-openflow-ctl",
-    #"//protocols/ospf/api:onos-protocols-ospf-api",
-    #"//protocols/ospf/protocol:onos-protocols-ospf-protocol",
-    #"//protocols/ospf/ctl:onos-protocols-ospf-ctl",
-    #"//protocols/ovsdb/rfc:onos-protocols-ovsdb-rfc",
-    #"//protocols/ovsdb/api:onos-protocols-ovsdb-api",
-    #"//protocols/ovsdb/ctl:onos-protocols-ovsdb-ctl",
-    "//protocols/p4runtime/api:onos-protocols-p4runtime-api",
-    "//protocols/p4runtime/model:onos-protocols-p4runtime-model",
-    #"//protocols/pcep/pcepio:onos-protocols-pcep-pcepio",
-    #"//protocols/pcep/server/api:onos-protocols-pcep-server-api",
-    #"//protocols/pcep/server/ctl:onos-protocols-pcep-server-ctl",
-    #"//protocols/snmp/api:onos-protocols-snmp-api",
-    #"//protocols/snmp/ctl:onos-protocols-snmp-ctl",
-    #"//protocols/isis/api:onos-protocols-isis-api",
-    #"//protocols/isis/ctl:onos-protocols-isis-ctl",
-    #"//protocols/isis/isisio:onos-protocols-isis-isisio",
-    #"//protocols/lisp/api:onos-protocols-lisp-api",
-    #"//protocols/lisp/ctl:onos-protocols-lisp-ctl",
-    #"//protocols/lisp/msg:onos-protocols-lisp-msg",
-    #"//protocols/tl1/api:onos-protocols-tl1-api",
-    #"//protocols/tl1/ctl:onos-protocols-tl1-ctl",
-    #"//protocols/restconf/client/api:onos-protocols-restconf-client-api",
-    #"//protocols/restconf/client/ctl:onos-protocols-restconf-client-ctl",
-    #"//protocols/xmpp/core/api:onos-protocols-xmpp-core-api",
-    #"//protocols/xmpp/core/ctl:onos-protocols-xmpp-core-ctl",
-    #"//drivers/utilities:onos-drivers-utilities",
-    #"//providers/netconf/device:onos-providers-netconf-device",
-    #"//providers/openflow/device:onos-providers-openflow-device",
-    #"//providers/openflow/packet:onos-providers-openflow-packet",
-    #"//providers/openflow/flow:onos-providers-openflow-flow",
-    #"//providers/openflow/group:onos-providers-openflow-group",
-    #"//providers/openflow/meter:onos-providers-openflow-meter",
-    #"//providers/ovsdb/device:onos-providers-ovsdb-device",
-    #"//providers/ovsdb/tunnel:onos-providers-ovsdb-tunnel",
-    #"//providers/rest/device:onos-providers-rest-device",
-    #"//providers/snmp/device:onos-providers-snmp-device",
-    #"//providers/isis/cfg:onos-providers-isis-cfg",
-    #"//providers/isis/topology:onos-providers-isis-topology",
-    #"//providers/lisp/device:onos-providers-lisp-device",
-    #"//providers/tl1/device:onos-providers-tl1-device",
-    #"//providers/general/device:onos-providers-general-device",
-    #"//providers/p4runtime/packet:onos-providers-p4runtime-packet",
-    #"//web/api:onos-rest",
-    #"//web/gui2:onos-gui2",
-    #"//web/gui:onos-gui",
-    #"//incubator/protobuf/models:onos-incubator-protobuf-models",
-    #"//incubator/protobuf/services/nb:onos-incubator-protobuf-services-nb",
-]
-
-ONOS_DRIVERS = [
-    # Drivers
-    "//drivers/default:onos-drivers-default",
-    #"//drivers/arista:onos-drivers-arista-oar",
-    #"//drivers/ciena/waveserver:onos-drivers-ciena-waveserver-oar",
-    #"//drivers/ciena/c5162:onos-drivers-ciena-c5162-oar",
-    #"//drivers/ciena/c5170:onos-drivers-ciena-c5170-oar",
-    #"//drivers/ciena/waveserverai:onos-drivers-ciena-waveserverai-oar",
-    #"//drivers/cisco/netconf:onos-drivers-cisco-netconf-oar",
-    #"//drivers/cisco/rest:onos-drivers-cisco-rest-oar",
-    #"//drivers/corsa:onos-drivers-corsa-oar",
-    #"//drivers/fujitsu:onos-drivers-fujitsu-oar",
-    #"//drivers/lumentum:onos-drivers-lumentum-oar",
-    #"//drivers/netconf:onos-drivers-netconf-oar",
-    #"//drivers/server:onos-drivers-server-oar",
-    #"//drivers/optical:onos-drivers-optical-oar",
-    #"//drivers/ovsdb:onos-drivers-ovsdb-oar",
-    #"//drivers/juniper:onos-drivers-juniper-oar",
-    #"//drivers/lisp:onos-drivers-lisp-oar",
-    #"//drivers/flowspec:onos-drivers-flowspec-oar",
-    #"//drivers/huawei:onos-drivers-huawei-oar",
-    #"//drivers/microsemi/ea1000:onos-drivers-microsemi-ea1000-oar",
-    #"//drivers/oplink:onos-drivers-oplink-oar",
-    #"//drivers/bmv2:onos-drivers-bmv2-oar",
-    #"//drivers/barefoot:onos-drivers-barefoot-oar",
-    #"//drivers/mellanox:onos-drivers-mellanox-oar",
-    #"//drivers/hp:onos-drivers-hp-oar",
-    #"//drivers/p4runtime:onos-drivers-p4runtime-oar",
-    #"//drivers/gnmi:onos-drivers-gnmi-oar",
-    #"//drivers/polatis/netconf:onos-drivers-polatis-netconf-oar",
-    #"//drivers/polatis/openflow:onos-drivers-polatis-openflow-oar",
-    #"//drivers/odtn-driver:onos-drivers-odtn-driver-oar",
-]
-
-ONOS_PROVIDERS = [
-    # Providers
-    #"//providers/bgp:onos-providers-bgp-oar",
-    #"//providers/bgpcep:onos-providers-bgpcep-oar",
-    #"//providers/host:onos-providers-host-oar",
-    #"//providers/lldp:onos-providers-lldp-oar",
-    #"//providers/netcfghost:onos-providers-netcfghost-oar",
-    #"//providers/netcfglinks:onos-providers-netcfglinks-oar",
-    #"//providers/netconf:onos-providers-netconf-oar",
-    #"//providers/openflow/message:onos-providers-openflow-message-oar",
-    #"//providers/ovsdb:onos-providers-ovsdb-oar",
-    #"//providers/ovsdb/host:onos-providers-ovsdb-host-oar",
-    #"//providers/ovsdb/base:onos-providers-ovsdb-base-oar",
-    #"//providers/pcep:onos-providers-pcep-oar",
-    #"//providers/null:onos-providers-null-oar",
-    #"//providers/openflow/base:onos-providers-openflow-base-oar",
-    #"//providers/openflow/app:onos-providers-openflow-app-oar",
-    #"//providers/rest:onos-providers-rest-oar",
-    #"//providers/isis:onos-providers-isis-oar",
-    #"//providers/snmp:onos-providers-snmp-oar",
-    #"//providers/link:onos-providers-link-oar",
-    #"//providers/lisp:onos-providers-lisp-oar",
-    #"//providers/tl1:onos-providers-tl1-oar",
-    #"//providers/general:onos-providers-general-oar",
-    #"//providers/p4runtime:onos-providers-p4runtime-oar",
-    #    '//providers/ietfte:onos-providers-ietfte-oar',
-    #"//providers/xmpp/device:onos-providers-xmpp-device-oar",
-]
-
-ONOS_APPS = [
-    # Apps
-    #"//apps/dhcp:onos-apps-dhcp-oar",
-    #"//apps/dhcprelay:onos-apps-dhcprelay-oar",
-    #"//apps/fwd:onos-apps-fwd-oar",
-    #"//apps/packet-stats:onos-apps-packet-stats-oar",
-    #"//apps/acl:onos-apps-acl-oar",
-    #"//apps/bgprouter:onos-apps-bgprouter-oar",
-    #"//apps/cip:onos-apps-cip-oar",
-    #"//apps/drivermatrix:onos-apps-drivermatrix-oar",
-    #"//apps/events:onos-apps-events-oar",
-    #"//apps/proxyarp:onos-apps-proxyarp-oar",
-    #"//apps/segmentrouting:onos-apps-segmentrouting-oar",
-    #"//apps/gangliametrics:onos-apps-gangliametrics-oar",
-    #"//apps/graphitemetrics:onos-apps-graphitemetrics-oar",
-    #"//apps/flowanalyzer:onos-apps-flowanalyzer-oar",
-    #"//apps/intentsync:onos-apps-intentsync-oar",
-    #"//apps/influxdbmetrics:onos-apps-influxdbmetrics-oar",
-    #"//apps/metrics:onos-apps-metrics-oar",
-    #"//apps/mfwd:onos-apps-mfwd-oar",
-    #"//apps/mlb:onos-apps-mlb-oar",
-    #"//apps/openstacknetworking:onos-apps-openstacknetworking-oar",
-    "//apps/mobility:onos-apps-mobility-oar",
-    #"//apps/newoptical:onos-apps-newoptical-oar",
-    #"//apps/optical-model:onos-apps-optical-model-oar",
-    #"//apps/optical-rest:onos-apps-optical-rest-oar",
-    #"//apps/pathpainter:onos-apps-pathpainter-oar",
-    #"//apps/pcep-api:onos-apps-pcep-api-oar",
-    #"//apps/pim:onos-apps-pim-oar",
-    #"//apps/linkprops:onos-apps-linkprops-oar",
-    #"//apps/reactive-routing:onos-apps-reactive-routing-oar",
-    #"//apps/roadm:onos-apps-roadm-oar",
-    #"//apps/sdnip:onos-apps-sdnip-oar",
-    #"//apps/test/cluster-ha:onos-apps-test-cluster-ha-oar",
-    #"//apps/test/demo:onos-apps-test-demo-oar",
-    #"//apps/test/distributed-primitives:onos-apps-test-distributed-primitives-oar",
-    #"//apps/test/election:onos-apps-test-election-oar",
-    #"//apps/test/flow-perf:onos-apps-test-flow-perf-oar",
-    #"//apps/test/intent-perf:onos-apps-test-intent-perf-oar",
-    #"//apps/test/route-scale:onos-apps-test-route-scale-oar",
-    #"//apps/test/loadtest:onos-apps-test-loadtest-oar",
-    #"//apps/test/netcfg-monitor:onos-apps-test-netcfg-monitor-oar",
-    #"//apps/test/messaging-perf:onos-apps-test-messaging-perf-oar",
-    #"//apps/test/primitive-perf:onos-apps-test-primitive-perf-oar",
-    #"//apps/test/transaction-perf:onos-apps-test-transaction-perf-oar",
-    #"//apps/virtualbng:onos-apps-virtualbng-oar",
-    #"//apps/vpls:onos-apps-vpls-oar",
-    #"//apps/vrouter:onos-apps-vrouter-oar",
-    #"//apps/routing/fibinstaller:onos-apps-routing-fibinstaller-oar",
-    #"//apps/routing/cpr:onos-apps-routing-cpr-oar",
-    #"//apps/routing/fpm:onos-apps-routing-fpm-oar",
-    #"//apps/vtn:onos-apps-vtn-oar",
-    #"//apps/faultmanagement:onos-apps-faultmanagement-oar",
-    #"//apps/openstacknode:onos-apps-openstacknode-oar",
-    #"//apps/cpman/app:onos-apps-cpman-app-oar",
-    #"//apps/scalablegateway:onos-apps-scalablegateway-oar",
-    #"//apps/castor:onos-apps-castor-oar",
-    #    '//apps/yms:onos-apps-yms-oar',
-    #"//apps/ofagent:onos-apps-ofagent-oar",
-    #"//apps/mappingmanagement:onos-apps-mappingmanagement-oar",
-    #"//apps/config:onos-apps-config-oar",
-    #"//apps/configsync:onos-apps-configsync-oar",
-    #"//apps/configsync-netconf:onos-apps-configsync-netconf-oar",
-    #"//apps/netconf/client:onos-apps-netconf-client-oar",
-    #"//apps/tetopology:onos-apps-tetopology-oar",
-    #"//apps/tetunnel:onos-apps-tetunnel-oar",
-    #    '//apps/tenbi/yangmodel:onos-apps-tenbi-yangmodel-feature',
-    #    '//apps/tenbi:onos-apps-tenbi-oar',
-    #"//protocols/restconf/server:onos-protocols-restconf-server-oar",
-    #"//apps/restconf:onos-apps-restconf-oar",
-    #"//apps/flowspec-api:onos-apps-flowspec-api-oar",
-    #"//apps/yang:onos-apps-yang-oar",
-    #"//apps/yang-gui:onos-apps-yang-gui-oar",
-    #"//apps/cord-support:onos-apps-cord-support-oar",
-    #"//apps/network-troubleshoot:onos-apps-network-troubleshoot-oar",
-    #"//apps/l3vpn:onos-apps-l3vpn-oar",
-    #"//apps/openroadm:onos-apps-openroadm-oar",
-    #"//apps/artemis:onos-apps-artemis-oar",
-    #"//apps/pi-demo/ecmp:onos-apps-pi-demo-ecmp-oar",
-    #"//apps/gluon:onos-apps-gluon-oar",
-    #"//apps/evpnopenflow:onos-apps-evpnopenflow-oar",
-    #"//apps/route-service:onos-apps-route-service-oar",
-    #"//apps/evpn-route-service:onos-apps-evpn-route-service-oar",
-    #"//incubator/protobuf/registry:onos-incubator-protobuf-registry-oar",
-    #"//incubator/protobuf/services/nb:onos-incubator-protobuf-services-nb-oar",
-    #"//apps/openstacknetworkingui:onos-apps-openstacknetworkingui-oar",
-    #"//apps/openstacktelemetry:onos-apps-openstacktelemetry-oar",
-    #"//apps/p4-tutorial/pipeconf:onos-apps-p4-tutorial-pipeconf-oar",
-    #"//apps/p4-tutorial/mytunnel:onos-apps-p4-tutorial-mytunnel-oar",
-    #"//apps/cfm:onos-apps-cfm-oar",
-    #"//apps/routeradvertisement:onos-apps-routeradvertisement-oar",
-    #"//apps/powermanagement:onos-apps-powermanagement-oar",
-    #"//apps/t3:onos-apps-t3-oar",
-    #"//apps/simplefabric:onos-apps-simplefabric-oar",
-    #"//apps/kafka-integration:onos-apps-kafka-integration-oar",
-    #"//apps/rabbitmq:onos-apps-rabbitmq-oar",
-    #"//apps/odtn/api:onos-apps-odtn-api-oar",
-    #"//apps/odtn/service:onos-apps-odtn-service-oar",
-    #"//apps/mcast:onos-apps-mcast-oar",
-    #"//apps/layout:onos-apps-layout-oar",
-    #"//apps/imr:onos-apps-imr-oar",
-    #"//apps/nodemetrics:onos-apps-nodemetrics-oar",
-    #"//web/gui2:onos-web-gui2-oar",
-]
-
-PROTOCOL_APPS = [
-    #"//protocols/grpc:onos-protocols-grpc-oar",
-    #"//protocols/p4runtime:onos-protocols-p4runtime-oar",
-    #"//protocols/gnmi:onos-protocols-gnmi-oar",
-    #"//protocols/xmpp/core:onos-protocols-xmpp-core-oar",
-    #"//protocols/xmpp/pubsub:onos-protocols-xmpp-pubsub-oar",
-]
-
-MODELS = [
-    #"//models/ietf:onos-models-ietf-oar",
-    #"//models/common:onos-models-common-oar",
-    #"//models/huawei:onos-models-huawei-oar",
-    #"//models/openconfig:onos-models-openconfig-oar",
-    #"//models/openconfig-infinera:onos-models-openconfig-infinera-oar",
-    #"//models/openroadm:onos-models-openroadm-oar",
-    #"//models/tapi:onos-models-tapi-oar",
-    #"//models/l3vpn:onos-models-l3vpn-oar",
-    #"//models/microsemi:onos-models-microsemi-oar",
-    #"//models/polatis:onos-models-polatis-oar",
-    #"//models/ciena/waveserverai:onos-models-ciena-waveserverai-oar",
-]
-
-PIPELINES = [
-    #"//pipelines/basic:onos-pipelines-basic-oar",
-    #"//pipelines/fabric:onos-pipelines-fabric-oar",
-]
-
-APP_JARS = [
-    #"//apps/cpman/api:onos-apps-cpman-api",
-    #"//apps/routing-api:onos-apps-routing-api",
-    #"//apps/dhcp/api:onos-apps-dhcp-api",
-    #"//apps/dhcp/app:onos-apps-dhcp-app",
-    #"//apps/imr/api:onos-apps-imr-api",
-    #"//apps/imr/app:onos-apps-imr-app",
-    #"//apps/dhcprelay:onos-apps-dhcprelay",
-    #"//apps/fwd:onos-apps-fwd",
-    #"//apps/iptopology-api:onos-apps-iptopology-api",
-    #"//apps/routing/common:onos-apps-routing-common",
-    #"//apps/vtn/vtnrsc:onos-apps-vtn-vtnrsc",
-    #"//apps/vtn/sfcmgr:onos-apps-vtn-sfcmgr",
-    #"//apps/vtn/vtnmgr:onos-apps-vtn-vtnmgr",
-    #"//apps/vtn/vtnweb:onos-apps-vtn-vtnweb",
-    #   '//apps/p4runtime-test:onos-apps-p4runtime-test',
-    #"//apps/kafka-integration/api:onos-apps-kafka-integration-api",
-    #"//apps/kafka-integration/app:onos-apps-kafka-integration-app",
-]
-
-APPS = ONOS_DRIVERS + ONOS_PROVIDERS + ONOS_APPS + MODELS + PIPELINES + \
-       PROTOCOL_APPS
-
-PACKAGES = [
-    "//tools/package:onos-package-admin",
-    "//tools/package:onos-package-test",
-    "//tools/package:onos-package",
-]
+load("//tools/build/bazel:generate_workspace.bzl", "ONOS_VERSION")
+load(":modules.bzl", "CORE", "APPS")
 
 filegroup(
     name = "onos",
-    srcs = CORE + APPS + PACKAGES,
+    srcs = CORE + APPS + [
+       ":onos-package-admin",
+       ":onos-package-test",
+       ":onos-package",
+     ],
     visibility = ["//visibility:public"],
 )
 
-filegroup(
-    name = "onos-env-defaults",
-    srcs = ["tools/build/envDefaults"],
+KARAF = "@apache_karaf//file"
+PATCHES = "@apache_karaf_patches//file"
+BRANDING = "//tools/package/branding:onos-tools-package-branding"
+
+# Generates auxiliary karaf.zip file; branded and augmented with ONOS runtime tools
+genrule(
+    name = "onos-karaf",
+    srcs = [KARAF, PATCHES, BRANDING] + glob([
+        "tools/package/bin/*",
+        "tools/package/etc/*",
+        "tools/package/init/*",
+        "tools/package/runtime/bin/*"
+      ]),
+    outs = ["karaf.zip"],
+    cmd = "$(location tools/package/onos-prep-karaf) $(location karaf.zip) $(location %s) %s $(location %s) $(location %s) tools/package" \
+              % (KARAF, ONOS_VERSION, BRANDING, PATCHES),
+    tools = ["tools/package/onos-prep-karaf"],
+)
+
+# Generates the principal onos.tar.gz bundle
+# FIXME: Need to include OAR files as dependencies and feature bundles as well
+genrule(
+    name = "onos-package",
+    srcs = ["//tools/package/features:onos-features", ":onos-karaf"],
+    outs = ["onos.tar.gz"],
+    cmd = "$(location tools/package/onos_stage.py) $(location onos.tar.gz) %s $(location :onos-karaf) $(SRCS)" % ONOS_VERSION,
+    tools = ["tools/package/onos_stage.py"],
+    output_to_bindir = True,
+)
+
+# Generates the onos-admin.tar.gz file with remote admin tools
+genrule(
+    name = "onos-package-admin",
+    srcs = glob([
+        "tools/package/runtime/bin/*",
+        "tools/dev/bin/onos-create-app",
+        "tools/test/bin/onos"
+      ]),
+    outs = ["onos-admin.tar.gz"],
+    cmd = "mkdir onos-admin-%s; cp $(SRCS) onos-admin-%s; tar zcf $(location onos-admin.tar.gz) onos-admin-%s"\
+          % (ONOS_VERSION, ONOS_VERSION, ONOS_VERSION),
+    output_to_bindir = True,
+)
+
+# Generates the onos-test.tar.gz file with test tools
+genrule(
+    name = "onos-package-test",
+    srcs = glob([
+        "tools/build/envDefaults",
+        "tools/dev/bash_profile",
+        "tools/dev/bin/onos-create-app",
+        "tools/test/**/*",
+        "tools/package/runtime/bin/*"
+      ]),
+    outs = ["onos-test.tar.gz"],
+    cmd = "mkdir onos-test-%s; cp -r tools onos-test-%s; tar zcf $(location onos-test.tar.gz) onos-test-%s"\
+          % (ONOS_VERSION, ONOS_VERSION, ONOS_VERSION),
+    output_to_bindir = True,
+)
+
+# Runs ONOS as a single instance from the /tmp directory
+# FIXME: Still work in progress
+genrule(
+    name = "onos-run",
+    outs = ["onos-runner"],
+    srcs = ["onos-run-karaf", "onos-package"],
+    cmd = "sed \"s#ONOS_TAR=#ONOS_TAR=$(location :onos-package)#\" $(location onos-run-karaf) > $(location onos-runner); chmod +x $(location onos-runner)",
+    executable = True,
+    output_to_bindir = True,
     visibility = ["//visibility:public"],
 )
diff --git a/modules.bzl b/modules.bzl
new file mode 100644
index 0000000..8ade79e
--- /dev/null
+++ b/modules.bzl
@@ -0,0 +1,301 @@
+UTILS = [
+    "//utils/osgiwrap:osgi-jar",
+    "//utils/osgi:onlab-osgi",
+    "//utils/junit:onlab-junit",
+    "//utils/misc:onlab-misc",
+    "//utils/rest:onlab-rest",
+    #"//tools/build/conf:onos-build-conf",
+]
+
+API = [
+    "//core/api:onos-api",
+    "//incubator/api:onos-incubator-api",
+]
+
+CORE = UTILS + API + [
+    "//core/net:onos-core-net",
+    "//core/common:onos-core-common",
+    #"//core/store/primitives:onos-core-primitives",
+    "//core/store/serializers:onos-core-serializers",
+    "//core/store/dist:onos-core-dist",
+    "//core/security:onos-security",
+    "//core/store/persistence:onos-core-persistence",
+    "//incubator/net:onos-incubator-net",
+    "//incubator/store:onos-incubator-store",
+    "//incubator/rpc:onos-incubator-rpc",
+    "//cli:onos-cli",
+    "//protocols/rest/api:onos-protocols-rest-api",
+    "//protocols/rest/ctl:onos-protocols-rest-ctl",
+    #"//protocols/bgp/bgpio:onos-protocols-bgp-bgpio",
+    #"//protocols/bgp/api:onos-protocols-bgp-api",
+    #"//protocols/bgp/ctl:onos-protocols-bgp-ctl",
+    "//protocols/netconf/api:onos-protocols-netconf-api",
+    "//protocols/netconf/ctl:onos-protocols-netconf-ctl",
+    "//protocols/openflow/api:onos-protocols-openflow-api",
+    "//protocols/openflow/ctl:onos-protocols-openflow-ctl",
+    #"//protocols/ospf/api:onos-protocols-ospf-api",
+    #"//protocols/ospf/protocol:onos-protocols-ospf-protocol",
+    #"//protocols/ospf/ctl:onos-protocols-ospf-ctl",
+    #"//protocols/ovsdb/rfc:onos-protocols-ovsdb-rfc",
+    #"//protocols/ovsdb/api:onos-protocols-ovsdb-api",
+    #"//protocols/ovsdb/ctl:onos-protocols-ovsdb-ctl",
+    "//protocols/p4runtime/api:onos-protocols-p4runtime-api",
+    "//protocols/p4runtime/model:onos-protocols-p4runtime-model",
+    #"//protocols/pcep/pcepio:onos-protocols-pcep-pcepio",
+    #"//protocols/pcep/server/api:onos-protocols-pcep-server-api",
+    #"//protocols/pcep/server/ctl:onos-protocols-pcep-server-ctl",
+    #"//protocols/snmp/api:onos-protocols-snmp-api",
+    #"//protocols/snmp/ctl:onos-protocols-snmp-ctl",
+    #"//protocols/isis/api:onos-protocols-isis-api",
+    #"//protocols/isis/ctl:onos-protocols-isis-ctl",
+    #"//protocols/isis/isisio:onos-protocols-isis-isisio",
+    #"//protocols/lisp/api:onos-protocols-lisp-api",
+    #"//protocols/lisp/ctl:onos-protocols-lisp-ctl",
+    #"//protocols/lisp/msg:onos-protocols-lisp-msg",
+    #"//protocols/tl1/api:onos-protocols-tl1-api",
+    #"//protocols/tl1/ctl:onos-protocols-tl1-ctl",
+    #"//protocols/restconf/client/api:onos-protocols-restconf-client-api",
+    #"//protocols/restconf/client/ctl:onos-protocols-restconf-client-ctl",
+    #"//protocols/xmpp/core/api:onos-protocols-xmpp-core-api",
+    #"//protocols/xmpp/core/ctl:onos-protocols-xmpp-core-ctl",
+    #"//drivers/utilities:onos-drivers-utilities",
+    #"//providers/netconf/device:onos-providers-netconf-device",
+    #"//providers/openflow/device:onos-providers-openflow-device",
+    #"//providers/openflow/packet:onos-providers-openflow-packet",
+    #"//providers/openflow/flow:onos-providers-openflow-flow",
+    #"//providers/openflow/group:onos-providers-openflow-group",
+    #"//providers/openflow/meter:onos-providers-openflow-meter",
+    #"//providers/ovsdb/device:onos-providers-ovsdb-device",
+    #"//providers/ovsdb/tunnel:onos-providers-ovsdb-tunnel",
+    #"//providers/rest/device:onos-providers-rest-device",
+    #"//providers/snmp/device:onos-providers-snmp-device",
+    #"//providers/isis/cfg:onos-providers-isis-cfg",
+    #"//providers/isis/topology:onos-providers-isis-topology",
+    #"//providers/lisp/device:onos-providers-lisp-device",
+    #"//providers/tl1/device:onos-providers-tl1-device",
+    #"//providers/general/device:onos-providers-general-device",
+    #"//providers/p4runtime/packet:onos-providers-p4runtime-packet",
+    #"//web/api:onos-rest",
+    #"//web/gui2:onos-gui2",
+    #"//web/gui:onos-gui",
+    #"//incubator/protobuf/models:onos-incubator-protobuf-models",
+    #"//incubator/protobuf/services/nb:onos-incubator-protobuf-services-nb",
+]
+
+ONOS_DRIVERS = [
+    # Drivers
+    "//drivers/default:onos-drivers-default",
+    #"//drivers/arista:onos-drivers-arista-oar",
+    #"//drivers/ciena/waveserver:onos-drivers-ciena-waveserver-oar",
+    #"//drivers/ciena/c5162:onos-drivers-ciena-c5162-oar",
+    #"//drivers/ciena/c5170:onos-drivers-ciena-c5170-oar",
+    #"//drivers/ciena/waveserverai:onos-drivers-ciena-waveserverai-oar",
+    #"//drivers/cisco/netconf:onos-drivers-cisco-netconf-oar",
+    #"//drivers/cisco/rest:onos-drivers-cisco-rest-oar",
+    #"//drivers/corsa:onos-drivers-corsa-oar",
+    #"//drivers/fujitsu:onos-drivers-fujitsu-oar",
+    #"//drivers/lumentum:onos-drivers-lumentum-oar",
+    #"//drivers/netconf:onos-drivers-netconf-oar",
+    #"//drivers/server:onos-drivers-server-oar",
+    #"//drivers/optical:onos-drivers-optical-oar",
+    #"//drivers/ovsdb:onos-drivers-ovsdb-oar",
+    #"//drivers/juniper:onos-drivers-juniper-oar",
+    #"//drivers/lisp:onos-drivers-lisp-oar",
+    #"//drivers/flowspec:onos-drivers-flowspec-oar",
+    #"//drivers/huawei:onos-drivers-huawei-oar",
+    #"//drivers/microsemi/ea1000:onos-drivers-microsemi-ea1000-oar",
+    #"//drivers/oplink:onos-drivers-oplink-oar",
+    #"//drivers/bmv2:onos-drivers-bmv2-oar",
+    #"//drivers/barefoot:onos-drivers-barefoot-oar",
+    #"//drivers/mellanox:onos-drivers-mellanox-oar",
+    #"//drivers/hp:onos-drivers-hp-oar",
+    #"//drivers/p4runtime:onos-drivers-p4runtime-oar",
+    #"//drivers/gnmi:onos-drivers-gnmi-oar",
+    #"//drivers/polatis/netconf:onos-drivers-polatis-netconf-oar",
+    #"//drivers/polatis/openflow:onos-drivers-polatis-openflow-oar",
+    #"//drivers/odtn-driver:onos-drivers-odtn-driver-oar",
+]
+
+ONOS_PROVIDERS = [
+    # Providers
+    #"//providers/bgp:onos-providers-bgp-oar",
+    #"//providers/bgpcep:onos-providers-bgpcep-oar",
+    #"//providers/host:onos-providers-host-oar",
+    #"//providers/lldp:onos-providers-lldp-oar",
+    #"//providers/netcfghost:onos-providers-netcfghost-oar",
+    #"//providers/netcfglinks:onos-providers-netcfglinks-oar",
+    #"//providers/netconf:onos-providers-netconf-oar",
+    #"//providers/openflow/message:onos-providers-openflow-message-oar",
+    #"//providers/ovsdb:onos-providers-ovsdb-oar",
+    #"//providers/ovsdb/host:onos-providers-ovsdb-host-oar",
+    #"//providers/ovsdb/base:onos-providers-ovsdb-base-oar",
+    #"//providers/pcep:onos-providers-pcep-oar",
+    #"//providers/null:onos-providers-null-oar",
+    #"//providers/openflow/base:onos-providers-openflow-base-oar",
+    #"//providers/openflow/app:onos-providers-openflow-app-oar",
+    #"//providers/rest:onos-providers-rest-oar",
+    #"//providers/isis:onos-providers-isis-oar",
+    #"//providers/snmp:onos-providers-snmp-oar",
+    #"//providers/link:onos-providers-link-oar",
+    #"//providers/lisp:onos-providers-lisp-oar",
+    #"//providers/tl1:onos-providers-tl1-oar",
+    #"//providers/general:onos-providers-general-oar",
+    #"//providers/p4runtime:onos-providers-p4runtime-oar",
+    #    '//providers/ietfte:onos-providers-ietfte-oar',
+    #"//providers/xmpp/device:onos-providers-xmpp-device-oar",
+]
+
+ONOS_APPS = [
+    # Apps
+    #"//apps/dhcp:onos-apps-dhcp-oar",
+    #"//apps/dhcprelay:onos-apps-dhcprelay-oar",
+    #"//apps/fwd:onos-apps-fwd-oar",
+    #"//apps/packet-stats:onos-apps-packet-stats-oar",
+    #"//apps/acl:onos-apps-acl-oar",
+    #"//apps/bgprouter:onos-apps-bgprouter-oar",
+    #"//apps/cip:onos-apps-cip-oar",
+    #"//apps/drivermatrix:onos-apps-drivermatrix-oar",
+    #"//apps/events:onos-apps-events-oar",
+    #"//apps/proxyarp:onos-apps-proxyarp-oar",
+    #"//apps/segmentrouting:onos-apps-segmentrouting-oar",
+    #"//apps/gangliametrics:onos-apps-gangliametrics-oar",
+    #"//apps/graphitemetrics:onos-apps-graphitemetrics-oar",
+    #"//apps/flowanalyzer:onos-apps-flowanalyzer-oar",
+    #"//apps/intentsync:onos-apps-intentsync-oar",
+    #"//apps/influxdbmetrics:onos-apps-influxdbmetrics-oar",
+    #"//apps/metrics:onos-apps-metrics-oar",
+    #"//apps/mfwd:onos-apps-mfwd-oar",
+    #"//apps/mlb:onos-apps-mlb-oar",
+    #"//apps/openstacknetworking:onos-apps-openstacknetworking-oar",
+    "//apps/mobility:onos-apps-mobility-oar",
+    #"//apps/newoptical:onos-apps-newoptical-oar",
+    #"//apps/optical-model:onos-apps-optical-model-oar",
+    #"//apps/optical-rest:onos-apps-optical-rest-oar",
+    #"//apps/pathpainter:onos-apps-pathpainter-oar",
+    #"//apps/pcep-api:onos-apps-pcep-api-oar",
+    #"//apps/pim:onos-apps-pim-oar",
+    #"//apps/linkprops:onos-apps-linkprops-oar",
+    #"//apps/reactive-routing:onos-apps-reactive-routing-oar",
+    #"//apps/roadm:onos-apps-roadm-oar",
+    #"//apps/sdnip:onos-apps-sdnip-oar",
+    #"//apps/test/cluster-ha:onos-apps-test-cluster-ha-oar",
+    #"//apps/test/demo:onos-apps-test-demo-oar",
+    #"//apps/test/distributed-primitives:onos-apps-test-distributed-primitives-oar",
+    #"//apps/test/election:onos-apps-test-election-oar",
+    #"//apps/test/flow-perf:onos-apps-test-flow-perf-oar",
+    #"//apps/test/intent-perf:onos-apps-test-intent-perf-oar",
+    #"//apps/test/route-scale:onos-apps-test-route-scale-oar",
+    #"//apps/test/loadtest:onos-apps-test-loadtest-oar",
+    #"//apps/test/netcfg-monitor:onos-apps-test-netcfg-monitor-oar",
+    #"//apps/test/messaging-perf:onos-apps-test-messaging-perf-oar",
+    #"//apps/test/primitive-perf:onos-apps-test-primitive-perf-oar",
+    #"//apps/test/transaction-perf:onos-apps-test-transaction-perf-oar",
+    #"//apps/virtualbng:onos-apps-virtualbng-oar",
+    #"//apps/vpls:onos-apps-vpls-oar",
+    #"//apps/vrouter:onos-apps-vrouter-oar",
+    #"//apps/routing/fibinstaller:onos-apps-routing-fibinstaller-oar",
+    #"//apps/routing/cpr:onos-apps-routing-cpr-oar",
+    #"//apps/routing/fpm:onos-apps-routing-fpm-oar",
+    #"//apps/vtn:onos-apps-vtn-oar",
+    #"//apps/faultmanagement:onos-apps-faultmanagement-oar",
+    #"//apps/openstacknode:onos-apps-openstacknode-oar",
+    #"//apps/cpman/app:onos-apps-cpman-app-oar",
+    #"//apps/scalablegateway:onos-apps-scalablegateway-oar",
+    #"//apps/castor:onos-apps-castor-oar",
+    #    '//apps/yms:onos-apps-yms-oar',
+    #"//apps/ofagent:onos-apps-ofagent-oar",
+    #"//apps/mappingmanagement:onos-apps-mappingmanagement-oar",
+    #"//apps/config:onos-apps-config-oar",
+    #"//apps/configsync:onos-apps-configsync-oar",
+    #"//apps/configsync-netconf:onos-apps-configsync-netconf-oar",
+    #"//apps/netconf/client:onos-apps-netconf-client-oar",
+    #"//apps/tetopology:onos-apps-tetopology-oar",
+    #"//apps/tetunnel:onos-apps-tetunnel-oar",
+    #    '//apps/tenbi/yangmodel:onos-apps-tenbi-yangmodel-feature',
+    #    '//apps/tenbi:onos-apps-tenbi-oar',
+    #"//protocols/restconf/server:onos-protocols-restconf-server-oar",
+    #"//apps/restconf:onos-apps-restconf-oar",
+    #"//apps/flowspec-api:onos-apps-flowspec-api-oar",
+    #"//apps/yang:onos-apps-yang-oar",
+    #"//apps/yang-gui:onos-apps-yang-gui-oar",
+    #"//apps/cord-support:onos-apps-cord-support-oar",
+    #"//apps/network-troubleshoot:onos-apps-network-troubleshoot-oar",
+    #"//apps/l3vpn:onos-apps-l3vpn-oar",
+    #"//apps/openroadm:onos-apps-openroadm-oar",
+    #"//apps/artemis:onos-apps-artemis-oar",
+    #"//apps/pi-demo/ecmp:onos-apps-pi-demo-ecmp-oar",
+    #"//apps/gluon:onos-apps-gluon-oar",
+    #"//apps/evpnopenflow:onos-apps-evpnopenflow-oar",
+    #"//apps/route-service:onos-apps-route-service-oar",
+    #"//apps/evpn-route-service:onos-apps-evpn-route-service-oar",
+    #"//incubator/protobuf/registry:onos-incubator-protobuf-registry-oar",
+    #"//incubator/protobuf/services/nb:onos-incubator-protobuf-services-nb-oar",
+    #"//apps/openstacknetworkingui:onos-apps-openstacknetworkingui-oar",
+    #"//apps/openstacktelemetry:onos-apps-openstacktelemetry-oar",
+    #"//apps/p4-tutorial/pipeconf:onos-apps-p4-tutorial-pipeconf-oar",
+    #"//apps/p4-tutorial/mytunnel:onos-apps-p4-tutorial-mytunnel-oar",
+    #"//apps/cfm:onos-apps-cfm-oar",
+    #"//apps/routeradvertisement:onos-apps-routeradvertisement-oar",
+    #"//apps/powermanagement:onos-apps-powermanagement-oar",
+    #"//apps/t3:onos-apps-t3-oar",
+    #"//apps/simplefabric:onos-apps-simplefabric-oar",
+    #"//apps/kafka-integration:onos-apps-kafka-integration-oar",
+    #"//apps/rabbitmq:onos-apps-rabbitmq-oar",
+    #"//apps/odtn/api:onos-apps-odtn-api-oar",
+    #"//apps/odtn/service:onos-apps-odtn-service-oar",
+    #"//apps/mcast:onos-apps-mcast-oar",
+    #"//apps/layout:onos-apps-layout-oar",
+    #"//apps/imr:onos-apps-imr-oar",
+    #"//apps/nodemetrics:onos-apps-nodemetrics-oar",
+    #"//web/gui2:onos-web-gui2-oar",
+]
+
+PROTOCOL_APPS = [
+    #"//protocols/grpc:onos-protocols-grpc-oar",
+    #"//protocols/p4runtime:onos-protocols-p4runtime-oar",
+    #"//protocols/gnmi:onos-protocols-gnmi-oar",
+    #"//protocols/xmpp/core:onos-protocols-xmpp-core-oar",
+    #"//protocols/xmpp/pubsub:onos-protocols-xmpp-pubsub-oar",
+]
+
+MODELS = [
+    #"//models/ietf:onos-models-ietf-oar",
+    #"//models/common:onos-models-common-oar",
+    #"//models/huawei:onos-models-huawei-oar",
+    #"//models/openconfig:onos-models-openconfig-oar",
+    #"//models/openconfig-infinera:onos-models-openconfig-infinera-oar",
+    #"//models/openroadm:onos-models-openroadm-oar",
+    #"//models/tapi:onos-models-tapi-oar",
+    #"//models/l3vpn:onos-models-l3vpn-oar",
+    #"//models/microsemi:onos-models-microsemi-oar",
+    #"//models/polatis:onos-models-polatis-oar",
+    #"//models/ciena/waveserverai:onos-models-ciena-waveserverai-oar",
+]
+
+PIPELINES = [
+    #"//pipelines/basic:onos-pipelines-basic-oar",
+    #"//pipelines/fabric:onos-pipelines-fabric-oar",
+]
+
+APP_JARS = [
+    #"//apps/cpman/api:onos-apps-cpman-api",
+    #"//apps/routing-api:onos-apps-routing-api",
+    #"//apps/dhcp/api:onos-apps-dhcp-api",
+    #"//apps/dhcp/app:onos-apps-dhcp-app",
+    #"//apps/imr/api:onos-apps-imr-api",
+    #"//apps/imr/app:onos-apps-imr-app",
+    #"//apps/dhcprelay:onos-apps-dhcprelay",
+    #"//apps/fwd:onos-apps-fwd",
+    #"//apps/iptopology-api:onos-apps-iptopology-api",
+    #"//apps/routing/common:onos-apps-routing-common",
+    #"//apps/vtn/vtnrsc:onos-apps-vtn-vtnrsc",
+    #"//apps/vtn/sfcmgr:onos-apps-vtn-sfcmgr",
+    #"//apps/vtn/vtnmgr:onos-apps-vtn-vtnmgr",
+    #"//apps/vtn/vtnweb:onos-apps-vtn-vtnweb",
+    #   '//apps/p4runtime-test:onos-apps-p4runtime-test',
+    #"//apps/kafka-integration/api:onos-apps-kafka-integration-api",
+    #"//apps/kafka-integration/app:onos-apps-kafka-integration-app",
+]
+
+APPS = ONOS_DRIVERS + ONOS_PROVIDERS + ONOS_APPS + MODELS + PIPELINES + \
+       PROTOCOL_APPS
diff --git a/tools/dev/BUILD b/tools/dev/BUILD
deleted file mode 100644
index 966d711..0000000
--- a/tools/dev/BUILD
+++ /dev/null
@@ -1,17 +0,0 @@
-
-filegroup(
-    name = "onos-admin",
-    srcs = [
-        "bin/onos-create-app",
-    ],
-    visibility = ["//visibility:public"],
-)
-
-filegroup(
-    name = "onos-test",
-    srcs = [
-        "bash_profile",
-        "bin/onos-create-app",
-    ],
-    visibility = ["//visibility:public"],
-)
\ No newline at end of file
diff --git a/tools/package/BUILD b/tools/package/BUILD
deleted file mode 100644
index 2067140..0000000
--- a/tools/package/BUILD
+++ /dev/null
@@ -1,87 +0,0 @@
-load("//tools/build/bazel:generate_workspace.bzl", "ONOS_VERSION")
-
-KARAF = "@apache_karaf//file"
-PATCHES = "@apache_karaf_patches//file"
-BRANDING = "//tools/package/branding:onos-tools-package-branding"
-
-BRANDED_KARAF_REQUIREMENTS = [
-    KARAF,
-    PATCHES,
-    BRANDING,
-]
-
-# Generates auxiliary karaf.zip file; branded and augmented with ONOS runtime tools
-genrule(
-    name = "onos-karaf",
-    srcs = BRANDED_KARAF_REQUIREMENTS + glob(["bin/*", "etc/*", "init/*", "runtime/bin/*"]),
-    outs = ["karaf.zip"],
-    cmd = "$(location onos-prep-karaf) $(location karaf.zip) $(location %s) %s $(location %s) $(location %s) tools/package" \
-              % (KARAF, ONOS_VERSION, BRANDING, PATCHES),
-    tools = ["onos-prep-karaf"],
-)
-
-# FIXME: Move /features to under tools/package/features
-PACKAGING_REQUIREMENTS = [
-    "//tools/package/features:onos-features",
-    ":onos-karaf",
-]
-
-# FIXME: Need to add OAR files as dependencies
-# Generates the principal distributable onos.tar.gz file
-genrule(
-    name = "onos-package",
-    srcs = PACKAGING_REQUIREMENTS + glob(["bin/*", "etc/*", "init/*", "config/*", "runtime/bin/*"]),
-    outs = ["onos.tar.gz"],
-    cmd = "$(location onos_stage.py) $(location onos.tar.gz) %s $(location :onos-karaf) $(SRCS)" % ONOS_VERSION,
-    visibility = ["//visibility:public"],
-    tools = ["onos_stage.py"],
-    output_to_bindir = True,
-)
-
-filegroup(
-    name = "onos-runtime-tools",
-    srcs = glob(["runtime/bin/*"]),
-)
-
-# Generates the onos-admin.tar.gz file with remote admin tools
-genrule(
-    name = "onos-package-admin",
-    srcs = ["//tools/dev:onos-admin", "//tools/test:onos-admin", ":onos-runtime-tools"],
-    outs = ["onos-admin.tar.gz"],
-    cmd = "mkdir onos-admin-%s; cp $(SRCS) onos-admin-%s; tar zcf $(location onos-admin.tar.gz) onos-admin-%s"\
-          % (ONOS_VERSION, ONOS_VERSION, ONOS_VERSION),
-    visibility = ["//visibility:public"],
-    output_to_bindir = True,
-)
-
-# Generates the onos-test.tar.gz file with test tools
-genrule(
-    name = "onos-package-test",
-    srcs = ["//tools/dev:onos-test", "//tools/test:onos-test", ":onos-runtime-tools", "//:onos-env-defaults"],
-    outs = ["onos-test.tar.gz"],
-    cmd = "mkdir onos-test-%s; cp -r tools onos-test-%s; tar zcf $(location onos-test.tar.gz) onos-test-%s"\
-          % (ONOS_VERSION, ONOS_VERSION, ONOS_VERSION),
-    visibility = ["//visibility:public"],
-    output_to_bindir = True,
-)
-
-# Runs ONOS as a single instance from the /tmp directory
-# FIXME: Still work in progress
-genrule(
-    name = "onos-run",
-    outs = ["onos-runner"],
-    srcs = ["onos-run-karaf", "onos-package"],
-    cmd = "sed \"s#ONOS_TAR=#ONOS_TAR=$(location :onos-package)#\" $(location onos-run-karaf) > $(location onos-runner); chmod +x $(location onos-runner)",
-    executable = True,
-    output_to_bindir = True,
-    visibility = ["//visibility:public"],
-)
-
-#staged_repos = ['$(location %s-repo)' % f for f in FEATURES]
-#staged_apps = ['$(location %s)' % a for a in APPS]
-#
-## feature_coords = 'foo:bar:1.3'
-#sources = [ '$(location :onos-features)', ]
-#sources += staged_repos + staged_apps
-
-
diff --git a/tools/test/BUILD b/tools/test/BUILD
deleted file mode 100644
index db476dd..0000000
--- a/tools/test/BUILD
+++ /dev/null
@@ -1,14 +0,0 @@
-
-filegroup(
-    name = "onos-admin",
-    srcs = [
-        "bin/onos",
-      ],
-    visibility = ["//visibility:public"],
-)
-
-filegroup(
-    name = "onos-test",
-    srcs = glob(["**/*"]),
-    visibility = ["//visibility:public"],
-)
\ No newline at end of file