Today's Deep-Dive: FLOSS issue queue
Ep. 17

Today's Deep-Dive: FLOSS issue queue

Episode description

This episode delves into a seemingly niche issue—a Drupal bug that limits linking to unpublished content, which opens a rabbit hole of software development, usability, and security concerns. The problem, where users can view but not reference drafts, is frustrating, especially for editors. It challenges how information should be organized and leads to patchwork solutions. This bug also raises security concerns, as allowing links to unpublished content could expose sensitive information.

A balance must be struck between fixing this issue and maintaining backward compatibility, a common challenge in software. While developers could offer a checkbox to enable or disable the feature, this introduces complexity for administrators. Even if the technical problem is fixed, usability issues—like accidentally linking to drafts—persist. This highlights the broader problem of how systems should be designed to be intuitive and secure.

The discussion expands into exploring how small bugs expose the intricacies of digital systems, emphasizing the importance of understanding the underlying complexities. The takeaway for listeners: don’t just accept flaws in technology—ask questions, investigate, and maybe even innovate. The conversation encapsulates the ripple effects of even the smallest software issues and how they relate to user experience, security, and development decisions.

Download transcript (.srt)
0:00

All right, ready to go deep on something

0:01

you might not expect.

0:03

A Drupal bug.

0:06

A what?

0:07

Yeah, you heard that right.

0:07

Drupal.

0:08

Oh, okay.

0:09

I know, I know, you're thinking website stuff.

0:10

Well, yeah.

0:11

But hold on, this isn't just some random glitch.

0:13

Okay.

0:14

This bug, this takes us down a rabbit hole,

0:16

like how software gets made, how we experience tech,

0:19

even security, the whole shebang.

0:22

You're not wrong, it does sound kinda niche

0:24

when you put it like that.

0:25

Niche, maybe, but important, definitely.

0:29

For sure, anyone using the internet, which is.

0:31

Basically everyone.

0:32

Pretty much.

0:33

And that's what we do here, right?

0:34

Shine a light on the systems we use every single day

0:37

and see how even a tiny bug can spiral.

0:39

Absolutely.

0:40

So what is this bug?

0:41

Picture this.

0:43

You're on a website, right?

0:43

Okay, got it.

0:44

And you can see this unpublished page,

0:47

you have permission and all.

0:50

Makes sense.

0:50

But here's the kicker, you can't link to it.

0:53

You can see it, but you can't reference it.

0:56

It's like some weird information paradox.

0:58

You're right, that is weird.

1:00

Logically, if you can see something,

1:02

shouldn't you be able to link it?

1:05

I can see why people are scratching

1:06

their heads over this one.

1:07

Oh, people are definitely scratching their heads.

1:08

Trust me, it's causing some serious frustration.

1:10

I bet.

1:11

Think about it, you're an editor,

1:12

you've got articles all over the place,

1:14

some finished, some still drafts.

1:16

Right, gotta have drafts.

1:17

You wanna connect them, make a nice flow,

1:19

but bam, this book throws a wrench in the works.

1:22

Ouch.

1:23

You can see those drafts, but linking them.

1:26

Nope, not a chance.

1:27

That just sounds so frustrating.

1:29

And from a bigger picture perspective,

1:31

doesn't this kind of go against

1:33

how information should be organized?

1:35

Like, if you can access it,

1:37

you should be able to link it, right?

1:39

100%.

1:40

And when systems act in ways we don't expect,

1:42

it just creates friction.

1:44

People get frustrated, they lose trust,

1:47

and then they're less likely

1:48

to use the platform effectively.

1:49

Yeah, for sure.

1:50

It's all about usability at the end of the day.

1:52

And we're not talking about a minor inconvenience here.

1:55

I mean, some users are patching their own systems.

1:57

Yeah.

1:58

Every single update.

2:01

Just to get around this thing.

2:03

Whoa, that's dedication.

2:06

Or maybe desperation.

2:07

Probably a bit of both.

2:09

It's a huge time sink, all because of this one little bug.

2:12

Wow, and I hate to say it,

2:14

but it might be even worse than just being annoying.

2:17

Think about the security implication.

2:19

Oh, right, you mentioned that earlier.

2:20

What are we talking about here?

2:21

Well, if there's a way to reference

2:23

that unpublished content,

2:24

even if it's not supposed to be possible.

2:27

Someone could exploit that.

2:28

Exactly, it's like leaving a back door

2:29

wide open to your website.

2:31

Information that shouldn't be public suddenly is.

2:33

Okay, so now we're talking workflow chaos

2:35

and security breaches.

2:37

You'd think someone would have fixed this by now, right?

2:39

You'd think so, wouldn't you?

2:40

But the thing is, software is rarely that simple.

2:43

What's the catch?

2:44

Backward compatibility.

2:46

Any fix, any solution can't break the websites

2:49

that rely on the old way of doing things.

2:51

Ah, so it's like walking a tightrope.

2:53

Basically, you fix it for one group,

2:54

you might break it for another.

2:56

Talk about a developer's nightmare.

2:58

So how do you even begin to tackle a problem like that?

3:02

It really is a tough nut to crack, isn't it?

3:04

But hey, the Drupal community, they're a resourceful bunch.

3:08

There are ideas out there.

3:10

Oh, I bet.

3:11

What are we talking, like crazy workarounds

3:13

or some elegant solution just waiting to be discovered?

3:17

Hopefully a little more elegant than that.

3:19

Some people, they're all about getting their hands dirty

3:22

with the code, you know, make those precise targeted fixes.

3:25

So it's like performing surgery on the software,

3:28

trying to remove the bug without damaging anything else.

3:31

That's a good way to put it.

3:32

But remember that backward compatibility thing?

3:35

Sometimes even the most precise fix

3:37

can cause unexpected problems down the line.

3:40

Right, like a domino effect.

3:41

You fix one thing and it ends up breaking something else

3:44

for someone else.

3:44

Exactly, and that's why some folks are pushing

3:47

for a different approach, something a bit more,

3:49

well, universal.

3:50

Okay, I'm intrigued.

3:52

What kind of universal solution are we talking about?

3:54

Imagine this, a simple little checkbox in the settings,

3:58

right there for everyone to see,

3:59

something like allow referencing of unpublished content.

4:03

Oh, I see where you're going with this.

4:05

Give people the choice, enable the function if they want it,

4:07

leave it off if they don't, simple.

4:09

You got it, but, and there's always a but, isn't there?

4:12

This approach comes with its own set of challenges.

4:15

It's that age-old trade-off control versus complexity.

4:18

Okay, break that down for me.

4:19

What makes a checkbox so complicated?

4:21

Well, on the one hand, it gives website administrators more control.

4:25

They get to decide if they want this functionality enabled or not.

4:28

But on the other hand, it also introduces another decision they need to make.

4:33

And more decisions usually mean more room for error.

4:36

That's it, exactly.

4:37

Now, suddenly they need to understand all the ins and outs of this checkbox.

4:41

What happens if you check it?

4:42

What breaks if you don't?

4:43

It's a lot to put on someone's plate, especially if they're not a tech expert.

4:48

It's a slippery slope from a simple checkbox to a full blown configuration nightmare.

4:54

And it highlights something really important, doesn't it?

4:56

This isn't just a technical problem with a technical solution.

5:00

It's about finding that sweet spot between functionality,

5:04

security, and making things easy for people to use.

5:08

Couldn't have said it better myself.

5:09

And speaking of making things easy to use,

5:12

there's another angle to this whole thing we haven't even touched on yet.

5:15

Do tell.

5:16

So let's imagine for a second that the developers,

5:19

they wave their magic wands and completely fix this bug.

5:22

Everyone can reference unpublished content without a hitch.

5:25

Problem solved, right.

5:27

Sounds too good to be true.

5:28

What's the catch this time?

5:30

Even if they fix the technical side of things,

5:32

there's still the human factor to consider.

5:34

Right now, visually, there's no way to tell

5:37

the difference between a published article and a draft

5:39

when you're looking at a list of potential links.

5:41

Oh, I see where you're going with this.

5:42

You could accidentally link to something that's not ready for prime time.

5:45

Not exactly ideal.

5:46

That's putting it mildly.

5:47

It's like accidentally sending out a draft email to your entire contact list.

5:52

Oof, I've been there.

5:54

Not fun.

5:55

And it goes to show how important a clear and intuitive user interface really is.

6:00

It's not just about making things look pretty.

6:02

It's about preventing mistakes and making sure

6:04

people can actually use the software in the way it was intended.

6:08

This is what blows my mind every time we do one of these deep dives.

6:11

We started with this Drupal bug, right?

6:12

Something so specific.

6:14

But now we're talking about information architecture,

6:17

user experience design, the whole nine yards.

6:19

It's all connected.

6:20

And it just goes to show you sometimes those seemingly small issues,

6:25

they can open up a whole can of worms.

6:27

Worms that need to be explored.

6:29

But before we get too far down the rabbit hole,

6:31

let's pause for a second and think about our listeners.

6:33

We've thrown a lot of information at them, some pretty technical stuff too.

6:37

So let's bring it back down to Earth for a moment.

6:39

What does all this mean for someone who's not a coder or a designer?

6:44

What's the takeaway message here?

6:45

That's the million dollar question, isn't it?

6:47

At the end of the day, I think the big takeaway here is this.

6:51

We interact with digital systems all the time, right?

6:55

Our phones, our computers, even our cars.

6:57

And we just kind of assume they'll work the way they're supposed to.

7:00

But they don't always work, do they?

7:01

Oh, absolutely not.

7:03

And this Drupal thing, it's a great example.

7:05

It might seem like a small issue on the surface,

7:08

but it shows just how complex these systems really are,

7:12

even when we don't see it.

7:13

Right.

7:13

We just take it for granted, click a button, expect a result.

7:17

But behind that click, there's a whole lot

7:19

of code, a whole lot of decisions that went into making that happen,

7:22

or in this case, not happen.

7:24

So where do things stand now?

7:26

Has someone, anyone, found the holy grail solution to this bug?

7:31

Well, not quite a holy grail, but they are working on it.

7:34

The Drupal community is on the case.

7:36

That's something, at least.

7:37

So it's not just going to be ignored, brushed under the rug.

7:40

No, not at all.

7:41

And that's one of the things I find so fascinating about this case.

7:44

It really highlights the power of open source software.

7:48

Here, you have a community of developers, users, everyone

7:51

coming together to try to solve a problem.

7:53

I'm like global brainstorming session.

7:55

Yeah.

7:56

And all because of this one little bug.

7:58

You've got it.

7:59

Though I think little might be a bit of an understatement by now.

8:02

The more we dig into this, the more we realize it's not so little,

8:05

after all, is it?

8:06

Not at all.

8:07

It's a whole rabbit hole of complexity.

8:09

But isn't that always the way?

8:10

It's like the more you learn, the more you realize you don't know.

8:13

Truth.

8:13

But that's OK.

8:14

That's where the excitement is.

8:15

Right.

8:15

It keeps things interesting.

8:17

So for our listeners who are still with us, still absorbing all of this,

8:21

what's the one thing you want them to remember?

8:24

The call to action, if you will.

8:26

Let's see.

8:27

I think the most important thing is this.

8:29

The next time you run into something online,

8:32

maybe it's a weird bug, a frustrating design, anything

8:35

that just doesn't seem quite right.

8:36

Don't just accept it.

8:38

Exactly.

8:39

Don't just shrug and move on.

8:40

Get curious.

8:41

Ask yourself, why is this like this?

8:44

What went into making it this way?

8:46

Because you never know.

8:47

You might just uncover a whole world

8:48

of fascinating complexity hiding right there

8:51

beneath the surface.

8:52

Or maybe, just maybe, you'll come up

8:54

with a brilliant solution that no one else has thought of.

8:56

That's the dream, isn't it?

8:57

To go from passive user to active innovator.

9:01

And on that note, I think we've explored just

9:03

about every nook and cranny of this Drupal bug.

9:05

We've talked about information architecture, user experience,

9:09

even a little bit of philosophy along the way.

9:11

And a good dose of cautionary tale, too.

9:13

Can't forget that.

9:15

and keep diving deep into the fascinating world

9:15

and keep diving deep into the fascinating world