ytdl-org / youtube-dl

Command-line program to download videos from YouTube.com and other video sites
http://ytdl-org.github.io/youtube-dl/
The Unlicense
132.59k stars 10.05k forks source link

pluralsight error again #20025

Closed jaan143 closed 5 years ago

jaan143 commented 5 years ago

Please follow the guide below


Make sure you are using the latest version: run youtube-dl --version and ensure your version is 2019.02.18. If it's not, read this FAQ entry and update. Issues with outdated version will be rejected.

Before submitting an issue make sure you have:

What is the purpose of your issue?


The following sections concretize particular purposed issues, you can erase any section (the contents between triple ---) not applicable to your issue


If the purpose of this issue is a bug report, site support request or you are not completely sure provide the full verbose output as follows:

Add the -v flag to your command line you run youtube-dl with (youtube-dl -v <your command line>), copy the whole output and insert it here. It should look similar to one below (replace it with your log inserted between triple ```):

[debug] System config: []
[debug] User config: []
[debug] Command-line args: [u'-v', u'http://www.youtube.com/watch?v=BaW_jenozKcj']
[debug] Encodings: locale cp1251, fs mbcs, out cp866, pref cp1251
[debug] youtube-dl version 2019.02.18
[debug] Python version 2.7.11 - Windows-2003Server-5.2.3790-SP2
[debug] exe versions: ffmpeg N-75573-g1d0487f, ffprobe N-75573-g1d0487f, rtmpdump 2.4
[debug] Proxy map: {}
...
<end of log>

If the purpose of this issue is a site support request please provide all kinds of example URLs support for which should be included (replace following example URLs by yours):

Note that youtube-dl does not support sites dedicated to copyright infringement. In order for site support request to be accepted all provided example URLs should not violate any copyrights.


Description of your issue, suggested solution and other information

pluralsight is giving error sins yesterday and before it was working fine

PS C:\Users\HDNLRG1011> youtube-dl --verbose -o 'd:\contents\New folder/%(playlist)s/%(playlist_index)s - %(title)s.%(ex t)s' https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger --sleep-interval 80 --limit-rate 250 k --username 12345@abc.com --password 12345 [debug] System config: [] [debug] User config: [] [debug] Custom config: [] [debug] Command-line args: ['--verbose', '-o', 'd:\contents\New folder/%(playlist)s/%(playlist_index)s - %(title)s.%(e xt)s', 'https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger', '--sleep-interval', '80', '--li mit-rate', '250k', '--username', 'PRIVATE', '--password', 'PRIVATE'] [debug] Encodings: locale cp1255, fs mbcs, out cp862, pref cp1255 [debug] youtube-dl version 2019.02.18 [debug] Python version 3.5.4 (CPython) - Windows-2012ServerR2-6.3.9600-SP0 [debug] exe versions: none [debug] Proxy map: {} [pluralsight:course] aspdotnet-core-api-openapi-swagger: Downloading JSON metadata [download] Downloading playlist: Documenting an ASP.NET Core API with OpenAPI / Swagger [pluralsight:course] playlist Documenting an ASP.NET Core API with OpenAPI / Swagger: Collected 61 video ids (downloadin g 61 of them) [download] Downloading video 1 of 61 [pluralsight] Downloading login page [pluralsight] Logging in ERROR: Unable to download webpage: HTTP Error 503: Service Temporarily Unavailable (caused by <HTTPError 503: 'Service T emporarily Unavailable'>); please report this issue on https://yt-dl.org/bug . Make sure you are using the latest versio n; see https://yt-dl.org/update on how to update. Be sure to call youtube-dl with the --verbose flag and include its c omplete output. File "c:\program files\python35\lib\site-packages\youtube_dl\extractor\common.py", line 605, in _request_webpage return self._downloader.urlopen(url_or_request) File "c:\program files\python35\lib\site-packages\youtube_dl\YoutubeDL.py", line 2225, in urlopen return self._opener.open(req, timeout=self._socket_timeout) File "c:\program files\python35\lib\urllib\request.py", line 472, in open response = meth(req, response) File "c:\program files\python35\lib\urllib\request.py", line 582, in http_response 'http', request, response, code, msg, hdrs) File "c:\program files\python35\lib\urllib\request.py", line 510, in error return self._call_chain(args) File "c:\program files\python35\lib\urllib\request.py", line 444, in _call_chain result = func(args) File "c:\program files\python35\lib\urllib\request.py", line 590, in http_error_default raise HTTPError(req.full_url, code, msg, hdrs, fp)

PS C:\Users\HDNLRG1011>

dstftw commented 5 years ago

Most likely pluralsight side server error. In any case you must provide account credentials.

jaan143 commented 5 years ago

@dstftw how can i provide pluralsight account ? it is working in browser

jaan143 commented 5 years ago

@dstftw bro please check your gmail

remitamine commented 5 years ago
youtube-dl --username 'example@example.com' --password pass --sleep-interval 80 --limit-rate 250 https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger
[pluralsight:course] aspdotnet-core-api-openapi-swagger: Downloading JSON metadata
[download] Downloading playlist: Documenting an ASP.NET Core API with OpenAPI / Swagger
[pluralsight:course] playlist Documenting an ASP.NET Core API with OpenAPI / Swagger: Collected 61 video ids (downloading 61 of them)
[download] Downloading video 1 of 61
[pluralsight] Downloading login page
[pluralsight] Logging in
[pluralsight] fc00e343-081d-4113-8399-47606dac77f5-0: Downloading JSON metadata
[pluralsight] fc00e343-081d-4113-8399-47606dac77f5-0: Downloading mp4-high-widescreen viewclip graphql
[pluralsight] fc00e343-081d-4113-8399-47606dac77f5-0: Waiting for 5 seconds to avoid throttling
[download] Sleeping 80 seconds...
[download] Destination: Course Overview-3fe4ca6e-f6a6-4d81-8472-7ad0490cb4f8.mp4
  % Total    % Received % Xferd  Average Speed   Time    Time     Time  Current
                                 Dload  Upload   Total   Spent    Left  Speed
  2 2638k    2 64617    0     0    744      0  1:00:31  0:01:26  0:59:05     0
davidvasandani commented 5 years ago

Thanks for the quick reply @remitamine. I tried to reproduce your command and it fails with the 503 error.

I'm on version 2019.03.09

EDIT: Added --verbose and --dump-pages output

/usr/local/bin/youtube-dl \
  --username 'username@domain.com' \
  --password password \
  --sleep-interval 80 \
  --limit-rate 250 \
  https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger
[pluralsight:course] aspdotnet-core-api-openapi-swagger: Downloading JSON metadata
[download] Downloading playlist: Documenting an ASP.NET Core API with OpenAPI / Swagger
[pluralsight:course] playlist Documenting an ASP.NET Core API with OpenAPI / Swagger: Collected 61 video ids (downloading 61 of them)
[download] Downloading video 1 of 61
[pluralsight] Downloading login page
[pluralsight] Logging in
ERROR: Unable to download webpage: HTTP Error 503: Service Temporarily Unavailable (caused by HTTPError()); please report this issue on https://yt-dl.org/bug . Make sure you are using the latest version; type  youtube-dl -U  to update. Be sure to call youtube-dl with the --verbose flag and include its complete output.

verbose output

root@docker-02:~# /usr/local/bin/youtube-dl \
>   --username 'user@domain.com' \
>   --password password \
>   --sleep-interval 80 \
>   --limit-rate 250 \
>   --verbose \
>   https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger
[debug] System config: []
[debug] User config: []
[debug] Custom config: []
[debug] Command-line args: [u'--username', u'PRIVATE', u'--password', u'PRIVATE', u'--sleep-interval', u'80', u'--limit-rate', u'250', u'--verbose', u'https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger']
[debug] Encodings: locale UTF-8, fs UTF-8, out UTF-8, pref UTF-8
[debug] youtube-dl version 2019.03.09
[debug] Python version 2.7.12 (CPython) - Linux-4.4.0-142-generic-x86_64-with-Ubuntu-16.04-xenial
[debug] exe versions: ffmpeg 2.8.15, ffprobe 2.8.15, rtmpdump 2.4
[debug] Proxy map: {}
[pluralsight:course] aspdotnet-core-api-openapi-swagger: Downloading JSON metadata
[download] Downloading playlist: Documenting an ASP.NET Core API with OpenAPI / Swagger
[pluralsight:course] playlist Documenting an ASP.NET Core API with OpenAPI / Swagger: Collected 61 video ids (downloading 61 of them)
[download] Downloading video 1 of 61
[pluralsight] Downloading login page
[pluralsight] Logging in
ERROR: Unable to download webpage: HTTP Error 503: Service Temporarily Unavailable (caused by HTTPError()); please report this issue on https://yt-dl.org/bug . Make sure you are using the latest version; type  youtube-dl -U  to update. Be sure to call youtube-dl with the --verbose flag and include its complete output.
  File "/usr/local/bin/youtube-dl/youtube_dl/extractor/common.py", line 619, in _request_webpage
    return self._downloader.urlopen(url_or_request)
  File "/usr/local/bin/youtube-dl/youtube_dl/YoutubeDL.py", line 2225, in urlopen
    return self._opener.open(req, timeout=self._socket_timeout)
  File "/usr/lib/python2.7/urllib2.py", line 435, in open
    response = meth(req, response)
  File "/usr/lib/python2.7/urllib2.py", line 548, in http_response
    'http', request, response, code, msg, hdrs)
  File "/usr/lib/python2.7/urllib2.py", line 473, in error
    return self._call_chain(*args)
  File "/usr/lib/python2.7/urllib2.py", line 407, in _call_chain
    result = func(*args)
  File "/usr/lib/python2.7/urllib2.py", line 556, in http_error_default
    raise HTTPError(req.get_full_url(), code, msg, hdrs, fp)

dump-pages output

root@docker-02:~# /usr/local/bin/youtube-dl \
>   --username 'user@domain.com' \
>   --password password \
>   --sleep-interval 80 \
>   --limit-rate 250 \
>   --dump-pages \
>   https://app.pluralsight.com/library/courses/aspdotnet-core-api-openapi-swagger
[pluralsight:course] aspdotnet-core-api-openapi-swagger: Downloading JSON metadata
[pluralsight:course] Dumping request to https://app.pluralsight.com/player/api/graphql
{"data":{"rpc":{"bootstrapPlayer":{"profile":{"firstName":null,"lastName":null,"email":"","username":null,"userHandle":null,"authed":false,"isAuthed":false,"plan":null},"course":{"name":"aspdotnet-core-api-openapi-swagger","title":"Documenting an ASP.NET Core API with OpenAPI / Swagger","courseHasCaptions":true,"translationLanguages":[{"code":"af","name":"Afrikaans"},{"code":"az","name":"Azərbaycan­ılı"},{"code":"id","name":"Bahasa Indonesia"},{"code":"ms","name":"Bahasa Melayu"},{"code":"bs","name":"bosanski"},{"code":"ca","name":"Català"},{"code":"cs","name":"čeština"},{"code":"sn","name":"chiShona"},{"code":"co","name":"Corsu"},{"code":"cy","name":"Cymraeg"},{"code":"da","name":"dansk"},{"code":"de","name":"Deutsch"},{"code":"et","name":"eesti"},{"code":"en","name":"English"},{"code":"es","name":"español"},{"code":"eo","name":"esperanto"},{"code":"eu","name":"euskara"},{"code":"fr","name":"français"},{"code":"fy","name":"Frysk"},{"code":"ga","name":"Gaeilge"},{"code":"gd","name":"Gàidhlig"},{"code":"gl","name":"galego"},{"code":"ha","name":"Hausa"},{"code":"haw","name":"Hawaiʻi"},{"code":"hr","name":"hrvatski"},{"code":"ig","name":"Igbo"},{"code":"xh","name":"isiXhosa"},{"code":"zu","name":"isiZulu"},{"code":"is","name":"íslenska"},{"code":"it","name":"italiano"},{"code":"sw","name":"Kiswahili"},{"code":"ht","name":"kreyòl ayisyen"},{"code":"lv","name":"latviešu"},{"code":"lb","name":"Lëtzebuergesch"},{"code":"lt","name":"lietuvių"},{"code":"hu","name":"magyar"},{"code":"mg","name":"Malagasy"},{"code":"mt","name":"Malti"},{"code":"nl","name":"Nederlands"},{"code":"no","name":"norsk"},{"code":"uz","name":"O'zbekcha"},{"code":"pl","name":"polski"},{"code":"pt","name":"português"},{"code":"mi","name":"Reo Māori"},{"code":"ro","name":"română"},{"code":"st","name":"Sesotho"},{"code":"sq","name":"Shqip"},{"code":"sk","name":"slovenčina"},{"code":"sl","name":"slovenščina"},{"code":"so","name":"Soomaali"},{"code":"sr","name":"srpski"},{"code":"fi","name":"suomi"},{"code":"sv","name":"svenska"},{"code":"tl","name":"Tagalog"},{"code":"vi","name":"Tiếng Việt"},{"code":"tr","name":"Türkçe"},{"code":"yo","name":"Yoruba"},{"code":"el","name":"Ελληνικά"},{"code":"be","name":"Беларуская"},{"code":"bg","name":"български"},{"code":"ky","name":"Кыргыз"},{"code":"kk","name":"Қазақ"},{"code":"mk","name":"македонски јазик"},{"code":"mn","name":"Монгол хэл"},{"code":"ru","name":"русский"},{"code":"tg","name":"Тоҷикӣ"},{"code":"uk","name":"українська"},{"code":"hy","name":"Հայերեն"},{"code":"ka","name":"ქართული"},{"code":"yi","name":"ייִדיש"},{"code":"iw","name":"עברית"},{"code":"ur","name":"اُردو"},{"code":"ar","name":"العربية"},{"code":"ps","name":"پښتو"},{"code":"sd","name":"سنڌي"},{"code":"fa","name":"فارسى"},{"code":"ku","name":"کوردیی ناوەڕاست"},{"code":"ne","name":"नेपाली"},{"code":"mr","name":"मराठी"},{"code":"hi","name":"हिंदी"},{"code":"bn","name":"বাংলা"},{"code":"pa","name":"ਪੰਜਾਬੀ"},{"code":"gu","name":"ગુજરાતી"},{"code":"ta","name":"தமிழ்"},{"code":"te","name":"తెలుగు"},{"code":"kn","name":"ಕನ್ನಡ"},{"code":"ml","name":"മലയാളം"},{"code":"si","name":"සිංහල"},{"code":"th","name":"ไทย"},{"code":"my","name":"ဗမာ"},{"code":"lo","name":"ພາສາລາວ"},{"code":"km","name":"ភាសាខ្មែរ"},{"code":"am","name":"አማርኛ"},{"code":"ko","name":"한국어"},{"code":"zh","name":"中文"},{"code":"zh-TW","name":"中文(台灣)"},{"code":"ja","name":"日本語"}],"supportsWideScreenVideoFormats":true,"timestamp":"Wed Feb 27 2019 00:00:25 GMT+0000 (UTC)","modules":[{"name":"fc00e343-081d-4113-8399-47606dac77f5","title":"Course Overview","duration":78,"formattedDuration":"1:18","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"3fe4ca6e-f6a6-4d81-8472-7ad0490cb4f8","duration":78,"formattedDuration":"1:18","id":"aspdotnet-core-api-openapi-swagger:fc00e343-081d-4113-8399-47606dac77f5:0:kevin-dockx","index":0,"moduleIndex":0,"moduleTitle":"Course Overview","name":"3fe4ca6e-f6a6-4d81-8472-7ad0490cb4f8","title":"Course Overview","watched":false}]},{"name":"7556d56f-9c6b-40c6-925e-f6deae784243","title":"Getting Started with OpenAPI / Swagger","duration":795,"formattedDuration":"13:15","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"4cb5a608-f263-4baf-a994-913c8bb1caed","duration":75,"formattedDuration":"1:15","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:0:kevin-dockx","index":0,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"4cb5a608-f263-4baf-a994-913c8bb1caed","title":"Coming Up","watched":false},{"authorized":true,"clipId":"a0f34445-2a32-41dc-a00e-b534e7f95673","duration":33,"formattedDuration":"0:33","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:1:kevin-dockx","index":1,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"a0f34445-2a32-41dc-a00e-b534e7f95673","title":"Course Prerequisites","watched":false},{"authorized":true,"clipId":"94ca70b6-4c50-409b-82c6-d65b203a8791","duration":73,"formattedDuration":"1:13","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:2:kevin-dockx","index":2,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"94ca70b6-4c50-409b-82c6-d65b203a8791","title":"Frameworks and Tooling","watched":false},{"authorized":true,"clipId":"f3ede516-0647-4a2f-800a-3c19c0706937","duration":192,"formattedDuration":"3:12","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:3:kevin-dockx","index":3,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"f3ede516-0647-4a2f-800a-3c19c0706937","title":"Why Use Swagger / OpenAPI to Document Your API?","watched":false},{"authorized":true,"clipId":"36d68fd1-4bf4-49b5-a73a-e158b1c1c8ae","duration":167,"formattedDuration":"2:47","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:4:kevin-dockx","index":4,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"36d68fd1-4bf4-49b5-a73a-e158b1c1c8ae","title":"Clearing up the Terminology Confusion","watched":false},{"authorized":true,"clipId":"65503956-9b7c-4c41-a1de-20a53e068085","duration":185,"formattedDuration":"3:05","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:5:kevin-dockx","index":5,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"65503956-9b7c-4c41-a1de-20a53e068085","title":"Demo - Introducing the Demo Application","watched":false},{"authorized":true,"clipId":"a097d739-d8d0-49d4-8dd3-61a43a24dc92","duration":65,"formattedDuration":"1:05","id":"aspdotnet-core-api-openapi-swagger:7556d56f-9c6b-40c6-925e-f6deae784243:6:kevin-dockx","index":6,"moduleIndex":1,"moduleTitle":"Getting Started with OpenAPI / Swagger","name":"a097d739-d8d0-49d4-8dd3-61a43a24dc92","title":"Summary","watched":false}]},{"name":"76271d02-7345-4b4b-85dc-51dbb184d4c4","title":"Documenting Your First API with OpenAPI / Swagger","duration":1940,"formattedDuration":"32:20","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"f0159066-75eb-46fc-b9a0-6afd066ecb13","duration":38,"formattedDuration":"0:38","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:0:kevin-dockx","index":0,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"f0159066-75eb-46fc-b9a0-6afd066ecb13","title":"Coming Up","watched":false},{"authorized":true,"clipId":"e6d644ec-5f51-4d8f-8839-8d958b66d452","duration":239,"formattedDuration":"3:59","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:1:kevin-dockx","index":1,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"e6d644ec-5f51-4d8f-8839-8d958b66d452","title":"Demo - Installing Swashbuckle","watched":false},{"authorized":true,"clipId":"7c0bb79f-385a-43fd-96e6-5e0e8b6eaf08","duration":252,"formattedDuration":"4:12","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:2:kevin-dockx","index":2,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"7c0bb79f-385a-43fd-96e6-5e0e8b6eaf08","title":"Demo - Inspecting the Generated OpenAPI Specification","watched":false},{"authorized":true,"clipId":"9d42c12a-a996-45be-adcf-73fe856b4694","duration":228,"formattedDuration":"3:48","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:3:kevin-dockx","index":3,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"9d42c12a-a996-45be-adcf-73fe856b4694","title":"Demo - Adding Swagger UI","watched":false},{"authorized":true,"clipId":"1105feb6-0cc0-4360-91f6-c8edeaa40270","duration":266,"formattedDuration":"4:26","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:4:kevin-dockx","index":4,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"1105feb6-0cc0-4360-91f6-c8edeaa40270","title":"Demo - Incorporating XML Comments on Actions","watched":false},{"authorized":true,"clipId":"7d168bd1-88ee-4ece-84d7-bbf269f2fd1a","duration":83,"formattedDuration":"1:23","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:5:kevin-dockx","index":5,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"7d168bd1-88ee-4ece-84d7-bbf269f2fd1a","title":"Demo - Incorporating XML Comments on Model Classes","watched":false},{"authorized":true,"clipId":"7add72bd-6930-4f13-af4b-d30e6ce03bf7","duration":146,"formattedDuration":"2:26","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:6:kevin-dockx","index":6,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"7add72bd-6930-4f13-af4b-d30e6ce03bf7","title":"Demo - Improving Documentation with Data Annotations","watched":false},{"authorized":true,"clipId":"7279224e-00f1-4f1a-85e5-b226129e6bd6","duration":192,"formattedDuration":"3:12","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:7:kevin-dockx","index":7,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"7279224e-00f1-4f1a-85e5-b226129e6bd6","title":"Demo - Improving Documentation with Examples","watched":false},{"authorized":true,"clipId":"89438196-7147-4088-b07d-a9c0e2e07baa","duration":222,"formattedDuration":"3:42","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:8:kevin-dockx","index":8,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"89438196-7147-4088-b07d-a9c0e2e07baa","title":"Demo - Ignoring Warnings Where Appropriate","watched":false},{"authorized":true,"clipId":"be9d0e2e-7f96-4ca4-85d5-abdca34668f6","duration":173,"formattedDuration":"2:53","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:9:kevin-dockx","index":9,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"be9d0e2e-7f96-4ca4-85d5-abdca34668f6","title":"Demo - Adding API Information and Description","watched":false},{"authorized":true,"clipId":"25127b5f-7192-4c4b-ba21-85369f1a8550","duration":95,"formattedDuration":"1:35","id":"aspdotnet-core-api-openapi-swagger:76271d02-7345-4b4b-85dc-51dbb184d4c4:10:kevin-dockx","index":10,"moduleIndex":2,"moduleTitle":"Documenting Your First API with OpenAPI / Swagger","name":"25127b5f-7192-4c4b-ba21-85369f1a8550","title":"Summary","watched":false}]},{"name":"f7bcb228-23ce-4ebe-af39-c16277e0b933","title":"Using and Overriding Conventions for OpenAPI Generation","duration":2558,"formattedDuration":"42:38","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"2d1b1ad9-5ad2-4699-9f45-60aa94868751","duration":76,"formattedDuration":"1:16","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:0:kevin-dockx","index":0,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"2d1b1ad9-5ad2-4699-9f45-60aa94868751","title":"Coming Up","watched":false},{"authorized":true,"clipId":"3fb3130d-0ae4-452b-80ea-662342785144","duration":95,"formattedDuration":"1:35","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:1:kevin-dockx","index":1,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"3fb3130d-0ae4-452b-80ea-662342785144","title":"The Importance of ApiExplorer","watched":false},{"authorized":true,"clipId":"f364c6c9-a218-4bfe-b2c6-80f4698e17b1","duration":66,"formattedDuration":"1:06","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:2:kevin-dockx","index":2,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"f364c6c9-a218-4bfe-b2c6-80f4698e17b1","title":"Why It's Important to Produce Correct Response Types","watched":false},{"authorized":true,"clipId":"fb400742-1d64-45f5-943b-f5011122302e","duration":392,"formattedDuration":"6:32","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:3:kevin-dockx","index":3,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"fb400742-1d64-45f5-943b-f5011122302e","title":"Demo - Describing Response Types (Status Codes) with ProducesReponseType ","watched":false},{"authorized":true,"clipId":"0c9eb76e-2bd8-4f66-9ae6-5b47e5137c59","duration":535,"formattedDuration":"8:55","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:4:kevin-dockx","index":4,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"0c9eb76e-2bd8-4f66-9ae6-5b47e5137c59","title":"Demo - Using API Analyzers to Improve the OpenAPI Specification","watched":false},{"authorized":true,"clipId":"2bc954d0-0f79-4d28-a857-0c0f21f1a164","duration":275,"formattedDuration":"4:35","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:5:kevin-dockx","index":5,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"2bc954d0-0f79-4d28-a857-0c0f21f1a164","title":"Demo - Working with API Conventions","watched":false},{"authorized":true,"clipId":"ac48af6c-73b0-45b5-84b9-3aa647b69d37","duration":352,"formattedDuration":"5:52","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:6:kevin-dockx","index":6,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"ac48af6c-73b0-45b5-84b9-3aa647b69d37","title":"Demo - Creating Custom Conventions","watched":false},{"authorized":true,"clipId":"a6c63673-3402-4de9-98b7-7490757a5dbe","duration":110,"formattedDuration":"1:50","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:7:kevin-dockx","index":7,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"a6c63673-3402-4de9-98b7-7490757a5dbe","title":"Attributes Versus Conventions","watched":false},{"authorized":true,"clipId":"83eb050d-ebab-4ebe-91a9-c025b4048e21","duration":113,"formattedDuration":"1:53","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:8:kevin-dockx","index":8,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"83eb050d-ebab-4ebe-91a9-c025b4048e21","title":"Content Negotiation","watched":false},{"authorized":true,"clipId":"73df2441-3816-4a58-a812-1edbe5e8188c","duration":362,"formattedDuration":"6:02","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:9:kevin-dockx","index":9,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"73df2441-3816-4a58-a812-1edbe5e8188c","title":"Demo - Specifying the Response Body Type with the Produces Attribute","watched":false},{"authorized":true,"clipId":"36aabba1-ebc1-4d70-a385-589c469abbcb","duration":93,"formattedDuration":"1:33","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:10:kevin-dockx","index":10,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"36aabba1-ebc1-4d70-a385-589c469abbcb","title":"Demo - Specifying the Request Body Type with the Consumes Attribute","watched":false},{"authorized":true,"clipId":"fc16fd46-7f3f-429b-ab62-8adc418e6f44","duration":85,"formattedDuration":"1:25","id":"aspdotnet-core-api-openapi-swagger:f7bcb228-23ce-4ebe-af39-c16277e0b933:11:kevin-dockx","index":11,"moduleIndex":3,"moduleTitle":"Using and Overriding Conventions for OpenAPI Generation","name":"fc16fd46-7f3f-429b-ab62-8adc418e6f44","title":"Summary","watched":false}]},{"name":"00190e2f-8a38-4342-9867-8127622a54b5","title":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","duration":1749,"formattedDuration":"29:09","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"d4919557-463f-4e4a-95f6-57624a22209c","duration":55,"formattedDuration":"0:55","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:0:kevin-dockx","index":0,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"d4919557-463f-4e4a-95f6-57624a22209c","title":"Coming Up","watched":false},{"authorized":true,"clipId":"3dafa39a-bb9e-4693-8473-5a8906ef1561","duration":99,"formattedDuration":"1:39","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:1:kevin-dockx","index":1,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"3dafa39a-bb9e-4693-8473-5a8906ef1561","title":"Content Negotiation with Vendor-specific Media Types","watched":false},{"authorized":true,"clipId":"d2a05ed5-f2d9-445b-ac2c-9d27b2a0ffdd","duration":295,"formattedDuration":"4:55","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:2:kevin-dockx","index":2,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"d2a05ed5-f2d9-445b-ac2c-9d27b2a0ffdd","title":"Demo - Supporting Vendor-specific Media Types ","watched":false},{"authorized":true,"clipId":"5633272f-5263-4356-a6cb-b7d47faa6c44","duration":83,"formattedDuration":"1:23","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:3:kevin-dockx","index":3,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"5633272f-5263-4356-a6cb-b7d47faa6c44","title":"OpenAPI Support for Schema Variation by Media Type (Output)","watched":false},{"authorized":true,"clipId":"463c981e-f74c-40b8-ae2e-3b6f1ee679b6","duration":327,"formattedDuration":"5:27","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:4:kevin-dockx","index":4,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"463c981e-f74c-40b8-ae2e-3b6f1ee679b6","title":"Demo - Supporting Schema Variation by Media Type (Output, ResolveConflictingActions)","watched":false},{"authorized":true,"clipId":"f1d17b3b-0bcd-4612-870e-6a9aed7e40de","duration":391,"formattedDuration":"6:31","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:5:kevin-dockx","index":5,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"f1d17b3b-0bcd-4612-870e-6a9aed7e40de","title":"Demo - Supporting Schema Variation by Media Type (Output, IOperationFilter)","watched":false},{"authorized":true,"clipId":"f4c8e569-f6fb-4ef9-a3c5-0743bdcb5c22","duration":104,"formattedDuration":"1:44","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:6:kevin-dockx","index":6,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"f4c8e569-f6fb-4ef9-a3c5-0743bdcb5c22","title":"OpenAPI Support for Schema Variation by Media Type (Input)","watched":false},{"authorized":true,"clipId":"a044b96f-7eb8-47b0-b761-04354cd2396f","duration":251,"formattedDuration":"4:11","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:7:kevin-dockx","index":7,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"a044b96f-7eb8-47b0-b761-04354cd2396f","title":"Demo - Supporting Schema Variation by Media Type (Input)","watched":false},{"authorized":true,"clipId":"6bbd1dbd-cd58-452b-ac71-7e7494f5c8d3","duration":52,"formattedDuration":"0:52","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:8:kevin-dockx","index":8,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"6bbd1dbd-cd58-452b-ac71-7e7494f5c8d3","title":"Advanced Scenarios","watched":false},{"authorized":true,"clipId":"300ffdca-8f78-49cd-b297-f6c2144bce21","duration":86,"formattedDuration":"1:26","id":"aspdotnet-core-api-openapi-swagger:00190e2f-8a38-4342-9867-8127622a54b5:9:kevin-dockx","index":9,"moduleIndex":4,"moduleTitle":"Generating OpenAPI Specifications for Advanced Input and Output Scenarios","name":"300ffdca-8f78-49cd-b297-f6c2144bce21","title":"Summary","watched":false}]},{"name":"aa1bbe61-3b10-4fe0-9e63-4659e6969e65","title":"Dealing with Different Versions and Protecting the Documentation","duration":2068,"formattedDuration":"34:28","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"768517b8-022e-4e13-8831-4ba5012ea7c2","duration":38,"formattedDuration":"0:38","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:0:kevin-dockx","index":0,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"768517b8-022e-4e13-8831-4ba5012ea7c2","title":"Coming Up","watched":false},{"authorized":true,"clipId":"e4fd12e8-579e-463d-8e88-fbf21a7413f5","duration":58,"formattedDuration":"0:58","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:1:kevin-dockx","index":1,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"e4fd12e8-579e-463d-8e88-fbf21a7413f5","title":"Working with Multiple OpenAPI Specifications","watched":false},{"authorized":true,"clipId":"2d511824-e79d-4020-8042-bfef3b958c6f","duration":211,"formattedDuration":"3:31","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:2:kevin-dockx","index":2,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"2d511824-e79d-4020-8042-bfef3b958c6f","title":"Demo - Working with Multiple OpenAPI Specifications","watched":false},{"authorized":true,"clipId":"919abff6-cfc8-4a36-b11b-01fbe06bd223","duration":110,"formattedDuration":"1:50","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:3:kevin-dockx","index":3,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"919abff6-cfc8-4a36-b11b-01fbe06bd223","title":"Versioning with ASP.NET Core’s Built-in Approach","watched":false},{"authorized":true,"clipId":"a7d5ef34-b1db-43cc-95d8-bec3c0fee651","duration":439,"formattedDuration":"7:19","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:4:kevin-dockx","index":4,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"a7d5ef34-b1db-43cc-95d8-bec3c0fee651","title":"Demo - Versioning Your API","watched":false},{"authorized":true,"clipId":"56440d93-1c9d-4475-827b-7819707b40cc","duration":474,"formattedDuration":"7:54","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:5:kevin-dockx","index":5,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"56440d93-1c9d-4475-827b-7819707b40cc","title":"Demo - Matching OpenAPI Specifications to API Versions","watched":false},{"authorized":true,"clipId":"b9cc0652-2411-48b2-87c2-f909526abcb6","duration":179,"formattedDuration":"2:59","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:6:kevin-dockx","index":6,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"b9cc0652-2411-48b2-87c2-f909526abcb6","title":"Protecting Your API","watched":false},{"authorized":true,"clipId":"84167422-465e-407b-8abf-20b795a3a0a7","duration":220,"formattedDuration":"3:40","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:7:kevin-dockx","index":7,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"84167422-465e-407b-8abf-20b795a3a0a7","title":"Demo - Protecting Your API","watched":false},{"authorized":true,"clipId":"77246088-61c9-43ac-bc65-7b1b64ec0239","duration":247,"formattedDuration":"4:07","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:8:kevin-dockx","index":8,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"77246088-61c9-43ac-bc65-7b1b64ec0239","title":"Demo - Adding Authentication Support to the OpenAPI Specification","watched":false},{"authorized":true,"clipId":"ca414022-f44b-4472-a3da-1a8c94537a34","duration":89,"formattedDuration":"1:29","id":"aspdotnet-core-api-openapi-swagger:aa1bbe61-3b10-4fe0-9e63-4659e6969e65:9:kevin-dockx","index":9,"moduleIndex":5,"moduleTitle":"Dealing with Different Versions and Protecting the Documentation","name":"ca414022-f44b-4472-a3da-1a8c94537a34","title":"Summary","watched":false}]},{"name":"707baed9-cd81-44c9-8e54-5280c7b54a0e","title":"Improving Your Documentation with Advanced Customization","duration":1095,"formattedDuration":"18:15","author":"kevin-dockx","authorized":true,"clips":[{"authorized":true,"clipId":"dffe3033-3789-46e9-8919-2dfa4bc7e76c","duration":45,"formattedDuration":"0:45","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:0:kevin-dockx","index":0,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"dffe3033-3789-46e9-8919-2dfa4bc7e76c","title":"Coming Up","watched":false},{"authorized":true,"clipId":"2ad093ec-6620-474f-931b-c831e9abe7a0","duration":33,"formattedDuration":"0:33","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:1:kevin-dockx","index":1,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"2ad093ec-6620-474f-931b-c831e9abe7a0","title":"Enriching Comments with Markdown","watched":false},{"authorized":true,"clipId":"62cadb66-f23a-45d3-ad52-3d3d1711fb9e","duration":203,"formattedDuration":"3:23","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:2:kevin-dockx","index":2,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"62cadb66-f23a-45d3-ad52-3d3d1711fb9e","title":"Demo - Enriching Comments with Markdown","watched":false},{"authorized":true,"clipId":"2dd11e37-993c-4b60-9087-85d745ca3b45","duration":127,"formattedDuration":"2:07","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:3:kevin-dockx","index":3,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"2dd11e37-993c-4b60-9087-85d745ca3b45","title":"Demo - Basic UI Customization with the Configuration API","watched":false},{"authorized":true,"clipId":"5971d612-7df2-47b2-ade7-8a100e14a465","duration":49,"formattedDuration":"0:49","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:4:kevin-dockx","index":4,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"5971d612-7df2-47b2-ade7-8a100e14a465","title":"Supporting Deep Linking","watched":false},{"authorized":true,"clipId":"2be7e5d8-f911-46ea-b995-2d5e67a60cc1","duration":59,"formattedDuration":"0:59","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:5:kevin-dockx","index":5,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"2be7e5d8-f911-46ea-b995-2d5e67a60cc1","title":"Demo - Supporting Deep Linking","watched":false},{"authorized":true,"clipId":"50a8875f-d555-40f3-a117-d695f444f23d","duration":139,"formattedDuration":"2:19","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:6:kevin-dockx","index":6,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"50a8875f-d555-40f3-a117-d695f444f23d","title":"Branding the UI","watched":false},{"authorized":true,"clipId":"af413aad-87ce-450f-a483-157140736b2c","duration":177,"formattedDuration":"2:57","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:7:kevin-dockx","index":7,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"af413aad-87ce-450f-a483-157140736b2c","title":"Demo - Branding the UI by Injecting Custom CSS","watched":false},{"authorized":true,"clipId":"2a8c4a4b-63df-4097-8601-b6bd73caa465","duration":191,"formattedDuration":"3:11","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:8:kevin-dockx","index":8,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"2a8c4a4b-63df-4097-8601-b6bd73caa465","title":"Demo - Branding the UI by Injecting a Custom Index Page","watched":false},{"authorized":true,"clipId":"afa95111-8358-4b87-8922-7dd85909907f","duration":68,"formattedDuration":"1:08","id":"aspdotnet-core-api-openapi-swagger:707baed9-cd81-44c9-8e54-5280c7b54a0e:9:kevin-dockx","index":9,"moduleIndex":6,"moduleTitle":"Improving Your Documentation with Advanced Customization","name":"afa95111-8358-4b87-8922-7dd85909907f","title":"Summary","watched":false}]}]}}}}}
[download] Downloading playlist: Documenting an ASP.NET Core API with OpenAPI / Swagger
[pluralsight:course] playlist Documenting an ASP.NET Core API with OpenAPI / Swagger: Collected 61 video ids (downloading 61 of them)
[download] Downloading video 1 of 61
[pluralsight] Downloading login page
[pluralsight] Dumping request to https://app.pluralsight.com/id/



<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="utf-8" /><script type="text/javascript">window.NREUM||(NREUM={});NREUM.info = {"beacon":"bam.nr-data.net","errorBeacon":"bam.nr-data.net","licenseKey":"2700af8a3c","applicationID":"8295735","transactionName":"Z1ZRN0EDCEMDABVYWl4cfjVwTTVZBQ0oX3ZfXUcRXA4KVRBMKF9RVUs=","queueTime":0,"applicationTime":6,"agent":"","atts":""}</script><script type="text/javascript">(window.NREUM||(NREUM={})).loader_config={xpid:"VwUGVl5VGwsCXVRVBAQ="};window.NREUM||(NREUM={}),__nr_require=function(t,n,e){function r(e){if(!n[e]){var o=n[e]={exports:{}};t[e][0].call(o.exports,function(n){var o=t[e][1][n];return r(o||n)},o,o.exports)}return n[e].exports}if("function"==typeof __nr_require)return __nr_require;for(var o=0;o<e.length;o++)r(e[o]);return r}({1:[function(t,n,e){function r(t){try{s.console&&console.log(t)}catch(n){}}var o,i=t("ee"),a=t(16),s={};try{o=localStorage.getItem("__nr_flags").split(","),console&&"function"==typeof console.log&&(s.console=!0,o.indexOf("dev")!==-1&&(s.dev=!0),o.indexOf("nr_dev")!==-1&&(s.nrDev=!0))}catch(c){}s.nrDev&&i.on("internal-error",function(t){r(t.stack)}),s.dev&&i.on("fn-err",function(t,n,e){r(e.stack)}),s.dev&&(r("NR AGENT IN DEVELOPMENT MODE"),r("flags: "+a(s,function(t,n){return t}).join(", ")))},{}],2:[function(t,n,e){function r(t,n,e,r,s){try{p?p-=1:o(s||new UncaughtException(t,n,e),!0)}catch(f){try{i("ierr",[f,c.now(),!0])}catch(d){}}return"function"==typeof u&&u.apply(this,a(arguments))}function UncaughtException(t,n,e){this.message=t||"Uncaught error with no additional information",this.sourceURL=n,this.line=e}function o(t,n){var e=n?null:c.now();i("err",[t,e])}var i=t("handle"),a=t(17),s=t("ee"),c=t("loader"),f=t("gos"),u=window.onerror,d=!1,l="nr@seenError",p=0;c.features.err=!0,t(1),window.onerror=r;try{throw new Error}catch(h){"stack"in h&&(t(8),t(7),"addEventListener"in window&&t(5),c.xhrWrappable&&t(9),d=!0)}s.on("fn-start",function(t,n,e){d&&(p+=1)}),s.on("fn-err",function(t,n,e){d&&!e[l]&&(f(e,l,function(){return!0}),this.thrown=!0,o(e))}),s.on("fn-end",function(){d&&!this.thrown&&p>0&&(p-=1)}),s.on("internal-error",function(t){i("ierr",[t,c.now(),!0])})},{}],3:[function(t,n,e){t("loader").features.ins=!0},{}],4:[function(t,n,e){function r(t){}if(window.performance&&window.performance.timing&&window.performance.getEntriesByType){var o=t("ee"),i=t("handle"),a=t(8),s=t(7),c="learResourceTimings",f="addEventListener",u="resourcetimingbufferfull",d="bstResource",l="resource",p="-start",h="-end",m="fn"+p,v="fn"+h,w="bstTimer",y="pushState",g=t("loader");g.features.stn=!0,t(6);var b=NREUM.o.EV;o.on(m,function(t,n){var e=t[0];e instanceof b&&(this.bstStart=g.now())}),o.on(v,function(t,n){var e=t[0];e instanceof b&&i("bst",[e,n,this.bstStart,g.now()])}),a.on(m,function(t,n,e){this.bstStart=g.now(),this.bstType=e}),a.on(v,function(t,n){i(w,[n,this.bstStart,g.now(),this.bstType])}),s.on(m,function(){this.bstStart=g.now()}),s.on(v,function(t,n){i(w,[n,this.bstStart,g.now(),"requestAnimationFrame"])}),o.on(y+p,function(t){this.time=g.now(),this.startPath=location.pathname+location.hash}),o.on(y+h,function(t){i("bstHist",[location.pathname+location.hash,this.startPath,this.time])}),f in window.performance&&(window.performance["c"+c]?window.performance[f](u,function(t){i(d,[window.performance.getEntriesByType(l)]),window.performance["c"+c]()},!1):window.performance[f]("webkit"+u,function(t){i(d,[window.performance.getEntriesByType(l)]),window.performance["webkitC"+c]()},!1)),document[f]("scroll",r,{passive:!0}),document[f]("keypress",r,!1),document[f]("click",r,!1)}},{}],5:[function(t,n,e){function r(t){for(var n=t;n&&!n.hasOwnProperty(u);)n=Object.getPrototypeOf(n);n&&o(n)}function o(t){s.inPlace(t,[u,d],"-",i)}function i(t,n){return t[1]}var a=t("ee").get("events"),s=t(19)(a,!0),c=t("gos"),f=XMLHttpRequest,u="addEventListener",d="removeEventListener";n.exports=a,"getPrototypeOf"in Object?(r(document),r(window),r(f.prototype)):f.prototype.hasOwnProperty(u)&&(o(window),o(f.prototype)),a.on(u+"-start",function(t,n){var e=t[1],r=c(e,"nr@wrapped",function(){function t(){if("function"==typeof e.handleEvent)return e.handleEvent.apply(e,arguments)}var n={object:t,"function":e}[typeof e];return n?s(n,"fn-",null,n.name||"anonymous"):e});this.wrapped=t[1]=r}),a.on(d+"-start",function(t){t[1]=this.wrapped||t[1]})},{}],6:[function(t,n,e){var r=t("ee").get("history"),o=t(19)(r);n.exports=r,o.inPlace(window.history,["pushState","replaceState"],"-")},{}],7:[function(t,n,e){var r=t("ee").get("raf"),o=t(19)(r),i="equestAnimationFrame";n.exports=r,o.inPlace(window,["r"+i,"mozR"+i,"webkitR"+i,"msR"+i],"raf-"),r.on("raf-start",function(t){t[0]=o(t[0],"fn-")})},{}],8:[function(t,n,e){function r(t,n,e){t[0]=a(t[0],"fn-",null,e)}function o(t,n,e){this.method=e,this.timerDuration=isNaN(t[1])?0:+t[1],t[0]=a(t[0],"fn-",this,e)}var i=t("ee").get("timer"),a=t(19)(i),s="setTimeout",c="setInterval",f="clearTimeout",u="-start",d="-";n.exports=i,a.inPlace(window,[s,"setImmediate"],s+d),a.inPlace(window,[c],c+d),a.inPlace(window,[f,"clearImmediate"],f+d),i.on(c+u,r),i.on(s+u,o)},{}],9:[function(t,n,e){function r(t,n){d.inPlace(n,["onreadystatechange"],"fn-",s)}function o(){var t=this,n=u.context(t);t.readyState>3&&!n.resolved&&(n.resolved=!0,u.emit("xhr-resolved",[],t)),d.inPlace(t,y,"fn-",s)}function i(t){g.push(t),h&&(x?x.then(a):v?v(a):(E=-E,O.data=E))}function a(){for(var t=0;t<g.length;t++)r([],g[t]);g.length&&(g=[])}function s(t,n){return n}function c(t,n){for(var e in t)n[e]=t[e];return n}t(5);var f=t("ee"),u=f.get("xhr"),d=t(19)(u),l=NREUM.o,p=l.XHR,h=l.MO,m=l.PR,v=l.SI,w="readystatechange",y=["onload","onerror","onabort","onloadstart","onloadend","onprogress","ontimeout"],g=[];n.exports=u;var b=window.XMLHttpRequest=function(t){var n=new p(t);try{u.emit("new-xhr",[n],n),n.addEventListener(w,o,!1)}catch(e){try{u.emit("internal-error",[e])}catch(r){}}return n};if(c(p,b),b.prototype=p.prototype,d.inPlace(b.prototype,["open","send"],"-xhr-",s),u.on("send-xhr-start",function(t,n){r(t,n),i(n)}),u.on("open-xhr-start",r),h){var x=m&&m.resolve();if(!v&&!m){var E=1,O=document.createTextNode(E);new h(a).observe(O,{characterData:!0})}}else f.on("fn-end",function(t){t[0]&&t[0].type===w||a()})},{}],10:[function(t,n,e){function r(t){var n=this.params,e=this.metrics;if(!this.ended){this.ended=!0;for(var r=0;r<d;r++)t.removeEventListener(u[r],this.listener,!1);if(!n.aborted){if(e.duration=a.now()-this.startTime,4===t.readyState){n.status=t.status;var i=o(t,this.lastSize);if(i&&(e.rxSize=i),this.sameOrigin){var c=t.getResponseHeader("X-NewRelic-App-Data");c&&(n.cat=c.split(", ").pop())}}else n.status=0;e.cbTime=this.cbTime,f.emit("xhr-done",[t],t),s("xhr",[n,e,this.startTime])}}}function o(t,n){var e=t.responseType;if("json"===e&&null!==n)return n;var r="arraybuffer"===e||"blob"===e||"json"===e?t.response:t.responseText;return h(r)}function i(t,n){var e=c(n),r=t.params;r.host=e.hostname+":"+e.port,r.pathname=e.pathname,t.sameOrigin=e.sameOrigin}var a=t("loader");if(a.xhrWrappable){var s=t("handle"),c=t(11),f=t("ee"),u=["load","error","abort","timeout"],d=u.length,l=t("id"),p=t(14),h=t(13),m=window.XMLHttpRequest;a.features.xhr=!0,t(9),f.on("new-xhr",function(t){var n=this;n.totalCbs=0,n.called=0,n.cbTime=0,n.end=r,n.ended=!1,n.xhrGuids={},n.lastSize=null,p&&(p>34||p<10)||window.opera||t.addEventListener("progress",function(t){n.lastSize=t.loaded},!1)}),f.on("open-xhr-start",function(t){this.params={method:t[0]},i(this,t[1]),this.metrics={}}),f.on("open-xhr-end",function(t,n){"loader_config"in NREUM&&"xpid"in NREUM.loader_config&&this.sameOrigin&&n.setRequestHeader("X-NewRelic-ID",NREUM.loader_config.xpid)}),f.on("send-xhr-start",function(t,n){var e=this.metrics,r=t[0],o=this;if(e&&r){var i=h(r);i&&(e.txSize=i)}this.startTime=a.now(),this.listener=function(t){try{"abort"===t.type&&(o.params.aborted=!0),("load"!==t.type||o.called===o.totalCbs&&(o.onloadCalled||"function"!=typeof n.onload))&&o.end(n)}catch(e){try{f.emit("internal-error",[e])}catch(r){}}};for(var s=0;s<d;s++)n.addEventListener(u[s],this.listener,!1)}),f.on("xhr-cb-time",function(t,n,e){this.cbTime+=t,n?this.onloadCalled=!0:this.called+=1,this.called!==this.totalCbs||!this.onloadCalled&&"function"==typeof e.onload||this.end(e)}),f.on("xhr-load-added",function(t,n){var e=""+l(t)+!!n;this.xhrGuids&&!this.xhrGuids[e]&&(this.xhrGuids[e]=!0,this.totalCbs+=1)}),f.on("xhr-load-removed",function(t,n){var e=""+l(t)+!!n;this.xhrGuids&&this.xhrGuids[e]&&(delete this.xhrGuids[e],this.totalCbs-=1)}),f.on("addEventListener-end",function(t,n){n instanceof m&&"load"===t[0]&&f.emit("xhr-load-added",[t[1],t[2]],n)}),f.on("removeEventListener-end",function(t,n){n instanceof m&&"load"===t[0]&&f.emit("xhr-load-removed",[t[1],t[2]],n)}),f.on("fn-start",function(t,n,e){n instanceof m&&("onload"===e&&(this.onload=!0),("load"===(t[0]&&t[0].type)||this.onload)&&(this.xhrCbStart=a.now()))}),f.on("fn-end",function(t,n){this.xhrCbStart&&f.emit("xhr-cb-time",[a.now()-this.xhrCbStart,this.onload,n],n)})}},{}],11:[function(t,n,e){n.exports=function(t){var n=document.createElement("a"),e=window.location,r={};n.href=t,r.port=n.port;var o=n.href.split("://");!r.port&&o[1]&&(r.port=o[1].split("/")[0].split("@").pop().split(":")[1]),r.port&&"0"!==r.port||(r.port="https"===o[0]?"443":"80"),r.hostname=n.hostname||e.hostname,r.pathname=n.pathname,r.protocol=o[0],"/"!==r.pathname.charAt(0)&&(r.pathname="/"+r.pathname);var i=!n.protocol||":"===n.protocol||n.protocol===e.protocol,a=n.hostname===document.domain&&n.port===e.port;return r.sameOrigin=i&&(!n.hostname||a),r}},{}],12:[function(t,n,e){function r(){}function o(t,n,e){return function(){return i(t,[f.now()].concat(s(arguments)),n?null:this,e),n?void 0:this}}var i=t("handle"),a=t(16),s=t(17),c=t("ee").get("tracer"),f=t("loader"),u=NREUM;"undefined"==typeof window.newrelic&&(newrelic=u);var d=["setPageViewName","setCustomAttribute","setErrorHandler","finished","addToTrace","inlineHit","addRelease"],l="api-",p=l+"ixn-";a(d,function(t,n){u[n]=o(l+n,!0,"api")}),u.addPageAction=o(l+"addPageAction",!0),u.setCurrentRouteName=o(l+"routeName",!0),n.exports=newrelic,u.interaction=function(){return(new r).get()};var h=r.prototype={createTracer:function(t,n){var e={},r=this,o="function"==typeof n;return i(p+"tracer",[f.now(),t,e],r),function(){if(c.emit((o?"":"no-")+"fn-start",[f.now(),r,o],e),o)try{return n.apply(this,arguments)}catch(t){throw c.emit("fn-err",[arguments,this,t],e),t}finally{c.emit("fn-end",[f.now()],e)}}}};a("actionText,setName,setAttribute,save,ignore,onEnd,getContext,end,get".split(","),function(t,n){h[n]=o(p+n)}),newrelic.noticeError=function(t,n){"string"==typeof t&&(t=new Error(t)),i("err",[t,f.now(),!1,n])}},{}],13:[function(t,n,e){n.exports=function(t){if("string"==typeof t&&t.length)return t.length;if("object"==typeof t){if("undefined"!=typeof ArrayBuffer&&t instanceof ArrayBuffer&&t.byteLength)return t.byteLength;if("undefined"!=typeof Blob&&t instanceof Blob&&t.size)return t.size;if(!("undefined"!=typeof FormData&&t instanceof FormData))try{return JSON.stringify(t).length}catch(n){return}}}},{}],14:[function(t,n,e){var r=0,o=navigator.userAgent.match(/Firefox[\/\s](\d+\.\d+)/);o&&(r=+o[1]),n.exports=r},{}],15:[function(t,n,e){function r(t,n){if(!o)return!1;if(t!==o)return!1;if(!n)return!0;if(!i)return!1;for(var e=i.split("."),r=n.split("."),a=0;a<r.length;a++)if(r[a]!==e[a])return!1;return!0}var o=null,i=null,a=/Version\/(\S+)\s+Safari/;if(navigator.userAgent){var s=navigator.userAgent,c=s.match(a);c&&s.indexOf("Chrome")===-1&&s.indexOf("Chromium")===-1&&(o="Safari",i=c[1])}n.exports={agent:o,version:i,match:r}},{}],16:[function(t,n,e){function r(t,n){var e=[],r="",i=0;for(r in t)o.call(t,r)&&(e[i]=n(r,t[r]),i+=1);return e}var o=Object.prototype.hasOwnProperty;n.exports=r},{}],17:[function(t,n,e){function r(t,n,e){n||(n=0),"undefined"==typeof e&&(e=t?t.length:0);for(var r=-1,o=e-n||0,i=Array(o<0?0:o);++r<o;)i[r]=t[n+r];return i}n.exports=r},{}],18:[function(t,n,e){n.exports={exists:"undefined"!=typeof window.performance&&window.performance.timing&&"undefined"!=typeof window.performance.timing.navigationStart}},{}],19:[function(t,n,e){function r(t){return!(t&&t instanceof Function&&t.apply&&!t[a])}var o=t("ee"),i=t(17),a="nr@original",s=Object.prototype.hasOwnProperty,c=!1;n.exports=function(t,n){function e(t,n,e,o){function nrWrapper(){var r,a,s,c;try{a=this,r=i(arguments),s="function"==typeof e?e(r,a):e||{}}catch(f){l([f,"",[r,a,o],s])}u(n+"start",[r,a,o],s);try{return c=t.apply(a,r)}catch(d){throw u(n+"err",[r,a,d],s),d}finally{u(n+"end",[r,a,c],s)}}return r(t)?t:(n||(n=""),nrWrapper[a]=t,d(t,nrWrapper),nrWrapper)}function f(t,n,o,i){o||(o="");var a,s,c,f="-"===o.charAt(0);for(c=0;c<n.length;c++)s=n[c],a=t[s],r(a)||(t[s]=e(a,f?s+o:o,i,s))}function u(e,r,o){if(!c||n){var i=c;c=!0;try{t.emit(e,r,o,n)}catch(a){l([a,e,r,o])}c=i}}function d(t,n){if(Object.defineProperty&&Object.keys)try{var e=Object.keys(t);return e.forEach(function(e){Object.defineProperty(n,e,{get:function(){return t[e]},set:function(n){return t[e]=n,n}})}),n}catch(r){l([r])}for(var o in t)s.call(t,o)&&(n[o]=t[o]);return n}function l(n){try{t.emit("internal-error",n)}catch(e){}}return t||(t=o),e.inPlace=f,e.flag=a,e}},{}],ee:[function(t,n,e){function r(){}function o(t){function n(t){return t&&t instanceof r?t:t?c(t,s,i):i()}function e(e,r,o,i){if(!l.aborted||i){t&&t(e,r,o);for(var a=n(o),s=m(e),c=s.length,f=0;f<c;f++)s[f].apply(a,r);var d=u[g[e]];return d&&d.push([b,e,r,a]),a}}function p(t,n){y[t]=m(t).concat(n)}function h(t,n){var e=y[t];if(e)for(var r=0;r<e.length;r++)e[r]===n&&e.splice(r,1)}function m(t){return y[t]||[]}function v(t){return d[t]=d[t]||o(e)}function w(t,n){f(t,function(t,e){n=n||"feature",g[e]=n,n in u||(u[n]=[])})}var y={},g={},b={on:p,addEventListener:p,removeEventListener:h,emit:e,get:v,listeners:m,context:n,buffer:w,abort:a,aborted:!1};return b}function i(){return new r}function a(){(u.api||u.feature)&&(l.aborted=!0,u=l.backlog={})}var s="nr@context",c=t("gos"),f=t(16),u={},d={},l=n.exports=o();l.backlog=u},{}],gos:[function(t,n,e){function r(t,n,e){if(o.call(t,n))return t[n];var r=e();if(Object.defineProperty&&Object.keys)try{return Object.defineProperty(t,n,{value:r,writable:!0,enumerable:!1}),r}catch(i){}return t[n]=r,r}var o=Object.prototype.hasOwnProperty;n.exports=r},{}],handle:[function(t,n,e){function r(t,n,e,r){o.buffer([t],r),o.emit(t,n,e)}var o=t("ee").get("handle");n.exports=r,r.ee=o},{}],id:[function(t,n,e){function r(t){var n=typeof t;return!t||"object"!==n&&"function"!==n?-1:t===window?0:a(t,i,function(){return o++})}var o=1,i="nr@id",a=t("gos");n.exports=r},{}],loader:[function(t,n,e){function r(){if(!E++){var t=x.info=NREUM.info,n=p.getElementsByTagName("script")[0];if(setTimeout(u.abort,3e4),!(t&&t.licenseKey&&t.applicationID&&n))return u.abort();f(g,function(n,e){t[n]||(t[n]=e)}),c("mark",["onload",a()+x.offset],null,"api");var e=p.createElement("script");e.src="https://"+t.agent,n.parentNode.insertBefore(e,n)}}function o(){"complete"===p.readyState&&i()}function i(){c("mark",["domContent",a()+x.offset],null,"api")}function a(){return O.exists&&performance.now?Math.round(performance.now()):(s=Math.max((new Date).getTime(),s))-x.offset}var s=(new Date).getTime(),c=t("handle"),f=t(16),u=t("ee"),d=t(15),l=window,p=l.document,h="addEventListener",m="attachEvent",v=l.XMLHttpRequest,w=v&&v.prototype;NREUM.o={ST:setTimeout,SI:l.setImmediate,CT:clearTimeout,XHR:v,REQ:l.Request,EV:l.Event,PR:l.Promise,MO:l.MutationObserver};var y=""+location,g={beacon:"bam.nr-data.net",errorBeacon:"bam.nr-data.net",agent:"js-agent.newrelic.com/nr-1118.min.js"},b=v&&w&&w[h]&&!/CriOS/.test(navigator.userAgent),x=n.exports={offset:s,now:a,origin:y,features:{},xhrWrappable:b,userAgent:d};t(12),p[h]?(p[h]("DOMContentLoaded",i,!1),l[h]("load",r,!1)):(p[m]("onreadystatechange",o),l[m]("onload",r)),c("mark",["firstbyte",s],null,"api");var E=0,O=t(18)},{}]},{},["loader",2,10,4,3]);</script>
    <meta name="viewport" content="width=device-width,initial-scale=1">
    <title>Sign In - Pluralsight</title>
    

<script src="//assets.adobedtm.com/2c5f2b30762ae62377916c09612cd9d60054fba9/satelliteLib-3f2001f88315610d295e482607f7d003c8627d08.js"></script>
<script type="text/javascript">
    !function() {
        var analytics = window.analytics = window.analytics || [];
        if (!analytics.initialize)
            if (analytics.invoked) window.console && console.error && console.error("Segment snippet included twice.");
            else {
                analytics.invoked = !0;
                analytics.methods = [
                    "trackSubmit", "trackClick", "trackLink", "trackForm", "pageview", "identify", "group", "track",
                    "ready", "alias", "page", "once", "off", "on"
                ];
                analytics.factory = function(t) {
                    return function() {
                        var e = Array.prototype.slice.call(arguments);
                        e.unshift(t);
                        analytics.push(e);
                        return analytics;
                    }
                };
                for (var t = 0; t < analytics.methods.length; t++) {
                    var e = analytics.methods[t];
                    analytics[e] = analytics.factory(e)
                }
                analytics.load = function(t) {
                    var e = document.createElement("script");
                    e.type = "text/javascript";
                    e.async = !0;
                    e.src = ("https:" === document.location.protocol ? "https://" : "http://") +
                        "cdn.segment.com/analytics.js/v1/" +
                        t +
                        "/analytics.min.js";
                    var n = document.getElementsByTagName("script")[0];
                    n.parentNode.insertBefore(e, n)
                };
                analytics.SNIPPET_VERSION = "3.0.1";

            }
    }();
</script>

<script src="//s.pluralsight.com/analytics/analytics-facade.v3.11.0.js"></script>

<script type="text/javascript">
    var analyticsFacade = new window.AnalyticsFacade({ contextName: 'identity' });
    analytics.load("n2LLbFI1MDxFKBLzI0es2Z7PrDhu6jEA");
    analyticsFacade.page();
</script>

<!--BEGIN QUALTRICS SITE INTERCEPT-->
<script type='text/javascript'>
    var qualtricsSampleRate = "100";
    var qualtricsZoneId = "ZN_eJW6FzXpOC4z2sJ";
    var qualtricsUrl = "//znejw6fzxpoc4z2sj-pluralsight.siteintercept.qualtrics.com/WRSiteInterceptEngine/?Q_ZID=ZN_eJW6FzXpOC4z2sJ&amp;Q_LOC=";

    (function(){var g=function(e,h,f,g){
            this.get=function(a){for(var a=a+"=",c=document.cookie.split(";"),b=0,e=c.length;b<e;b++){for(var d=c[b];" "==d.charAt(0);)d=d.substring(1,d.length);if(0==d.indexOf(a))return d.substring(a.length,d.length)}return null};
            this.set=function(a,c){var b="",b=new Date;b.setTime(b.getTime()+6048E5);b="; expires="+b.toGMTString();document.cookie=a+"="+c+b+"; path=/; "};
            this.check=function(){var a=this.get(f);if(a)a=a.split(":");else if(100!=e)"v"==h&&(e=Math.random()>=e/100?0:100),a=[h,e,0],this.set(f,a.join(":"));else return!0;var c=a[1];if(100==c)return!0;switch(a[0]){case "v":return!1;case "r":return c=a[2]%Math.floor(100/c),a[2]++,this.set(f,a.join(":")),!c}return!0};
            this.go=function(){if(this.check()){var a=document.createElement("script");a.type="text/javascript";a.src=g+ "&t=" + (new Date()).getTime();document.body&&document.body.appendChild(a)}};
            this.start=function(){var a=this;window.addEventListener?window.addEventListener("load",function(){a.go()},!1):window.attachEvent&&window.attachEvent("onload",function(){a.go()})}};
        try { (new g(qualtricsSampleRate, "r", "QSI_S_" + qualtricsZoneId, qualtricsUrl + encodeURIComponent(window.location.href))).start() } catch (i) { }
    })();
</script>

<div id="ZN_eJW6FzXpOC4z2sJ"><!--DO NOT REMOVE-CONTENTS PLACED HERE--></div>
<!--END SITE INTERCEPT-->

    <link rel="stylesheet" href="/id/content/dist/sign-in-276c86c101f9fe64c069.css" />
    <script src="https://code.jquery.com/jquery-1.12.4.min.js"></script>
</head>
<body>
    <input id="pageObjectTag" type="hidden" value="SignInPage" />


    

    <div id="container">
        <div id="left">
            <div class="spacer"></div>
            <div class="signin">
                <div class="wrapper">
                    <div class="logo">
                        <img src="/id/content/img/login-logo.png" alt="Pluralsight" />
                    </div>
<form action="/id/" id="signInForm" method="post"><input id="RedirectUrl" name="RedirectUrl" type="hidden" value="" />                        <div>
                            <label Class="psds-text-input__label" for="Username">Email or Username</label>
                            <input Class="psds-text-input__field psds-text-input__field--appearance-subtle" autocapitalize="none" autocorrect="off" data-val="true" data-val-required="The Email or Username field is required." id="Username" name="Username" type="text" value="" />
                        </div>
                        <div>
                            <label Class="psds-text-input__label" for="Password">Password</label>
                            <input Class="psds-text-input__field psds-text-input__field--appearance-subtle" data-val="true" data-val-required="The Password field is required." id="Password" name="Password" type="password" />
                        </div>
<input id="ShowCaptcha" name="ShowCaptcha" type="hidden" value="False" />
<input id="ReCaptchaSiteKey" name="ReCaptchaSiteKey" type="hidden" value="6LeVIgoTAAAAAIhx_TOwDWIXecbvzcWyjQDbXsaV" />                        <button type="submit" id="login" class="psds-button psds-button--size-medium">
                            Sign in
                        </button>
</form>
                    <div class="links">
                        <a class="psds-link psds-link--appearance-default" href="/id/ForgotPassword">Forgot password?</a>
                        <a class="psds-link psds-link--appearance-default" href="/id/signin/sso?redirectTo=">
                            Sign in with company or school
                        </a>
                    </div>

                    <div class="or">
                        <hr class="bar" />
                        <span>OR</span>
                        <hr class="bar" />
                    </div>

                    <a href="https://www.pluralsight.com/pricing" id="create-account-link" class="psds-button psds-button--size-medium psds-button--appearance-stroke">
                        <span class="psds-button__text">Create an account</span>
                    </a>
                </div>
            </div>
            <footer id="footer">
                Copyright &copy; 2004 - 2019 Pluralsight LLC. All rights reserved.
                <div>
                    <a class="psds-link psds-link--appearance-subtle" href="https://www.pluralsight.com/terms">Terms of Use</a>
                    | <a class="psds-link psds-link--appearance-subtle" href="https://www.pluralsight.com/privacy">Privacy Policy</a>
                </div>
            </footer>
        </div>
        <div id="right">
            <div class="banner">
                <div class="marketing-banner">
                    <div class="marketing-banner-text">Let's create the future <strong>together</strong>.</div>
                    <a href="https://www.pluralsight.com/pricing" class="psds-button psds-button--size-medium psds-button--appearance-stroke">
                        <span class="psds-button__text">Start a FREE 10-day trial</span>
                    </a>
                </div>
            </div>
        </div>
    </div>
    <script>
        $('.alert').append('<div class="close" aria-label="close">&times;</div>');
        $('.alert .close').click(function () {
            $(this).parent().hide();
        });
        $(function () {
            $("#signInForm").submit(function () {
                analyticsFacade.track('user_sign_in_button_clicked', {});
            });
            $("#errorMessage .close").click(function() {
                analyticsFacade.track('user_sign_in_error_message_dismissed', {});
            });
        });
    </script>
</body>
</html>
[pluralsight] Logging in
ERROR: Unable to download webpage: HTTP Error 503: Service Temporarily Unavailable (caused by HTTPError()); please report this issue on https://yt-dl.org/bug . Make sure you are using the latest version; type  youtube-dl -U  to update. Be sure to call youtube-dl with the --verbose flag and include its complete output.
Kerruba commented 5 years ago

I get the same error here:

youtube-dl --verbose --username "xxxx" --password "xxxxx" https://app.pluralsight.com/library/courses/oauth2-json-web-tokens-openid-connect-introduction/table-of-contents
[debug] System config: []
[debug] User config: []
[debug] Custom config: []
[debug] Command-line args: [u'--verbose', u'--username', u'PRIVATE', u'--password', u'PRIVATE', u'https://app.pluralsight.com/library/courses/oauth2-json-web-tokens-openid-connect-introduction/table-of-contents']
[debug] Encodings: locale UTF-8, fs UTF-8, out UTF-8, pref UTF-8
[debug] youtube-dl version 2019.03.09
[debug] Python version 2.7.15 (CPython) - Linux-4.15.0-1033-oem-x86_64-with-debian-buster-sid
[debug] exe versions: none
[debug] Proxy map: {}
[pluralsight:course] oauth2-json-web-tokens-openid-connect-introduction: Downloading JSON metadata
[download] Downloading playlist: Introduction to OAuth2, OpenID Connect and JSON Web Tokens (JWT)
[pluralsight:course] playlist Introduction to OAuth2, OpenID Connect and JSON Web Tokens (JWT): Collected 48 video ids (downloading 48 of them)
[download] Downloading video 1 of 48
[pluralsight] Downloading login page
[pluralsight] Logging in
ERROR: Unable to download webpage: HTTP Error 503: Service Temporarily Unavailable (caused by HTTPError()); please report this issue on https://yt-dl.org/bug . Make sure you
are using the latest version; type  youtube-dl -U  to update. Be sure to call youtube-dl with the --verbose flag and include its complete output.
  File "/usr/local/bin/youtube-dl/youtube_dl/extractor/common.py", line 619, in _request_webpage
    return self._downloader.urlopen(url_or_request)
  File "/usr/local/bin/youtube-dl/youtube_dl/YoutubeDL.py", line 2225, in urlopen
    return self._opener.open(req, timeout=self._socket_timeout)
  File "/home/linuxbrew/.linuxbrew/Cellar/python@2/2.7.15_2/lib/python2.7/urllib2.py", line 435, in open
    response = meth(req, response)
  File "/home/linuxbrew/.linuxbrew/Cellar/python@2/2.7.15_2/lib/python2.7/urllib2.py", line 548, in http_response
    'http', request, response, code, msg, hdrs)
  File "/home/linuxbrew/.linuxbrew/Cellar/python@2/2.7.15_2/lib/python2.7/urllib2.py", line 473, in error
    return self._call_chain(*args)
  File "/home/linuxbrew/.linuxbrew/Cellar/python@2/2.7.15_2/lib/python2.7/urllib2.py", line 407, in _call_chain
    result = func(*args)
  File "/home/linuxbrew/.linuxbrew/Cellar/python@2/2.7.15_2/lib/python2.7/urllib2.py", line 556, in http_error_default
    raise HTTPError(req.get_full_url(), code, msg, hdrs, fp)
Kerruba commented 5 years ago

@jaan143 and @davidneudorfer, something changed for you?

Kerruba commented 5 years ago

I was able to make it work by using a different IP (a VPN in my case) I took inspiration from https://github.com/ytdl-org/youtube-dl/issues/18534 Now it seems to work

xvMODvx commented 5 years ago

I was having problems running it the way I've always done it. The way I solved the problem was to try using youtube-dl through pip instead of the version through npm like I was. Hope this helps someone.