js updated for accessing nitos nodes
[myslice.git] / portal / templates / slice-tab-experiment.html
1 <script type="text/javascript">
2 function is_finished(len_platforms, pf_status){
3     if(len_platforms == pf_status){
4         return true;
5     }else{
6         return false;
7     }
8 }
9
10 // Specific DIVs for each type of testbed
11 $(document).ready(function() {
12     var platform_status = Array();
13     var platform_empty = Array();
14     {% for platform in platforms %}
15     // /sfa/Describe?hrn=onelab.upmc.projectx.slicex&platform[]={{platform}}&type=slice
16     $.post("/sfa/Describe",{'hrn':'{{slicename}}', 'type':'slice', 'platform':['{{platform}}']}, function( data ) {
17         if('parsed' in data['{{platform}}'] && 'rspec' in data['{{platform}}']['parsed']){
18             rspec = data['{{platform}}']['parsed']['rspec'];
19             if('node' in rspec){
20                 if(rspec['node'] instanceof Array) {
21                     jQuery.each( rspec['node'], function( i, node ) {
22                         render_node('{{platform}}',node);
23                     });
24                 }else{
25                     render_node('{{platform}}',rspec['node']);
26                 }
27             }else{
28                 platform_empty.push('{{platform}}');
29             }
30         }else{
31             platform_empty.push('{{platform}}');
32         }
33         platform_status.push('{{platform}}');
34         if(is_finished({{len_platforms}},platform_status.length)){
35             $("#loading").hide();
36             if(platform_empty.length == {{len_platforms}}){
37                 $("#warning_message").show();
38             }
39         }
40     });
41     {% endfor %}
42 });
43 </script>
44 <div class="col-md-10 col-md-offset-1">
45 <div id="access">
46     <h2>How to access your reserved resources?</h2>
47     <img src="{{ STATIC_URL }}img/loading.gif" id="loading" alt="Loading reserved resources" />
48 </div>
49 <div id="warning_message" style="display:none; color:orange; font-weigh:bold;">
50 Please add resources to your slice from the left tab <a href="/resources/{{slicename}}">"Resources"</a>
51 </div>
52 <div id="default">
53 </div>
54 {% if "ple" in platforms %}
55 <div id="ple_header" style="display:none;">
56         <h3>PlanetLab Europe</h3>
57         
58         <p>
59                 PlanetLab Europe resources are accessible directly via SSH. Your SSH public key is deployed automatically
60                 on the reserved nodes. To access your slice on a resource just type the following command:
61         </p>
62 </div>
63 <div id="ple" style="display:none;">
64 </div>
65 <div id="ple_footer" style="display:none;">
66         <p><strong>NOTE:</strong> Your original slicename <b>{{slicename}}</b> has been converted to PlanetLab specific format <b>{{ple_slicename}}</b> in order to do SSH.</p>
67         <p>
68                 Be aware that after you reserve a PlanetLab Europe resource your slice will be deployed with a delay of about 15 minutes, 
69                 after witch you will be able to access the resource.
70         </p>
71     <div id="initscript">
72         <div>
73             <h4>Init Script on PLE</h4>
74             <i>This bash script will be deployed on all PLE nodes of your slice</i>
75         </div>
76         <textarea style="width:100%; height:100px;" id="initscript_code"></textarea><br>
77 <!-- TODO !!!
78         <div>
79             <select>
80                 <option>All</option>
81                 <option>node1</option>
82                 <option>node2</option>
83             </select>
84         </div>
85 -->
86         <button name="deploy" class="btn btn-success btn-sm" onclick="deploy('{{slicename}}');">Deploy</button>
87         <button name="delete" class="btn btn-danger btn-xs" onclick="del('{{slicename}}');">Delete</button>
88     </div>
89     <script type="text/javascript">
90     $(document).ready(function() {
91         $.post("/initscript/get/",{'slice_hrn':'{{slicename}}'}, function( data ) {
92             jQuery('#initscript_code').val(data['initscript_code']);
93         });
94     });
95     function deploy(slice_hrn){
96         var initscript_code = jQuery('#initscript_code').val()
97         $.post("/initscript/update/",{'slice_hrn':slice_hrn, 'initscript_code':initscript_code}, function( data ) {
98             if (data['ret'] == 0) {
99                 mysliceAlert('Success: initscript deployed','success', true);
100             }else{
101                 mysliceAlert('Rest Error for: '+data.error,'warning', true);
102             }
103             //jQuery('#initscript_code').val(data['initscript_code']);
104         });
105     }
106     function del(slice_hrn){
107         $.post("/initscript/delete/",{'slice_hrn':slice_hrn}, function( data ) {
108             if (data['ret'] == 0) {
109                 mysliceAlert('Success: initscript deleted','success', true);
110                 jQuery('#initscript_code').val('');
111             }else{
112                 mysliceAlert('Rest Error for: '+data.error,'warning', true);
113             }
114
115         });
116     }
117     </script>
118     <br>
119 </div>
120 {% endif %}
121 {% if "iotlab" in platforms %}
122 <div id="iotlab_header" style="display:none;">
123         <h3>FIT IoT-Lab</h3>
124         <p>FIT IoT-Lab resources are accessible directly via SSH and <a href="https://www.iot-lab.info/testbed/" target="_blank">web GUI.</a>
125                 To acess IoT-Lab resources using web GUI, use the same login and  password of OneLab portal. To acess Iot-Lab resources using SSH type
126                 the following command:
127         </p>
128 </div>
129 <div id="iotlab" style="display:none;">
130 </div>
131 {% endif %}
132 {% if "nitos" in platforms %}
133 <div id="nitos_header" style="display:none;">
134         <h3>NITOS Volos (Greece)</h3>
135         
136         <p>
137          NITOS resources are not directly accessible. You will need to log in on a gateway server and from there access the node.
138          You will find the ssh commands to connect to NITOS nodes below:
139         </p>
140         <h4>NITLab</h4>
141 </div>
142 <div id="nitos" style="display:none;">
143 </div>
144 <div id="nitos_footer" style="display:none;">
145     <p><b>NOTE:</b> Nodes 002-009 are orbit-like nodes. For these nodes use "baseline_orbit.ndz". All these images come with OMF5.4 resource controller. To do OMF6 experiments use "baseline_omf6_1_1.ndz" and  "baseline_orbit_omf6_1_1.ndz" for grid nodes and orbit nodes respectively. </p>
146         <p>
147         The complete tutorial on NITOS nodes:
148         <a target="_blank" href="http://nitlab.inf.uth.gr/NITlab/index.php/testbed/instructions/basic-tutorial">NITOS basic tutorial</a>
149         </p>
150     <p>OMF based experiments' tutorials are available <a href="http://nitlab.inf.uth.gr/NITlab/index.php/testbed/instructions/omf-tutorials-scenarios" target="_blank">here.</a></p> 
151         <p>To learn more about OMF, please click <a href="http://omf.mytestbed.net/projects/omf/wiki/OMF_Main_Page" target="_blank">here.</a></p>
152
153 </div>
154 {% endif %}
155 {% if "nitos-paris" in platforms %}
156 <div id="paris.fit-nitos.fr_header" style="display:none;">
157         <h4>FIT NITOS-Lab Paris</h4>
158 </div>
159 <div id="paris.fit-nitos.fr" style="display:none;">
160 </div>
161 <div id="paris.fit-nitos.fr_footer" style="display:none;">
162         <p>
163                 On the node itself you will have to modify the file /etc/omf-resctl-5.3/omf-resctl.yaml (OMF5.4 only) according to your slice settings and then
164                 restart the OMF Resource Controller and finally execute the experiment:
165         </p>
166         <p class="command">
167                 $ omf exec --slice {{slicename}} your_exp.rb
168         </p>
169
170         <p>
171         The complete tutorial on FIT NITOS nodes:
172         <a target="_blank" href="http://doc.onelab.eu/nitos.html">basic tutorial</a>
173         </p>
174     <p>OMF based experiments' tutorials are available <a href="http://nitlab.inf.uth.gr/NITlab/index.php/testbed/instructions/omf-tutorials-scenarios" target="_blank">here.</a></p> 
175         <p>To learn more about OMF, please click <a href="http://omf.mytestbed.net/projects/omf/wiki/OMF_Main_Page" target="_blank">here.</a></p>
176 </div>
177 {% endif %}
178 <div style="padding-top:20px;"> 
179         <h2>Available Tools</h2>
180         <p><img src="{{ STATIC_URL }}img/terminal_icon.png" width="50"> <b>SSH</b></p>
181         <p>
182         Secure Shell (SSH) is a cryptographic network protocol for secure data communication, remote command-line login, remote command execution, and other secure network services between two networked computers that connects, via a secure channel over an insecure network, a server and a client (running SSH server and SSH client programs, respectively). The protocol specification distinguishes between two major versions that are referred to as SSH-1 and SSH-2.
183         </p>
184         <p> More info: <a href="http://en.wikipedia.org/wiki/Secure_Shell" target="_blank">http://en.wikipedia.org/wiki/Secure_Shell</a></p>
185         <br>
186         <p><img src="{{ STATIC_URL }}img/putty-logo.png" width="50"> <b>PuTTY</b></p>
187         <p>
188                 PuTTY is an SSH and telnet client, developed originally by Simon Tatham for the Windows platform. PuTTY is open source software that is available with source code and is developed and supported by a group of volunteers.
189         </p>
190         <p>More info: <a href="http://www.putty.org/" target="_blank">http://www.putty.org/</a></p>     
191         <br>
192         <p><img src="{{ STATIC_URL }}img/nepi_logo.png" width="90"></p>
193         <p>NEPI, the Network Experimentation Programming Interface, is a life-cycle management tool for network experiments. The idea behind NEPI is to provide a single tool to design, deploy, and control network experiments, and gather the experiment results. Going further, NEPI was specially conceived to function with arbitrary experimentation platforms, so researchers could use a single tool to work with network simulators, emulators, or physical testbeds, or even a mixture of them. To accomplish this, NEPI provides a high-level interface to describe experiments that is independent from any experimentation platform, but is able to capture platform specific configurations. Experiment definitions can be stored in XML format to be later reproduced, and modified according to experimentation needs. Experiment execution is orchestrated by a global experiment controller, that is platform independent, and different platform-dependent testbed controllers, creating a control hierarchy that is able t adapt to platform specific requirements while providing an integrated control scheme.</p>
194         <p> More info: <a href="http://nepi.inria.fr" target="_blank">http://nepi.inria.fr</a></p>
195         <br>
196         <p><img src="{{ STATIC_URL }}img/omf-logo.png" width="90"></p>
197         <p>OMF is a Testbed Control, Measurement and Management Framework.</p>
198         <p>
199         OMF was originally developed for the ORBIT wireless testbed at Winlab, Rutgers University. Since 2007, OMF has been actively extended to operate on testbeds with many different type of network and resource technologies. It is now deployed and used on different testbeds in Australia, Europe, and in the U.S. OMF is currently being extended further to support exciting new features and technologies. This website is hosting this ongoing activity. OMF development is now conducted essentially within the TEMPO project at NICTA (Australia) in strong collaboration with Winlab (Rutgers University).
200         </p>
201         <p>In addition to the main OMF software, this site also hosts OMF sub-projects addressing various related aspects of a testbed's control, measurement, and management.</p>
202         <p>More Info: <a href="http://mytestbed.net/projects/omf" target="_blank">http://mytestbed.net/projects/omf</a></p>
203 </div>
204 </div>