page.html 6.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149
  1. <html>
  2. <head>
  3. <title>ngrok</title>
  4. <link href="/static/css/highlight.min.css" rel="stylesheet">
  5. <link href="/static/css/bootstrap.min.css" rel="stylesheet">
  6. <script src="/static/js/highlight.min.js"></script>
  7. <script src="/static/js/vkbeautify.js"></script>
  8. <script src="/static/js/jquery-1.9.1.min.js"></script>
  9. <script src="/static/js/jquery.timeago.js"></script>
  10. <script src="/static/js/angular.js"></script>
  11. <script src="/static/js/base64.js"></script>
  12. <script src="/static/js/ngrok.js"></script>
  13. <script type="text/javascript">
  14. window.data = JSON.parse({% . %});
  15. </script>
  16. <style type="text/css">
  17. body { margin-top: 50px; }
  18. table.params { font-size: 12px; font-family: Courier, monospace; }
  19. .txn-selector tr { cursor: pointer; }
  20. .txn-selector tr:hover { background-color: #ddd; }
  21. tr.selected, tr.selected:hover {
  22. background-color: #ff9999;
  23. background-color: #000000;
  24. color:white;
  25. }
  26. </style>
  27. </head>
  28. <body ng-app="ngrok">
  29. <div class="container" ng-controller="HttpTxns">
  30. <div class="navbar navbar-inverse navbar-fixed-top">
  31. <div class="navbar-inner">
  32. <div class="container">
  33. <a class="brand" href="#">ngrok</a>
  34. <ul class="nav">
  35. <li class="active"><a href="#">Inbound Requests</a></li>
  36. <!--
  37. <li><a href="#">Outbound Requests</a></li>
  38. <li><a href="#">Configuration</a></li>
  39. -->
  40. </ul>
  41. </div>
  42. </div>
  43. </div>
  44. <div ng-show="txns.length==0" class="row">
  45. <div class="span6 offset3">
  46. <div class="well" style="padding: 20px 50px;">
  47. <h4>No requests to display yet</h4>
  48. <p class="lead">Make a request to <a target="_blank" href="{{ publicUrl }}">{{ publicUrl }}</a> to get started!</p>
  49. </div>
  50. </div>
  51. </div>
  52. <div ng-show="txns.length>0" class="row">
  53. <div class="span6">
  54. <h4>All Requests</h4>
  55. <table class="table txn-selector">
  56. <tr ng-controller="TxnNavItem" ng-class="{'selected':isActive()}" ng-repeat="txn in txns" ng-click="makeActive()">
  57. <td>{{ txn.Req.MethodPath }}</td>
  58. <td>{{ txn.Resp.Status }}</td>
  59. <td><span class="pull-right">{{ txn.Duration }}</span></td>
  60. </tr>
  61. </table>
  62. </div>
  63. <div class="span6" ng-controller="HttpTxn" ng-show="!!Txn">
  64. <div class="row-fluid">
  65. <div class="span4">
  66. <span title="{{ISO8601(Txn.Start)}}" class="muted">
  67. {{TimeFormat(Txn.Start)}}
  68. </span>
  69. </div>
  70. <div class="span4">
  71. <i class="icon-time"></i> Duration
  72. <span style="margin-left: 8px;" class="muted">{{Txn.Duration}}</span>
  73. </div>
  74. <div class="span4">
  75. <i class="icon-user"></i> IP
  76. <span style="margin-left: 8px;" class="muted">{{Txn.Req.Header['X-Real-Ip'][0]}}</span>
  77. </div>
  78. </div>
  79. <hr />
  80. <div ng-show="!!Req" ng-controller="HttpRequest">
  81. <h3>{{ Req.MethodPath }}</h3>
  82. <div onbtnclick="replay()" btn="Replay" tabs="Summary,Headers,Raw,Binary">
  83. </div>
  84. <div ng-show="isTab('Summary')">
  85. <keyval title="Query Params" tuples="Req.Params"></keyval>
  86. <div body="Req.Body" binary="Req.Binary"></div>
  87. </div>
  88. <div ng-show="isTab('Headers')">
  89. <keyval title="Headers" tuples="Req.Header"></keyval>
  90. </div>
  91. <div ng-show="isTab('Raw')">
  92. <pre><code class="http">{{ Req.RawText }}</code></pre>
  93. </div>
  94. <div ng-show="isTab('Binary')">
  95. <pre><code>{{ Req.RawBytes }}</code></pre>
  96. </div>
  97. </div>
  98. <hr style="margin: 40px 0 20px" />
  99. <div ng-show="!!Resp" ng-controller="HttpResponse">
  100. <h3 ng-class="Resp.statusClass">{{ Resp.Status }}</h3>
  101. <div tabs="Summary,Headers,Raw,Binary"></div>
  102. <div ng-show="isTab('Summary')">
  103. <div body="Resp.Body" binary="Resp.Binary"></div>
  104. </div>
  105. <div ng-show="isTab('Headers')">
  106. <keyval title="Headers" tuples="Resp.Header"></keyval>
  107. </div>
  108. <div ng-show="isTab('Raw')">
  109. <pre><code class="http">{{ Resp.RawText }}</code></pre>
  110. </div>
  111. <div ng-show="isTab('Binary')">
  112. <pre><code>{{ Resp.RawBytes }}</code></pre>
  113. </div>
  114. </div>
  115. </div>
  116. </div>
  117. </div>
  118. <!-- UserVoice JavaScript SDK (only needed once on a page) -->
  119. <script>(function(){var uv=document.createElement('script');uv.type='text/javascript';uv.async=true;uv.src='//widget.uservoice.com/4KUmdF6WZd302MfwoayMw.js';var s=document.getElementsByTagName('script')[0];s.parentNode.insertBefore(uv,s)})()</script>
  120. <!-- A tab to launch the Classic Widget -->
  121. <script>
  122. UserVoice = window.UserVoice || [];
  123. UserVoice.push(['showTab', 'classic_widget', {
  124. mode: 'feedback',
  125. primary_color: '#cc6d00',
  126. link_color: '#007dbf',
  127. forum_id: 211925,
  128. tab_label: 'Feedback',
  129. tab_color: '#cc6d00',
  130. tab_position: 'middle-left',
  131. tab_inverted: false
  132. }]);
  133. </script>
  134. </body>
  135. </html>