1 <!-- html-header type=current begin -->
8 <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
12 <script>window.is_euro_union = 1;</script>
13 <script src="https://a.fsdn.com/con/js/sftheme/vendor/promise.polyfill.min.js"></script>
14 <script src="https://a.fsdn.com/con/js/sftheme/cmp.js"></script>
15 <script src="https://slashdot.org/country.js"></script>
16 <script type='text/javascript'>
17 if (window.is_euro_union) {
19 // to test: 'Display UI': 'always',
20 'Publisher Name': 'Slashdot',
21 'Publisher Logo': 'https://a.fsdn.com/sd/sdlogo.svg',
22 'Consent Scope': 'global group',
23 'Consent Scope Group URL': 'https://slashdot.org/gdpr-cookies.pl',
27 <link rel="stylesheet" href="//a.fsdn.com/con/css/sftheme/sandiego/cmp.css" type="text/css">
28 <style type="text/css">
29 .qc-cmp-publisher-logo, .qc-cmp-nav-bar-publisher-logo {
30 background-color: #016765;
34 if (!window.is_euro_union) {
35 (function (s,o,n,a,r,i,z,e) {s['StackSonarObject']=r;s[r]=s[r]||function(){
36 (s[r].q=s[r].q||[]).push(arguments)},s[r].l=1*new Date();i=o.createElement(n),
37 z=o.getElementsByTagName(n)[0];i.async=1;i.src=a;z.parentNode.insertBefore(i,z)
38 })(window,document,'script','https://www.stack-sonar.com/ping.js','stackSonar');
39 stackSonar('stack-connect', '66');
43 <script id="before-content" type="text/javascript">
45 if (typeof window.sdmedia !== 'object') {
48 if (typeof window.sdmedia.site !== 'object') {
49 window.sdmedia.site = {};
52 var site = window.sdmedia.site;
53 site.rootdir = "//slashdot.org";
57 pagemark: '425547131907250267',
58 before_content: (new Date).getTime()
60 function pageload_done( $, console, maybe ){
61 pageload.after_readycode = (new Date).getTime();
62 pageload.content_ready_time = pageload.content_ready - pageload.before_content;
63 pageload.script_ready_time = pageload.after_readycode - pageload.content_ready;
64 pageload.ready_time = pageload.after_readycode - pageload.before_content;
65 // Only report 1% of cases.
66 maybe || (Math.random()>0.01) || $.ajax({ data: {
68 pagemark: pageload.pagemark,
69 dom: pageload.content_ready_time,
70 js: pageload.script_ready_time
74 <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
76 <title>400,000 Websites Vulnerable Through Exposed .git Directories - Slashdot</title>
77 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
79 <meta name="description" content="Open .git directories are a bigger cybersecurity problem than many might imagine, at least according to a Czech security researcher who discovered almost 400,000 web pages with an open .git directory possibly exposing a wide variety of data. From a report: Vladimir Smitka began his .git directory od...">
81 <meta name="twitter:card" content="summary">
82 <meta name="twitter:site" content="@slashdot">
83 <meta name="twitter:domain" content="tech.slashdot.org">
84 <meta property="og:url" content="https://tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories?utm_source=feedburner&utm_medium=feed&utm_campaign=Feed%3A+Slashdot%2Fslashdot+%28Slashdot%29">
86 <meta property="og:title" content="400,000 Websites Vulnerable Through Exposed .git Directories - Slashdot">
87 <meta property="og:description" content="Open .git directories are a bigger cybersecurity problem than many might imagine, at least according to a Czech security researcher who discovered almost 400,000 web pages with an open .git directory possibly exposing a wide variety of data. From a report: Vladimir Smitka began his .git directory od...">
91 <meta property="og:image" content="https://a.fsdn.com/sd/topics/security_64.png">
93 <meta property="fb:admins" content="100000696822412">
94 <meta property="fb:page_id" content="267995220856">
96 <meta name="viewport" content="width=1000, user-scalable=yes, minimum-scale=0, maximum-scale=10.0" />
97 <meta name="apple-mobile-web-app-capable" content="yes">
98 <meta name="apple-mobile-web-app-status-bar-style" content="black">
100 <link rel="canonical" href="https://tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories">
102 <link rel="alternate" media="only screen and (max-width: 640px)" href="http://m.slashdot.org/story/345540" >
105 <link rel="stylesheet" type="text/css" media="screen, projection" href="//a.fsdn.com/sd/classic.ssl.css?8f5016a67a2f2048" >
106 <!--[if IE 8]><link rel="stylesheet" type="text/css" media="screen, projection" href="//a.fsdn.com/sd/ie8-classic.ssl.css?8f5016a67a2f2048" ><![endif]-->
107 <!--[if IE 7]><link rel="stylesheet" type="text/css" media="screen, projection" href="//a.fsdn.com/sd/ie7-classic.ssl.css?8f5016a67a2f2048" ><![endif]-->
121 <!-- SMACKS: NEW CSS -->
122 <link rel="stylesheet" href="//a.fsdn.com/sd/css/app.css?8f5016a67a2f2048">
124 <script type='text/javascript'>
125 var _gaq = _gaq || [];
136 <script type="text/javascript" id="pbjs_script" data-dom="https://d3tglifpd8whs6.cloudfront.net" src="https://d3tglifpd8whs6.cloudfront.net/js/prebid/slash-story/slash-story.min.js"></script>
137 <script type='text/javascript'>
138 /*global performance */
139 var googletag = window.googletag || {};
140 googletag.cmd = googletag.cmd || [];
142 window.Ads_disallowPersonalization = 1;
143 bizx.cmp.ifConsent('all', 'all', function(){
144 window.Ads_disallowPersonalization = 0;
146 window.Ads_disallowPersonalization = 1;
148 window.bizxPrebid.Ads.initPrebid(window.bizxPrebid.adUnits);
152 <!-- prep GPT ads -->
153 <script type='text/javascript'>
155 function page_type (loc) {
157 only four page types:
161 - Other (but AdOps wants 'Homepage' again)
163 var path = loc.pathname;
164 var just_the_root = /^\/?$/.test(path);
165 var story_or_poll = /^\/(story(?=\/)|submission(?=\/)|poll(?=\/|Booth|s\b))/i.exec(path);
167 var page_type = just_the_root ? 'homepage'
168 : story_or_poll ? story_or_poll[1]
172 if (page_type.toLowerCase() === 'submission')
173 page_type = 'story'; // submissions are like stories, right?
174 else if (page_type.toLowerCase() === 'other')
175 page_type = 'homepage'; // this one might move out of here
179 function page_section (loc) {
180 //var greek = ['alpha', 'beta', 'gamma', 'delta'].join('|');
181 //var hostwise = '^([a-z]+)(?:-(?:'+greek+'))?\\.(?:slashdot\\.org|\\.xb\\.sf\\.net)$';
182 var pathwise = '^/(?:(recent|popular|blog)|stories/([^/]+))';
183 var rootwise = '^\/?$';
185 //var hostwisely = new RegExp(hostwise,'i').exec(loc.hostname);
186 var pathwisely = new RegExp(pathwise,'i').exec(loc.pathname);
187 var rootwisely = new RegExp(rootwise,'i').exec(loc.pathname);
189 var section = (rootwisely && 'homepage')
190 || (pathwisely && (pathwisely[1] || pathwisely[2]))
194 return section.replace(/[^_a-z]/ig, '');
196 function single_size (size) {
197 return '' + size[0] + 'x' + size[1];
199 function sz_sz (sz) {
202 if (sz[0] instanceof Array) {
204 sizes.push(single_size(sz[size]));
206 return sizes.join(',');
208 return single_size(sz);
212 function unique_tpc_array(array1,array2) {
213 var j = array1.concat(array2);
214 j.forEach(function (v,i,a) {
215 a[i] = v.replace(/[^_a-z]/ig, '');
217 return j.filter(function (v,i,a) {
218 return v != '' && a.indexOf(v) === i;
224 - 'npt' = "no page type" in ad unit name
227 '728x90_A': { 'sz': [[728, 90], [970, 90], [970, 250], [980, 66]] },
228 '728x90_B': { 'sz': [728, 90] },
229 '728x90_C': { 'sz': [728, 90], 'skip': { 'homepage': 1 } },
230 'HubIcon_200x90_A': { 'sz': [[200, 90], [220, 90]]},
231 'PowerSwitch_980x66_A': { 'sz': [980, 66], 'skip': { 'homepage': 1 } },
232 'PollPeel': { 'sz': [200, 90], 'skip': { 'homepage': 1 } },
233 //'VideoWidget_300x250': { 'sz': [300, 250], 'npt': 1 },
234 '300x250_A': { 'sz': [[300, 250], [300, 600], [300, 1050]] },
235 '300x250_B': { 'sz': [[300, 250], [300, 600]] },
236 '300x250_C': { 'sz': [[300, 250], [300, 600]] },
237 '300x250_D': { 'sz': [[300, 250], [300, 600]] },
238 'Pulse_300x600_A': { 'sz': [300, 600] },
239 //'Polls_Detail_300x250_A': { 'sz': [[300, 250], [300, 600]], 'npt': 1 },
240 //'Poll_300x250_A': { 'sz': [[300, 250], [300, 600]], 'npt': 1 },
241 //'SD_Story_1x1': { 'sz': [1, 1] },
242 '1x1': { 'sz': [1, 1] }
245 //var network_path = '/41014381/Slashdot/';
246 var network_path = '/41014381/Slashdot/';
247 var tag_name_prefix = 'SD';
248 var tag_name_linkage = '_';
249 var tag_name_pagetype = page_type(location);
250 var tag_topic = page_section(location);
251 if(tag_name_pagetype == 'poll'){
252 tag_name_pagetype = 'Poll';
254 var before_tag_pagetyped = network_path
260 var before_tag_pagetypeless = network_path
263 /* + tag_name_pagetype */
264 /* + tag_name_linkage */
268 googletag.cmd.push(function() {
270 function remove_sticky_top() {
271 setTimeout(function(){
272 $('#div-gpt-ad-728x90_a').parent('div').addClass('adwrap-viewed-banner');
273 $('#div-gpt-ad-728x90_a').addClass('viewableImpression');
276 function remove_sticky_railad() {
277 setTimeout(function(){
278 $('#slashboxes .adwrap-unviewed').addClass('adwrap-viewed-railad');
279 $('.railad').addClass('viewableImpression');
282 function viewable_imp (slot) {
284 if(typeof slot[i] !== 'string') continue;
286 case "/41014381/Slashdot/SD_homepage_728x90_A":
287 case "/41014381/Slashdot/SD_story_728x90_A":
288 case "/41014381/Slashdot/SD_Poll_728x90_A":
289 case "/41014381/Slashdot/SD_homepage_728x90_Ref_A":
290 case "/41014381/Slashdot/SD_story_728x90_Ref_A":
291 case "/41014381/Slashdot/SD_Poll_728x90_Ref_A":
294 case "/41014381/Slashdot/SD_homepage_300x250_A":
295 case "/41014381/Slashdot/SD_story_300x250_A":
296 case "/41014381/Slashdot/SD_Poll_300x250_A":
297 case "/41014381/Slashdot/SD_homepage_300x250_Ref_A":
298 case "/41014381/Slashdot/SD_story_300x250_Ref_A":
299 case "/41014381/Slashdot/SD_Poll_300x250_Ref_A":
300 remove_sticky_railad();
303 //if(slot[i] === "/41014381/Slashdot/SD_homepage_728x90_A") remove_sticky_top();
304 //if(slot[i] === "/41014381/Slashdot/SD_homepage_300x250_A") remove_sticky_railad();
307 function define_me_a_slot (tag) {
308 if (tags[tag].skip && tags[tag].skip[tag_name_pagetype])
310 var sandbox_regex = /\.xb\.sf\.net$/i;
311 var full_name = tags[tag].npt // "no page type"
312 ? before_tag_pagetypeless + tag
313 : before_tag_pagetyped + tag
315 var div_id = 'div-gpt-ad-' + tag.toLowerCase();
318 // extend jQuery and get URL query params
320 getQueryParameters : function(str) {
321 return (str || document.location.search).replace(/(^\?)/,'').split("&").map(function(n){
322 return n = n.split("="),this[n[0]] = n[1],this
327 var queryParams = $.getQueryParameters();
329 if( queryParams.source === 'autorefresh' ) {
330 full_name = full_name.replace(/(\d+x\d+)/,'$1_Ref');
331 //console.log('TAG NAME: ', full_name);
334 service = googletag.defineSlot(
338 ).addService(googletag.pubads());
340 service.setTargeting('sz', tags[tag].sz);
343 var frontend_tpc = tag_topic.split(",");
344 var backend_tpc = [ "it", "technology", "internet", "security", "git" ];
346 var tpc_final = unique_tpc_array(frontend_tpc, backend_tpc);
347 service.setTargeting('tpc', tpc_final);
348 if (location.hostname.match(sandbox_regex)) {
349 service.setTargeting('test', 'adops');
355 define_me_a_slot(tag, false);
357 googletag.pubads().addEventListener('impressionViewable', function(event) {
358 viewable_imp(event.slot);
361 googletag.pubads().setTargeting('requestSource', 'GPT');
362 googletag.pubads().setRequestNonPersonalizedAds(window.Ads_disallowPersonalization);
363 googletag.pubads().enableAsyncRendering();
366 googletag.pubads().collapseEmptyDivs();
367 window.bizxPrebid.SAFEFRAMES = true;
368 bizxPrebid.Ads.pushToGoogle();
369 googletag.enableServices();
377 <script type="text/javascript"> try{(function(){ var cb = new Date().getTime(); var s = document.createElement("script"); s.defer = true; s.src = "//tag.crsspxl.com/s1.js?d=2397&cb="+cb; var s0 = document.getElementsByTagName('script')[0]; s0.parentNode.insertBefore(s, s0); })();}catch(e){} </script>
379 <!-- AdBlock Check -->
381 var isAdBlockActive = true;
383 <script async src="//a.fsdn.com/sd/js/scripts/ad.js?8f5016a67a2f2048"></script>
386 <body class="anon firehose ">
389 <script src="//a.fsdn.com/sd/all-minified.js?8f5016a67a2f2048" type="text/javascript"></script>
392 <script type="text/javascript">
394 var regexp=/\s*(?:\d+|many)\s+more\s*/i;
397 var auto_more_count = 1;
399 function auto_more(){
400 var $more_link = $('#more-experiment a');
401 $more_link.each(function(){
402 var $lastitem = $('#firehoselist>article.fhitem:visible:last');
403 if ( Bounds.intersect(window, $lastitem) ) {
406 !--auto_more_count && (auto_more=undefined);
407 // don't allow a call till the next paginate gets built and |more_possible|
408 $(document).unbind('scroll', call_auto_more);
413 function call_auto_more(){ auto_more && auto_more(); }
416 $('#more-experiment a').
417 live('more-possible', function( event ){
418 var $more_link=$(this);
419 if ( regexp.test($more_link.text()) ) {
421 $(document).bind('scroll', call_auto_more);
423 $(document).unbind('scroll', call_auto_more);
429 <!--[if lt IE 9]><script src="//a.fsdn.com/sd/html5.js"></script><![endif]-->
432 <script type="text/javascript">
434 if (typeof window.janrain !== 'object') window.janrain = {};
435 if (typeof window.janrain.settings !== 'object') window.janrain.settings = {};
437 /* _______________ can edit below this line _______________ */
439 janrain.settings.tokenUrl = 'https://slashdot.org/token_callback.pl';
440 janrain.settings.type = 'embed';
441 janrain.settings.appId = 'ggidemlconlmjciiohla';
442 janrain.settings.appUrl = 'https://login.slashdot.org';
443 janrain.settings.providers = [
448 janrain.settings.providersPerPage = '5';
449 janrain.settings.format = 'one column';
450 janrain.settings.actionText = 'Sign in with';
451 janrain.settings.showAttribution = false;
452 janrain.settings.fontColor = '#666666';
453 janrain.settings.fontFamily = 'lucida grande, Helvetica, Verdana, sans-serif';
454 janrain.settings.backgroundColor = '#ffffff';
455 janrain.settings.width = '300';
456 janrain.settings.borderColor = '#cccccc';
457 janrain.settings.borderRadius = '5'; janrain.settings.buttonBorderColor = '#CCCCCC';
458 janrain.settings.buttonBorderRadius = '0';
459 janrain.settings.buttonBackgroundStyle = 'gray';
460 janrain.settings.language = '';
461 janrain.settings.linkClass = 'janrainEngage';
463 /* _______________ can edit above this line _______________ */
465 function isReady() { janrain.ready = true; };
466 if (document.addEventListener) {
467 document.addEventListener("DOMContentLoaded", isReady, false);
469 window.attachEvent('onload', isReady);
472 var e = document.createElement('script');
473 e.type = 'text/javascript';
474 e.id = 'janrainAuthWidget';
476 e.src = 'https://rpxnow.com/js/lib/login.slashdot.org/engage.js';
478 var s = document.getElementsByTagName('script')[0];
479 s.parentNode.insertBefore(e, s);
483 <script src="//cdn-social.janrain.com/social/janrain-social.min.js"></script>
484 <script type="text/javascript">
487 janrain.settings.appUrl = "https://login.slashdot.org";
488 $twitter = $('body .janrain_twitterButton');
489 $twitter.append('<i class="icon-twitter"></i>');
491 janrain.settings.social = {
499 shareCountMin: "100",
500 shareCountMode: "combined"
505 <!-- index2_variant ||-->
508 <script type="text/javascript">
509 if (!window.is_euro_union) {
510 window._taboola = window._taboola || [];
511 _taboola.push({home:'auto'});
512 !function (e, f, u) {
515 f.parentNode.insertBefore(e, f);
516 }(document.createElement('script'),
517 document.getElementsByTagName('script')[0],
518 '//cdn.taboola.com/libtrc/slashdot/loader.js');
522 <!-- html-header type=current end --><!-- header type=current begin -->
526 <link rel="top" title="News for nerds, stuff that matters" href="//slashdot.org/" >
527 <link rel="search" title="Search Slashdot" href="//tech.slashdot.org/search.pl">
528 <link rel="alternate" title="Slashdot RSS" href="http://rss.slashdot.org/Slashdot/slashdotMain" type="application/rss+xml">
529 <link rel="shortcut icon" href="/favicon.ico" type="image/x-icon">
532 <div id="top_parent"></div>
533 <a name="topothepage"></a>
535 <div class="container">
536 <div class="nav-wrap">
537 <nav class="nav-primary" role="navigation" aria-label="Global Navigation">
539 <a href="//slashdot.org"><span>Slashdot</span></a>
542 <ul class="nav-site">
543 <li><a href="//slashdot.org"><i class="icon-book" title="Stories"></i><span>Stories</span></a></li>
545 <ul class="filter-firehose">
546 <li class="nav-label">Firehose <i class="icon-angle-right"></i></li>
547 <li><a href="//slashdot.org/recent">All</a></li>
548 <li><a href="//slashdot.org/popular">Popular</a></li>
551 <li><a href="//slashdot.org/polls"><i class="icon-chart-bar" title="Polls"></i><span>Polls</span></a></li>
554 <li><a href="//ask.slashdot.org"><i class="icon-question-circle"></i><span>Ask</span></a></li>
556 <li><a href="//events.slashdot.org"><i class="icon-calendar"></i><span>Events</span></a></li>
558 <li><a href="http://deals.slashdot.org/?utm_source=slashdot&utm_medium=navbar&utm_campaign=dealshp_1" target="_blank"><i class="sd-mini" title="Deals"></i> <span>Deals</span></a></li>
560 <a href="//slashdot.org/submission" class="btn btn-success">Submit</a>
562 <nav class="nav-user" role="navigation" aria-label="user access and account controls">
563 <form id="search" class="form-inline nav-search-form" method="get" action="//slashdot.org/index2.pl">
564 <!-- //tech.slashdot.org/index2.pl" -->
565 <div class="form-group">
566 <label class="sr-only" for="sitesearch">Search Slashdot</label>
567 <div class="input-group">
568 <input type="text" id="" class="" name="fhfilter" value="" placeholder="Search">
571 <button type="submit" class="btn icon-search"></button>
573 <ul class="user-access">
577 <a href="//slashdot.org/my/login" onclick="show_login_box(); return false;"><i class="icon-login"></i><span> Login</span></a>
583 <li class="nav-label">or</li>
588 <a href="//slashdot.org/my/newuser" ><i class="icon-user-add"></i><span> Sign up</span></a>
596 <div class="nav-secondary-wrap">
597 <nav class="nav-secondary" role="secondary-navigation">
599 <li class="nav-label">Topics: </li>
600 <li><a href="//devices.slashdot.org">Devices</a></li>
601 <li><a href="//build.slashdot.org">Build</a></li>
602 <li><a href="//entertainment.slashdot.org">Entertainment</a></li>
603 <li><a href="//technology.slashdot.org">Technology</a></li>
604 <li><a href="//slashdot.org/?fhfilter=opensource">Open Source</a></li>
605 <li><a href="//science.slashdot.org">Science</a></li>
606 <li><a href="//yro.slashdot.org">YRO</a></li>
607 <!-- <li><a href="//slashdot.org/topics.pl">more...</a></li> -->
610 <nav class="nav-social" role="social navigation">
612 <li class="nav-label">Follow us:</li>
613 <li><a href="http://rss.slashdot.org/Slashdot/slashdotMain" target="_blank"><i class="icon-rss-squared"></i><span class="sr-only">RSS</span></a></li>
614 <li><a href="http://www.facebook.com/slashdot" target="_blank"><i class="icon-facebook-squared"></i><span class="sr-only">Facebook</span></a></li>
615 <li><a href="https://plus.google.com/112601993642376762846/" target="_blank"><i class="icon-gplus-squared"></i><span class="sr-only">Google+</span></a></li>
616 <li><a href="http://twitter.com/slashdot" target="_blank"><i class="icon-twitter-squared"></i><span class="sr-only">Twitter</span></a></li>
617 <li><a href="//slashdot.org/newsletter" target="_blank"><i class="icon-mail-squared"></i><span class="sr-only">Newsletter</span></a></li>
625 <div class="message-bar" id="firehose-message-tray">
626 <span class="icon-quote-left"></span>
630 Slashdot is powered by <strong><a href="//tech.slashdot.org/submission">your submissions</a></strong>, so send in your scoop
636 <div id='embbeded_login_modal' class="hide">
637 <form action="https://slashdot.org/my/login" method="post" onsubmit="if (global_returnto) { this.returnto.value = global_returnto }" class="embedded"><fieldset style="-webkit-border-radius:10px 10px 0 0;border-radius:10px 10px 0 0;-moz-border-radius:10px 10px 0 0">
638 <div style='height:25px;'> </div>
639 <input type="hidden" name="returnto" value="">
640 <input type="hidden" name="op" value="userlogin">
642 <label class="fleft" for="unickname">Nickname:</label>
643 <input type="text" name="unickname" value="">
646 <label class="fleft" for="upasswd">Password:</label>
647 <input type="password" name="upasswd" placeholder="6-1024 characters long">
649 <label class="checkbox"><input type="checkbox" name="login_temp" value="yes"> Public Terminal</label>
652 <input type="submit" name="userlogin" value="Log In" class="fno"> <a href="//slashdot.org/my/mailpassword" class="btn link" onclick="getModalPrefs('sendPasswdModal', 'Retrieve Password', 1); return false;">Forgot your password?</a>
655 <div id="janrainEngageEmbed"></div>
656 <div class="actions">
657 <a class="ico close" onclick="hide_login_slider();" href=""><span>Close</span></a>
662 <div class="banner-wrapper">
663 <div class="adwrap adwrap-unviewed banner-contain">
665 <div id='div-gpt-ad-728x90_a'><script type='text/javascript'>
666 googletag.cmd.push(function(){
667 googletag.display('div-gpt-ad-728x90_a');});</script></div>
668 <div id='div-gpt-ad-hubicon_200x90_a'><script type='text/javascript'>
669 googletag.cmd.push(function(){
670 googletag.display('div-gpt-ad-hubicon_200x90_a');});</script></div>
674 <a name="main-articles"></a>
676 <!-- header type=current end --><!-- body begin -->
686 <style type="text/css">
688 text-decoration:none;
697 menu[type=context]:not(.brief) {
698 background-color:#dfdfdf;
703 border-color:#eeeeee #aaaaaa #aaaaaa #eeeeee;
704 -moz-border-radius-topright:.7em;
705 -webkit-border-top-right-radius: 0.7em 0.7em;
708 menu.full[type=context] > a.slash-hover:first-child {
709 -moz-border-radius-topright:.6em;
710 -webkit-border-top-right-radius: 0.6em 0.6em;
715 menu.brief[type=context] > a {
716 -moz-border-radius:.6em;
717 -webkit-border-radius: 0.6em;
719 background-color:#000000;
723 span.briefmenu a.tag:not(.datatype) {
731 /* #tag-menu a, #feedback-menu a { */
732 menu.tag-menu-admin a {
739 margin:-0.1em -0.5em;
744 .tags .edit-bar { position:relative; }
745 article aside .share .addthis_toolbox { display:block; width:60px; float:left; }
746 article aside.view_mode .share { min-width:120px; padding-top:.5em; }
747 #firehose.list article header h2 {padding-left: 20px; !important}
748 .novote .vote { display:none; }
750 .vote > a, .votedup > a, .voteddown > a {
751 display:inline-block;
754 margin: 2px 10px 0 0;
755 color:rgb(255,255,255);
756 text-decoration:none;
763 border-color:rgba(0,0,0,0.5);
766 .vote > a, .votedup > a, .voteddown > a {color:rgb(0,0,0);}
768 article.fhitem-submission h2 .vote > a, article.fhitem-submission h2 .votedup > a, article.fhitem-submission h2 .voteddown > a { border-color:rgba(0,0,0,0.15); }
769 .vote .up, .vote .down, .votedup .up, .votedup .down, .voteddown .up, .voteddown .down { border-radius: 4px; -moz-border-radius: 4px; -webkit-border-radius: 4px; /* text-shadow:0 0 2px #000000; }*/}
770 article:not(.fhitem-story) .vote .up,article:not(.fhitem-story) .vote .down,article:not(.fhitem-story) .votedup .up,article:not(.fhitem-story) .votedup .down,article:not(.fhitem-story) .voteddown .up,article:not(.fhitem-story) .voteddown .down { /*text-shadow:none !important; */}
771 .voteddown .down, .votedup .up { margin-right: 10px; text-indent:2px; line-height:24px; }
772 article:not(.fhitem-story) .votedup .up,article:not(.fhitem-story) .voteddown .down {background: rgb(174,174,174);background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(rgb(174,174,174)), to(rgb(193,193,193)));background-image: -moz-linear-gradient(100% 100% 90deg,rgb(193,193,193), rgb(174,174,174) 100%);color:rgb(0,0,0);}
773 article.fhitem-story .votedup .up,article.fhitem-story .voteddown .down {background: rgb(0,66,66);background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(rgb(0,53,53)), to(rgb(0,102,102)));background-image: -moz-linear-gradient(100% 100% 90deg,rgb(0,102,102), rgb(0,53,53) 100%);}
778 #tag-menu span.var-tag {
783 menu.reasons-menu a {
784 padding:0 .25em 0 .25em;
786 -moz-border-radius:.5em;
787 -webkit-border-radius:.5em;
791 menu.reasons-menu a:hover {
792 background:rgb(153,153,153);
793 background:-moz-linear-gradient(100% 100% 90deg, rgb(102,102,102), rgb(153,153,153) 70%) repeat scroll 0 0 rgb(102,102,102);
794 background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(rgb(153,153,153)), to(rgb(102,102,102)));
796 text-decoration:none;
800 article.fhitem-story menu.reasons-menu a:hover {
801 background:#002323 !important;
802 background:-moz-linear-gradient(100% 100% 90deg, #002323, #005353 70%) repeat scroll 0 0 #002323 !important;
803 background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(#005353), to(#002323)) !important;
813 div.fhitem h3 menu.reasons-menu {
817 div.fhitem h3 menu.reasons-menu a.tag {
821 #tag-menu a.slash-hover,
822 #feedback-menu a.slash-hover,
824 .tag-display span.tag:hover,
825 .tag-display span.tag.trigger {
827 background-color:rgb(0, 85, 85);
830 #tag-menu a.slash-hover span.var-tag {
842 text-decoration:none;
845 -moz-border-radius:.6em 0 0 .6em;
846 -webkit-border-radius:.6em 0 0 .6em;
847 -o-border-radius:.6em 0 0 .6em;
848 border-radius:.6em 0 0 .6em;
849 color:#fff !important;
850 background:transparent !important;
854 background:rgb(153,153,153) !important;
855 background:-moz-linear-gradient(100% 100% 90deg, rgb(102,102,102), rgb(153,153,153) 70%) repeat scroll 0 0 rgb(102,102,102) !important;
856 background-image: -webkit-gradient(linear, 0% 0%, 0% 100%, from(rgb(153,153,153)), to(rgb(102,102,102))) !important;
861 <menu id="nix-reasons" style="display:none">
862 <a class="tag">binspam</a><a class="tag">dupe</a><a class="tag">notthebest</a><a class="tag">offtopic</a><a class="tag">slownewsday</a><a class="tag">stale</a><a class="tag">stupid</a>
864 <menu id="nod-reasons" style="display:none">
865 <a class="tag">fresh</a><a class="tag">funny</a><a class="tag">insightful</a><a class="tag">interesting</a><a class="tag">maybe</a>
867 <menu id="comment-nix-reasons" style="display:none">
868 <a class="tag">offtopic</a><a class="tag">flamebait</a><a class="tag">troll</a><a class="tag">redundant</a><a class="tag">overrated</a>
870 <menu id="comment-nod-reasons" style="display:none">
871 <a class="tag">insightful</a><a class="tag">interesting</a><a class="tag">informative</a><a class="tag">funny</a><a class="tag">underrated</a>
874 <menu id="tag-nod-reasons" style="display:none">
875 <a class="tag">descriptive</a>
877 <menu id="feedback-menu" class="tag-menu-admin" type="context">
878 <a class="tag">typo</a><a class="tag">dupe</a><a class="tag">error</a>
880 <menu id="tag-menu" class="tag-menu-admin none" type="context">
882 <!-- <a data-op="!" class="nix">!<span class="var-tag hide"></span></a>-->
886 <script type="text/javascript">
888 var $CURRENT_MENU, $TAG_MENU=$('#tag-menu'), NOTNOT=/^!!/, IE7=/^7\.0/, TAG_PREFIX=/^\/tag\//;
890 function get_tag_name( $tag ){
891 return ($tag.attr('href') || '').replace(TAG_PREFIX, '') || $tag.text().toLowerCase();
894 function trigger_menu( e, selector, $menu, menu_content ){
895 var $target=$(original_target(e, selector)), in_use=$target.is('.trigger');
896 if ( $CURRENT_MENU ) {
897 $CURRENT_MENU.menu('cancel', e);
898 $CURRENT_MENU = null;
902 menu_content && $menu.stop(true, true).hide().html(menu_content);
903 ($CURRENT_MENU=$menu).menu('context', e);
908 function open_menu( trigger, $menu ){
909 var $trigger=$(trigger), $fhitem=$trigger.closest('.fhitem');
910 $fhitem.length && user_intent('interest', $fhitem[0]);
912 $menu.appendTo(document.body).css({ opacity:0 }).show();
914 var right = $fhitem.offset().left + $fhitem.width(),
915 global = $trigger.offset(),
916 local = $menu.offsetParent().offset();
918 // Ugly IE position hack required:
919 $.browser.msie && IE7.test($.browser.version) && (local.top = 0);
921 // pin the menu (horizontally) on-screen
922 global.left = Math.min(global.left, right-$menu.width());
924 $trigger.addClass('trigger');
926 position: 'absolute',
927 top: global.top - local.top + $trigger.height(),
928 left: global.left - local.left,
933 function close_menu( trigger, $menu ){
935 $(trigger).removeClass('trigger');
936 ($CURRENT_MENU===$menu) && ($CURRENT_MENU=false);
939 /* T2 tag context-menu */
940 var $TAG_MENU=$('#tag-menu'), NOTNOT=/^!!/;
943 var user_is_admin = 0;
947 $('a[rel=tag]').live('mousedown',function(ea){
948 window.open(this.href);
952 $('.tag-bar .disagree').live('mousedown',function(ee){
953 var fhitem = $(original_target(ee)).closest('.fhitem')[0],
954 command = ('!' + $(original_target(ee)).attr("data-tag")).replace(NOTNOT, '');
955 try { Tags.submit(fhitem, command); } catch ( err ) { }
962 live('mousedown', function( e ){
968 live('click', function( e ){
970 var target = original_target(e),
971 tag = $(target).text();
979 cssNamespace: 'slash',
983 start: function( e, ui ){
984 var $tag = $(ui.trigger),
985 tag = get_tag_name($tag),
986 context = firehose_settings && firehose_settings.viewtitle;
988 // Insert the tagname into the menu items where needed.
989 $TAG_MENU.find('span.var-tag').text(tag);
990 $TAG_MENU.find('a.nix').attr('title','not ' + tag);
993 // non-admins may only delete their own tags
994 $TAG_MENU.find('a:[data-op="-"]').toggle($tag.is('.my'));
997 // *tagname* in *viewtitle*
998 $TAG_MENU.find('a:[data-op="="]').toggle(!!context);
999 context && $TAG_MENU.find('span.var-view').text(context);
1001 open_menu($tag, $TAG_MENU);
1004 select: function( e, ui ){
1005 var $tag = $(ui.trigger),
1006 tag = get_tag_name($tag),
1007 op = $(ui.select).attr('data-op'),
1011 // Global for positioning other things.
1012 $related_trigger = $tag;
1020 fhitem = $tag.closest('.fhitem')[0];
1021 command = (op + tag).replace(NOTNOT, '');
1022 try { Tags.submit(fhitem, command); } catch ( err ) { }
1027 stop: function( e, ui ){ close_menu(ui.trigger, $TAG_MENU); }
1033 /* T2 feedback context-menu */
1037 /* T2 datatype context-menu (admin-only) */
1049 <!-- SMACKS: BEGIN STORY CONTENT -->
1050 <div class="container">
1051 <!--SMACKS: BEGING CENTER COLUMN -->
1052 <div class="main-wrap has-rail-right">
1053 <div class="main-content">
1054 <div class="grid_24 a2 ">
1056 <div id="firehose" class="nothumbs">
1057 <div id="firehoselist" class="fhroot fleft grid_24">
1058 <div id="announcement">
1059 <div id="announcementText" style="display: none;"> <span class="headline">Migrate from GitHub to SourceForge quickly and easily with <strong><a href="https://sourceforge.net/p/forge/documentation/GitHub%20Importer/">this tool</a></strong>.</span> Check out all of SourceForge’s <strong><a href="https://sourceforge.net/blog/brief-history-sourceforge-look-to-future/">recent improvements.</a></strong></div>
1060 <a href="" class="btn-close" title="don't show me this again" onclick="closeAnnouncement(); return false;">×</a>
1064 <script type="text/javascript">
1066 if (!$.cookie('hide_sitenotice_36')) {
1067 $('#announcement').fadeIn(300);
1070 function closeAnnouncement() {
1071 $('#announcement').fadeOut(300);
1072 $.cookie('hide_sitenotice_36', 'true', { path: '/', domain: 'slashdot.org', expires: 1 });
1075 <article id="firehose-102639752" data-fhid="102639752" data-fhtype="story" class="fhitem fhitem-story article usermode thumbs grid_24">
1076 <span class="sd-info-block" style="display: none">
1077 <span class="sd-key-firehose-id">102639752</span>
1078 <span class="type">story</span>
1093 <span class="topic" id="topic-102639752">
1094 <a href="//tech.slashdot.org/index2.pl?fhfilter=security" onclick="return addfhfilter('security');">
1096 <img src="//a.fsdn.com/sd/topics/security_64.png" width="64" height="64" alt="Security" title="Security">
1107 <a href="//tech.slashdot.org/index2.pl?fhfilter=internet" onclick="return addfhfilter('internet');">
1109 <img src="//a.fsdn.com/sd/topics/internet_64.png" width="64" height="64" alt="The Internet" title="The Internet">
1118 <a href="//tech.slashdot.org/index2.pl?fhfilter=it" onclick="return addfhfilter('it');">
1120 <img src="//a.fsdn.com/sd/topics/it_64.png" width="64" height="64" alt="IT" title="IT">
1129 <a href="//tech.slashdot.org/index2.pl?fhfilter=technology" onclick="return addfhfilter('technology');">
1131 <img src="//a.fsdn.com/sd/topics/technology_64.png" width="64" height="64" alt="Technology" title="Technology">
1151 <span id="title-102639752" class="story-title"> <a href="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories">400,000 Websites Vulnerable Through Exposed<nobr> <wbr></nobr>.git Directories</a> <span class=" no extlnk"><a class="story-sourcelnk" href="https://www.scmagazine.com/home/news/400000-websites-vulnerable-through-exposed-git-directories/" title="External link - https://www.scmagazine.com/home/news/400000-websites-vulnerable-through-exposed-git-directories/" target="_blank"> (scmagazine.com) </a></span></span>
1155 <!--<span class="comments commentcnt-102639752" >32</span>-->
1159 <!-- comment bubble -->
1161 <span class="comment-bubble"><a href="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories#comments" title="">32</a></span>
1164 <div class="details" id="details-102639752">
1165 <span class="story-details">
1166 <span class="story-views">
1167 <span class="sodify" onclick="firehose_set_options('color', 'red')" title="Filter Firehose to entries rated red or better"></span><span class="icon-beaker pop1 " alt="Popularity" title="Filter Firehose to entries rated red or better" onclick="firehose_set_options('color', 'red')"><span></span></span>
1170 <span class="story-byline">
1185 <time id="fhtime-102639752" datetime="on Thursday September 06, 2018 @04:00PM">on Thursday September 06, 2018 @04:00PM</time>
1188 from the <span class="dept-text">security-woes</span> dept.
1194 <div class="body" id="fhbody-102639752">
1201 <div id="text-102639752" class="p">
1204 Open .git directories are a bigger cybersecurity problem than many might imagine, at least according to a Czech security researcher who <a href="https://www.scmagazine.com/home/news/400000-websites-vulnerable-through-exposed-git-directories/">discovered almost 400,000 web pages with an open .git directory</a> possibly exposing a wide variety of data. From a report:<i> Vladimir Smitka began his .git directory odyssey in July when he began looking at Czech websites to find how many were improperly configured and allow access to their .git folders within the file versions repository. Open .git directories are a particularly dangerous issue, he said, because they can contain a great deal of sensitive information. "Information about the website's structure, and sometimes you can get very sensitive data such as database passwords, API keys, development IDE settings, and so on. However, this data shouldn't be stored in the repository, but in previous scans of various security issues, I have found many developers that do not follow these best practices," Smitka wrote. Smitka queried 230 million websites to discover the 390,000 allowing access to their .git directories. The vast majority of the websites with open directories had a .com TLD with .net, .de, .org and uk comprising most of the others.</i><br>
1216 <aside class="grid_24 view_mode">
1218 <div class="units-12 story-detail-tags">
1219 <span id="sharethis-102639752" class="">
1226 <div class="story-controls">
1228 class="janrainSocialPlaceholder"
1229 data-janrain-url="https://tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories"
1230 data-janrain-title="400,000 Websites Vulnerable Through Exposed .git Directories"
1231 data-janrain-message="400,000 Websites Vulnerable Through Exposed .git Directories @slashdot"
1238 <div class="story-tags">
1239 <div class="tright tw">
1241 <span class="tright tags">
1243 <menu type="toolbar" class="edit-bar">
1244 <span id="tagbar-102639752" class="tag-bar none">
1245 <a class="topic tag" rel="statictag" href="//slashdot.org/tag/" target="_blank"></a>
1246 <a class="popular tag" rel="statictag" href="//slashdot.org/tag/git" target="_blank">git</a>
1247 <a class="popular tag" rel="statictag" href="//slashdot.org/tag/internet" target="_blank">internet</a>
1248 <a class="popular tag" rel="statictag" href="//slashdot.org/tag/it" target="_blank">it</a>
1252 <a class="edit-toggle" href="/my/login/" onclick="show_login_box();return false;">
1253 <span class="icon-tag btn collapse"></span>
1257 <div class="tag-menu">
1258 <input class="tag-entry default" type="text" value="apply tags">
1278 <section class="grid_24" id="newa2footerv2">
1279 <div class="grid_6 pr">
1280 <h3><a title="Previous story" href="//games.slashdot.org/story/18/09/06/1921222/eve-online-studio-acquired-by-korean-mmo-maker?sdsrc=prev">←</a></h3>
1282 <div class="grid_12 rl">
1283 <h3>You may like to read:</h3>
1285 <div class="grid_6 ns">
1286 <h3><a title="Next story" href="//tech.slashdot.org/story/18/09/06/205221/ive-seen-the-future-of-consumer-ai-and-it-doesnt-have-one?sdsrc=next">→</a></h3>
1288 <div class="grid_6">
1290 <a href="//games.slashdot.org/story/18/09/06/1921222/eve-online-studio-acquired-by-korean-mmo-maker?sdsrc=prev">'Eve Online' Studio Acquired By Korean MMO Maker </a>
1293 <div class="grid_12">
1301 <h2><a href="//tech.slashdot.org/story/18/01/08/1954203/james-damore-sues-google-for-allegedly-discriminating-against-conservative-white-men?sdsrc=popbyskid">James Damore Sues Google For Allegedly Discriminating Against Conservative White Men</a><br></h2>
1302 <h2><a href="//tech.slashdot.org/story/18/03/19/1736231/self-driving-uber-car-kills-arizona-woman-in-first-fatal-crash-involving-pedestrian?sdsrc=popbyskid">Self-Driving Uber Car Kills Arizona Woman in First Fatal Crash Involving Pedestrian</a><br></h2>
1303 <h2><a href="//tech.slashdot.org/story/17/11/16/0050243/twitter-bans-removes-verified-status-of-white-supremacists?sdsrc=popbyskid">Twitter Bans, Removes Verified Status of White Supremacists</a><br></h2>
1304 <h2><a href="//tech.slashdot.org/story/18/02/15/2255242/pro-gun-russian-bots-flood-twitter-after-parkland-shooting?sdsrc=popbyskid">Pro-Gun Russian Bots Flood Twitter After Parkland Shooting</a><br></h2>
1305 <h2><a href="//tech.slashdot.org/story/17/11/19/043243/i-see-things-differently-james-damore-on-his-autism-and-the-google-memo?sdsrc=popbyskid">'I See Things Differently': James Damore on his Autism and the Google Memo</a><br></h2>
1311 <div class="grid_6">
1314 <a href="//tech.slashdot.org/story/18/09/06/205221/ive-seen-the-future-of-consumer-ai-and-it-doesnt-have-one?sdsrc=next">'I've Seen the Future of Consumer AI, and it Doesn't Have One'</a>
1332 <!-- SMACKS: BEGIN RIGHT RAIL -->
1333 <aside id="slashboxes" class="rail-right">
1335 <div id="slashboxesin" class="yui-b">
1340 <div class="railad adwrap-unviewed">
1341 <div id='div-gpt-ad-300x250_a'><script type='text/javascript'>
1342 googletag.cmd.push(function(){
1343 googletag.display('div-gpt-ad-300x250_a');});</script></div>
1345 <div id="taboola-below-article-thumbnails"></div>
1346 <script type="text/javascript">
1347 if ( isAdBlockActive) {
1348 window._taboola = window._taboola || [];
1350 mode: 'thumbnails-rr2',
1351 container: 'taboola-below-article-thumbnails',
1352 placement: 'Below Article Thumbnails',
1359 <!-- SMACKS: END RIGHT RAIL -->
1361 <!-- END STORY CONTENT -->
1363 <!-- THIS IS THE LOCATION FOR THE NEW STORY_B CODE -->
1364 <div class="adwrap">
1365 <div id='div-gpt-ad-728x90_b'><script type='text/javascript'>
1366 googletag.cmd.push(function(){
1367 googletag.display('div-gpt-ad-728x90_b');});</script></div>
1369 <div id="stackcommerce-adwrap" style="display:none;">
1370 <div style="margin:auto;max-width:970px;max-height:250px;">
1371 <div data-sc-widget data-publisher-id="66" data-categories="88,90" data-items-per-page="4" data-col-count="4" data-utm-source="slashdot.org" data-utm-content="story-deal-feed"></div>
1374 <script type="text/javascript">
1375 if (!window.is_euro_union) {
1376 if (isAdBlockActive) {
1378 url: '/ajax.pl?op=nel',
1379 success: function(html){
1381 $('#firehoselist article').eq(0).after(html);
1384 var stackCommerceDiv = document.getElementById('stackcommerce-adwrap');
1385 stackCommerceDiv.style = '';
1386 var stackCommerce = document.createElement('script');
1387 stackCommerce.async = true;
1388 stackCommerce.type = 'text/javascript';
1389 stackCommerce.src = 'https://widgets.stackcommerce.com/js-deal-feed/0.1/widget.js';
1390 var node = document.getElementsByTagName('script')[0];
1391 node.parentNode.insertBefore(stackCommerce, node);
1399 <!--------------------------->
1402 <!-- SMACKS: BEGIN COMMENTS CONTAINER -->
1403 <div class="container">
1404 <!-- SMACKS: BEGIN COMMENTS SECTION -->
1405 <div class="main-wrap">
1406 <div class="main-content">
1407 <div id="comments" class="a2commentwrap">
1409 <a name="comments"></a>
1410 <div id="comments" class="container">
1411 <div class="main-wrap">
1412 <div class="main-content">
1413 <section class="d2incommentspl">
1414 <div class="commentwrap" id="commentwrap">
1416 <div class="commentBox">
1417 <div class="title hide">
1420 <span class="escape-link"><a href="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories" title="Back to Article - 400,000 Websites Vulnerable Through Exposed<nobr> <wbr></nobr>.git Directories">400,000 Websites Vulnerable Through Exposed<nobr> <wbr></nobr>.git Directories</a></span>
1422 <span class="commentBoxLinks"><a href="#" onclick="D2.ajaxFetchComments(0,1); return false"><span id="more_comments_num_d"></span> More</a>
1426 | <span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&op=reply&threshold=1&commentsort=0&mode=thread&pid=" onclick="D2.replyTo(0); return false;">Reply</a>
1429 <a class="login" href="//tech.slashdot.org/login.pl" onclick="show_login_box(); return false">Login</a></span>
1435 <section class="grid_24" id="d2header"><div>
1437 <h2 class="commentspl test"><a title="Back to Article - 400,000 Websites Vulnerable Through Exposed<nobr> <wbr></nobr>.git Directories" href="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories">400,000 Websites Vulnerable Through Exposed<nobr> <wbr></nobr>.git Directories</a></h2>
1439 <nav class="grid_24">
1440 <div class="grid_14 widthauto">
1442 <span class="ind"></span><a class="btn first" href="//tech.slashdot.org/comments.pl?sid=12580412&op=reply&threshold=1&commentsort=0&mode=thread&pid=" onclick="D2.replyTo(0); return false;">Post</a>
1444 <!-- <a href="//tech.slashdot.org/search.pl?op=comments&sid=12580412" class="btn">Search <span class="totalcommentcnt">32</span> Comments</a> -->
1447 <a href="#" onclick="D2.ajaxFetchComments(0,1,'','',-1); return false" class="btn" id="d2loadall">Load All Comments</a>
1452 <div class="grid_10 d1or2">
1456 <div id="d2out" class="horizontal rooted grid_15">
1457 <div id="d2act" class="hide">
1458 <div class="loki" id="gods">
1459 <script type="text/javascript">
1461 D2.slider = new D2.Slider(
1462 D2.user_threshold(),
1463 D2.user_highlightthresh(),
1468 <div id="bones" class="grid_12">
1469 <div class="ccw-count-container grid_24">
1470 <span id="ccw-full-count-text" class="grid_8 ccw-count-text tcenter"><span></span><span id="ccw-full-phrase"> Full</span></span>
1471 <span id="ccw-abbr-count-text" class="grid_8 ccw-count-text"><span></span><span id="ccw-abbr-phrase"> Abbreviated</span></span>
1472 <span id="ccw-hide-count-text" class="grid_8 ccw-count-text tleft"><span></span><span id="ccw-hide-phrase"> Hidden</span></span>
1475 <div id="ccw-body" class="ccw-core">
1476 <div id="ccw-panel-container" class="ccw-core">
1477 <div id="ccw-full-panel" class="ccw-panel">
1478 /Sea<div class="ccw-panel-border"></div>
1479 <div id="ccw-full-count-pos" class="ccw-core-pos ccw-count-pos"></div>
1481 <div id="ccw-abbr-panel" class="ccw-panel">
1482 <div class="ccw-panel-border"></div>
1483 <div id="ccw-abbr-count-pos" class="ccw-core-pos ccw-count-pos"></div>
1485 <div id="ccw-hide-panel" class="ccw-panel">
1486 <div id="ccw-hide-count-pos" class="ccw-core-pos ccw-count-pos"></div>
1489 <div id="ccw-control" class="ccw-core">
1490 <div id="ccw-centering-rail" class="ccw-core">
1491 <div id="ccw-hide-bar-pos" class="ccw-core-pos">
1492 <div id="ccw-hide-bar" class="ccw-bar">
1493 <div id="ccw-hide-bar-tab" class="ccw-bar-tab"></div>
1494 <div class="ccwa"></div>
1495 <div class="ccwb"></div>
1496 <div id="ccw-hide-bar-upzone" class="ccw-upzone" onclick="D2.slider.stepTHT(HIDE_BAR, +1)"></div>
1497 <div id="ccw-hide-bar-downzone" class="ccw-downzone" onclick="D2.slider.stepTHT(HIDE_BAR, -1)"></div>
1500 <div id="ccw-abbr-bar-pos" class="ccw-core-pos">
1501 <div id="ccw-abbr-bar" class="ccw-bar">
1502 <div id="ccw-abbr-bar-tab" class="ccw-bar-tab"></div>
1503 <div class="ccwa"></div>
1504 <div class="ccwb"></div>
1505 <div id="ccw-abbr-bar-upzone" class="ccw-upzone" onclick="D2.slider.stepTHT(ABBR_BAR, +1)"></div>
1506 <div id="ccw-abbr-bar-downzone" class="ccw-downzone" onclick="D2.slider.stepTHT(ABBR_BAR, -1)"></div>
1512 <div class="ccw-score-label grid_24">
1513 <div class="grid_3"><span class="sc">Score:</span></div>
1514 <div class="grid_3">5<span class="lg"></span></div>
1515 <div class="grid_3">4<span class="lg"></span></div>
1516 <div class="grid_3">3<span class="lg"></span></div>
1517 <div class="grid_3">2<span class="lg"></span></div>
1518 <div class="grid_3">1<span class="lg"></span></div>
1519 <div class="grid_3">0<span class="lg"></span></div>
1520 <div class="grid_3">-1<span class="lg"></span></div>
1524 <div class="commentControlFooter">
1525 <a href="#" onclick="D2.ajaxFetchComments(0,1); return false"><span id="more_comments_num_c"></span> More</a>
1529 | <span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&op=reply&threshold=1&commentsort=0&mode=thread&pid=" onclick="D2.replyTo(0); return false;">Reply</a>
1532 <a class="login" href="//tech.slashdot.org/login.pl" onclick="show_login_box(); return false">Login</a><div id="login_cover" class="hide" onclick="hide_login_box()"></div>
1533 <div id="login_box" class="hide">
1534 <div id="login_box_content">
1535 <div id='embbeded_login_modal' class="hide">
1536 <form action="https://slashdot.org/my/login" method="post" onsubmit="if (global_returnto) { this.returnto.value = global_returnto }" class="embedded"><fieldset style="-webkit-border-radius:10px 10px 0 0;border-radius:10px 10px 0 0;-moz-border-radius:10px 10px 0 0">
1537 <div style='height:25px;'> </div>
1538 <input type="hidden" name="returnto" value="//tech.slashdot.org/comments.pl?sid=12580412">
1539 <input type="hidden" name="op" value="userlogin">
1541 <label class="fleft" for="unickname">Nickname:</label>
1542 <input type="text" name="unickname" value="">
1545 <label class="fleft" for="upasswd">Password:</label>
1546 <input type="password" name="upasswd" placeholder="6-1024 characters long">
1548 <label class="checkbox"><input type="checkbox" name="login_temp" value="yes"> Public Terminal</label>
1551 <input type="submit" name="userlogin" value="Log In" class="fno"> <a href="//slashdot.org/my/mailpassword" class="btn link" onclick="getModalPrefs('sendPasswdModal', 'Retrieve Password', 1); return false;">Forgot your password?</a>
1554 <div id="janrainEngageEmbed"></div>
1555 <div class="actions">
1556 <a class="ico close" onclick="hide_login_slider();" href=""><span>Close</span></a>
1559 <div class="actions">
1560 <a class="ico close" href="#" onclick="hide_login_box(); return false"><span>Close</span></a>
1564 <script type="text/javascript">logged_in = 0</script>
1566 <div id="commentControlBoxStatus" class="hide"></div>
1572 <a href="//tech.slashdot.org/search.pl?op=comments&sid=12580412" class="ui-icon search_comments">Search <span class="totalcommentcnt">32</span> Comments</a>
1574 <a class="pref ui-icon-w" href="//tech.slashdot.org/users.pl" onclick="show_login_box(); $('#modal_box').addClass('login'); return false;">Log In/Create an Account</a>
1578 <section id="besttabs" class="grid_24">
1579 <span class="legend">Comments Filter:</span>
1580 <ul class="besttabslist">
1582 <a href="#" data-filter-url="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories#comments">All</a>
1586 <a href="" data-filter-url="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories/insightful-comments#comments">Insightful</a>
1590 <a href="" data-filter-url="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories/informative-comments#comments">Informative</a>
1594 <a href="" data-filter-url="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories/interesting-comments#comments">Interesting</a>
1598 <a href="" data-filter-url="//tech.slashdot.org/story/18/09/06/1954253/400000-websites-vulnerable-through-exposed-git-directories/funny-comments#comments">Funny</a>
1604 $('#besttabs').show();
1605 $('.besttabslist').on('click', 'li a', function(e){
1607 var url = $(this).data('filter-url');
1608 //console.log('URL= ', url);
1610 .closest('ul').find('li').removeClass('active')
1612 .closest('li').addClass('active');
1613 window.location = url;
1618 <aside class="grid_24">
1620 <small><strong>The Fine Print:</strong> The following comments are owned by whoever posted them. We are not responsible for them in any way.</small>
1627 </div><script src="//a.fsdn.com/sd/comments-minified.js?8f5016a67a2f2048" type="text/javascript"></script>
1630 <script type="text/javascript">
1632 D2.d2_keybindings_disable()[191] = 1;
1634 D2.comments({ 57265748: { uid: 666, pid: 0, read: 0, points: 0, kids: [ 57265928 ], opid: 0 }, 57266046: { uid: 666, pid: 57265968, subject: "Re:Alternate headline: 99.8% websites are OK", read: 0, points: 0, kids: [ ], opid: 57265968 }, 57265838: { uid: 666, pid: 0, read: 0, points: 0, kids: [ ], opid: 0 }, 57265702: { uid: 1516577, pid: 57265676, subject: "Re:.htaccess", read: 0, points: 2, kids: [ ], opid: 57265676 }, 57265754: { uid: 265505, pid: 0, read: 0, points: 1, kids: [ 57265854, 57265868 ], opid: 0 }, 57265826: { uid: 666, pid: 0, read: 0, points: 0, kids: [ 57265832 ], opid: 0 }, 57266128: { uid: 124937, pid: 57266028, subject: "Re:So?", read: 0, points: 2, kids: [ 57267568 ], opid: 57266028 }, 57266652: { uid: 898571, pid: 57266554, subject: "Re:So?", read: 0, points: 1, kids: [ ], opid: 57266554 }, 57265760: { uid: 666, pid: 0, read: 0, points: -1, kids: [ ], opid: 0 }, 57267314: { uid: 197329, pid: 57265676, subject: "Re:.htaccess", read: 0, points: 2, kids: [ ], opid: 57265676 }, 57265776: { uid: 666, pid: 0, read: 0, points: 0, kids: [ ], opid: 0 }, 57265832: { uid: 2813011, pid: 57265826, read: 0, points: 2, kids: [ ], opid: 57265826 }, 57266024: { uid: 666, pid: 0, read: 0, points: 0, kids: [ 57266638 ], opid: 0 }, 57265706: { uid: 666, pid: 57265676, read: 0, points: 0, kids: [ 57265724 ], opid: 57265676 }, 57267330: { uid: 197329, pid: 57265868, subject: "Re:Your central git repo ...", read: 0, points: 2, kids: [ ], opid: 57265868 }, 57266650: { uid: 467024, pid: 57266028, subject: "Re:So?", read: 0, points: 2, kids: [ ], opid: 57266028 }, 57266750: { uid: 5486298, pid: 0, read: 0, points: 0, kids: [ ], opid: 0 }, 57266638: { uid: 260285, pid: 57266024, read: 0, points: 2, kids: [ ], opid: 57266024 }, 57266180: { uid: 666, pid: 0, read: 0, points: 0, kids: [ ], opid: 0 }, 57265724: { uid: 666, pid: 57265706, read: 0, points: 0, kids: [ 57265824 ], opid: 57265706 }, 57266028: { uid: 673578, pid: 0, read: 0, points: 2, kids: [ 57266128, 57266554, 57266650 ], opid: 0 }, 57267598: { uid: 182339, pid: 57265676, read: 0, points: 3, kids: [ ], opid: 57265676 }, 57265824: { uid: 666, pid: 57265724, read: 0, points: 0, kids: [ ], opid: 57265724 }, 57265676: { uid: 666, pid: 0, read: 0, points: 0, kids: [ 57265702, 57265706, 57267314, 57267598 ], opid: 0 }, 57265854: { uid: 666, pid: 57265754, subject: "Re:Your central git repo ...", read: 0, points: 0, kids: [ ], opid: 57265754 }, 57265928: { uid: 1122017, pid: 57265748, subject: "Re:https://slashdot.org/.git", read: 0, points: 4, kids: [ ], opid: 57265748 }, 57267568: { uid: 666, pid: 57266128, subject: "Re:So?", read: 0, points: 0, kids: [ ], opid: 57266128 }, 57266554: { uid: 666, pid: 57266028, subject: "Re:So?", read: 0, points: 1, kids: [ 57266652 ], opid: 57266028 }, 57265820: { uid: 2813011, pid: 0, read: 0, points: 3, kids: [ ], opid: 0 }, 57265868: { uid: 30335, pid: 57265754, subject: "Re:Your central git repo ...", read: 0, points: 4, kids: [ 57267330 ], opid: 57265754 }, 57265968: { uid: 148257, pid: 0, read: 0, points: 2, kids: [ 57266046 ], opid: 0 }, 57266440: { uid: 666, pid: 0, read: 0, points: 0, kids: [ ], opid: 0 } });
1636 D2.thresh_totals({6:{6:{1:32,3:0,2:0}},3:{6:{1:28,3:0,2:4},4:{1:28,3:3,2:1},3:{1:28,3:4,2:0},5:{1:28,3:0,2:4}},2:{6:{1:19,3:0,2:13},4:{1:19,3:3,2:10},3:{1:19,3:6,2:7},2:{1:19,3:13,2:0},5:{1:19,3:0,2:13}},1:{6:{1:16,3:0,2:16},4:{1:16,3:3,2:13},1:{1:16,3:16,2:0},3:{1:16,3:6,2:10},2:{1:16,3:14,2:2},5:{1:16,3:0,2:16}},4:{6:{1:30,3:0,2:2},4:{1:30,3:2,2:0},5:{1:30,3:0,2:2}},0:{6:{1:1,3:0,2:31},4:{1:1,3:3,2:28},1:{1:1,3:25,2:6},3:{1:1,3:6,2:25},0:{1:1,3:31,2:0},2:{1:1,3:14,2:17},5:{1:1,3:0,2:31}},"-1":{6:{1:0,3:0,2:32},3:{1:0,3:6,2:26},2:{1:0,3:14,2:18},1:{1:0,3:25,2:7},4:{1:0,3:3,2:29},0:{1:0,3:32,2:0},"-1":{1:0,3:32,2:0},5:{1:0,3:0,2:32}},5:{6:{1:32,3:0,2:0},5:{1:32,3:0,2:0}}});
1639 D2.root_comments([57265676,57265748,57265754,57265760,57265776,57265820,57265826,57265838,57265968,57266024,57266028,57266180,57266440,57266750]);
1640 D2.root_comments_hash({57265748:1,57265838:1,57265826:1,57265754:1,57265760:1,57265776:1,57266024:1,57266750:1,57266180:1,57266028:1,57265676:1,57265820:1,57265968:1,57266440:1});
1642 D2.d2_comment_order(0);
1645 D2.user_is_admin(0);
1646 D2.user_is_subscriber(0);
1647 D2.user_smallscreen(0);
1648 D2.user_threshold(1);
1649 D2.user_highlightthresh(4);
1652 D2.discussion_id(12580412);
1654 D2.d2_seen('57265676,26,4,18,24,6,6,16,44,4,2,6,6,16,14,60,40,56,4,18,82,52,260,114,84,12,2,98,564,16,238,30');
1655 D2.more_comments_num(0);
1668 <ul id="commentlisting" class="d2">
1669 <li id="tree_57265676" class="comment hidden"><span class="ind"></span>
1670 <div id="comment_status_57265676" class="commentstatus"></div>
1671 <div id="comment_57265676" class="cw">
1674 <div id="replyto_57265676"></div>
1676 <ul id="group_57265676">
1677 <li id="hiddens_57265676" class="hide"></li>
1680 <ul id="commtree_57265676"><li id="tree_57265702" class="comment oneline"><span class="ind"></span>
1681 <div id="comment_status_57265702" class="commentstatus"></div>
1682 <div id="comment_57265702" class="cw">
1683 <div id="comment_top_57265702" class="commentTop newcomment">
1685 <h4><a id="comment_link_57265702" name="comment_link_57265702" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265702" onclick="return D2.setFocusComment(57265702)" >Re:</a>
1688 <span id="comment_score_57265702" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265702); return false"><span class=opt>Score:</span>2</a>, Informative)</span></h4>
1690 <div class="details">
1691 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~MidSpeck">MidSpeck</a> <span class="uid"><a href="//slashdot.org/~MidSpeck">( 1516577 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1692 <span class="otherdetails" id="comment_otherdetails_57265702"></span>
1695 <div class="commentBody">
1696 <div id="comment_body_57265702"><p>^/.*/\.git/<br>Protect git repositories in all subdirectories as well.</p></div>
1699 <div class="commentSub" id="comment_sub_57265702">
1704 <div id="replyto_57265702"></div>
1706 <ul id="group_57265702">
1707 <li id="hiddens_57265702" class="hide"></li>
1710 </li><li id="tree_57265706" class="comment hidden"><span class="ind"></span>
1711 <div id="comment_status_57265706" class="commentstatus"></div>
1712 <div id="comment_57265706" class="cw">
1715 <div id="replyto_57265706"></div>
1717 <ul id="group_57265706">
1718 <li id="hiddens_57265706" class="hide"></li>
1721 <ul id="commtree_57265706"><li id="tree_57265724" class="comment hidden"><span class="ind"></span>
1722 <div id="comment_status_57265724" class="commentstatus"></div>
1723 <div id="comment_57265724" class="cw">
1726 <div id="replyto_57265724"></div>
1728 <ul id="group_57265724">
1729 <li id="hiddens_57265724" class="hide"></li>
1732 <ul id="commtree_57265724"><li id="tree_57265824" class="comment hidden"><span class="ind"></span>
1733 <div id="comment_status_57265824" class="commentstatus"></div>
1734 <div id="comment_57265824" class="cw">
1737 <div id="replyto_57265824"></div>
1739 <ul id="group_57265824">
1740 <li id="hiddens_57265824" class="hide"></li>
1743 </li><li id="hidestring_57265724"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=57265724">1 reply</a> beneath your current threshold.</b></noscript></li></ul></li><li id="hidestring_57265706"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=57265706">1 reply</a> beneath your current threshold.</b></noscript></li></ul></li><li id="tree_57267314" class="comment oneline"><span class="ind"></span>
1744 <div id="comment_status_57267314" class="commentstatus"></div>
1745 <div id="comment_57267314" class="cw">
1746 <div id="comment_top_57267314" class="commentTop newcomment">
1748 <h4><a id="comment_link_57267314" name="comment_link_57267314" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57267314" onclick="return D2.setFocusComment(57267314)" >Re:</a>
1751 <span id="comment_score_57267314" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57267314); return false"><span class=opt>Score:</span>2</a>)</span></h4>
1753 <div class="details">
1754 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~jrumney">jrumney</a> <span class="uid"><a href="//slashdot.org/~jrumney">( 197329 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1755 <span class="otherdetails" id="comment_otherdetails_57267314"></span>
1758 <div class="commentBody">
1759 <div id="comment_body_57267314">Why stop there? Are there any dot files/directories that need to be served over HTTP?</div>
1762 <div class="commentSub" id="comment_sub_57267314">
1767 <div id="replyto_57267314"></div>
1769 <ul id="group_57267314">
1770 <li id="hiddens_57267314" class="hide"></li>
1773 </li><li id="tree_57267598" class="comment oneline"><span class="ind"></span>
1774 <div id="comment_status_57267598" class="commentstatus"></div>
1775 <div id="comment_57267598" class="cw">
1776 <div id="comment_top_57267598" class="commentTop newcomment">
1778 <h4><a id="comment_link_57267598" name="comment_link_57267598" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57267598" onclick="return D2.setFocusComment(57267598)" >Re: .htaccess</a>
1781 <span id="comment_score_57267598" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57267598); return false"><span class=opt>Score:</span>3</a>)</span></h4>
1783 <div class="details">
1784 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~spongman">spongman</a> <span class="uid"><a href="//slashdot.org/~spongman">( 182339 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1785 <span class="otherdetails" id="comment_otherdetails_57267598"></span>
1788 <div class="commentBody">
1789 <div id="comment_body_57267598"><p>Why doesn't Apache block all '.'-prefixed directories by default?</p></div>
1792 <div class="commentSub" id="comment_sub_57267598">
1797 <div id="replyto_57267598"></div>
1799 <ul id="group_57267598">
1800 <li id="hiddens_57267598" class="hide"></li>
1803 </li><li id="hidestring_57265676"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=57265676">1 reply</a> beneath your current threshold.</b></noscript></li></ul></li><li id="tree_57265748" class="comment hidden"><span class="ind"></span>
1804 <div id="comment_status_57265748" class="commentstatus"></div>
1805 <div id="comment_57265748" class="cw">
1808 <div id="replyto_57265748"></div>
1810 <ul id="group_57265748">
1811 <li id="hiddens_57265748" class="hide"></li>
1814 <ul id="commtree_57265748"><li id="tree_57265928" class="comment full contain"><span class="ind"></span>
1815 <div id="comment_status_57265928" class="commentstatus"></div>
1816 <div id="comment_57265928" class="cw">
1817 <div id="comment_top_57265928" class="commentTop newcomment">
1819 <h4><a id="comment_link_57265928" name="comment_link_57265928" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265928" onclick="return D2.setFocusComment(57265928)" >Re:https://slashdot.org/.git</a>
1822 <span id="comment_score_57265928" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265928); return false"><span class=opt>Score:</span>4</a>, Informative)</span></h4>
1824 <div class="details">
1825 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~ls671">ls671</a> <span class="uid"><a href="//slashdot.org/~ls671">( 1122017 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1826 <span class="otherdetails" id="comment_otherdetails_57265928">
1827 on Thursday September 06, 2018 @04:52PM (<span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265928">#57265928</a>)
1828 <small><a href="http://slashdot.org/" title="http://slashdot.org/" class="user_homepage_display">Homepage</a> </small>
1832 <div class="commentBody">
1833 <div id="comment_body_57265928"><p>Slashdot is still using CVS try <a href="https://slashdot.org/CVS/" title="slashdot.org">https://slashdot.org/CVS/</a> [slashdot.org]</p><p>you will see, it works!<nobr> <wbr></nobr>:)</p></div>
1836 <div class="commentSub" id="comment_sub_57265928">
1837 <span class="ind"></span><a id="reply_link_57265928" class="btn link" href="//tech.slashdot.org/comments.pl?sid=12580412&op=Reply&threshold=1&commentsort=0&mode=thread&pid=57265928" onclick="D2.replyTo(57265928); return false;">Reply to This</a> <span class="ind"></span><a class="btn link" href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=1&commentsort=0&mode=thread&cid=57265748" onclick="return D2.selectParent(57265748)">Parent</a> <a href="#" class="comment_share_toggle btn link">Share</a>
1838 <div class="comment_share sharethis-0 hide"><span class="au"></span>
1839 <a class="janrain t" href="#" data-provider="twitter" data-message="Re:https://slashdot.org/.git by ls671 @slashdot" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265928" data-title="Re:https://slashdot.org/.git">twitter</a>
1840 <a class="janrain f" href="#" data-provider="facebook" data-message="Re:https://slashdot.org/.git by ls671" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265928" data-title="Re:https://slashdot.org/.git">facebook</a>
1841 <a class="janrain l" href="#" data-provider="linkedin" data-message="Re:https://slashdot.org/.git by ls671" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265928" data-title="Re:https://slashdot.org/.git">linkedin</a>
1842 <a class="g" href="https://plus.google.com/share?url=https://tech.slashdot.org/comments.pl?sid=12580412%26cid=57265928" onclick="javascript:window.open(this.href,'', 'menubar=no,toolbar=no,resizable=yes,scrollbars=yes,height=600,width=600');return false;"><img src="//www.gstatic.com/images/icons/gplus-16.png" alt="Share on Google+"/></a>
1844 <span class="ind"></span><a id="reply_link_57265928" title="Flag this comment as Inappropriate" class="ui-icon flag fright" href="//tech.slashdot.org/comments.pl?sid=12580412&op=flag&threshold=1&commentsort=0&mode=thread&pid=57265928" onclick="return false;">Flag as Inappropriate</a>
1848 <div id="replyto_57265928"></div>
1850 <ul id="group_57265928">
1851 <li id="hiddens_57265928" class="hide"></li>
1854 </li></ul></li><li id="tree_57265754" class="comment oneline"><span class="ind"></span>
1855 <div id="comment_status_57265754" class="commentstatus"></div>
1856 <div id="comment_57265754" class="cw">
1857 <div id="comment_top_57265754" class="commentTop newcomment">
1859 <h4><a id="comment_link_57265754" name="comment_link_57265754" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265754" onclick="return D2.setFocusComment(57265754)" >Your central git repo ...</a>
1862 <span id="comment_score_57265754" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265754); return false"><span class=opt>Score:</span>1</a>)</span></h4>
1864 <div class="details">
1865 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~Qbertino">Qbertino</a> <span class="uid"><a href="//slashdot.org/~Qbertino">( 265505 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1866 <span class="otherdetails" id="comment_otherdetails_57265754"></span>
1869 <div class="commentBody">
1870 <div id="comment_body_57265754"><p>... belongs behind ssh or, at least, behind http access and SSL.<br>If I catch you doing otherwise for anything other than FOSS software I'll smack you. Hard.</p></div>
1873 <div class="commentSub" id="comment_sub_57265754">
1878 <div id="replyto_57265754"></div>
1880 <ul id="group_57265754">
1881 <li id="hiddens_57265754" class="hide"></li>
1884 <ul id="commtree_57265754"><li id="tree_57265854" class="comment hidden"><span class="ind"></span>
1885 <div id="comment_status_57265854" class="commentstatus"></div>
1886 <div id="comment_57265854" class="cw">
1889 <div id="replyto_57265854"></div>
1891 <ul id="group_57265854">
1892 <li id="hiddens_57265854" class="hide"></li>
1895 </li><li id="tree_57265868" class="comment full contain"><span class="ind"></span>
1896 <div id="comment_status_57265868" class="commentstatus"></div>
1897 <div id="comment_57265868" class="cw">
1898 <div id="comment_top_57265868" class="commentTop newcomment">
1900 <h4><a id="comment_link_57265868" name="comment_link_57265868" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265868" onclick="return D2.setFocusComment(57265868)" >Re:Your central git repo ...</a>
1903 <span id="comment_score_57265868" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265868); return false"><span class=opt>Score:</span>4</a>, Informative)</span></h4>
1905 <div class="details">
1906 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~tlhIngan">tlhIngan</a> <span class="uid"><a href="//slashdot.org/~tlhIngan">( 30335 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1907 <span class="otherdetails" id="comment_otherdetails_57265868"> <<a href="mailto:%5Bten.frow%5D+%5Bta%5D+%5Btodhsals%5D">[ten.frow] [ta] [todhsals]</a>>
1908 on Thursday September 06, 2018 @04:41PM (<span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265868">#57265868</a>)
1913 <div class="commentBody">
1914 <div id="comment_body_57265868"><blockquote><div><p>... belongs behind ssh or, at least, behind http access and SSL.<br>If I catch you doing otherwise for anything other than FOSS software I'll smack you. Hard.</p></div></blockquote><p>And it probably is. The thing is, the website owners are using git to version control and deploy their website (not a bad idea). So they develop their web site, push it to the central git repo, and whenever they need to go live, they just do a "git pull" on the webserver and it'll pull down the latest version of the website.</p><p>Problem is, they forget about the hidden<nobr> <wbr></nobr>.git directory git makes that stores all sorts of useful information and with a little persistence, allow you access to the raw source code since you can access the individual git objects. (Or maybe even clone it using git).</p></div>
1917 <div class="commentSub" id="comment_sub_57265868">
1918 <span class="ind"></span><a id="reply_link_57265868" class="btn link" href="//tech.slashdot.org/comments.pl?sid=12580412&op=Reply&threshold=1&commentsort=0&mode=thread&pid=57265868" onclick="D2.replyTo(57265868); return false;">Reply to This</a> <span class="ind"></span><a class="btn link" href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=1&commentsort=0&mode=thread&cid=57265754" onclick="return D2.selectParent(57265754)">Parent</a> <a href="#" class="comment_share_toggle btn link">Share</a>
1919 <div class="comment_share sharethis-0 hide"><span class="au"></span>
1920 <a class="janrain t" href="#" data-provider="twitter" data-message="Re:Your central git repo ... by tlhIngan @slashdot" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265868" data-title="Re:Your central git repo ...">twitter</a>
1921 <a class="janrain f" href="#" data-provider="facebook" data-message="Re:Your central git repo ... by tlhIngan" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265868" data-title="Re:Your central git repo ...">facebook</a>
1922 <a class="janrain l" href="#" data-provider="linkedin" data-message="Re:Your central git repo ... by tlhIngan" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265868" data-title="Re:Your central git repo ...">linkedin</a>
1923 <a class="g" href="https://plus.google.com/share?url=https://tech.slashdot.org/comments.pl?sid=12580412%26cid=57265868" onclick="javascript:window.open(this.href,'', 'menubar=no,toolbar=no,resizable=yes,scrollbars=yes,height=600,width=600');return false;"><img src="//www.gstatic.com/images/icons/gplus-16.png" alt="Share on Google+"/></a>
1925 <span class="ind"></span><a id="reply_link_57265868" title="Flag this comment as Inappropriate" class="ui-icon flag fright" href="//tech.slashdot.org/comments.pl?sid=12580412&op=flag&threshold=1&commentsort=0&mode=thread&pid=57265868" onclick="return false;">Flag as Inappropriate</a>
1929 <div id="replyto_57265868"></div>
1931 <ul id="group_57265868">
1932 <li id="hiddens_57265868" class="hide"></li>
1935 <ul id="commtree_57265868"><li id="tree_57267330" class="comment oneline"><span class="ind"></span>
1936 <div id="comment_status_57267330" class="commentstatus"></div>
1937 <div id="comment_57267330" class="cw">
1938 <div id="comment_top_57267330" class="commentTop newcomment">
1940 <h4><a id="comment_link_57267330" name="comment_link_57267330" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57267330" onclick="return D2.setFocusComment(57267330)" >Re:</a>
1943 <span id="comment_score_57267330" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57267330); return false"><span class=opt>Score:</span>2</a>)</span></h4>
1945 <div class="details">
1946 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~jrumney">jrumney</a> <span class="uid"><a href="//slashdot.org/~jrumney">( 197329 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1947 <span class="otherdetails" id="comment_otherdetails_57267330"></span>
1950 <div class="commentBody">
1951 <div id="comment_body_57267330">I do this, it is very convenient for deploying updates to the site. But I always put the web interface into a subdirectory, and only configure the web server to see that so the<nobr> <wbr></nobr>.git directory is not visible over HTTP. And dotfiles and directories are blocked in the webserver config for extra protection against accidental inclusion of invisible files.</div>
1954 <div class="commentSub" id="comment_sub_57267330">
1959 <div id="replyto_57267330"></div>
1961 <ul id="group_57267330">
1962 <li id="hiddens_57267330" class="hide"></li>
1965 </li></ul></li><li id="hidestring_57265754"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=57265754">1 reply</a> beneath your current threshold.</b></noscript></li></ul></li><li id="tree_57265760" class="comment hidden"><span class="ind"></span>
1966 <div id="comment_status_57265760" class="commentstatus"></div>
1967 <div id="comment_57265760" class="cw">
1970 <div id="replyto_57265760"></div>
1972 <ul id="group_57265760">
1973 <li id="hiddens_57265760" class="hide"></li>
1976 </li><li id="tree_57265776" class="comment hidden"><span class="ind"></span>
1977 <div id="comment_status_57265776" class="commentstatus"></div>
1978 <div id="comment_57265776" class="cw">
1981 <div id="replyto_57265776"></div>
1983 <ul id="group_57265776">
1984 <li id="hiddens_57265776" class="hide"></li>
1987 </li><li id="tree_57265820" class="comment full contain"><span class="ind"></span>
1988 <div id="comment_status_57265820" class="commentstatus"></div>
1989 <div id="comment_57265820" class="cw">
1990 <div id="comment_top_57265820" class="commentTop newcomment">
1992 <h4><a id="comment_link_57265820" name="comment_link_57265820" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265820" onclick="return D2.setFocusComment(57265820)" >reheating yesterday's food</a>
1995 <span id="comment_score_57265820" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265820); return false"><span class=opt>Score:</span>3</a>)</span></h4>
1997 <div class="details">
1998 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~Tsolias">Tsolias</a> <span class="uid"><a href="//slashdot.org/~Tsolias">( 2813011 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
1999 <span class="otherdetails" id="comment_otherdetails_57265820">
2000 on Thursday September 06, 2018 @04:32PM (<span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265820">#57265820</a>)
2005 <div class="commentBody">
2006 <div id="comment_body_57265820"><p>just an article from 2015 <a href="https://en.internetwache.org/dont-publicly-expose-git-or-how-we-downloaded-your-websites-sourcecode-an-analysis-of-alexas-1m-28-07-2015/" title="internetwache.org">https://en.internetwache.org/d...</a> [internetwache.org]</p><p>I can give you also next year's article about<nobr> <wbr></nobr>.file vulnerabilities. (spoiler alert) <a href="https://en.internetwache.org/scanning-the-alexa-top-1m-for-ds-store-files-12-03-2018/" title="internetwache.org">https://en.internetwache.org/s...</a> [internetwache.org]</p></div>
2009 <div class="commentSub" id="comment_sub_57265820">
2010 <span class="ind"></span><a id="reply_link_57265820" class="btn link" href="//tech.slashdot.org/comments.pl?sid=12580412&op=Reply&threshold=1&commentsort=0&mode=thread&pid=57265820" onclick="D2.replyTo(57265820); return false;">Reply to This</a> <a href="#" class="comment_share_toggle btn link">Share</a>
2011 <div class="comment_share sharethis-0 hide"><span class="au"></span>
2012 <a class="janrain t" href="#" data-provider="twitter" data-message="reheating yesterday's food by Tsolias @slashdot" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265820" data-title="reheating yesterday's food">twitter</a>
2013 <a class="janrain f" href="#" data-provider="facebook" data-message="reheating yesterday's food by Tsolias" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265820" data-title="reheating yesterday's food">facebook</a>
2014 <a class="janrain l" href="#" data-provider="linkedin" data-message="reheating yesterday's food by Tsolias" data-url="https://tech.slashdot.org/comments.pl?sid=12580412&cid=57265820" data-title="reheating yesterday's food">linkedin</a>
2015 <a class="g" href="https://plus.google.com/share?url=https://tech.slashdot.org/comments.pl?sid=12580412%26cid=57265820" onclick="javascript:window.open(this.href,'', 'menubar=no,toolbar=no,resizable=yes,scrollbars=yes,height=600,width=600');return false;"><img src="//www.gstatic.com/images/icons/gplus-16.png" alt="Share on Google+"/></a>
2017 <span class="ind"></span><a id="reply_link_57265820" title="Flag this comment as Inappropriate" class="ui-icon flag fright" href="//tech.slashdot.org/comments.pl?sid=12580412&op=flag&threshold=1&commentsort=0&mode=thread&pid=57265820" onclick="return false;">Flag as Inappropriate</a>
2021 <div id="replyto_57265820"></div>
2023 <ul id="group_57265820">
2024 <li id="hiddens_57265820" class="hide"></li>
2027 </li><li id="tree_57265826" class="comment hidden"><span class="ind"></span>
2028 <div id="comment_status_57265826" class="commentstatus"></div>
2029 <div id="comment_57265826" class="cw">
2032 <div id="replyto_57265826"></div>
2034 <ul id="group_57265826">
2035 <li id="hiddens_57265826" class="hide"></li>
2038 <ul id="commtree_57265826"><li id="tree_57265832" class="comment oneline"><span class="ind"></span>
2039 <div id="comment_status_57265832" class="commentstatus"></div>
2040 <div id="comment_57265832" class="cw">
2041 <div id="comment_top_57265832" class="commentTop newcomment">
2043 <h4><a id="comment_link_57265832" name="comment_link_57265832" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265832" onclick="return D2.setFocusComment(57265832)" >KKK</a>
2046 <span id="comment_score_57265832" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265832); return false"><span class=opt>Score:</span>2</a>)</span></h4>
2048 <div class="details">
2049 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~Tsolias">Tsolias</a> <span class="uid"><a href="//slashdot.org/~Tsolias">( 2813011 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2050 <span class="otherdetails" id="comment_otherdetails_57265832"></span>
2053 <div class="commentBody">
2054 <div id="comment_body_57265832"><p><div class="quote"><p>Thats what you get on hiring those bootcamp "graduates"</p></div><p>Kode w/ Karlie Kloss, like it or not.</p></div>
2057 <div class="commentSub" id="comment_sub_57265832">
2062 <div id="replyto_57265832"></div>
2064 <ul id="group_57265832">
2065 <li id="hiddens_57265832" class="hide"></li>
2068 </li></ul></li><li id="tree_57265838" class="comment hidden"><span class="ind"></span>
2069 <div id="comment_status_57265838" class="commentstatus"></div>
2070 <div id="comment_57265838" class="cw">
2073 <div id="replyto_57265838"></div>
2075 <ul id="group_57265838">
2076 <li id="hiddens_57265838" class="hide"></li>
2079 </li><li id="tree_57265968" class="comment oneline"><span class="ind"></span>
2080 <div id="comment_status_57265968" class="commentstatus"></div>
2081 <div id="comment_57265968" class="cw">
2082 <div id="comment_top_57265968" class="commentTop newcomment">
2084 <h4><a id="comment_link_57265968" name="comment_link_57265968" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57265968" onclick="return D2.setFocusComment(57265968)" >Alternate headline: 99.8% websites are OK</a>
2087 <span id="comment_score_57265968" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57265968); return false"><span class=opt>Score:</span>2</a>)</span></h4>
2089 <div class="details">
2090 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~jmichaelg">jmichaelg</a> <span class="uid"><a href="//slashdot.org/~jmichaelg">( 148257 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2091 <span class="otherdetails" id="comment_otherdetails_57265968"></span>
2094 <div class="commentBody">
2095 <div id="comment_body_57265968"><p>230 million websites. 400k poorly configured. 4*10^5/2.3*10^8 is less than 0.2% of websites surveyed screwed this up.</p><p>400k is a big number but it's good to know most developers aren't that stupid on this issue.</p></div>
2098 <div class="commentSub" id="comment_sub_57265968">
2103 <div id="replyto_57265968"></div>
2105 <ul id="group_57265968">
2106 <li id="hiddens_57265968" class="hide"></li>
2109 <ul id="commtree_57265968"><li id="tree_57266046" class="comment hidden"><span class="ind"></span>
2110 <div id="comment_status_57266046" class="commentstatus"></div>
2111 <div id="comment_57266046" class="cw">
2114 <div id="replyto_57266046"></div>
2116 <ul id="group_57266046">
2117 <li id="hiddens_57266046" class="hide"></li>
2120 </li><li id="hidestring_57265968"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=57265968">1 reply</a> beneath your current threshold.</b></noscript></li></ul></li><li id="tree_57266024" class="comment hidden"><span class="ind"></span>
2121 <div id="comment_status_57266024" class="commentstatus"></div>
2122 <div id="comment_57266024" class="cw">
2125 <div id="replyto_57266024"></div>
2127 <ul id="group_57266024">
2128 <li id="hiddens_57266024" class="hide"></li>
2131 <ul id="commtree_57266024"><li id="tree_57266638" class="comment oneline"><span class="ind"></span>
2132 <div id="comment_status_57266638" class="commentstatus"></div>
2133 <div id="comment_57266638" class="cw">
2134 <div id="comment_top_57266638" class="commentTop newcomment">
2136 <h4><a id="comment_link_57266638" name="comment_link_57266638" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57266638" onclick="return D2.setFocusComment(57266638)" >Re: yarn dist</a>
2139 <span id="comment_score_57266638" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57266638); return false"><span class=opt>Score:</span>2</a>)</span></h4>
2141 <div class="details">
2142 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~TimMD909">TimMD909</a> <span class="uid"><a href="//slashdot.org/~TimMD909">( 260285 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2143 <span class="otherdetails" id="comment_otherdetails_57266638"></span>
2146 <div class="commentBody">
2147 <div id="comment_body_57266638">... Equifax types for free security tests from 3rd parties and press coverage, presumably...</div>
2150 <div class="commentSub" id="comment_sub_57266638">
2155 <div id="replyto_57266638"></div>
2157 <ul id="group_57266638">
2158 <li id="hiddens_57266638" class="hide"></li>
2161 </li></ul></li><li id="tree_57266028" class="comment oneline"><span class="ind"></span>
2162 <div id="comment_status_57266028" class="commentstatus"></div>
2163 <div id="comment_57266028" class="cw">
2164 <div id="comment_top_57266028" class="commentTop newcomment">
2166 <h4><a id="comment_link_57266028" name="comment_link_57266028" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57266028" onclick="return D2.setFocusComment(57266028)" >So?</a>
2169 <span id="comment_score_57266028" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57266028); return false"><span class=opt>Score:</span>2</a>)</span></h4>
2171 <div class="details">
2172 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~cshark">cshark</a> <span class="uid"><a href="//slashdot.org/~cshark">( 673578 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2173 <span class="otherdetails" id="comment_otherdetails_57266028"></span>
2176 <div class="commentBody">
2177 <div id="comment_body_57266028"><p>An open git directory will be everything you need to reconstruct the site, more often than not from the same server you're targeting. Scary. Database servers are rarely open. Short of some serious hacking, there isn't a lot you're going to be able to do with this stuff once you've obtained the information you're waving around here.</p><p>Until such time as I see hackers actually logging in with this information and defacing github, I'm going to remain unconvinced of the severity of this one.</p></div>
2180 <div class="commentSub" id="comment_sub_57266028">
2185 <div id="replyto_57266028"></div>
2187 <ul id="group_57266028">
2188 <li id="hiddens_57266028" class="hide"></li>
2191 <ul id="commtree_57266028"><li id="tree_57266128" class="comment oneline"><span class="ind"></span>
2192 <div id="comment_status_57266128" class="commentstatus"></div>
2193 <div id="comment_57266128" class="cw">
2194 <div id="comment_top_57266128" class="commentTop newcomment">
2196 <h4><a id="comment_link_57266128" name="comment_link_57266128" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57266128" onclick="return D2.setFocusComment(57266128)" >Re:</a>
2199 <span id="comment_score_57266128" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57266128); return false"><span class=opt>Score:</span>2</a>)</span></h4>
2201 <div class="details">
2202 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~OrangeTide">OrangeTide</a> <span class="uid"><a href="//slashdot.org/~OrangeTide">( 124937 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2203 <span class="otherdetails" id="comment_otherdetails_57266128"></span>
2206 <div class="commentBody">
2207 <div id="comment_body_57266128"><p>My website's<nobr> <wbr></nobr>.git directories are open intentionally. Makes for convenient mirroring and viewing of archives without having to hope and pray wayback machine picked up my obscure website.</p><p>I'm not too worried. It's just data on the filesystem, it's not executing programs. And the data is not supposed to contain any secrets. If it ever does then I better rewrite my git history.</p></div>
2210 <div class="commentSub" id="comment_sub_57266128">
2215 <div id="replyto_57266128"></div>
2217 <ul id="group_57266128">
2218 <li id="hiddens_57266128" class="hide"></li>
2221 <ul id="commtree_57266128"><li id="tree_57267568" class="comment hidden"><span class="ind"></span>
2222 <div id="comment_status_57267568" class="commentstatus"></div>
2223 <div id="comment_57267568" class="cw">
2226 <div id="replyto_57267568"></div>
2228 <ul id="group_57267568">
2229 <li id="hiddens_57267568" class="hide"></li>
2232 </li><li id="hidestring_57266128"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=57266128">1 reply</a> beneath your current threshold.</b></noscript></li></ul></li><li id="tree_57266554" class="comment oneline"><span class="ind"></span>
2233 <div id="comment_status_57266554" class="commentstatus"></div>
2234 <div id="comment_57266554" class="cw">
2235 <div id="comment_top_57266554" class="commentTop newcomment">
2237 <h4><a id="comment_link_57266554" name="comment_link_57266554" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57266554" onclick="return D2.setFocusComment(57266554)" >Re:</a>
2240 <span id="comment_score_57266554" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57266554); return false"><span class=opt>Score:</span>1</a>)</span></h4>
2242 <div class="details">
2243 <span class="by"><span class="byby">by </span>Anonymous Coward</span><span class="writes" style="display:none"> writes:</span>
2244 <span class="otherdetails" id="comment_otherdetails_57266554"></span>
2247 <div class="commentBody">
2248 <div id="comment_body_57266554"><p>The most likely actual security implication is hard coded keys to 3rd party APIs.</p><p>Not that this is an inevitable threat, itâ(TM)s just something I could see being inadvertently exposed and useful without much additional effort.</p></div>
2251 <div class="commentSub" id="comment_sub_57266554">
2256 <div id="replyto_57266554"></div>
2258 <ul id="group_57266554">
2259 <li id="hiddens_57266554" class="hide"></li>
2262 <ul id="commtree_57266554"><li id="tree_57266652" class="comment oneline"><span class="ind"></span>
2263 <div id="comment_status_57266652" class="commentstatus"></div>
2264 <div id="comment_57266652" class="cw">
2265 <div id="comment_top_57266652" class="commentTop newcomment">
2267 <h4><a id="comment_link_57266652" name="comment_link_57266652" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57266652" onclick="return D2.setFocusComment(57266652)" >Re:</a>
2270 <span id="comment_score_57266652" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57266652); return false"><span class=opt>Score:</span>1</a>)</span></h4>
2272 <div class="details">
2273 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~Orrin+Bloquy">Orrin Bloquy</a> <span class="uid"><a href="//slashdot.org/~Orrin+Bloquy">( 898571 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2274 <span class="otherdetails" id="comment_otherdetails_57266652"></span>
2277 <div class="commentBody">
2278 <div id="comment_body_57266652"><p><div class="quote"><p>itâ(TM)s</p></div><p>Clear something up, are you typing curly quotes/apostrophes on purpose or do you have your browser configured to automatically do that.</p></div>
2281 <div class="commentSub" id="comment_sub_57266652">
2286 <div id="replyto_57266652"></div>
2288 <ul id="group_57266652">
2289 <li id="hiddens_57266652" class="hide"></li>
2292 </li></ul></li><li id="tree_57266650" class="comment oneline"><span class="ind"></span>
2293 <div id="comment_status_57266650" class="commentstatus"></div>
2294 <div id="comment_57266650" class="cw">
2295 <div id="comment_top_57266650" class="commentTop newcomment">
2297 <h4><a id="comment_link_57266650" name="comment_link_57266650" href="//tech.slashdot.org/comments.pl?sid=12580412&cid=57266650" onclick="return D2.setFocusComment(57266650)" >Re:</a>
2300 <span id="comment_score_57266650" class="score"> (<a href="#" onclick="getModalPrefs('modcommentlog', 'Moderation Comment Log', 57266650); return false"><span class=opt>Score:</span>2</a>)</span></h4>
2302 <div class="details">
2303 <span class="by"><span class="byby">by </span><a href="//slashdot.org/~jonwil">jonwil</a> <span class="uid"><a href="//slashdot.org/~jonwil">( 467024 )</a></span></a></span><span class="writes" style="display:none"> writes:</span>
2304 <span class="otherdetails" id="comment_otherdetails_57266650"></span>
2307 <div class="commentBody">
2308 <div id="comment_body_57266650"><p>What about if that<nobr> <wbr></nobr>.git folder (and the website's source code) included private keys for stuff. Or credentials/API keys for 3rd party services. Or credentials for database and other servers.</p></div>
2311 <div class="commentSub" id="comment_sub_57266650">
2316 <div id="replyto_57266650"></div>
2318 <ul id="group_57266650">
2319 <li id="hiddens_57266650" class="hide"></li>
2322 </li></ul></li><li id="tree_57266180" class="comment hidden"><span class="ind"></span>
2323 <div id="comment_status_57266180" class="commentstatus"></div>
2324 <div id="comment_57266180" class="cw">
2327 <div id="replyto_57266180"></div>
2329 <ul id="group_57266180">
2330 <li id="hiddens_57266180" class="hide"></li>
2333 </li><li id="tree_57266440" class="comment hidden"><span class="ind"></span>
2334 <div id="comment_status_57266440" class="commentstatus"></div>
2335 <div id="comment_57266440" class="cw">
2338 <div id="replyto_57266440"></div>
2340 <ul id="group_57266440">
2341 <li id="hiddens_57266440" class="hide"></li>
2344 </li><li id="tree_57266750" class="comment hidden"><span class="ind"></span>
2345 <div id="comment_status_57266750" class="commentstatus"></div>
2346 <div id="comment_57266750" class="cw">
2349 <div id="replyto_57266750"></div>
2351 <ul id="group_57266750">
2352 <li id="hiddens_57266750" class="hide"></li>
2355 </li><li id="hidestring_0"><noscript><b class='more'><span class="ind"></span><a href="//tech.slashdot.org/comments.pl?sid=12580412&threshold=-1&commentsort=0&mode=thread&pid=0">10 replies</a> beneath your current threshold.</b></noscript></li>
2356 <li id="roothiddens" class="hide"></li>
2363 <noscript><p><b>There may be more comments in this discussion. Without JavaScript enabled, you might want to <a href="//tech.slashdot.org/users.pl?op=editcomm">turn on Classic Discussion System</a> in your preferences instead.</b></p></noscript>
2364 <div id="discussion_buttons" class="clearfix">
2374 <div class="newcmnt"><div id="replyto_0"></div></div>
2377 <script type="text/javascript">
2379 D2.currents()['hidden'] = 16;
2380 D2.currents()['full'] = 3;
2381 D2.currents()['oneline'] = 13;
2382 // D2.currents_total(32);
2384 D2.abbrev_comments({});
2385 D2.noshow_comments([57265676,57265706,57265724,57265824,57265748,57265854,57265760,57265776,57265826,57265838,57266046,57266024,57267568,57266180,57266440,57266750]);
2386 D2.pieces_comments([57265702,57267314,57267598,57265754,57267330,57265832,57265968,57266638,57266028,57266128,57266554,57266652,57266650]);
2387 D2.init_hiddens([57265724,57265706,57265676,57265754,57265968,57266128,0]);
2392 if (D2.thresh_totals()[6][6][1] == 0) {
2407 <div id="clickgen" class="grid_24 b">
2408 <section class="grid_16 f">
2411 <a href="" class="selected btmrel" onClick="getRelatedStoriesForStory(345540);return false">Related Links</a>
2412 <span class="tops fright">Top of the: <a href="" class="btmday" onClick="getTopStories(1);return false">day</a>, <a class="btmweek" href="" onClick="getTopStories(7); return false">week</a>, <a href="" onClick="getTopStories(30);return false" class="btmmonth">month</a>.</span>
2414 <ul class="nobullets bmrelatedlist">
2419 <span class="cmntcnt"><span class="slant"></span><span>1175<span class="hide"> comments</span></span></span><a href="//tech.slashdot.org/story/18/01/08/1954203/james-damore-sues-google-for-allegedly-discriminating-against-conservative-white-men?sdsrc=popbyskidbtmprev">James Damore Sues Google For Allegedly Discriminating Against Conservative White Men</a>
2424 <span class="cmntcnt"><span class="slant"></span><span>953<span class="hide"> comments</span></span></span><a href="//tech.slashdot.org/story/18/03/19/1736231/self-driving-uber-car-kills-arizona-woman-in-first-fatal-crash-involving-pedestrian?sdsrc=popbyskidbtmprev">Self-Driving Uber Car Kills Arizona Woman in First Fatal Crash Involving Pedestrian</a>
2429 <span class="cmntcnt"><span class="slant"></span><span>707<span class="hide"> comments</span></span></span><a href="//tech.slashdot.org/story/17/11/16/0050243/twitter-bans-removes-verified-status-of-white-supremacists?sdsrc=popbyskidbtmprev">Twitter Bans, Removes Verified Status of White Supremacists</a>
2434 <span class="cmntcnt"><span class="slant"></span><span>705<span class="hide"> comments</span></span></span><a href="//tech.slashdot.org/story/18/02/15/2255242/pro-gun-russian-bots-flood-twitter-after-parkland-shooting?sdsrc=popbyskidbtmprev">Pro-Gun Russian Bots Flood Twitter After Parkland Shooting</a>
2439 <span class="cmntcnt"><span class="slant"></span><span>682<span class="hide"> comments</span></span></span><a href="//tech.slashdot.org/story/17/11/19/043243/i-see-things-differently-james-damore-on-his-autism-and-the-google-memo?sdsrc=popbyskidbtmprev">'I See Things Differently': James Damore on his Autism and the Google Memo</a>
2446 <aside class="grid_8 st">
2447 <section class="grid_24 f">
2449 <h5 class="tlnav"><a href="//tech.slashdot.org/story/18/09/06/205221/ive-seen-the-future-of-consumer-ai-and-it-doesnt-have-one?sdsrc=nextbtmnext">next</a></h5>
2450 <div class="grid_24">
2453 <span class="grid_7 tcenter"><img src="//a.fsdn.com/sd/topics/ai_64.png" width="64" height="64" alt="AI"></span>
2455 <p class="grid_12"><a href="//tech.slashdot.org/story/18/09/06/205221/ive-seen-the-future-of-consumer-ai-and-it-doesnt-have-one?sdsrc=nextbtmprev">'I've Seen the Future of Consumer AI, and it Doesn't Have One'</a></p>
2456 <span class="grid_5 tcenter comments"><span class="cmntcnt_large fleft"><span class="slant"></span><span>97<span class="hide"> comments</span></span></span></span>
2461 <section class="grid_24">
2463 <h5 class="tlnav"><a href="//games.slashdot.org/story/18/09/06/1921222/eve-online-studio-acquired-by-korean-mmo-maker?sdsrc=prevbtmprev">previous</a></h5>
2464 <div class="grid_24">
2466 <span class="grid_7 tcenter"><img src="//a.fsdn.com/sd/topics/business_64.png" width="64" height="64" alt="Businesses"></span>
2468 <p class="grid_12"><a href="//games.slashdot.org/story/18/09/06/1921222/eve-online-studio-acquired-by-korean-mmo-maker?sdsrc=prevbtmprev">'Eve Online' Studio Acquired By Korean MMO Maker</a></p>
2470 <span class="grid_5 tcenter comments"><span class="cmntcnt_large fleft"><span class="slant"></span><span>57<span class="hide"> comments</span></span></span></span>
2476 <div id="taboola-below-article-text-links"></div>
2477 <script type="text/javascript">
2478 window._taboola = window._taboola || [];
2480 mode: 'text-links-a',
2481 container: 'taboola-below-article-text-links',
2482 placement: 'Below Article Text Links',
2491 <div class="row top-space">
2494 <div class="grid_24">
2497 <div class="adwrap">
2498 <div id='div-gpt-ad-728x90_c'><script type='text/javascript'>
2499 googletag.cmd.push(function(){
2500 googletag.display('div-gpt-ad-728x90_c');});</script></div>
2502 <!-- end 728px ad -->
2503 <!-- Slashdot Deals 6 Best Sellers -->
2504 <div class="row deals-footer">
2505 <div class="units-8 indent-2 deals-wrapper">
2506 <div class="deals-header"><h1>Slashdot Top Deals</h1></div>
2507 <div id="deals-output">
2508 <script id="deals-template" type="text/x-handlebars-template">
2511 <a href="{{urlPath permalink}}?&utm_source=slashdot.org&utm_medium=dealfeed-footerfeed&utm_campaign={{slug}}" target="_blank">
2512 <img src="{{main_image}}" alt="" />
2514 <p class="title"><a href="{{urlPath permalink}}?&utm_source=slashdot.org&utm_medium=dealfeed-footerfeed&utm_campaign={{slug}}" target="_blank">{{title}}</a></p>
2515 <p class="deal-price">{{centConversion price_in_cents}}</p>
2523 if ( isAdBlockActive ) {
2524 $.getScript( "//a.fsdn.com/sd/js/scripts/min/deals-min.js", function(){
2530 <!-- End Slashdot Deals 6 Best Sellers -->
2535 <!-- SMACKS: END COMMENTS SECTION -->
2537 <!-- SMACKS: END COMMENTS CONTAINER -->
2542 <script type="text/javascript">
2545 $('#firehose-filter').
2546 focus(function(event){
2547 gFocusedText = this;
2549 blur(function(event){
2550 if ( gFocusedText === this ) {
2551 gFocusedText = null;
2556 apply_updates_when( 'at-end', true);
2561 <!-- body end --><!-- footer type=current begin -->
2568 <footer id="fhft" class="grid_24 nf aoc">
2569 <div id="logo_nf" class="fleft">
2570 <a href="//slashdot.org"><span>Slashdot</span></a>
2572 <nav role="firehose footer">
2580 <span class="ind"></span><a class="btn first" href="//tech.slashdot.org/comments.pl?sid=12580412&op=reply&threshold=1&commentsort=0&mode=thread&pid=" onclick="D2.replyTo(0); return false;">Post</a>
2582 <a class="btn hide" id="footer_moderate_button">Moderate</a>
2583 <a class="btn hide" id="footer_moderatorhelp_button">Moderator Help</a>
2584 <a class="btn hide" id="footer_delete_button" title="Checked comments will be deleted.">Delete</a>
2587 var old_moderate_btn = $("#discussion_moderate_button");
2588 if (old_moderate_btn.length) {
2589 var moderate_btn = $("#footer_moderate_button");
2591 function(){old_moderate_btn.click()}
2593 moderate_btn.removeClass('hide');
2596 var old_moderatorhelp_btn = $("#discussion_moderatorhelp_button");
2597 if (old_moderatorhelp_btn.length) {
2598 var moderatorhelp_btn = $("#footer_moderatorhelp_button");
2599 moderatorhelp_btn.click(
2600 function(){old_moderatorhelp_btn.click()}
2602 moderatorhelp_btn.attr(
2603 'href', old_moderatorhelp_btn.attr('href')
2605 moderatorhelp_btn.removeClass('hide');
2608 var old_delete_btn = $("#discussion_delete_button");
2609 if (old_delete_btn.length) {
2610 var delete_btn = $("#footer_delete_button");
2612 function(){old_delete_btn.click()}
2614 delete_btn.removeClass('hide');
2617 $('#discussion_buttons').addClass('hide');
2618 })(Slash.jQuery); // (function($){
2622 <li class="fleft selected">
2623 <span class="nbutton btn hide link reset" id="more_comments_button">
2624 <a href="#" onclick="D2.ajaxFetchComments(0,1); return false">
2625 <span id="more_comments_num_a" class="hide">Get more comments</span>
2632 <span class="loadedcommentcnt">32</span> of <span class="totalcommentcnt">32</span> loaded
2637 <script type="text/javascript">D2.finishLoading()</script>
2642 <ul class="fright submitstory">
2644 <a href="/submit">Submit<span class="opt"> Story</span></a>
2652 <section class="bq">
2653 <blockquote class="msg grid_24" cite="https://slashdot.org">
2654 <p>The hardest part of climbing the ladder of success is getting through
2655 the crowd at the bottom.</p>
2656 <span class="slant"></span>
2659 <footer id="ft" class="grid_24">
2660 <nav class="grid_10" role="footer">
2662 <li><a href="//slashdot.org/faq">FAQ</a></li>
2663 <li><a href="//slashdot.org/archive.pl">Story Archive</a></li>
2664 <li><a href="//slashdot.org/hof.shtml">Hall of Fame</a></li>
2665 <li><a href="http://slashdotmedia.com/advertising-and-marketing-services/">Advertising</a></li>
2666 <li><a href="http://slashdotmedia.com/terms-of-use/">Terms</a></li>
2667 <li><a href="http://slashdotmedia.com/privacy-statement/">Privacy Statement</a></li>
2668 <li id='eu_privacy' style='display:none'><a href="#" title="Privacy Choices" onclick="bizx.cmp.promptConsent();return false;">Privacy Choices</a></li>
2669 <li><a href="http://slashdotmedia.com/opt-out-choices/">Opt-out Choices</a></li>
2670 <li><a href="//slashdot.org/faq/slashmeta.shtml">About</a></li>
2671 <li><a href="mailto:feedback@slashdot.org">Feedback</a></li>
2672 <li><a href="#" onclick="set_mobile_pref('mobile',1);return false;">Mobile View</a></li>
2673 <li><a href="//slashdot.org/blog">Blog</a></li>
2677 if (window.is_euro_union) {
2678 document.getElementById('eu_privacy').style.display = 'inline';
2683 <div class="grid_14 tright tm">Trademarks property of their respective owners. Comments owned by the poster. <span class="nobr">Copyright © 2018 SlashdotMedia. All Rights Reserved.</span></div>
2687 <div class="overlay"></div>
2688 <div class="modal-box">
2689 <a href="#" id="close-modal">Close</a>
2690 <article class="modal-content">
2698 <div id="modal_cover" class="hide" onclick="hide_modal_box(); return false;"></div>
2699 <div id="modal_box" class="hide">
2700 <div id="modal_box_content"></div>
2702 <span class="fadeout"></span>
2703 <span class="fadeoutfade"></span>
2704 <span class="pf"><a class="ico close" onclick="hide_modal_box(); return false;" href="#"><span>Close</span></a></span>
2705 <h3 class="pf"><div id="logo"><a href="//slashdot.org">Slashdot</a></div><span id="preference_title"></span></h3>
2710 <script type="text/javascript">
2711 if (!window.is_euro_union) {
2713 /*global _ml:true, window */
2714 _ml = window._ml || {};
2717 var s = document.getElementsByTagName('script')[0], cd = new Date(), mltag = document.createElement('script');
2718 mltag.type = 'text/javascript'; mltag.async = true;
2719 mltag.src = '//ml314.com/tag.aspx?' + cd.getDate() + cd.getMonth() + cd.getFullYear();
2720 s.parentNode.insertBefore(mltag, s);
2724 <!-- End CCM Tag -->
2726 <script type="text/javascript">
2727 window.google_analytics_uacct = "UA-32013-5";
2729 var _gaq = _gaq || [];
2735 _gaq.push(['_setAccount', 'UA-36136016-1']);
2736 _gaq.push(['b._setAccount', 'UA-32013-5']);
2737 _gaq.push(['_setDomainName', '.slashdot.org']);
2738 _gaq.push(['b._setDomainName', '.slashdot.org']);
2741 _gaq.push(['_addIgnoredRef', 'slashdot.org']);
2742 _gaq.push(['b._addIgnoredRef', 'slashdot.org']);
2746 _gaq.push(['_setCustomVar', 1, 'User Type', 'Anon', 3]);
2747 _gaq.push(['b._setCustomVar', 1, 'User Type', 'Anon', 3]);
2749 _gaq.push(['_setCustomVar', 2, 'Page','article2', 3]);
2750 _gaq.push(['b._setCustomVar', 2, 'Page','article2', 3]);
2756 // track beta behavior for user
2757 var betamatches = document.cookie.match(/betagroup=(-?\d+)/);
2759 if(betamatches && betamatches[1]) {
2760 if(betamatches[1] == -1) {
2761 _gaq.push(['_setCustomVar', 3, 'Beta-Usage','opt-out', 3]);
2763 _gaq.push(['_setCustomVar', 3, 'Beta-Usage','unredirected', 3]);
2769 _gaq.push(['_trackPageview']);
2770 _gaq.push(['b._trackPageview']);
2771 _gaq.push(['_trackPageLoadTime']);
2772 _gaq.push(['b._trackPageLoadTime']);
2775 if (!window.is_euro_union) {
2777 var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
2778 ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
2779 var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
2784 <!-- CCM GA Push -->
2786 if (typeof _ml !== 'undefined' && _ml.us) {
2787 if (_ml.us.tp && _ml.us.tp.length > 0) {
2788 ga('set', 'dimension2', _ml.us.tp[0]);
2790 if (_ml.us.pc && _ml.us.pc.length > 0) {
2791 ga('set', 'dimension7', _ml.us.pc[0]);
2793 ga('set', 'dimension3', _ml.us.ind);
2794 ga('set', 'dimension4', _ml.us.cr);
2795 ga('set', 'dimension5', _ml.us.cs);
2796 ga('set', 'dimension6', _ml.us.dm);
2797 ga('set', 'dimension8', _ml.us.sn);
2802 <script type="text/javascript">
2803 var topBannerViewed = false;
2804 if($('#div-gpt-ad-728x90_a').length > 0 && window.outerWidth >= 1070 && !isAdBlockActive){
2805 $(window).scroll(function(){
2806 var y = $(document).scrollTop();
2807 var z = y + window.outerHeight;
2810 $('.nav-wrap').outerHeight(true),
2811 $('.nav-secondary-wrap').outerHeight(true)
2814 if(offset[row]) navOffset = navOffset + parseInt(offset[row]);
2816 $('.adwrap-unviewed').each(function(){
2817 var cls = 'adwrap-sticky';
2818 var toggleCls = 'adwrap';
2819 //$('.banner-wrapper').css('height', $('.banner-contain').outerHeight());
2820 if($(this).hasClass('railad')) {
2821 if(topBannerViewed){
2822 var topPixels = $(this).offset().top;
2823 navOffset += $('.adwrap').outerHeight();
2824 if(y >= topPixels && y >= navOffset){
2825 $('#slashboxes').css('top', 0).css('position','fixed').css('right',13);
2827 $('#slashboxes').removeAttr('style');
2832 var topPixels = $(this).offset().top;
2833 if(y >= topPixels && y >= navOffset){
2834 $(this).addClass(cls);
2835 $(this).removeClass('adwrap');
2836 if(cls == 'adwrap-sticky') { //top banner
2837 topBannerViewed = false;
2838 $('#slashboxes').css('top',$(this).outerHeight() || 0).css('position','fixed').css('right',13);
2840 if(topBannerViewed) {
2841 console.log('hereeee');
2842 $('#slashboxes').css('top', 0).css('position','fixed').css('right',13);
2845 $(this).removeClass(cls);
2846 $(this).addClass(toggleCls);
2847 $('#slashboxes').removeAttr('style');
2850 if($('.adwrap-viewed-banner').length > 0){
2851 topBannerViewed = true;
2852 $('.adwrap-viewed-banner').removeClass('adwrap-unviewed').removeClass('adwrap-sticky').addClass('adwrap');
2854 if($('.adwrap-viewed-railad').length > 0){
2855 $('.adwrap-viewed-railad').removeClass('adwrap-unviewed').removeClass('adwrap-railad-sticky');
2856 $('#slashboxes').removeAttr('style');
2863 <script type="text/javascript">
2864 var _paq = _paq || [];
2865 _paq.push(["setCookieDomain", "*.slashdot.org"]);
2866 _paq.push(['trackPageView']);
2867 _paq.push(['enableLinkTracking']);
2868 function initPiwikAndNels() {
2870 var u="//analytics.slashdotmedia.com/";
2871 _paq.push(['setTrackerUrl', u+'sd.php']);
2872 _paq.push(['setSiteId', 40]);
2873 var d=document, g=d.createElement('script'), s=d.getElementsByTagName('script')[0];
2874 g.type='text/javascript'; g.async=true; g.defer=true; g.src=u+'sd.js'; s.parentNode.insertBefore(g,s);
2877 if(window.location.pathname == '/'){
2878 var nelId = (location.search.split('nel_id=')[1] || '').split('&')[0];
2879 var url = '/ajax.pl?op=nel';
2881 url += '&nel_id='+nelId;
2885 success: function(html){
2886 $('#firehoselist article').eq(1).after(html);
2891 if(document.getElementById('announcementText')){
2892 $('#announcementText').hide();
2893 var hlUrl = '/ajax.pl?op=hl_nel';
2895 hlUrl += '&nel_id='+nelId;
2899 success: function(html){
2900 if(html.length < 10){
2901 $('#announcementText').show();
2904 $('#announcementText').html(html).show();
2906 error: function () {
2907 $('#announcementText').show();
2912 bizx.cmp.ifConsent('publisher', ['storage', 'measurement'], initPiwikAndNels);
2916 <script type="text/javascript">
2917 _linkedin_data_partner_id = "113712";
2918 </script><script type="text/javascript">
2919 if (!window.is_euro_union) {
2920 (function(){var s = document.getElementsByTagName("script")[0];
2921 var b = document.createElement("script");
2922 b.type = "text/javascript";b.async = true;
2923 b.src = "https://snap.licdn.com/li.lms-analytics/insight.min.js";
2924 s.parentNode.insertBefore(b, s);})();
2928 <img height="1" width="1" style="display:none;" alt="" src="https://dc.ads.linkedin.com/collect/?pid=113712&fmt=gif" />
2932 <script async type="text/javascript" src="//ads.pro-market.net/ads/scripts/site-143573.js"></script>
2933 <script id="after-content" type="text/javascript">
2934 (function( $, fn, console ){
2935 $ && fn && $(function(){ fn($, console); });
2936 })(window.jQuery, window.pageload_done, window.console);
2939 <script type='text/javascript'>
2940 if(!document.location.href.match(/source=autorefresh/)) {
2941 document.write('<img src="//slashdot.org/images/js.gif?257">');
2945 <img src="//slashdot.org/images/njs.gif?8">
2947 <div class="busy genericspinner hide"><span>Working...</span></div>
2949 if(typeof(Storage)!=="undefined"){
2950 window.scrollTo(0,sessionStorage.scrollPos);
2951 $(window).scroll(function () {
2952 //You've scrolled this much:
2953 sessionStorage.scrollPos = $(window).scrollTop();
2957 $('a').click(function(){
2958 delete sessionStorage.scrollPos;
2961 // window.onbeforeunload = function () {
2962 // console.log('bakc button clicked');
2963 // delete sessionStorage.scrollPos;
2965 window.onpopstate=function() {
2966 delete sessionStorage.scrollPos;
2972 <!-- 1x1 story page -->
2973 <div id='div-gpt-ad-1x1'><script type='text/javascript'>
2974 googletag.cmd.push(function(){
2975 googletag.display('div-gpt-ad-1x1');});</script></div>
2978 <script type="text/javascript">
2979 if (!window.is_euro_union) {
2980 window._taboola = window._taboola || [];
2981 _taboola.push({flush: true});
2989 <!-- footer type=current end -->