In a variety of online services and social networks, user objects can be the basic building blocks from which everything else is derived. Our Twitter work-alike is no different.
We’ll store user information inside of Redis as a HASH, similar to how we stored articles in chapter 1. Data that we’ll store includes the username of the user, how many followers they have, how many people they’re following, how many status messages they’ve posted, their sign-up date, and any other meta-information we decide to store down the line. A sample
HASH that includes this information for a user with the username of dr_josiah (my Twitter username) is shown in figure 8.1.
From this figure, you can see that I have a modest number of followers, along with other information. When a new user signs up, we only need to create an object with the following, followers, and post count set to zero, a new timestamp for the sign-up time, and the relevant username. The function to perform this initial creation is shown next.
In our function, we perform the expected setting of the initial user information in the
user’s HASH, but we also acquire a lock around the user’s login name. This lock is necessary:
it guarantees that we won’t have two requests trying to create a user with the
same login at the same time. After locking, we verify that the login name hasn’t been
taken by another user. If the name hasn’t been taken, we generate a new unique ID for
the user, add the login name to the mapping of login names to user IDs, and then create
the user’s HASH.
SENSITIVE USER INFORMATIONBecause the user HASH will be fetched countless times for rendering a template, or for returning directly as a response to an API request, we don’t store sensitive user information in this HASH. For now, we’ll assume that HASHed passwords, email addresses, and more are stored at other keys, or in a different database entirely.
We’ve finished creating the user and setting all of the necessary meta-information
about them. From here, the next step in building our Twitter work-alike is the status