Nokia: Putting in support for metro network services within XOS for E-CORD

Change-Id: I9277ccf808479dd593ee1b7b640a2247a5b28a39
diff --git a/views/ngXosViews/ecordTopology/mocks/sca.py b/views/ngXosViews/ecordTopology/mocks/sca.py
new file mode 100644
index 0000000..1b7aec3
--- /dev/null
+++ b/views/ngXosViews/ecordTopology/mocks/sca.py
@@ -0,0 +1,80 @@
+#!/usr/bin/python
+
+import copy
+import json
+from flask import Flask, make_response, request
+from flask.ext.cors import CORS
+from subprocess import call
+
+app = Flask(__name__)
+app.debug = True
+CORS(app)
+
+e_lines = {}
+
+
+@app.route('/SCA_ETH_FDFr_EC/findByState', methods=['GET'])
+def get_elines_by_state():
+    resp = make_response(json.dumps(e_lines.values()))
+    resp.mimetype = 'application/json'
+    resp.headers['Access-Control-Allow-Origin'] = '*'
+    return resp
+
+
+@app.route('/SCA_ETH_FDFr_EC', methods=['GET'])
+def get_elines():
+    resp = make_response(json.dumps(e_lines.values()))
+    resp.mimetype = 'application/json'
+    resp.headers['Access-Control-Allow-Origin'] = '*'
+    return resp
+
+
+@app.route('/SCA_ETH_FDFr_EC/<name>/', methods=['GET'])
+def get_eline(name):
+    resp = make_response(json.dumps(e_lines[int(name)]))
+    resp.mimetype = 'application/json'
+    resp.headers['Access-Control-Allow-Origin'] = '*'
+    return resp
+
+
+# Convert long value to dotted hex value with specified length in bytes
+def longToHex(l, length=6):
+    h = ("%x" % l)
+    if len(h) % 2 != 0:
+        h = '0' + h
+    result = ':'.join([h[i:i+2] for i in range(0, len(h), 2)])
+    prefix = '00:' * (length - (len(h) / 2) - (len(h) % 2))
+    return prefix + result
+
+
+@app.route('/SCA_ETH_FDFr_EC', methods=['POST'])
+def create_eline():
+    # Store E-Line
+    e_line = json.loads(request.data)
+    e_line['id'] = len(e_lines) + 1
+
+    e_lines[e_line['id']] = e_line
+
+    # Create E-Line in ONOS
+    flow_points = e_line['SCA_ETH_Flow_Points']
+
+    # src_host = flow_points[0]['scaEthFppUniN']['transportPort']['Hostname'] + '/-' + flow_points[0]['scaEthFppUniN']['transportPort']['Port']
+    # dst_host = flow_points[1]['scaEthFppUniN']['transportPort']['Hostname'] + '/-' + flow_points[1]['scaEthFppUniN']['transportPort']['Port']
+
+    src_index = int(flow_points[0]['scaEthFppUniN']['transportPort']['Hostname'][-2:])
+    dst_index = int(flow_points[1]['scaEthFppUniN']['transportPort']['Hostname'][-2:])
+
+    src_host = str(longToHex(src_index, 6)) + '/-1'
+    dst_host = str(longToHex(dst_index, 6)) + '/-1'
+
+    print 'Creating E-Line between %s (%s) and %s (%s)' % (src_index, src_host, dst_index, dst_host)
+    call(['onos', 'localhost', 'add-host-intent', src_host, dst_host])
+
+    # Return response
+    resp = make_response(json.dumps(e_line))
+    resp.mimetype = 'application/json'
+    resp.headers['Access-Control-Allow-Origin'] = '*'
+    return resp
+
+if __name__ == '__main__':
+    app.run(host='0.0.0.0', port=6000)