\n\n\n',ut=e=>{const t=e?"gray":"white";return``},gt=1e3;const pt=e=>"boolean"==typeof e,mt=e=>Number.isInteger(e),ft=e=>"[object String]"===Object.prototype.toString.call(e),bt=e=>["top","bottom","top-left","top-right","bottom-left","bottom-right"].includes(e);const vt=()=>Math.round((new Date).getTime()/1e3),yt=e=>{const i=new t("user_engagement"),r="utsid-send";let n,c=0,h=!1,g=!1,m={clientHints:{},isScrollable:0,totalClicks:0,sessionLength:0,ippMissclicks:0,visible:0,caught:0,lastevent:0,isFullscreen:0,isTabFocused:0,eventImps:0,retryCounts:0,isScrolled:0,isMouseMoved:0,pagePercentageSeen:0,belowTheFoldSeen:0,touchEnd:0,touchMove:0,clicksByType:{idle:0,input:0,video:0,button:0,link:0,img:0},browsingTopics:[],ufp:P()},f=d(),b=vt();function v(){var t,r;0===m.isFullscreen&&(m.isFullscreen=document.fullscreenElement||document.webkitFullscreenElement||document.mozFullScreenElement?1:0),m.isTabFocused=document.hidden||document.mozHidden||document.webkitHidden?0:1,m.sessionStartTime=b,m.sessionId=f,m.sessionLength=vt()-b,m.timeZoneOffset=(new Date).getTimezoneOffset(),m.zones=[],e&&(m.zones=e.getZoneIds()),m.pUrl=encodeURIComponent(o()),m.pReferrer=encodeURIComponent((()=>{const e=document.referrer;return e?l(e):""})()),m.pTitle=encodeURI(u()),m.pDescription=encodeURIComponent(p("description",i)),m.pKeywords=encodeURIComponent(p("keywords",i)),m.pHasIframes=(()=>{const e=document.getElementsByTagName("iframe");return e.length?e.length:0})(),m.pWidth=Math.ceil(window.scrollWidth||document.body.scrollWidth),m.pHeight=Math.ceil(window.scrollHeight||document.body.scrollHeight),m.vWidth=Math.ceil(window.innerWidth||document.body.clientWidth),m.vHeight=Math.ceil(window.innerHeight||document.body.clientHeight),m.inIframe=a(),sessionStorage.getItem("template")&&(m.ippTemplate=sessionStorage.getItem("template")),m.visible=(t=m.vWidth,r=m.vHeight,a()&&(t<10||r<10)?0:1),m.caught=(()=>{let e=0;if(a())try{window.top.location.href}catch(t){e=1}return e})(),m.isScrollable=((e,t)=>{if(e>t){const i=.05;return e-t>Math.ceil(t*i)?1:0}return 0})(m.pHeight,m.vHeight)}function y(){i.debug("Touch move detected."),m.touchMove++,g=!0}function w(){1!==m.isMouseMoved&&(i.debug("Mouse move tracked"),m.isMouseMoved=1,g=!0)}function T(){i.debug("Touch end detected."),m.touchEnd++,g=!0,A()}function A(){if(i.debug("checkScrolling()"),m.pHeight<=m.vHeight)return m.pagePercentageSeen=100,void(m.belowTheFoldSeen=100);var e=Math.ceil(window.scrollTop||document.body.scrollTop),t=Math.ceil((e+m.vHeight)/m.pHeight*100);t>100&&(t=100),t!=m.pagePercentageSeen&&(i.debug("Scroll event detected."),m.isScrolled=1,g=!0),t>m.pagePercentageSeen&&(i.debug("Page percentage seen updated."),m.pagePercentageSeen=t,g=!0);var r=Math.ceil(e/(m.pHeight-m.vHeight)*100);r>100&&(r=100),r>m.belowTheFoldSeen&&(i.debug("Bellow the fold percentage seen updated."),m.belowTheFoldSeen=r,g=!0)}function k(){m.ippMissclicks++,g=!0}function E(e){i.debug("Click tracked"),m.totalClicks++;var t=e.target,r=null;do{null!==r&&""!==r||(r=C(t)),t=t.parentElement}while(t&&"body"!==t.nodeName.toLowerCase()&&"document"!==t.nodeName.toLowerCase());null===r&&(r="idle"),m.clicksByType[r]++,g=!0}function C(e){var t=null;return-1!==["a","video","button","input","textarea","img","select"].indexOf(e.nodeName.toLowerCase())&&("a"===(t=e.nodeName.toLowerCase())?t="link":"textarea"!==t&&"select"!==t||(t="input")),t}function S(){i.debug("Impression tracked"),m.eventImps++}function x(){i.debug("Retry tracked!"),m.retryCounts++}function I(){var e="//usrpubtrk.com/ut/hb.php?cb="+Math.random();return e+="&v=1",i.debug("Target Url: "+e.toString()),e}function R(e=!1){if(!h){if(h=!0,v(),e&&(m.lastevent=1),i.isDebugEnabled&&i.debug("send payload:",JSON.parse(JSON.stringify(m))),"navigator"in window&&"sendBeacon"in window.navigator&&void 0!==navigator.sendBeacon&&void 0!==Blob){m.sentTimestamp=Date.now();var t=new Blob([JSON.stringify(m)],{type:"text/plain; charset=UTF-8"});navigator.sendBeacon(I(),t)}else{var r="XMLHttpRequest"in window?new XMLHttpRequest:new ActiveXObject("Microsoft.XMLHTTP");r.open("POST",I(),!0),r.setRequestHeader("Content-Type","text/plain;charset=UTF-8");try{m.sentTimestamp=Date.now(),r.send(JSON.stringify(m))}catch(e){}}m.lastevent=0,h=!1}}function N(){i.debug("visibility state is",document.visibilityState),"hidden"===document.visibilityState&&g?(clearInterval(n),R(),g=!1):"visible"===document.visibilityState&&(n=setInterval(O,6e4))}function L(){var e=new CustomEvent(r,{detail:{issued:"UT",data:{utsid:f}}});document.dispatchEvent(e)}function O(){if(m.sessionLength=vt()-b,m.sessionLength>=7200)return i.debug("Session limit reached! Send last payload and tear down"),R(),clearInterval(n),i.debug("detaching behavior listeners"),document.removeEventListener("click",E,!1),document.removeEventListener("mousemove",w,!1),document.removeEventListener("scroll",A,!1),document.removeEventListener("in-page-missclick",k,!1),document.removeEventListener("impression-event",S,!1),document.removeEventListener("impression-retry-event",x,!1),document.removeEventListener("touchend",T,!1),document.removeEventListener("touchmove",y,!1),document.removeEventListener("touchcancel",A,!1),document.removeEventListener("visibilitychange",N),void window.removeEventListener("beforeunload",R);0!==c&&1!==c&&5!==c&&10!==c&&c%30!=0||R(),c++}!async function e(){if("complete"===document.readyState||"interactive"===document.readyState)return m.clientHints=await s(i,true),m.browsingTopics=await async function(){let e=[];if("browsingTopics"in document&&document.featurePolicy.allowsFeature("browsing-topics"))try{e=await document.browsingTopics(),i.debug("document.browsingTopics() return value:",e)}catch(e){i.debug("Error calling document.browsingTopics(): ",e)}return e}(),"ontouchstart"in window||navigator.maxTouchPoints>0||navigator.msMaxTouchPoints>0?(document.addEventListener("touchend",T,!1),document.addEventListener("touchmove",y,!1),document.addEventListener("touchcancel",A,!1)):(document.addEventListener("mousemove",w,!1),document.addEventListener("scroll",A,!1)),document.addEventListener("click",E,!1),document.addEventListener("impression-event",S,!1),document.addEventListener("impression-retry-event",x,!1),document.addEventListener("in-page-missclick",k,!1),v(),A(),0===c&&O(),n=setInterval(O,6e4),window[r]=f,L(),setTimeout(L,2e4),document.addEventListener("visibilitychange",N),void window.addEventListener("beforeunload",()=>{R(!0)});setTimeout(e,100)}()},wt="sandboxedDetector";class Tt{#i;#he;#ue;#ge=!1;#pe=!1;#me=!1;constructor(e,t,i){this.#i=e,this.#he=t,this.#ue=i}isSandboxed(){return this.#pe}load(){if(this.#ge)return void this.#i.debug("already checked");if(this.#ge=!0,this.#i.debug("load sandbox detector"),!a())return void this.#i.debug("not in iframe. exit");this.#i.debug("iframe detected");const e=this.#ue.getState();if(e&&e.expiresAt>Date.now())return this.#i.debug("previous state present. Expires at:",new Date(e.expiresAt)),e.isSandboxed?(this.#i.debug("sandboxed recently! show overlay"),void(this.#pe=!0)):void this.#i.debug("not sandboxed recently. dont check further");this.#i.debug("attach detector listener to events");const t={zoneId:wt,callback:this.#fe.bind(this)};N||this.#he.subscribe("mousedown",t,!0),this.#he.subscribe("click",t,!0)}#fe(e){if(!e.isTrusted)return void this.#i.debug(`${e.type} on ${e.target.tagName}. Detector skipped: event is not trusted`,e);if(this.#he.isShowingPop)return void this.#i.debug("detector skipped: pop being currently shown");this.#he.isShowingPop=!0,this.#i.debug("detector taking action. prevent other pops from showing");let t=null;try{t=window.open("about:blank","_blank")}catch(e){this.#i.error("detector error",e)}t&&t.close(),null===t&&(this.#i.debug("sandbox detected"),this.#pe=!0),this.#ue.setState({expiresAt:Date.now()+36e5,isSandboxed:this.#pe}),N||this.#he.unsubscribe("mousedown",wt,!0),this.#he.unsubscribe("click",wt,!0),setTimeout(()=>{this.#he.isShowingPop=!1},300)}showSandboxWarningOverlay(){this.#me||(this.#me=!0,this.#i.debug("show sandbox warning overlay"),this.#be())}#ve(){const e=document.createElement("div");e.id="sbxwo",Object.assign(e.style,{position:"fixed",top:0,left:0,width:"100%",height:"100%",backgroundColor:"rgba(0, 0, 0, 0.8)",color:"#fff",zIndex:1e4,display:"flex",alignItems:"center",justifyContent:"center",flexDirection:"column",padding:"20px",boxSizing:"border-box",textAlign:"center"});const t=document.createElement("div");t.innerHTML="\n
Ad Functionality Blocked
\n
\n It looks like your page is running in a sandbox that blocks certain functionality.\n This setting is preventing our ads from working properly.\n Please disable the sandbox restrictions or adjust your settings.\n
\n To continue playing please remove Sandbox from iframe tab or add "allow-popups" to Sandbox\n
\n ',e.appendChild(t),document.body.appendChild(e)}}const At="x4G9Tq2Kw6R7v1Dy3P0B5N8Lc9M2zF",kt="ZpQw9XkLmN8c3vR3",Et="adblock-settings",Ct=(()=>{let e=document.currentScript;return e||(e=document.getElementById("aclib")),e||(e=document.getElementById("adcash-lib")),e})();let St=null;class xt{#ye;#we={pop:!1,autoTag:!1,inPagePush:!1,interstitial:!1,videoSlider:!1};#Te;#b;#Ae=new Set;#ke=new Set;#i;#Ee=!1;#Ce=!1;#Se;#f="adexchangeclear.com";#T="70.0";#o=null;#xe="aclib";#Ie;#Re=!1;isShowingPop=!1;#C;#Ne=!1;#Le={};#Oe;constructor(e={}){if(St)return St;St=this;let i="aclib";if(e.classes&&(this.#Le=e.classes,i="aclib_adbl"),this.#i=new t(i),this.#Se=(e=>{const t={mousedown:[],click:[],touchstart:[]},i={mousedown:[],scroll:[],click:[],touchstart:[]},r=i=>{const r=i.currentTarget===window?"win":"doc";e.debug(`${r} mousedown with capture: in`),t.mousedown.forEach(t=>{e.debug(`${r} mousedown with capture: calling observer`),t.callback(i)})},n=t=>{const r=t.currentTarget===window?"win":"doc";e.debug(`${r} mousedown: in`),i.mousedown.forEach(i=>{e.debug(`${r} mousedown: calling observer`),i.callback(t)})},s=i=>{const r=i.currentTarget===window?"win":"doc";e.debug(`${r} click with capture: in`),t.click.forEach(t=>{e.debug(`${r} click with capture: calling observer`),t.callback(i)})},o=t=>{const r=t.currentTarget===window?"win":"doc";e.debug(`${r} click: in`),i.click.forEach(i=>{e.debug(`${r} click: calling observer`),i.callback(t)})},a=e=>{i.scroll.forEach(t=>{t.callback(e)})};return{subscribe:(e,r,n)=>{if(!t[e]||!i[e])throw new Error(`${e} is not observable!`);n?t[e].push(r):i[e].push(r)},unsubscribe:(e,r,n)=>{if(!t[e]||!i[e])throw new Error(`${e} is not observable!`);if(n)for(let i=0;i{window.addEventListener("mousedown",r,!0),window.addEventListener("mousedown",n,!1),window.addEventListener("click",s,!0),window.addEventListener("click",o,!1),document.addEventListener("mousedown",r,!0),document.addEventListener("mousedown",n),document.addEventListener("click",s,!0),document.addEventListener("click",o),window.addEventListener("scroll",a)},detachListeners:()=>{window.removeEventListener("mousedown",r,!0),window.removeEventListener("mousedown",n,!1),window.removeEventListener("click",s,!0),window.removeEventListener("click",o,!1),document.removeEventListener("mousedown",r,!0),document.removeEventListener("mousedown",n),document.removeEventListener("click",s,!0),document.removeEventListener("click",o),window.removeEventListener("scroll",a)}}})(this.#i),this.#Se.attachListeners(),this.getClientHints(),this.#Ie=d(),this.#C=P(),this.#Oe=new Tt(new t("sd"),St,new he("sndbxchckiborjforqp2")),this.#i.debug("init adcash lib. listeners attached. ready to publish"),this.#i.debug("is mobile device:",N),window[At]&&(this.#o=JSON.parse(JSON.stringify(window[At])),this.#ye=this.#o.cdnDomain,delete window[At]),window[kt]&&(this.#o=JSON.parse(((e,t="xR9tB2pL6q7MwVe")=>[...atob(e)].map((e,i)=>String.fromCharCode(e.charCodeAt(0)^t.charCodeAt(i%t.length))).join(""))(window[kt])),this.#ye=this.#o.cdnDomain,delete window[kt]),this.#o||(this.#ye=new URL(Ct.src).host,Ct.hasAttribute(Et)&&(this.#o=JSON.parse(Ct.getAttribute(Et)),Ct.removeAttribute(Et))),this.#o&&this.#i.debug("adblock settings:",this.#o),Ct.getAttribute("data-preview"))return this.#i.debug("preview mode"),void(this.#Ne=!0);this.#De(),this.#Pe(),this.#Ue(),this.#Oe.load()}isSandboxed(){return this.#Oe.isSandboxed()}showSandboxWarningOverlay(){this.#Oe.showSandboxWarningOverlay()}async getClientHints(e){if(void 0===this.#Te){this.#Te=await s(this.#i,!0);let e="";for(const t in this.#Te)e+=`&${t}=${this.#Te[t]}`;this.#b=e}return e?this.#Te:this.#b}getCdnDomain(){return this.#ye}getSesionRandomString(){return this.#Ie}enableAdbMode(){this.#i.debug("enable adb mode"),this.#Re=!0}isAdbMode(){return this.#Re}subscribe(e,t,i){this.#Se.subscribe(e,t,i)}unsubscribe(e,t,i){this.#Se.unsubscribe(e,t,i)}#Ue(){if(document.body){const e=document.createElement("a");e.style.display="none",e.style.visibility="hidden",e.style.position="relative",e.style.left="-1000px",e.style.top="-1000px";let t=this.#f;return this.#o&&(t=this.#o.adserverDomain),e.href=`${location.protocol}//${t}/ad/visit.php?al=1`,void document.body.appendChild(e)}setTimeout(this.#Ue.bind(this),100)}#Pe(){yt(St)}#De(){if(document.head){let e=new Set([this.#ye,this.#f]);return this.#o&&e.add(this.#o.adserverDomain),e=Array.from(e),this.#i.debug("prefetch domains:",e),void e.forEach(e=>{const t=document.createElement("link");t.rel="dns-prefetch",t.href=`//${e}`,document.head.appendChild(t)})}setTimeout(this.#De.bind(this),100)}getZoneIds(){return Array.from(this.#Ae)}runPop(e){const{zoneId:t,delay:i,targetElementsCssSelector:r,triggerOnTargetElementsClick:n,targetCountries:s,triggerOnTargetCountries:o,sub1:a,sub2:l,publisherUrl:d,storeUrl:c,c1:h,c2:u,c3:g,pubHash:p,pubClickId:m,pubValue:f,fallbackOn:b,isAutoTag:v,collectiveZoneId:y,aggressivity:w,recordPageView:T,linkedZoneId:A,abTest:k,tagVersionSuffix:E}=e;if(!t)throw new Error("mandatory zoneId is not provided!");if(!ft(t))throw new Error("zoneId is not a string!");if(void 0!==i&&(!mt(i)||i<0))throw new Error("delay is not an integer or is less than zero");if(void 0!==r){if(!ft(r))throw new Error("targetElementsCssSelector is not a string");if(!(e=>{try{document.createDocumentFragment().querySelector(e)}catch{return!1}return!0})(r))throw new Error("targetElementsCssSelector is not a valid css selector");if(!pt(n))throw new Error("triggerOnTargetElementsClick is not a boolean")}if(void 0!==s){if(!(e=>{if(!Array.isArray(e))return!1;if(0===e.length)return!1;for(let t=0;t{window.PopUnder&&(this.#Ae.add(C.zoneId),new PopUnder(C),clearInterval(e))},100)}else{this.#i.debug("loading suv5 script on page"),this.#Ee=!0;const e=document.createElement("script");e.type="text/javascript",e.src=`${location.protocol}//${this.#ye}/script/suv5.js`,e.onload=()=>{this.#we.pop=!0,this.#Ee=!1,v?this.#Ae.add(y):this.#Ae.add(C.zoneId),new PopUnder(C)},e.onerror=()=>{this.#we.pop=!1,this.#Ee=!1,this.#i.error(`failed loading ${e.src}`)},document.head.appendChild(e)}}runInPagePush(e){if(this.#we.inPagePush)return void this.#i.error("in-page push zone already loaded on page");this.#we.inPagePush=!0;const{zoneId:t,delay:i,maxAds:r,renderPosDesktop:n,renderPosMobile:s,offsetTop:o,sub1:a,isAutoTag:l,collectiveZoneId:d,linkedZoneId:c,aggressivity:h,recordPageView:u,abTest:g,tagVersionSuffix:p}=e;let{refreshRate:m}=e;if(!t)throw new Error("mandatory zoneId is not provided!");if(!ft(t))throw new Error("zoneId is not a string!");if(void 0!==m&&(!mt(m)||m<0))throw new Error("refreshRate is not an integer or is less than zero");if(void 0!==i&&(!mt(i)||i<0))throw new Error("delay is not an integer or is less than zero");if(void 0!==r&&(!mt(r)||r<1))throw new Error("maxAds is not an integer or is less than one");if(void 0!==n&&!bt(n))throw new Error("renderPosDesktop is not valid");if(void 0!==s&&!bt(s))throw new Error("renderPosMobile is not valid");if(void 0!==o&&(!mt(o)||o<0))throw new Error("offsetTop is not an integer or is less than zero");this.#i.debug("loading in-page push on page"),l?this.#Ae.add(d):this.#Ae.add(t),void 0!==m&&m>0&&m<10&&(m<5?m*=60:m=30),this.#i.debug("ipp rr set to",m);const f={zoneId:t,refreshRate:m??60,delay:i??0,maxAds:r??1,renderPosDesktop:n??"top",renderPosMobile:s??"top",offsetTop:o??0,sub1:a,isAutoTag:l,collectiveZoneId:d,linkedZoneId:c,aggressivity:h,recordPageView:u,abTest:g,tagVersionSuffix:p,adserverDomain:this.#f,adblockSettings:this.#o,adcashGlobalName:this.#xe,isLoadedAsPartOfLibrary:!1,uniqueFingerprint:this.#C};if(this.#Le.InPagePush)return f.isLoadedAsPartOfLibrary=!0,void new this.#Le.InPagePush(f);if(window.InPagePush)new window.InPagePush(f);else{const e=document.createElement("script");e.type="text/javascript",e.src=`${window.location.protocol}//${this.#ye}/script/inpagepush.js`,e.setAttribute("nipp","1"),e.onload=()=>{new window.InPagePush(f)},e.onerror=()=>{this.#i.error(`failed loading ${e.src}`)},document.head.appendChild(e)}}runBanner(e){const{zoneId:t,width:i,height:r,renderIn:n,sub1:s,currentScript:o}=e;if(!t)throw new Error("mandatory zoneId is not provided!");if(!ft(t))throw new Error("zoneId is not a string!");if(void 0!==i&&!mt(i))throw new Error("Banner width is not an integer");if(void 0!==r&&!mt(r))throw new Error("Banner height is not an integer");let a;this.#i.debug("loading banner on page",t),n||(document.currentScript&&document.currentScript.parentElement&&(a=document.currentScript.parentElement),o&&(a=o.parentElement));const l={zoneId:t,width:i,height:r,renderIn:n,currentElement:a,sub1:s,adcashGlobalName:this.#xe,uniqueFingerprint:this.#C,adblockSettings:this.#o};if(this.#Le.Banner)new this.#Le.Banner(l);else if(this.#we.banner||this.#Ce){if(window.Banner)return this.#Ae.add(l.zoneId),void new Banner(l);const e=setInterval(()=>{window.Banner&&(this.#Ae.add(l.zoneId),new Banner(l),clearInterval(e))},100)}else{this.#Ce=!0;const e=document.createElement("script");e.type="text/javascript",e.src=`${location.protocol}//${this.#ye}/script/banner.js`,e.onload=()=>{this.#we.banner=!0,this.#Ce=!1,this.#Ae.add(l.zoneId),new Banner(l)},e.onerror=()=>{this.#we.banner=!1,this.#Ce=!1,this.#i.error(`failed loading ${e.src}`)},e.setAttribute("data-adel","ban"),e.setAttribute("a-lib","1"),document.head.appendChild(e)}}runInterstitial(e){if(this.#we.interstitial)return void this.#i.error("interstitial zone already loaded on page");this.#we.interstitial=!0;const{zoneId:t,sub1:i,isAutoTag:r,collectiveZoneId:n,linkedZoneId:s,aggressivity:o,recordPageView:a,abTest:l,tagVersionSuffix:d}=e;if(!t)throw new Error("mandatory zoneId is not provided!");if(!ft(t))throw new Error("zoneId is not a string!");this.#i.debug("loading interstitial on page");const c={zoneId:t,sub1:i,isAutoTag:r,collectiveZoneId:n,linkedZoneId:s,aggressivity:o,recordPageView:a,abTest:l,tagVersionSuffix:d,adcashGlobalName:this.#xe,adserverDomain:this.#f,adblockSettings:this.#o,uniqueFingerprint:this.#C,isLoadedAsPartOfLibrary:!1};if(this.#Ae.add(t),this.#Le.Interstitial)return c.isLoadedAsPartOfLibrary=!0,void new this.#Le.Interstitial(c);if(window.Interstitial)new Interstitial(c);else{const e=document.createElement("script");e.type="text/javascript",e.src=`${location.protocol}//${this.#ye}/script/interstitial.js`,e.setAttribute("a-lib","1"),e.onload=()=>{new Interstitial(c)},e.onerror=()=>{this.#i.error(`failed loading ${e.src}`)},document.head.appendChild(e)}}async#$e(e,t=!0){this.#i.debug("fetch collective zone config");let i=`${window.location.protocol}//${this.#f}/ad/czcf.php`;if(this.isAdbMode()){const e=`/${O("abcdefgh0123456789")}`;i=`${window.location.protocol}//${this.#o.adserverDomain}${e}`}i+=`?cz=${e}`,i+=`&atv=${this.#T}`;const r=await this.getClientHints();let n;r&&(i+=r),this.isAdbMode()&&(i+="&sadbl=2",i+="&fmt=atg",i=D(i)),this.#i.debug("collective zone config url: ",i);try{n=await fetch(i)}catch(i){return this.#i.error(i),this.#o&&t?(this.#i.debug("collective zone config fetch failed: try alt domain and path"),this.enableAdbMode(),this.#$e(e,!1)):null}return 200!==n.status?null:(n=await n.json(),V(n))}async runAutoTag(e){if(this.#we.autoTag)return void this.#i.error("autotag zone already loaded on page");this.#we.autoTag=!0;const t=e.zoneId;if(!t)throw new Error("mandatory zoneId is not provided!");if(!ft(t))throw new Error("zoneId is not a string!");const i=await this.#$e(t);if(!i)return void this.#i.error(`failed to fetch collective zone config! czid: ${t}`);if(this.#i.debug("collective zone config:",i),!i.rotationList){this.#i.debug("running in NORMAL MODE (no rotation)");const r=i.indexedFormats;let n=!0;for(const s in r){switch(s){case"suv4":case"pop":this.runPop({zoneId:r[s].zoneId.toString(),targetElementsCssSelector:r[s]["element-list"],triggerOnTargetElementsClick:"allow"===r[s]["element-action"],targetCountries:r[s]["country-list"],triggerOnTargetCountries:"allow"===r[s]["country-action"],isAutoTag:!0,collectiveZoneId:t,aggressivity:i.aggressivity,abTest:i.ab_test,recordPageView:n,tagVersionSuffix:e.tagVersionSuffix});break;case"interstitial":this.runInterstitial({zoneId:r[s].zoneId.toString(),isAutoTag:!0,collectiveZoneId:t,aggressivity:i.aggressivity,abTest:i.ab_test,recordPageView:n,tagVersionSuffix:e.tagVersionSuffix});break;case"ippg":this.runInPagePush({zoneId:r[s].zoneId.toString(),refreshRate:r[s].rr,delay:r[s].d,maxAds:r[s].mads,renderPosDesktop:r[s]["render-pos-desktop"],renderPosMobile:r[s]["render-pos-mobile"],offsetTop:r[s]["offset-top"],isAutoTag:!0,collectiveZoneId:t,aggressivity:i.aggressivity,abTest:i.ab_test,recordPageView:n,tagVersionSuffix:e.tagVersionSuffix});break;default:this.#i.error(`ad format type not recognised from collective zone config. adformat.type: ${s}; czid: ${t}`)}n=!1}return}this.#i.debug("running in ROTATION MODE (rotation present)");const r={adcashGlobalName:this.#xe,collectiveZoneConfig:i,adserverDomain:this.#f,adblockSettings:this.#o,clientHintsQueryStr:this.#b,tagVersionSuffix:e.tagVersionSuffix,isLoadedAsPartOfLibrary:!1,uniqueFingerprint:this.#C};if(this.#Le.AutoTagRotation)return this.#Ae.add(t),r.isLoadedAsPartOfLibrary=!0,void new this.#Le.AutoTagRotation(r);this.#i.debug("loading autotag rotation script on page");const n=document.createElement("script");n.type="text/javascript",n.src=`${location.protocol}//${this.#ye}/script/atagv2.js`,n.onload=()=>{this.#Ae.add(t),new ue(r)},n.onerror=()=>{this.#i.error(`failed loading ${n.src}`)},document.head.appendChild(n)}runVideoSlider(e){if(this.#we.videoSlider)return void this.#i.error("videoslider zone already loaded on page");this.#we.videoSlider=!0;const{zoneId:t,sub1:i,vastXml:r,linkedZoneId:n}=e;if(!t)throw new Error("mandatory zoneId is not provided!");if(!ft(t))throw new Error("zoneId is not a string!");const s={zoneId:t,sub1:i,adserverDomain:this.#f,adcashGlobalName:this.#xe,uniqueFingerprint:this.#C,isPreviewMode:this.#Ne,vastXml:r,linkedZoneId:n,adblockSettings:this.#o};if(this.#Le.VideoSlider)return s.isLoadedAsPartOfLibrary=!0,void new this.#Le.VideoSlider(s);if(window.VideoSlider)new VideoSlider(s);else{const e=document.createElement("script");e.type="text/javascript",e.src=`${window.location.protocol}//${this.#ye}/script/videoSliderAlt.js`,e.onload=()=>{this.#Ae.add(t),new VideoSlider(s)},e.onerror=()=>{this.#i.error(`failed loading ${e.src}`)},document.head.appendChild(e)}}}const It=new t("aclib_adblock_index");window.Adcash?It.debug("lib already on page. exit"):(It.debug("load lib on page"),((e={})=>{const t={aclib:new xt(e),Adcash:xt,AtcshAltNm:xt};Object.keys(t).forEach(e=>{Object.defineProperty(window,e,{value:t[e]})})})({classes:{AutoTagRotation:ue,PopUnder:class{#s;#y=null;#t={};#L=!1;#Ve=!1;#Me=!1;#Fe=!1;#O;#v=!1;#R=!0;#i;#T="70.0";#D=null;#qe=12;#k=!1;constructor(e){this.#i=new t(`suv5_${e.zoneId}`),this.#s=window[e.adcashGlobalName],e.tagVersionSuffix&&(this.#T+=e.tagVersionSuffix),this.#i.debug("tag version:",this.#T),this.#i.debug("init pop with config:",e),this.#t=e,this.elementTargeting=new me(this.#t.targetElementsCssSelector,this.#t.triggerOnTargetElementsClick,this.#t.zoneId),!N||this.elementTargeting.isPresent()||this.#t.linkedZoneId||(this.#R=!1),this.#i.debug("useCapture:",this.#R),this.overlays=new pe(this.elementTargeting,this.#P.bind(this),this.#ze.bind(this),this.#i,this.#t.zoneId,this.#R),this.#V(),this.localStorage=new he(`suv5_${e.zoneId}_state`);const i=this.localStorage.getState();i&&i.adbExpiresAt>Date.now()&&this.#s.enableAdbMode();const r=Date.now();if(i&&i.renderAfterTimestamp>r){const e=i.renderAfterTimestamp-r;this.#i.debug(`previous state present. bid after ${e/1e3} sec`),setTimeout(this.#Be.bind(this),e)}else this.#Be()}async#S(){const e=await this.#s.getClientHints(!1);let t=`${window.location.protocol}//${this.#t.adserverDomain}/script/suurl5.php`;if(this.#t.adblockSettings&&this.#s.isAdbMode()){const{adserverDomain:e}=this.#t.adblockSettings,i=`/${O("abcdefgh0123456789")}`;t=`${window.location.protocol}//${e}${i}`}if(t+=`?r=${this.#t.zoneId}`,this.#v&&(t+="&rbd=1"),this.#t.targetCountries){const e=this.#t.targetCountries.join(",");this.#t.triggerOnTargetCountries?t+="&allowed_countries="+encodeURIComponent(e):t+="&excluded_countries="+encodeURIComponent(e)}return t=t+e+"&cbur="+Math.random()+"&cbiframe="+a()+"&cbWidth="+c()+"&cbHeight="+h()+"&cbtitle="+encodeURIComponent(u())+"&cbpage="+encodeURIComponent(o())+"&cbref="+encodeURIComponent(g())+"&cbdescription="+encodeURIComponent(p("description"))+"&cbkeywords="+encodeURIComponent(p("keywords"))+"&cbcdn="+encodeURIComponent(this.#s.getCdnDomain())+"&ufp="+encodeURIComponent(this.#t.uniqueFingerprint)+"&ts="+Date.now()+"&srs="+this.#s.getSesionRandomString()+"&atv="+this.#T,this.#t.sub1&&(t+=`&sub1=${encodeURIComponent(this.#t.sub1)}`),this.#t.sub2&&(t+=`&sub2=${encodeURIComponent(this.#t.sub2)}`),this.#t.publisherUrl&&(t+=`&pu=${encodeURIComponent(this.#t.publisherUrl)}`),this.#t.storeUrl&&(t+=`&storeurl=${encodeURIComponent(this.#t.storeUrl)}`),this.#t.c1&&(t+=`&c1=${encodeURIComponent(this.#t.c1)}`),this.#t.c2&&(t+=`&c2=${encodeURIComponent(this.#t.c2)}`),this.#t.c3&&(t+=`&c3=${encodeURIComponent(this.#t.c3)}`),this.#t.pubHash&&(t+=`&pub_hash=${encodeURIComponent(this.#t.pubHash)}`),this.#t.pubClickId&&(t+=`&pub_clickid=${encodeURIComponent(this.#t.pubClickId)}`),this.#t.pubValue&&(t+=`&pub_value=${encodeURIComponent(this.#t.pubValue)}`),this.#t.fallbackOn&&(t+=`&fallbackon=${encodeURIComponent(this.#t.fallbackOn)}`),this.#t.adblockSettings&&(t+="&abtg=1"),this.#t.isAutoTag&&(t+="&atag=1"),this.#t.aggressivity&&(t+=`&aggr=${this.#t.aggressivity}`),this.#t.collectiveZoneId&&(t+=`&czid=${this.#t.collectiveZoneId}`),this.#t.recordPageView&&(t+="&ppv=1"),this.#t.linkedZoneId&&(t+=`&pblcz=${this.#t.linkedZoneId}`),this.#t.abTest&&(t+=`&ab_test=${this.#t.abTest}`),this.#t.adblockSettings&&this.#t.adblockSettings.adbVersion&&(t+=`&adbv=${this.#t.adblockSettings.adbVersion}`),this.#s.isSandboxed()&&(t+="&sbx=1"),this.#t.adblockSettings&&this.#s.isAdbMode()?(t+="&sadbl=2",t+="&fmt=suv5",this.#i.debug(`bid url: ${t}`),D(t)):(this.#i.debug(`bid url: ${t}`),t)}#$(e){try{let t=this.#D?this.#D(""):window.open("");return t.document.open(),t.document.writeln('
23 OCT 2025 - We are back! If you have been following us over the last few years, you will know that the last 2 months have been rough. We website was practically not loading. Sorry for the mess. We are back though and everything should run smoothly now. New servers. Updated domains. And new owners. We invite you all to start uploading torrents again!
TORRENT DETAILS
Linux Shell Commands For Absolute Beginners Using Ubuntu 20x
TORRENT SUMMARY
Status:
All the torrents in this section have been verified by our verification system
As part of this course, you will learn most of the important Linux commands that can come in handy while working in Linux-based environments.
Here are the high-level details of the Linux Commands that are covered as part of this hands-on course.
You will get started by having an appropriate environment to practice. Windows users can set up Ubuntu 20.04 using wsl.
Once the environment is ready, you will understand how to get started with basic Linux Commands.
The most commonly used command in Linux is ls. It is used to list the files. We will see different variations of ls by going through all the relevant arguments.
One of the powerful Linux commands and also my favorite is “find“. It helps us to filter the files and directories based on name, type, modified time, etc. You will learn how to use the find command effectively from the perspective of finding the files based on the criteria.
As we understand how to get details related to files and folders in Linux, we will go through the details related to previewing the data in files using important Linux commands such as cat, tail, more, etc. Also, we will review Linux commands such as cut, sort, uniq to process the data. All these commands are typically used against text files.
After going through details related to ls, find commands as well as commands related to processing data in files, we will walk you through the details related to file and folder properties in Linux. You will get an overview of commands such as useradd, userdel, chmod, etc which are typically associated with file permissions.
One of the key aspects related to files and folders is to manage them effectively. We will go through the details about managing files and folders using Linux commands such as cp for copy, mv for move or rename, rm for delete or remove, tar to build uncompressed as well as compressed tar balls. Also, you will get a taste of the awk command to automate some of the common tasks such as reorganizing the files based on patterns.
The core components of a computer are nothing but CPU, Memory, and Storage. In this section or module, you will be learning Linux commands such as lscpu to get CPU details, free to get memory details, and then df and du to get storage details.
At times, we need to make sure the data is in files as well as codebase to troubleshoot the production issues or bugs in QA. In this section, you will learn how to use the Linux command called diff to compare files and folders and review the differences.
Environment Variables are the ones that can impact the sessions logged in by users in Linux. As part of this section, you will be learning details related to Variables, Environment Variables. Also, you will understand how to list all the Environment Variables using Linux commands such env, and how to get a value of a Variable or Environment Variable using the Linux command echo. On top of these things, you will also learn all important aspects related to one of the most important Environment Variables called PATH.
As we gain a decent amount of knowledge related to Linux commands using a single server, it is time for us to explore other important commands such as ssh, scp, pssh, pscp, etc which require more than one Linux System or Server. Also, we need to go through basic networking concepts. To learn commands to interact between the servers as well as to understand basic networking concepts, we will get started with AWS to provision Ubuntu-based virtual machines. These Virtual Machines will be used in the subsequent sections to learn the concepts mentioned earlier as part of this bullet point.
Once we go through the details about getting started with AWS, we will focus on learning all key concepts related to SSH such as sshd daemon, updating ssh config files, and restarting sshd using systemctl or service command. Also, we will go through the details related to passwordless login and also ability to run commands remotely via ssh. We will also understand how to set up parallel ssh and then run commands on multiple Linux systems in parallel.
To be comfortable with learning in a Linux environment, it is very important for one to understand key concepts such as different types of IP Addresses, Port Numbers, relationships between applications and databases with ports, etc. In this section, we will go through all important networking concepts using apache2, MongoDB, etc.
Once we are comfortable with SSH, it is time for us to use tools such as scp which uses ssh under the hood to copy files and folders between the Linux Systems. We will also explore parallel scp to copy files in parallel to multiple target systems from one source system. Also, we will go through the details related to speeding up the copy using different techniques which include submitting multiple scp commands using nohup.
One of the important aspects for any IT Engineer is to troubleshoot the application issues deployed in Linux by reviewing logs generated by applications. After going through scp, you will learn how to troubleshoot issues by using grep and find against log files of the applications deployed on the Linux Server.
To ensure that we can monitor and manage Linux Servers, we not only need to understand how to manage applications and databases in Linux but also need to understand the performance of the applications. For managing applications and databases on a Linux server, one should be familiar with commands such as apt to install applications and systemctl or service to manage the life cycle of applications and databases. To monitor, one should be familiar with commands such as ps, lsof, top, etc. You will learn how to monitor and manage applications as well as databases using examples such as ssh, apache2, mongodb, jupyterlab, etc.
As we learned quite a few commands and tools on Linux, now it is time for us to work on increasing productivity by using appropriate tools, especially for Windows users. You will see the relevance and also how to setup tools such as notepad++, winscp, visual studio code with remote development extension, git tools for Windows, etc.
Organizations will end up having hundreds of servers to support their applications. However, these hundreds of servers need to follow a handful of templates. Using Server Automation tools like Ansible, we should be able to automate the process of configuring a large number of servers using a handful of templates. You will get an overview of Ansible covering some of the core concepts of Ansible such as running commands, inventory, playbooks, variables, roles, etc.
Also, you will understand how to use programming languages like Python to take care of automation by using modules such as os, glob, subprocess, etc.
Basic Linux Commands
Running the first command on Linux
Getting usage of Linux commands using the help
Overview of Files and Folders
Fully Qualified or Absolute Paths and Relative Paths of Files and Folders
Listing files and folders in Linux File System using ls
Overview of ls command to list files and folders in Linux
Setup Files and Folders from GitHub Account to learn Shell Commands
Setup Jupyter Lab to go through help on linux commands
Getting the properties of files and folders using the ls command in Linux
Sorting ls output while listing files in Linux
List files and folders in Linux sorted by time
List files and folders in Linux sorted by size
Overview of Hidden Folders and Files
Listing Hidden Files and Folders in Linux
Listing the files and folders recursively in Linux
Exploring Control Arguments while listing files in Linux
Overview of representation of file sizes
Overview of alias command and ll to list files and folders
Filtering files and folders in Linux File System
Introduction to the filtering files and folders on Linux File System
Accessing Windows Files and Folders from Linux setup using wsl
Overview of grep command
Few basic examples using grep and piping
Overview of Piping while running shell commands
Overview of Basic Pattern Matching
Deep Dive into the wc command to get word count or line count
Overview of the find command to filter files and folders
Understand the behavior of the simplest form of find command in Linux
Using Linux find command to find directories or folders
Using Linux find command to find files by type and pattern
Overview of Standard Directories in Linux
Get the list of files based on the modified time using the Linux find command
Get the list of files based on size using the Linux find command
Processing Data in Files using Linux Commands
Introduction to commands used for processing data in files using Linux
Overview of Different File Formats
Get file format or type using file command in Linux
Preview the data in the text file using head command in Linux
Preview the data in the text file using tail command
Install apache web server on Ubuntu Linux
Generate Apache Logs every second using shell script and nohup
Monitoring Logs using tail command in Linux
Preview the data in the text file using more command
Extract data from files in Linux using cut command
Sort data in files in Linux using sort command
Sort data in files in Linux using sort command based on key and delimiter
Extract Information and Redirect to a file in Linux
Getting Unique Records from File using sort in Linux
Using uniq to get unique values in Linux
Understanding File and Folder Properties
Introduction to Properties of Files and Folders
Understand File and Folder Properties provided by ls command
Understanding Owner of the Files in Linux
Overview of groups associated with files and folders in Linux
Creating Groups in Linux using groupadd
Create users in Linux using useradd command
Specifying bash as the default shell while creating users in Linux
Create Users with Group in Linux
Add users to supplementary or secondary groups in Linux
Overview of File Permissions in Linux
Overview of umask for default permissions on Files and Folders
Permissions on Home Folders for different Linux Users
File and Folder Permissions for Groups and Others
Conclusion for File and Folder Properties using Linux
Managing Files and Folders in Linux
Introduction to Managing Files and Folders in Linux
Generate empty files in Linux using touch command
Creating Directories in Linux using mkdir command
Overview of awk command in Linux
Overview of cp command to copy files in Linux
Using cp command to copy files in Linux
Create multiple folders at once using awk in Linux
Copy files using Patterns in Linux
Automate file copy using awk and cp in linux
Copying folders recursively using cp command in Linux
Copying files using cp while preserving properties in Linux
Moving Files in linux using mv command
Automate file move using awk and mv in linux
Overview of tar command to take the backups
Create backup of files and folders using tar command in linux
Restoring Files and Folders using tar command in Linux
Moving Folders in Linux using mv command
Overview of rm command to remove files from Linux File System
Delete files from Linux File System using rm command
Use alias to delete files interactively from Linux File System
Delete folders from Linux File System using rm command
Restore Data Folder from the tar ball
Delete files using find and rm from Linux file system based on name
Delete files using find and awk from Linux file system based on name
Generate log files for multiple years using touch with patterns
Update timestamp of files based on names in Linux using touch
Delete files using find and rm based on modified time in Linux
Renaming the files and folders in Linux
Basic System Commands in Linux
Introduction to Basic System Commands in Linux
Overview of core components of a computer
Get CPU Details using lscpu command in Linux
Get Memory Details using free on Linux
Get Storage Details using df in Linux
Get Disk Usage Details using du in Linux
Get largest folders and files using du and sort on Linux
Understand Storage Details of Directories using du on Windows
Get storage use of folders and files
Get Storage Details of larger files using find and du
Comparing Files and Folders in Linux using diff
Introduction to comparing files and folders in Linux using diff
Overview of the diff command
Prepare Dataset to explore diff command in Linux
Understand the output of the diff command in Linux
Compare Files Ignoring Blank Lines and White Spaces using diff in Linux
Compare Files Ignoring case using diff in Linux
Unified and Side By Side Comparison using diff in Linux
Compare Folders in Linux using the diff command
Variables and Environment Variables in Linux
Creating and Printing Variables using echo in Linux
Overview of Environment Variables in Linux and env command
Overview of Environment Variables in Windows
Review some of the standard environment variables in Linux
Get the location of commands in linux using which
Review PATH and unset PATH in Linux
Relevance of PATH Environment Variable while running Linux Commands
Overview of Profile and rc in Linux
Create a simple shell script and grant execute permissions in Linux
Update PATH with parent folders of custom applications
Update PATH in profile with parent folders of custom applications
Getting Started with AWS
Introduction to Getting Started with AWS
Signing up for AWS
Overview of AWS Web Console
Overview of AWS EC2 Console or Dashboard
Create AWS EC2 Key Pair using AWS EC2 Console
Create our first AWS EC2 Instance using Ubuntu 20
Login into AWS EC2 Instance using Key Pair
Overview of AWS Free Tier and Pricing
Overview of AWS Web Console Cloud Shell
Overview of AWS EC2 Instance Concepts
Managing AWS EC2 Instances
Overview of SSH to interact with remote servers
Introduction to Overview of SSH to interact with Remote Servers
Create Multiple AWS EC2 Instances
Different Modes of SSH Login to Remote Servers
Understanding Password less login to Remote Server
Overview of SSH Daemons on Remote Servers
Understand SSH Properties Files and Properties
Enabling Password login on Remote Server
Run Commands on Remote Servers using SSH
Connect to Remote Servers from Windows using Powershell as well as wsl
Setup pssh or parallel-ssh on Mac as well as Ubuntu Linux
Run Commands on multiple servers using parallel-ssh or pssh
Run Commands on multiple servers using pssh using the hosts file
Enable Password less login using ssh keys and the ssh-copy-id command
Terminate AWS EC2 Instances used for demo
Basic Networking Concepts using Linux
Introduction to Basic Networking Concepts using Linux
Provision EC2 Instance from AWS
Overview of AWS Security Groups
Overview of Different Types of IP Addresses
Install Apache Webserver on Ubuntu
Update Security Group to access Apache Web Application
Overview of Daemon or Background Processes and Ports
Understanding Structure of IP Address
Overview of DNS Aliases for IP Addresses
Install Jupyter Lab on Ubuntu
Run Jupyter Lab using Localhost
Update Security Group to access Jupyter Lab
Setup Mongo DB on AWS EC2 Instance
Run MongoDB on Universal IP Address
Update Security Group to access Mongo DB
Cleanup AWS EC2 Instance used to demo networking concepts
Copy Files and Folders between Multiple Systems using scp
Introduction to Copying Files and Folders between multiple Linux Systems using scp
Provision of multiple EC2 Instances from AWS
Connect to EC2 Instances using Windows Powershell
Connect to EC2 Instances from Linux on Windows
Prepare Data Sets to explore Copying Files
Overview of scp for secure copy between Multiple Systems
Copy Files using scp between Multiple Systems
Copy Folders using scp between Multiple Systems
Copy Tar Ball or Zip File using scp between Linux Servers
Setup parallel-scp or pscp to copy files to multiple systems
Prepare Target Systems by recreating folders using pssh
Copy Files onto remote machines in parallel using pscp
Copy Folders onto remote machines in parallel using pscp
Overview of Copying Files and Folders between two systems in parallel
Submit Long-Running Applications or Commands in the Background using nohup
Run multiple scp commands in parallel using nohup in Linux
Stop or Terminate AWS EC2 Instances used for the tasks
Troubleshooting Application issues using find and grep in Linux
Introduction to Troubleshooting Applicatin Issues using find and grep in Linux
Review Standard Location for Application Logs on Linux
Setup Log Files to explore grep and find to troubleshoot the issues
Overview of Standard Log Message Format
Quick Review of find command to get log file names based on criteria
Getting help or official documentation or man page on Linux grep command
Overview of Standard Input, output and error
Redirect Linux Command or Program Results to a file
Overview of Null Device in Linux
Redirect stanard output and error to files and null device in Linux
Overview of Case Sensitivity in Linux
Search for error lines from files in Linux using find and grep
Get File Names with errors using grep and find in Linux
Perform Whole Word Search using Grep Command
Search for multiple patterns in the files using find and grep in Linux
Get number of lines with pattern using find and grep in linux
Get line number and output line using grep in Linux
Get additional lines along with error or exception lines using grep in Linux
Monitoring and Managing Linux Servers using System Commands
Introduction to Monitoring and Managing Linux Servers using System Commands
Setup EC2 Instance on AWS using Ubuntu 2
Overview of Managing Softwares on Ubuntu using apt
Install Apache Web Server and Mongodb on Ubuntu
Manage Applications and Databases using systemctl or service command
Start Apache Web Server and Mongodb using systemctl
Overview of Service and its components
Recap of commands to get Linux Server Details
Get CPU or Load Average of Linux Server using uptime command
Overview of ps command to get details about processes on Linux Server
Get details of all the processes running on Linux Server using ps
Get list of processes owned by user on Linux Server using ps
Customize the output of ps command for specific details of processes
Number of processes on Linux Server owned by each user using ps
Get Process Details for a service on Linux Server using ps command
Overview of lsof command to get list of open files on Linux
Get open file details using lsof for a given process id
Get open file details using lsof for a given port number
Get Process Details using lsof command for a given file
Troubleshoot Port Usage on Linux using lsof command
Overview of top command in Linux to get system performance details
Getting help or man page of top command in Linux
Using Command Line Options of top command in LInux
Customize top interactive interface in Linux
Switching between groups in top interactive interface in Linux
Kill Processes using top interactive interface in Linux
Terminate AWS EC2 Instance setup to practice Linux system management commands
Overview of Developer Tools for Linux using Windows
Introduction to Developer Tools for Linux on Windows
Install Notepad++ on Windows
Install WinScp on Windows to access files on remote Linux Servers or Sites
Add Site to WinScp for Password Login into Remote Linux Server
Add Site to WinScp for Passwordless Login into Remote Linux Server
Copying Files between Windows and Remote Linux Systems using WinScp
Opening Files on Remote Machines using WinScp and Notepad++ Locally on Windows
Overview of Advanced Editing Capabilities of Notepad++
Overview of Visual Studio Code on Windows for Remote Development
Install Visual Studio Code on Windows
Install Remote Development Extension Kit for Visual Studio Code
Setup Project on remote machine for remote development using Visual Studio Code
Open Remote Project via SSH using Visual Studio Code
Open Project via WSL using Visual Studio Code
Access Configuration Files on Remote Machines using Visual Studio Code
Install Git and Git Bash on Windows
Install Beyond Compare on Windows
Setup Repository using Git to explore Beyond Compare
Quick Demo of Beyond Compare to compare code base
Overview of Ansible for Server Automation
Introduction to Overview of Ansible for Server Automation
Setup Ansible on Ubuntu 20
Provision EC2 Instances to learn Ansible
Run first command using Ansible on Multiple Instances using inline inventory
Run first command using Ansible on Multiple Instances using inventory file
Update Ansible Hosts Files on AWS EC2 Reboots
Overview of Ansible help, man page and official documentation
Add User and Group Manually in Linux
Add Group on remote instances using ansible
Adding User using Ansible user module on remote servers
Add Folder on remote systems using Ansible file module
Copy authorized keys using Ansible copy module
Setup Project Structure for Ansible Playbooks using Visual Studio Code
Create and Run first ansible playbook
Define Variables for Credentials to run Ansible Playbooks
Develop Ansible Playbook to Mange Users
Getting Started with Developing Ansible Roles
Develop and Validate Ansible Playbook with Role
Adding more tasks to the Ansible Role and Troubleshooting the issues
Create Ansible Playbook with Variables
Using Lists and Loops in Ansible Playbooks
Using Tags to run specific tasks from Playbooks
Update Ansible Role and Playbook with variables and tags
Add Variables under vars folder of Ansible Role
Terminate AWS EC2 Instances used for Ansible Tasks for Server Automation
Conclusion of Overview of Server Automation using Ansible
Overview of Automation using Python on Linux
Introduction to Overview of Automation using Python on Linux
Validate Python and Python Modules such as pip on Ubuntu
Setup and Validate Jupyter Lab on Ubuntu
Create Folder for Notebooks using Jupyter Lab
Overview of getpass module to get username
Running Linux Shell Commands from Jupyter Notebooks
Overview of Python os module
Setup Data Sets for Python and Linux Integration
Overview of Python glob module
Overview of running Linux Commands using subprocess
Sort all files in Linux File System by size using Python
Uncompress all Compressed Files using Python on Linux
Overview of Python Multiprocessing Module
Uncompress Files in Parallel using Python multiprocessing
Add Extension to Files using Python
Overview of Copying Files using Python and scp
Run Commands on Remote Machines using Python and ssh
Copy Files to multiple systems in parallel using Python and scp
Desired Audience
Here is the desired audience for this advanced course.
Experienced application developers to gain expertise related to Linux shell commands
Experienced Data Engineers to gain enough skills related to Linux shell commands
Testers to improve their testing capabilities by using Linux shell commands effectively
Prerequisites
Logistics
Computer with decent configuration (At least 4 GB RAM, however 8 GB is highly desired)
Dual Core is required and Quad-Core is highly desired
Chrome Browser
High-Speed Internet
Who this course is for:
Students who want to learn Linux commands by hands-on practice
Freshers and entry level IT professionals who want to gain the knowledge of Linux commands
Any Software developers such as Python, Java, etc who would like to gain proficiency of Linux Commands
Any Software Testers who would like to gain proficiency related to Linux Commands
This course is designed for all those IT Professionals who frequently work on Linux based Environment
System Administrators, Network Administrators, DevOps Engineers, etc
Requirements
PC or Mac with decent configuration
At least 8 GB RAM, i5 or equivalent processor
CPU with dual core or with higher configuration
Last Updated 6/2022
VISITOR COMMENTS (0 )
FILE LIST
Filename
Size
.pad/0
334 B
.pad/1
71 B
.pad/2
9 B
TutsNode.com.txt
63 B
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/10. Comparing Files and Folders in Linux using diff/5. Compare Files Ignoring Blank Lines and White Spaces using diff in Linux.srt
9.6 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/10. Comparing Files and Folders in Linux using diff/8. Compare Folders in Linux using diff command.srt
9.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/11. Variables and Environment Variables in Linux/10. Update PATH with parent folders of custom applications.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/11. Variables and Environment Variables in Linux/11. Update PATH in profile with parent folders of custom applications.srt
9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/11. Variables and Environment Variables in Linux/7. Relevance of PATH Environment Variable while running Linux Commands.srt
9.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/11. Variables and Environment Variables in Linux/8. Overview of Profile and rc in Linux.srt
9.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/12. Getting Started with AWS/10. Overview of AWS EC2 Instance Concepts.srt
8.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/12. Getting Started with AWS/6. Create our first AWS EC2 Instance using Ubuntu 20.srt
10.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/12. Getting Started with AWS/7. Login into AWS EC2 Instance using Key Pair.srt
9.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/12. Getting Started with AWS/8. Overview of AWS Free Tier and Pricing.srt
10.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/12. Getting Started with AWS/9. Overview of AWS Web Console Cloud Shell.srt
7.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/11. Run Commands on multiple servers using parallel-ssh or pssh.srt
10.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/13. Enable Password less login using ssh keys and ssh-copy-id command.srt
9.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/2. Create Multiple AWS EC2 Instances.srt
8.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/5. Overview of SSH Daemons on Remote Servers.srt
10.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/7. Enabling Password login on Remote Server.srt
10.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/8. Run Commands on Remote Servers using SSH.srt
9.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/13. Overview of SSH to interact with remote servers/9. Connect to Remote Servers from Windows using Powershell as well as wsl.srt
9.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/14. Basic Networking Concepts using Linux/1. Provision EC2 Instance from AWS.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/14. Basic Networking Concepts using Linux/10. Run Jupyter Lab using Localhost.srt
10.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/14. Basic Networking Concepts using Linux/12. Setup Mongo DB on AWS EC2 Instance.srt
8.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/14. Basic Networking Concepts using Linux/14. Update Security Group to access Mongo DB.srt
8.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/14. Basic Networking Concepts using Linux/2. Overview of AWS Security Groups.srt
9.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/14. Basic Networking Concepts using Linux/9. Install Jupyter Lab on Ubuntu.srt
10.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/15. Copy Files and Folders between Multiple Systems using scp/3. Connect to EC2 Instances from Linux on Windows.srt
9.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/15. Copy Files and Folders between Multiple Systems using scp/5. Overview of scp for secure copy between Multiple Systems.srt
10.6 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/15. Copy Files and Folders between Multiple Systems using scp/6. Copy Files using scp between Multiple Systems.mp4
97.7 MB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/15. Copy Files and Folders between Multiple Systems using scp/6. Copy Files using scp between Multiple Systems.srt
15.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/15. Copy Files and Folders between Multiple Systems using scp/7. Copy Folders using scp between Multiple Systems.srt
9.7 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/16. Troubleshooting Application issues using find and grep in Linux/12. Search for error lines from files in Linux using find and grep.srt
10.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/16. Troubleshooting Application issues using find and grep in Linux/15. Search for multiple patterns in the files using find and grep in Linux.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/16. Troubleshooting Application issues using find and grep in Linux/16. Get number of lines with pattern using find and grep in linux.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/2. Setup Ubuntu Linux on Windows using wsl/10. Overview of installing OS Packages on Ubuntu Virtual Machines.srt
9.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/2. Setup Ubuntu Linux on Windows using wsl/3. Setup Ubuntu VM on Windows 10 or 11 using wsl.srt
9.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/2. Setup Ubuntu Linux on Windows using wsl/4. Setup Ubuntu VM on Windows 10 or 11 using wsl.srt
8.6 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/2. Setup Ubuntu Linux on Windows using wsl/5. Setup Ubuntu 18.04 Virtual Machine on Windows 10 or Windows 11.srt
13.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/2. Setup Ubuntu Linux on Windows using wsl/6. Managing Life Cycle of Virtual Machines using wsl on Windows 10 or Windows 11.srt
8.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/2. Setup Ubuntu Linux on Windows using wsl/9. Accessing Windows File System from wsl Ubuntu Virtual Machines.srt
10.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/3. Getting Started with Linux shell commands/2. Running first command on Linux.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/3. Getting Started with Linux shell commands/5. Fully Qualified or Absolute Paths and Relative Paths of Files and Folders.srt
12.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/10. Listing the files and folders recursively in Linux.srt
9.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/11. Exploring Control Arguments while listing files in Linux.srt
12.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/13. Overview of alias command and ll to list files and folders.srt
13.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/3. Setup Jupyter Lab to go through help on linux commands.srt
8.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/4. Getting the properties of files and folders using ls command in Linux.srt
9.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/7. List files and folders in Linux sorted by size.srt
9.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/4. Listing files and folders in Linux File System using ls/9. Listing Hidden Files and Folders in Linux.srt
8.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/12. Overview of Standard Directories in Linux.srt
9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/13. Get list of files based on modified time using Linux find command.srt
9.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/2. Accessing Windows Files and Folders from Linux setup using wsl.srt
9.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/4. Few basic examples using grep and piping.srt
11 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/5. Overview of Piping while running shell commands.srt
9.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/6. Overview of Basic Pattern Matching.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/7. Deep Dive into wc command to get word count or line count.srt
9.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/8. Overview of find command to filter files and folders.srt
9.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/5. Filtering files and folders in Linux File System/9. Understand behavior of simplest form of find command in Linux.srt
3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/6. Processing Data in Files using Linux Commands/15. Using uniq to get unique values in Linux.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/6. Processing Data in Files using Linux Commands/2. Overview of Different File Formats.srt
8.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/6. Processing Data in Files using Linux Commands/3. Get file format or type using file command in linux.srt
12.2 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/6. Processing Data in Files using Linux Commands/7. Generate Apache Logs every second using shell script and nohup.srt
9.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/6. Processing Data in Files using Linux Commands/8. Monitoring Logs using tail command in Linux.srt
7.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/11. Overview of umask for default permissions on Files and Folders.mp4
93.9 MB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/11. Overview of umask for default permissions on Files and Folders.srt
14 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/12. Permissions on Home Folders for different Linux Users.srt
11.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/13. File and Folder Permissions for Groups and Others.srt
9.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/5. Creating Groups in Linux using groupadd.srt
4.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/6. Create users in Linux using useradd command.srt
14 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/7. Understanding File and Folder Properties/9. Add users to supplementary or secondary groups in Linux.srt
10.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/10. Copying folders recursively using cp command in Linux.srt
10.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/11. Copying files using cp while preserving properties in Linux.mp4
95.9 MB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/11. Copying files using cp while preserving properties in Linux.srt
12.6 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/12. Moving Files in linux using mv command.srt
11.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/13. Automate file move using awk and mv in linux.srt
10 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/15. Create backup of files and folders using tar command in linux.srt
10.4 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/16. Restoring Files and Folders using tar command in Linux.srt
10.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/17. Moving Folders in Linux using mv command.srt
14.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/2. Generate empty files in linux using touch command.srt
13.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/20. Use alias to delete files interactively from Linux File System.mp4
90.5 MB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/20. Use alias to delete files interactively from Linux File System.srt
12.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/21. Delete folders from Linux File System using rm command.srt
11.5 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/23. Delete files using find and rm from Linux file system based on name.srt
7.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/24. Delete files using find and awk from Linux file system based on name.srt
8.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/25. Generate log files for multiple years using touch with patterns.srt
8.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/26. Update timestamp of files based on names in Linux using touch.srt
8.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/27. Delete files using find and rm based on modified time in Linux.srt
11.1 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/28. Renaming the files and folders in Linux.srt
13.3 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/3. Creating Directories in Linux using mkdir command.srt
11.7 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/4. Overview of awk command in Linux.srt
12.9 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/6. Using cp command to copy files in Linux.srt
7.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/7. Create multiple folders at once using awk in Linux.srt
8.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/8. Managing Files and Folders in Linux/9. Automate file copy using awk and cp in linux.srt
10.6 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/9. Basic System Commands in Linux/10. Get Storage Details of larger files using find and du.srt
10.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/9. Basic System Commands in Linux/6. Get Disk Usage Details using du in Linux.srt
8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/9. Basic System Commands in Linux/7. Get largest folders and files using du and sort on Linux.srt
9.8 KB
[TutsNode.net] - Linux Shell Commands for Absolute Beginners using Ubuntu 20x/9. Basic System Commands in Linux/9. Get storage use of folders and files.srt