Transcript #111: loguru: Python logging made simple
Return to episode page view on github00:00 Hello and welcome to Python Bytes, where we deliver Python news and headlines directly to your earbuds.
00:05 This is episode 111, recorded January 4th, 2019.
00:10 I'm Michael Kennedy.
00:11 I'm Brian Ockin.
00:12 Hey, Ryan. Can you believe it's 2019?
00:14 Yeah, it's kind of hard to remember to say that.
00:16 Yeah, it's going to take a while.
00:18 So before we get into the topics, I just want to say thank you to Datadog,
00:22 they're sponsoring this episode.
00:23 Check them out at pythonbytes.fm/datadog.
00:26 More about that later.
00:28 I never really enjoy the built-in logging in Python.
00:31 It's never seemed like super, super clear to me.
00:33 So I've ended up using other packages, something like logbook or something like that,
00:38 or maybe just a print statement.
00:39 But what you found today, Brian, is pretty sweet, actually.
00:43 It might convince me to stop using logbook and use something else.
00:46 You know, I was playing with this morning.
00:48 So what we're talking about is, I think it's logguru.
00:51 I think that's how you pronounce it.
00:53 L-O-G-U-R-U.
00:54 All right, like log and guru smushed together, joined by the G.
00:58 Yeah.
00:58 Or it could be logguru.
00:59 Logguru.
01:00 I don't think so.
01:01 I'm going with logguru.
01:02 And the tagline is, Python logging made stupidly simple.
01:06 And I think this is, it's like a one API function for the most part.
01:11 So the built-in logging for Python, it does a lot.
01:14 And you can have like multiple, multiple logging entry points and multiple logging output points and everything.
01:21 And logguru kind of took the model of everything gets logged to all the places.
01:28 And there's a default place that's standard error.
01:31 And that's better than print mucking up your standard output.
01:34 And by default, it just, you know, just a few lines of code and it works just fine.
01:39 You can just say from logguru, import logger.
01:42 And just use the logger and say like debug or info or whatever.
01:47 But then if you want to do more advanced things, like one of the things I had to play with because I couldn't believe it was this easy, was file logging and log rotation.
01:57 So let's say you're logging some stuff and you want to be able to store it into, log it into a file.
02:02 And then at some point, like make that a new file, like a date stamped file or time stamped or something.
02:10 And it just has that really easy.
02:12 And then you can give it different options for if your file gets to like 50 megabytes, at that point, start a new file.
02:19 And there's even like compression.
02:21 So when you're rolling over to the new one, take the old one and zip it.
02:25 Or you can time it and just do a new log every hour or a new log every day.
02:29 I love the zipping aspect.
02:30 That's awesome.
02:31 It just does that automatically or do you have to tell it to?
02:33 You have to tell it to.
02:35 It's a fairly simple, easy thing.
02:37 And one of the bonuses of this package is the readme on GitHub is kind of a tour of all the features with examples.
02:44 So it's really easy to pop through and see what's going on.
02:49 I mean, I really spent like just a few minutes trying it out and I already love it.
02:53 So I think of this as the logging API that fits in my brain and I can do things right off the bat.
03:00 It's cool.
03:01 Yeah, that's super cool.
03:02 On one of my websites, I had like a bunch of logging happening and I went and checked it out, checked out the log directory.
03:09 And it was like five gigs of text files.
03:11 But they compressed down to like 200 megs or something totally manageable.
03:15 So that's pretty awesome that you can have it kind of do that step for you in the background.
03:19 A couple of things strike me really as nice here.
03:22 One is the use of color.
03:24 It'll print out like here's the time, here's the log level, like info or error or whatever, the message and so on.
03:31 And it'll actually show those in different colors because by default it prints just to logs to the terminal, right?
03:38 Standard out or something like that.
03:40 Yeah.
03:40 And it looks really nice.
03:41 So I tried it both on it just to make sure it was cross compatible and stuff like that.
03:45 I tried it both on a Mac and on a Windows machine.
03:48 And then I also tried it if I'm logging stuff from and running it within PyCharm, how does that look?
03:54 And all of this looks really good still.
03:56 That's awesome.
03:57 And it also has the ability to wrap functions and catch the unhandled errors.
04:03 So the syntax is like log or dot catch all or something.
04:07 It's a decorator.
04:08 And if there's an error, it'll print a colorized, properly indented, formatted traceback.
04:13 Yeah.
04:14 And then it has some traceback options too.
04:16 And the traceback options are even pretty cool.
04:18 They like blow it up into these little mini graph.
04:22 And you can specify how deep, how like just the traceback for the function that they got hit or its parent or how many parents.
04:30 That's pretty cool.
04:30 Yeah.
04:31 One of the things I like about the honesty of here is the last feature is crossed out.
04:36 The last feature says it's 10 times faster than built-in logging.
04:40 No, that's crossed out because clearly adding all these features isn't free.
04:44 It does cost a little bit of performance.
04:47 But there are plans for some of these, some of the things to be critical functions to be implemented and see in the future.
04:54 I think it's convenient right away.
04:56 One of the things I was always interested about is to how to figure out how to get email notification in some cases.
05:04 Like in particular, if you had a critical log error in a critical something, sending off an email to the right person.
05:12 I wouldn't know how to do that right off the bat.
05:15 But this one apparently works cleanly with the notifiers library to be able to send email.
05:21 Yeah.
05:21 Notifiers is nice as well.
05:23 I think we've covered it before.
05:24 One other final thing here is you can actually put color into your statements as well.
05:29 So if I want to have like, they've got a little screencast-y GIF thing on the GitHub repo you can just watch.
05:35 Like it says, there are several options available.
05:38 If you want options to be blue, you put bracket blue, like HTML tags around it.
05:43 And it colorizes it.
05:44 So I think it's really nice for communicating back what's going on.
05:47 Yeah.
05:47 I'm sure it does a lot of cool features.
05:49 One of the things I like about the API is once you've figured out something, other people will be able to tell what you're doing because it's not confusing to read.
05:57 Yeah.
05:57 It's very cool.
05:58 This might be my new favorite logging library.
06:00 Now I have to get over the inertia of actually having my other stuff already working and wanting to switch to it.
06:06 That's going to take a while.
06:06 But this is cool.
06:07 I like it.
06:07 Good find.
06:08 So we had a pretty big episode back in July.
06:13 We had Brett Cannon and Carol Willing on to talk about how Gita Van Rossum had stepped down as the BDFL, the overseer of the Python project.
06:25 Still involved as a core developer, but not making all the decisions and taking all the weight.
06:30 Right?
06:30 Remember that?
06:30 Yeah.
06:31 Well, things have more or less been on hold, stalled out until they can somehow come up with a group of core developers can come up with a way to govern themselves.
06:41 So, for example, Lucas Lange was looking at maybe moving the releases of Python from every 18 months to yearly, which has a bunch of advantages.
06:51 But that's a change that has to be decided on.
06:54 They had no way to decide things.
06:55 So all sorts of stuff like that had just been put on hold.
06:58 Well, we've covered the different governance models that were being considered.
07:03 The big news this week is Python now has decided that it has a new governance model, and they have decided on which one it's going to be.
07:12 Yes.
07:12 It's a, yeah.
07:13 Finally.
07:14 Finally, things can start going.
07:16 Now, don't get too excited.
07:18 Yeah.
07:18 There's a lot of holes left.
07:20 There are a lot of holes.
07:21 So what has been decided is the governance model.
07:24 They still need to decide how the new governance model actually drives Python the project itself.
07:30 So there's like a two-step process.
07:32 Find out how we're going to make decisions, and then the first decision is how does that new organization manage Python.
07:39 So we're like halfway there.
07:40 All right.
07:40 I think also there's still elections to be who's going to be part of this thing.
07:43 So let me give you the rundown by way of Brett Cannon.
07:46 So Brett Cannon, also a core developer, has been on the show a couple times, and it's including the one that I mentioned.
07:51 And so he did a really nice write-up of what was the problem, where have we been, what were the options, and how did they decide.
07:59 So we covered before, like we said, there were seven governance proposals.
08:04 One from like, we'll elect a new dictator, a new BDFL, maybe without the FL for life part, down to maybe we'll have like a panel or something like that.
08:15 So there's some votes.
08:16 The votes were open to all core developers, and they decided we're not going to have other people vote who are not core developers, because this is about the core developers governing themselves.
08:27 And why should other people decide how they get governed, basically, right?
08:31 They don't have as much skin in the game.
08:33 Yeah.
08:33 So people who are deciding sort of their own fate voted.
08:35 And in the end, the winning one was PEP 8016, which is called the Steering Council.
08:44 So from now on, Python will be driven or controlled or led by a steering council, which is very similar to what Django's project organization actually looks like.
08:53 They said, Brett said even that some of the language of the PEP here was copied and pasted directly from Django.
08:59 Interesting.
09:00 Yeah.
09:01 So this is a council of five people who will determine how to run the Python project.
09:05 So the only thing that they can't decide, they basically have absolute power, this group of five developers.
09:14 However, the one thing they cannot decide is how the council is elected.
09:18 So they can't go, you know, this council thing in elections, we don't like them.
09:24 We're going to get rid of those.
09:25 Right.
09:25 Other than that, though, they basically have BDFL like powers.
09:29 Right.
09:29 That's good.
09:30 It means basically that Python will not, project will not be leaderless, but it doesn't directly solve how to get the design and things like do we change the release cycle and things like that.
09:41 Cool, right?
09:42 Yeah.
09:42 Right.
09:43 So now we got to figure out who the council is.
09:46 Yeah.
09:46 So the next step is to elect the council.
09:48 That'll be done Monday.
09:50 So three, three, four days from now, three days.
09:52 And that starts on Monday and then goes to January 20th.
09:56 And then somewhere around there we'll know.
10:00 Actually, no, that's nominations.
10:01 The voting starts on Monday, January 21st.
10:04 So sometime in February we'll know who, which five people are on the steering council.
10:08 How do you feel about this?
10:09 I think it's the right, well, not that nobody asked my opinion, but this seems reasonable to me.
10:14 Yeah, I agree.
10:15 You have a mic.
10:15 You get a, that's the power of the mic is you get to just state your opinion, right?
10:19 Yeah.
10:21 No, I think it's, I think this is totally reasonable.
10:24 I think there's a couple of things.
10:26 I thought it was really interesting the discussion between having an even or an odd number of people on the council, right?
10:34 Because this way there's always going to be a majority.
10:37 There could never be a deadlock, right?
10:39 Whereas if they had been even, you could have to have like a definitely win over a majority, right?
10:45 If there were six instead of five, you always got to get that little extra vote to go through.
10:50 But yeah, I think it's, you know, this seems totally reasonable to me.
10:53 I think there would have been a lot of value in finding the next BDFL without the FL part, right?
11:00 The next leader dictator type.
11:02 I think that kind of might've been my favorite, but it's such, it's just such a risky proposition.
11:09 Because on one hand, if you get the right person, they can just move quick and it could be awesome.
11:13 But if you get somebody who doesn't take it in the right direction or a direction that you think is the wrong direction, like it could really go off the rails.
11:20 So this certainly seems like a safe path forward and it's definitely more community driven than it has been in the past.
11:27 Yeah.
11:28 I don't know if this will slow down.
11:29 So one of the things that Brett brought up is they still haven't figured out really how to, how to guide the language itself for language design.
11:38 And so, yeah, it'll be interesting to watch how that.
11:42 Yep.
11:42 And sure will.
11:43 So there's a lot of detail in Brett's article, so you should all go check it out.
11:47 But it's, it looks like things are starting to move again.
11:51 Just that six short months later.
11:53 Yeah.
11:53 Perfect.
11:54 So one of the things you often have to do is work with files and paths and all this kind of stuff.
11:59 And I don't know, you tell me, Brian, am I living in the path?
12:01 I still, if I got to work with files, import OS, OS.path, I still probably do that just out of habit.
12:08 Am I doing it wrong?
12:09 You're doing it wrong.
12:10 At least according to Trey.
12:12 And I agree.
12:13 Now, I am with Trey.
12:15 So Trey Hunter wrote a blog post called Why You Should Be Using Pathlib.
12:19 And it's basically just a fairly convincing argument talking about some of the different benefits of pathlib over OS.path and OS and glob and stuff.
12:30 I actually didn't know before reading this.
12:32 I didn't know that you could do glob-like stuff with the pathlib.
12:35 And recursive globbing.
12:36 Yeah, recursive.
12:37 I had actually looked for that before because in some, some shells you can do star star to recursively look for stuff.
12:44 And you can use star star for, for the glob library or the glob, whatever.
12:51 But it's built in.
12:52 You can do our glob with, with pathlib.
12:55 It's pretty cool.
12:55 That's pretty awesome.
12:56 Some of the things that are nice about it, he's comparing it to OS path and OS.path.
13:02 It's really working.
13:03 It's a string library.
13:04 It's passing it, figuring out strings that represent paths.
13:07 But now we have a more functional, the pathlib uses the path object, which is a more functional thing that all of the path method, path object methods, return path objects.
13:20 So you can chain them together.
13:22 Right.
13:22 I love the fluent API.
13:24 Like you say path and then give it like a directory.
13:28 You can say make dir and all nice options like parents equals true exists.
13:33 Okay.
13:33 So it'll create like the whole directory chain.
13:35 It won't fail if it already exists.
13:36 Like that is like that right there might convince me to like put my OS.path away.
13:42 Yeah.
13:42 And also like right off the batty, that shows an example where how do you import OS path and OS?
13:48 Do you, do you import all the, all the little pieces from there so that you can have shorter methods?
13:56 Or do you just say OS path and you have to say OS path everywhere?
14:00 And it makes for kind of unwieldy code.
14:02 I copied some of the examples that he had into our show notes.
14:07 It's just really kind of a cool thing.
14:10 One of the things I didn't realize is that like the, like if you're opening a file, you can say like with open file name as some file object, then you work with it.
14:21 It closes automatically.
14:22 That all works with a path lib objects now too.
14:26 So you can use a lot of the other standard library things just with path lib objects.
14:31 Right.
14:32 Long as you're on Python three, six or above.
14:33 Yes.
14:34 Yeah.
14:34 Now this is really cool.
14:36 I like it.
14:36 I definitely like it.
14:37 Why wouldn't you be?
14:38 Exactly.
14:38 Why wouldn't you be?
14:39 It would be wrong.
14:40 Not as wrong as using legacy Python, but you know, it's okay.
14:45 I do know that some of the Linux distributions lag behind a ways.
14:49 And you know, if you haven't upgraded that for a while, that could be a reason actually.
14:52 But yeah, this is definitely something people should be checking out.
14:55 I really like the fluent API, the chaining.
14:58 That's cool.
14:59 All right.
14:59 Now, before we get to the next one, Brian, let me tell you about our sponsor, Datadog.
15:03 They've sponsored many of the episodes and they're a big supporter of the show.
15:06 So we're really happy to have them back this year.
15:09 And they're a cloud scale monitoring platform that brings together metrics, logs, distributed
15:14 traces all in one place.
15:16 Like one of the big problems you have is, well, I made a request to my web server.
15:20 The web server talked to this service.
15:22 That server's talked to a database.
15:23 Like those all seem like separate things, right?
15:25 But if you want to track them all together, right, you can use Datadog for that.
15:29 So you can trace clients, including support for auto instrumenting, like automatically tracking
15:35 requests through things like Django, Flask, Postgres, and others.
15:39 So you get all the tracking across service boundaries, which is pretty sweet for troubleshooting
15:44 slow requests and optimizing your Python apps.
15:46 So you can start monitoring your environment with a free trial and Datadog will send you a
15:52 cool little Datadog t-shirt.
15:54 Just go to pythonbytes.fm/Datadog and get started.
15:57 Very cool.
15:57 Yeah, for sure.
15:58 Thank you, Datadog.
15:59 Now, this next one is actually a two-in-one sort of thing because there's a new, new-ish,
16:06 let's call it new-ish library for visualizing and stuff, mostly around data science and
16:11 notebooks.
16:11 So we've talked about things like people know about matplotlib and Seaborn and other stuff,
16:17 but maybe they haven't heard about Altair.
16:19 So Altair comes from Jake Vanderplass and Brian Granger, who are both really big in the data
16:25 science space.
16:25 And this is a really cool declarative way to visualize stuff in Python.
16:30 Have you ever looked at matplotlib and you're like, why do I have to do all these things?
16:34 I just want a line on the screen.
16:36 There's so many steps, it seems like.
16:38 Well, Altair seems to avoid that.
16:41 So basically, it assumes that you're working with some sort of Pandas data frame, right?
16:45 So it takes Pandas stuff and visualizes it really well.
16:49 So for example, if I had a Pandas data frame called cars, I could say chart of cars, mark
16:56 points, and just, you know, X in code, X equals horsepower, Y equals miles per hour, and it
17:01 colors it based on the origin.
17:02 Boom, you get a nice graph.
17:03 Like really declarative.
17:05 You just state what like your axes are and stuff and it does it.
17:08 So that's really, really nice, right?
17:09 You said you were actually using it a little bit.
17:11 Yeah, actually, we had a project for visualizing our test result data.
17:15 And since I knew about this and I get to make calls like that, I said, hey, let's try Altair.
17:22 And one of the benefits of it is this data frame model.
17:27 So the people working with it have had to learn data frames.
17:31 And the result is they're like, hey, we actually working with data frames makes this easier because
17:38 we can do a lot of manipulations within the data frame model.
17:41 Yeah, that's pretty cool.
17:42 They're like, wait, data frames are kind of awesome.
17:43 We should use them.
17:44 Yeah, definitely.
17:45 Yeah, that's really cool.
17:46 So that's Altair, which maybe we should spend more time talking about it.
17:50 But the other item I want to talk about is Altair recipes from Antonio Piccolboni, who actually
17:58 is the creator of Altair recipes.
17:59 So the idea is you can create some of these charts, but not all the kinds of charts that
18:04 you might want to create are easily one lineable in Altair.
18:10 So what he's done is he's created a bunch of helper libraries that will take the data in
18:17 the similar way I described before, easily generate the other types of things that you might want,
18:22 like a box plot or histograms or things like that.
18:27 So there's a whole bunch of different examples of different types of things, you know, auto correlation, box plots, heat maps, histograms, all kinds of stuff.
18:35 That's down to just one line again using his code.
18:41 So pretty cool.
18:42 Yeah, very nice.
18:43 Yeah.
18:44 So basically, it's like a wrapper around more additional types of graphs.
18:48 And I'm linking to a whole bunch of different examples in here.
18:54 So in the little section on Altair recipes, just click on the examples and you can go see all the different graphs and whether or not they're helpful.
19:00 Ooh, a layered histogram.
19:01 A layered histogram.
19:02 Isn't that cool?
19:03 That's really cool.
19:04 Yeah.
19:04 And Antonio says it's fully documented, highly consistent API, 90% plus test coverage with a maintainability grade of A.
19:12 So very nice stuff.
19:14 Do you know how he computes the maintainability grade?
19:16 Did you see that?
19:17 No, I don't.
19:17 I don't either, but I'm really fascinated to figure out what the maintainability grade of my other stuff is.
19:22 Maintainability grade.
19:23 Yeah, we should look into that.
19:24 Yeah, we should definitely look into that.
19:25 Antonio, send us a note about how you computed that.
19:28 That's cool.
19:28 But if you're using, if you're looking for visualization and especially if you're using Altair, check out Altair recipes.
19:33 It's on GitHub and it looks pretty cool.
19:35 Very cool.
19:35 What do you got next for us?
19:36 More testing?
19:37 More coverage?
19:38 Yeah, I've been thinking about testing and I kind of do that a lot.
19:42 A couple of fun pytest plugins that were sent to me and I apologize for not remembering who sent these to me, but keep them coming.
19:51 I love trying out new things.
19:53 The first one I want to show is, talk about is called pytest-Picked, P-I-C-K-E-D.
20:00 And the name confused me at first, but after you start using it, it sort of makes sense.
20:05 Here's the idea.
20:06 You've got a bunch of, you're using GitHub or not necessarily GitHub, any Git repo.
20:13 Some Git repo, yeah.
20:14 Yeah.
20:14 And you're working with a test or something and you really, you know you're going to want to try to run the tests that you have modified.
20:22 So Git knows this.
20:24 With Git status, you can tell which files are modified.
20:27 So this plugin utilizes Git status and allows you to run all of the modified test files in one test suite without having to like specify them or keyword them or anything.
20:38 That's pretty cool.
20:39 So if I have like a thousand test files, that may be a little excessive, but let's just roll with it.
20:44 And I edit three of them since the last time I committed to Git.
20:48 I can go run this and it'll say, well, these are the three changed test files.
20:53 Therefore, we're going to run just the tests in those three files and pytest.
20:56 Yeah.
20:57 And you can run just those three or you can run those three first and then the rest of the suite.
21:02 Okay.
21:02 That's pretty sweet.
21:04 You know what I would like, which is probably a much harder problem to solve, but would be awesome, is if you could combine code coverage along with this and sort of reverse it.
21:16 Say like, well, these are all the source files and the test files that change.
21:20 But the source files that change, what tests touch some line of code in these source files?
21:26 So what do I need to run to get coverage on the changes that direction?
21:30 That would be awesome.
21:31 I think there is something like that, but it was last time I tried it.
21:34 It was a little clunky to use, but I'll look it up again.
21:37 Yeah.
21:37 Okay.
21:38 Cool.
21:38 But this is really nice.
21:39 I mean, certainly if the mode that you're in is I'm changing a bunch of the tests and I want to just run those.
21:45 This is awesome.
21:45 Yeah.
21:46 Well, and the mode for a lot of people developing tests or maintaining software really all together is either writing new tests.
21:55 When you're in that mode, you're definitely going to be having modified test files.
21:59 Yeah.
21:59 Or you're debugging something and you're like throwing some logging in it or something like that in a log in a test.
22:05 Yeah.
22:06 I definitely see a good use for this.
22:08 And you have a two for us.
22:09 That's just the one.
22:09 Yeah.
22:10 So the other one is a kind of a new project, but I thought it was fun.
22:14 It's called the pytest Clarity.
22:16 pytest dash clarity.
22:17 It's just another colorizer.
22:20 So it makes the diffs.
22:21 So if you have a assert equals comparison that fails, the left and right comparison, sometimes it's a little hard to read.
22:29 And this one is a colorizer that puts the changes from the left and right, right on top of each other and colorizes them differently.
22:39 So that's nice and helpful.
22:41 Yeah, that's cool.
22:41 Definitely colors.
22:42 Color is awesome.
22:44 Right.
22:44 It shows you what's different, what's the same.
22:46 It's beautiful.
22:46 You know, right away.
22:47 Yeah.
22:48 The one thing I'm in conversation with the person writing this, that it defaultly turns on verbose.
22:55 And for small projects, having verbose on, which means that every test file is going to get listed.
23:01 Actually, every test is going to get listed in the output.
23:04 That's fine for small projects.
23:05 But when you get into hundreds and thousands of tests, that can be unwieldy.
23:10 Yeah, I can imagine.
23:12 But you can turn that off with the dash QQ and the clarity still works.
23:16 Cool.
23:17 I've got...
23:18 Yeah.
23:18 Yeah, those are definitely nice testing additions.
23:21 Quite cool.
23:22 So the last one I want to close out with is a little bit of web security.
23:26 And we've talked about web security before on the show, various things like the Django Hunter and stuff like that, for example.
23:32 But this one has to do with headers.
23:35 Now, did you know that when you have a web app, it obviously exchanges headers and cookies and stuff with the clients.
23:44 But there's a whole bunch of things that you should send across, probably, to make your website more secure.
23:51 Yeah.
23:52 There's like a handful of them.
23:53 And the OWASP organization has a place that talks about, these are the headers you should send.
23:59 For example, about caching certain pages.
24:01 Or if you're setting a cookie, that the cookie should only be exchanged over a secure connection.
24:07 So imagine you've got like a site.
24:09 Maybe it's a bank.
24:10 You can log into it.
24:12 If you go to hdpsbank.com or whatever the bank website is, right, it's going to set maybe a login cookie.
24:19 But if you open up a browser and you type bank.com and just hit enter, maybe that goes over HTTP and then HTTPS.
24:26 But if you don't set the right headers or flags, it could pass that login cookie over HTTP the first time before it goes over to HTTPS.
24:35 Things like that.
24:36 So you can say only exchange these cookies over secure connections and things like little details like this.
24:42 But there's a bunch of them and they're hard to remember.
24:44 One of the guys that was actually listening to Talk Python on Flask, where David Lord talked about this thing called FlaskTalesman,
24:52 which is a plugin for Flask that will automatically do that kind of stuff.
24:57 It'll just take the response, set those cookies, not the cookies, the headers that need to be set and things like that.
25:03 So it's really nice that Flask has this option.
25:06 He's like, well, but why don't the others?
25:08 This security guy, pen tester, he's like, there should be something like this for all of the frameworks.
25:14 So what he did was he created this thing, which I'll tell you the package name.
25:18 And I can't believe that he got it on PyPI.
25:20 The package name is secure.
25:23 You think that would be taken by now.
25:26 But the idea is it's secure headers and cookies for the Python web frameworks.
25:30 It's pretty cool.
25:32 It supports AIoHTP, Bottle, Cherry Pie, Django, Flask, Falcon, Hug, Basinite, Pyramid, Court, Responder, Sanix, Starlet, and Tornado.
25:40 And if one of those is not on your list, you can actually just sort of feed it the response anyway.
25:45 Isn't that cool?
25:46 That's actually very cool.
25:47 Wow.
25:48 So it has built-in integration to those things like Pyramid Tweens or other types of stuff.
25:53 You can plug it in so it automatically happens.
25:56 But if you don't have it automatically doing it, you can just call the various bits as well.
26:01 So it sends things like strict transport security, same origin iframes, cross-site protection, all that kind of stuff.
26:08 It just does that automatically.
26:09 And you can also create secure cookies.
26:12 So you just go to the secure cookie thing and say, I'd like the secure cookie to have this name and this value.
26:19 And it'll set that it's over HTTPS only, that it's over HTTP rather than JavaScript only, things like this.
26:25 Same site origin, same site stuff.
26:27 So all these little details about getting security right are wrapped up and then packaged in a way you can use it cross-framework.
26:34 Check that out.
26:35 Yeah, it's pretty sweet.
26:36 Did you mention Pyramid Tweens?
26:38 Is that a 12-year-old using Pyramid?
26:41 Well, it's 11 to like early 13-year-old.
26:44 No, it's like a layer that you can put in between request response.
26:49 And it's like a thing that gets called before and after responses, I believe.
26:53 Okay.
26:53 Apparently it's not there in your Pyramid class.
26:55 Yeah, I guess not.
26:56 And I don't think I really talked about it there.
26:58 But you can basically plug it in and say, anytime you send a response, call this function.
27:03 And so you can just in that function say, upgrade the response to have the secure headers in the response without doing it all over the place.
27:11 You just plug in this one little bit.
27:12 Okay, cool.
27:13 Yeah, it's pretty cool.
27:14 So if you're doing a web map and you care about security, this is definitely worth checking out.
27:19 All right, well, that's it for all of our items that we're officially covering.
27:23 I have some extras.
27:24 How about you?
27:24 I don't, actually.
27:26 Other than I've been podcasting away and I got like seven episodes of Test and Code in December.
27:33 That's awesome.
27:34 I've been listening to a lot of them.
27:35 You've got some good stuff going on lately.
27:37 And I'm going to keep it up.
27:38 I'm not going to do seven in January, but there should be four.
27:40 Yeah.
27:41 Awesome.
27:41 I'm really glad to see that coming along.
27:43 So I have, it's good you don't have many because I have a bunch.
27:46 So I'll go through them kind of quick.
27:47 But there was this pretty big bug that came out about SQLite.
27:51 SQLite is an embedded database that runs in process.
27:53 That happens to be shipped and included in Python.
27:56 So that got my attention, but it's also included in the browsers for like Web SQL stuff that JavaScript can use and it can be embedded in like Electron JS apps for the same reason.
28:08 Stuff like that.
28:09 Right.
28:09 So it's really a lot of places.
28:11 Now, the problem is it turns out that there is a bug in SQLite that with simple SQL select commands, you can do very bad things to anything that runs the SQLite that is vulnerable.
28:25 And this was just really recently.
28:27 All right.
28:28 So it seemed like this could have been a really big problem in Python since Python has SQLite.
28:34 SQLite has this problem.
28:35 And it would have had to been the case that there was some SQL injection, right?
28:41 Like you took user input and you fed it to SQLite directly.
28:44 Yeah.
28:44 Right.
28:45 So that's already there have to be kind of a problem in your code for this to happen.
28:48 But it turns out I threw this out on Twitter and some folks came out there and really like, you know, a lot of people shared it.
28:57 A lot of people talked about it.
28:58 And somebody said, you know, actually, that's an interesting thought.
29:02 M.
29:02 Boris on Twitter is like, you kind of got me curious that maybe this is a problem for Python.
29:09 Let me check.
29:09 So he took the proof of concept exploits and ran it against SQLite and Python.
29:14 And it looks like it's not a problem.
29:16 That's pretty good, right?
29:17 So if you hear that there's this big problem with SQLite, it seems like it's not a problem with Python.
29:21 But that's not for sure.
29:23 But it seems that way.
29:24 And also don't take user input and throw it into a query.
29:27 Yeah, exactly.
29:29 It's already like in order for this to be a problem for your Python app, you already have to have a problem.
29:34 This just makes it worse.
29:35 So if this was going to be a problem before, you should probably deal with that regardless.
29:40 All right.
29:41 So next one.
29:42 This is a follow up on our AI and health care.
29:44 We talked about AI and the AI analyzing cancerous mammograms and helping doctors get much better at that.
29:52 And we were speculating, maybe I was speculating, that maybe there won't be a need for doctors.
29:57 We'll just upload it to the cloud doctor and we get an answer, right?
30:01 Things like that.
30:01 Hey, Google, do I have cancer?
30:02 Exactly.
30:03 Send us three pictures.
30:05 I'll tell you.
30:06 Well, this guy named Bradley sent us feedback.
30:09 He says, hey, I really found this interesting.
30:11 I'm a data scientist at the National Oncology Program.
30:14 And I work directly with clinicians.
30:16 And it's my strong opinion that AI cannot take the job from the medical folks, the MDs.
30:22 However, it will make it way more efficient for all the low hanging fruit.
30:26 He says, you know, look, health care is both science and an art.
30:30 And the AI is going to have a really hard time on the art side of things.
30:35 Also probably the human interaction side of things.
30:37 So really doesn't think that there's a big danger of that.
30:40 Well, you know, I guess time will tell, but he's definitely got a lot more to go on than I do, right?
30:46 He works as a data scientist with these folks.
30:48 So that's cool.
30:49 Got some inside feedback.
30:50 Yeah, that's pretty much what we were speculating anyway.
30:52 I mean, it's not something you can break down into an algorithm.
30:55 Yeah, for sure.
30:56 Next item really quick, Python 3.7.2 is out.
31:00 So be sure to get the latest Python 3.7 if you're trying to run that.
31:05 And if you're running homebrew, you can just do brew update and brew upgrade.
31:09 And you'll have Python 3.7.2, which is pretty awesome.
31:12 Neat.
31:12 Yeah.
31:12 So I'm already running that on my local machine, but not yet in production.
31:17 It's not on the right Linux version yet.
31:19 And then finally, I launched a new course, Brian.
31:22 Yeah, I'm excited about this.
31:24 Yeah, so this is one written by Matt McKay of Full Stack Python, and it's Introduction to Ansible.
31:30 So that one's been coming along for a long time, and he finally got it out.
31:34 It's really good, and I'm learning a lot about all sorts of things, also including Ansible.
31:39 So if you're interested in Ansible, check it out over at training.talkpython.fm, or just click the link.
31:44 Nice.
31:45 Did you come with a joke this time?
31:47 I did not.
31:47 Do you have a joke for us?
31:49 Well, luckily, I found a joke.
31:50 And by found a joke, I mean Joachim sent us a joke, one of our listeners, and I'll tell it to you.
31:57 Okay.
31:58 Okay, so hold on.
32:00 Got to zoom in.
32:01 Fonds are small.
32:02 Eyes are old.
32:02 So an engineer, a physicist, and a programmer were discussing what was the oldest profession of the three.
32:09 Engineers, look, all the matter engineered into amazing constructs like stars, galaxies, planets.
32:17 So obviously engineering.
32:19 The physicist says, before there were planets, the matter had to be made from chaos.
32:24 Physics is responsible for all the quarks, gluons, photons, and electrons.
32:28 Not to be outdone.
32:30 The programmer says, aha, but where do you think the chaos came from?
32:33 Yeah, that's good.
32:33 Yeah, pretty good.
32:34 So definitely, I'm sure we've all caused a little bit of chaos out in the world with our apps.
32:42 That's a good one.
32:43 Not to like, we should be done now.
32:45 But I just remembered another thing.
32:46 Okay.
32:47 Speaking of chaos, is like, in 2019, more and more browsers were saying, let's just try to have all websites be secure.
32:55 So I got hit by this.
32:57 And Python testing.net is not, doesn't have SSL on it, but it's just warning everybody.
33:04 By the way, like Brian might steal your information.
33:07 I'm not going to do anything with your information.
33:09 Let me see.
33:10 I pull up.
33:11 Oh my goodness.
33:11 I got to get out of here, man.
33:12 This is not secure on it.
33:14 Yeah.
33:15 What up?
33:16 So I could just buy an SSL certificate or whatever, do the free one, and jump through that hoop.
33:23 But I felt like it'd be a good time to change it anyway.
33:26 So I'm going to start the process of turning this into a static site generated site.
33:31 Oh, you are?
33:32 Okay.
33:32 Awesome.
33:33 Well, that sounds really fun.
33:34 And that'll be, I know some good sites that definitely run that way.
33:38 So that'll be good.
33:39 Yeah.
33:39 Okay.
33:41 That's all I got.
33:41 Well, even though it says not secure, I'm still going to go there.
33:44 It's okay.
33:45 Okay.
33:46 All right.
33:47 Well, great to chat with you as always, Brian.
33:49 Yeah, you too.
33:50 Yep.
33:50 Thanks.
33:50 Bye.
33:50 Thank you for listening to Python Bytes.
33:52 Follow the show on Twitter via at Python Bytes.
33:55 That's Python Bytes as in B-Y-T-E-S.
33:58 And get the full show notes at pythonbytes.fm.
34:01 If you have a news item you want featured, just visit pythonbytes.fm and send it our way.
34:05 We're always on the lookout for sharing something cool.
34:09 On behalf of myself and Brian Okken, this is Michael Kennedy.
34:12 Thank you for listening and sharing this podcast with your friends and colleagues.