The present invention generally relates to domain names, and, more specifically, to methods for sorting a plurality of domain names.
For Internet users and businesses alike, the Internet continues to be increasingly valuable. More people use the Web for everyday tasks, from social networking, shopping, banking, and paying bills to consuming media and entertainment. E-commerce is growing, with businesses delivering more services and content across the Internet, communicating and collaborating online, and inventing new ways to connect with each other. With this increased popularity and value comes an increased desire for websites and web service providers to procure multiple domain names that may be related to their website, web service, brand, or product. Further, as domain names have become more valuable, many domain name speculators and brokers have amassed vast numbers of domain names. As individuals and entities procure more and more domain names, it can become increasingly difficult for the individual or entity to manage or otherwise keep track of the plurality of domain names that they own or have an interest in. Additionally, these users or entities may have little time to organize a portfolio of domain names.
The present invention overcomes the aforementioned drawbacks by providing methods and systems for sorting a plurality of domain names. By implementing the disclosed domain name sorting methods, users are able to easily keep track of a plurality of domain names grouped by projects in a hierarchal manner. Although useful with any number of domain names, the disclosed methods become particularly more useful when the number of domain names and/or number of projects increases. Further, in some embodiments, sorting can occur automatically thereby reducing or eliminating the amount of time a user must spend to organize a portfolio of domain names.
In one implementation, the present disclosure describes a method including sorting by a computing device a plurality of domain names into a plurality of projects to create a sorted plurality of domain names. In one embodiment, the plurality of domain names are each associated with a same user account. The method further includes storing the sorted plurality of domain names as part of the user account.
In another embodiment, the present disclosure describes a server device that is configured to sort a plurality of domain names into a plurality of projects to create a sorted plurality of domain names. In one embodiment, the plurality of domain names are each associated with a same user account. The server is further configured to store the sorted plurality of domain names as part of the user account.
In another embodiment, the present disclosure describes a method performed by a computer server in electronic communication with a computer network. The method includes presenting to a user, via a graphical user interface (GUI) on a display device in electronic communication with the computer network, one or more cards on a screen layout, the cards each having a graphical representation of data pertaining to a domain name in an account of the user. The GUI enables the user to perform one or more interactions on the cards. The graphical representation of one or more of the cards may include a front of the card and a back of the card; one of the interactions may be enabling the user to flip the card so that the front or the back of the card is displayed. The front of the card may include the domain name to which the card pertains, and may further include one or more functional properties of the domain name. The functional properties included on the front of the card may include one or more of a domain summary, one or more indicators of an applied service, and an auto-renewal setting. The front of the card may further include one or more prompts selectable by the user to perform one or more of the interactions. The prompts may include a “flip” icon that, when selected, causes the card to flip from the front of the card to the back of the card on the GUI.
The back of the card may include a content pane that displays one or more functional properties of the domain name and/or one or more traffic statistics of the domain name. The back of the card may further include a navigation menu selectable by the user to cause different of the functional properties to be displayed in the content pane when selected. The back of the card may include one or more prompts selectable by the user to perform one or more of the interactions. The prompts may include a “flip” icon that, when selected, causes the card to flip from the back of the card to the front of the card on the GUI. The GUI may display a plurality of the cards on the screen layout, and two or more of the cards may be displayed in a stack when the domain names of each of the cards in the stack are grouped in a project in the account of the user.
The method may further include receiving interaction data describing a performed interaction of the interactions, and modifying one or more functional properties of the domain name associated with one or more of the cards involved in the performed interaction. The interactions may include one or more of dragging one of the cards onto another of the cards, dragging a stack comprising a plurality of the cards onto another of the cards not in the stack, flipping one of the cards, and shuffling the cards. When the performed interaction is dragging a first of the cards onto a second of the cards, modifying the one or more properties of the domain name may involve forwarding traffic to the domain name of the first card to the domain name of the second card. When the performed interaction is dragging the stack onto another of the cards not in the stack, modifying the one or more properties of the domain name may involve changing a resource record of the domain name of each of the cards in the stack to match a resource record of the domain name of the card not in the stack.
Referring first to
In one embodiment, the server 100 is configured to communicatively couple to a client device 106 through the network interface and the Internet 104 to provide a user interface (such as a graphical user interface or GUI) to search for, procure, buy, sell, register, research, and/or manage one or more domain names. Communications between the server 100 and the client device 106 may be achieved using any electronic communication medium, communication protocol, and computer software suitable for transmission of data over the Internet 104. Examples include, respectively and without limitation: a wired connection, WiFi or other wireless network, cellular network, or satellite network; Transmission Control Protocol and Internet Protocol (“TCP/IP”), Global System for mobile Communications (“GSM”) protocols, code division multiple access (“CDMA”) protocols, and Long Term Evolution (“LTE”) mobile phone protocols; web browsers such as MICROSOFT INTERNET EXPLORER, MOZILLA FIREFOX, and APPLE SAFARI; and other client-executable software modules.
The client device 106 may comprise various computing devices such as, for example, a desktop computer, a laptop computer, a tablet, a smart phone, other network servers, or any other electronic device capable of communicating with the server 100 over the Internet 104. Such a client device 106 may include one or more processing devices, display devices 110, user interfaces, and/or network interfaces. Typically, though not always, the client device 106 is utilized by a user 112 to access the server 100 or a service provided by the server 100. In various embodiments, a user 112 utilizes the client device 106 to access a domain name management user account provided by the server 100 via the Internet 104. The user 112 may be an individual, a group of individuals, a business or other organization, or any other entity that desires to search for, procure, buy, sell, register, research, and/or manage domain names, whether the intent is commercial or non-commercial in nature.
The server 100 may include or be configured to communicate electronically with one or more data stores 114 in order to retrieve information from or store information to the data store 114. In some embodiments, a data store 114 may be a component of the server 100, such as, for example, a memory device of the server 100, or communicatively coupled to the server 100 (such as a memory module or a disk drive). In other embodiments, a data store 114 may be part of a different server (e.g., the second server 108), or as part of a different network-accessible data store. Electronic communication with the data store 114 may be achieved over the Internet 104 using any suitable electronic communication medium, communication protocol, and computer software including, without limitation: a wired connection, WiFi or other wireless network, cellular network, or satellite network; TCP/IP or another open or encrypted protocol; browser software, application programming interfaces, middleware, or dedicated software programs. Electronic communication with the data store 114 may be achieved over another type of network, such as an intranet or virtual private network, or may be via direct wired communication interfaces or any other suitable interface for transmitting data electronically from a data store 114 to the server 100. A data store 114 may include a repository of information that is or can be made freely or securely accessible by the server 100.
In one embodiment, the data store 114 is configured to store information pertaining to a particular user account or a plurality of user accounts for an online domain name management service. Such information may include, for example, demographic information (e.g., name, contact information), payment information, account preferences and settings, and one or more records of a plurality or domain names which are currently owned by and/or managed by a user of the user account or, in some embodiments, are included as part of a wish list or watch list. Additionally, the data store 114 may include information required to provide a user interface to allow a user 112 or a client device 106 to interact with the domain name management service. Such information may include information to provide a website or web page allowing a user 112 of a user account to interact therewith to manage a plurality of domain names. Other suitable information stored within the data store 114 may include, without limitation: databases or database systems, which may be a local database, online database, desktop database, server-side database, relational database, hierarchical database, network database, object database, object-relational database, associative database, concept-oriented database, entity-attribute-value database, multi-dimensional database, semi-structured database, star schema database, XML database, file, collection of files, spreadsheet, or other means of data storage located on a computer, client, server, or any other storage device known in the art or developed in the future; file systems; and electronic files such as web pages, spreadsheets, and documents. Such data stores 114 may also include, without limitation to the illustrated examples: search engine databases; website information databases, such as domain registries; hosting service provider databases; website customer databases, and internet aggregation databases such as archive.org; government records databases, such as business entity registries maintained by a Secretary of State or corporation commission; public data aggregators, such as FACTUAL, ZABASEARCH, genealogical databases, and the like; social networking data stores, such as public, semi-private, or private information from FACEBOOK, TWITTER, FOURSQUARE, LINKEDIN, and the like; business listing data stores, such as YELP!, Yellow Pages, GOOGLE PLACES, LOCU, and the like; media-specific data stores, such as art museum databases, library databases, and the like; point-of-sale transaction data stores; and offline crawling data stores.
In certain embodiments, the web server 100 is also communicatively coupled a Domain Name System (DNS) server 116 through the Internet 104 or locally through a LAN.
The Internet 104 comprises a vast number of computers (e.g., client devices 106) and computer networks that are interconnected through communication links. The interconnected computers exchange information using various services. In particular, a request for a web page or website may be made to the server 100 or another server by visiting the website's address, known as a Uniform Resource Locator (“URL”). Upon receipt, the requesting device can display the web pages. The request and display of the websites are typically conducted using a browser being an application program that effects the requesting and displaying of web pages.
Browsers are able to locate specific websites because each website, resource, and computer on the Internet has a unique Internet Protocol (IP) address. Presently, there are two standards for IP addresses. The older IP address standard, often called IP Version 4 (IPv4), is a 32-bit binary number, which is typically shown in dotted decimal notation, where four 8-bit bytes are separated by a dot from each other (e.g., 64.202.167.32). The notation is used to improve human readability. The newer IP address standard, often called IP Version 6 (IPv6) or Next Generation Internet Protocol (IPng), is a 128-bit binary number. The standard human readable notation for IPv6 addresses presents the address as eight 16-bit hexadecimal words, each separated by a colon (e.g., 2EDC:BA98:0332:0000:CF8A:000C:2154:7313).
IP addresses, however, even in human readable notation, are difficult for people to remember and use. A URL is much easier to remember and may be used to point to any computer, directory, or file on the Internet. A browser is able to access a website on the Internet 104 through the use of a URL. The URL may include a Hypertext Transfer Protocol (HTTP) request combined with the website's Internet address, also known as the website's domain name. An example of a URL with a HTTP request and domain name is: http://www.example.com. In this hypothetical URL, as used throughout, the “http” identifies the URL as a HTTP request and the “example.com” is the domain name. A domain can host multiple websites that can be accessed by appending character strings that constitute the full path to the website's files. For example, the domain for FACEBOOK includes one or more websites, as the term is used herein, for each of its users. A user-specific website is requested by appending a directory to the FACEBOOK main URL, e.g.: http://www.facebook.com/username.
Domain names are much easier to remember and use than their corresponding IP addresses. The Internet Corporation for Assigned Names and Numbers (ICANN) approves some Generic Top-Level Domains (gTLD) and delegates the responsibility to a particular organization (a “registry”) for maintaining an authoritative source for the registered domain names within a TLD and their corresponding IP addresses. For certain TLDs (e.g., .biz, .info, .name, and .org) the registry is also the authoritative source for contact information related to the domain name and is referred to as a “thick” registry. For other TLDs (e.g., .com and .net) only the domain name, registrar identification, and name server information is stored within the registry, and a registrar (e.g., GODADDY) is the authoritative source for the contact information related to the domain name. Such registries are referred to as “thin” registries. Most gTLDs are organized through a central domain name Shared Registration System (SRS) based on their TLD.
The process for registering a domain name with .com, .net, .org, and some other TLDs allows a user 112 to use an ICANN-accredited registrar, such as GODADDY, to register their domain name. For example, if the user 112 wishes to register the domain name “example.com,” the user 112 may initially determine whether the desired domain name is available by contacting the domain name registrar. The user 112 may make this contact using the registrar's web page and typing the desired domain name into a field on the registrar's web page created for this purpose. Upon receiving the request from the user 112, the registrar may ascertain whether “example.com” has already been registered by checking the SRS database associated with the TLD of the domain name (e.g., “.com”). The results of the search then may be displayed on the web page to thereby notify the user 112 of the availability of the domain name. If the domain name is available, the user 112 may proceed with the registration process. Otherwise, the user 112 may keep selecting alternative domain names until an available domain name is found. Domain names are typically registered for a period of one to ten years with first rights to continually re-register the domain name.
A user 112 (e.g., individual or entity) may amass a portfolio of domain names that they own or are otherwise responsible for. This portfolio may be associated with, for example, a user account for a domain name management service offered by the server 100. The domain name management service may be provided by a domain name registrar (e.g., GODADDY) as a free or paid service. A user 112 may be required to log on to the particular user account upon accessing the domain name management web service through the Internet 104. In certain embodiments, some or all domain names in the portfolio may be owned by, licensed by, or managed by the user 112 of the user account. The plurality of domain names within the portfolio may have been procured by the user (e.g., through a purchase or transfer) through the domain name management service, or through another available service. The plurality of domain names may be managed by the domain name management service (e.g., by performing status updates and data updates for the domain names). Other domain name management features not explicitly disclosed herein but understood in the art are contemplated by this disclosure, as well. Some or all of the plurality of domain names in the portfolio may be purchased or managed at other online domain services, but are associated nonetheless with the user 112 of the user account through ownership or other property interest (e.g., contract, license, etc.). This ownership or interest may be determined through investigation by the server 100 performing domain lookup procedures (e.g., a WHOIS query), the server 100 contacting the other online domain name service, or by a user 112 indicating ownership or property interest in the domain name. In certain embodiments, the portfolio of domain names may include one or more domain names that the user 112 does not presently have an ownership or property interest in, but that the user 112 may be watching or is otherwise interested in procuring. Further, the embodiments described herein are not exclusively limited to pure domain names (e.g., example.com), but may in certain embodiments included subdomains (e.g., blog.example.com) and directories (example.com/blog).
As the number of domain names associated with the user account grows, the task of managing the plurality of domain names can become increasingly cumbersome. For example, some user accounts may include thousands of domain names associated with the user account. In a commercial or retail setting, a user 112 (e.g., a company) may own or have property interest in thousands of domain names that are related to the name of their company and/or products or services. In an example used throughout this disclosure, a company having the name “Example” may wish to protect their brand (“Example”) and prevent brand domain name confusion. In doing so, the company may procure “example.com” as well as every domain name including “example” in every top-level domain (e.g., example.net, example.biz, example.info, etc.). In another example, the user company may wish to procure multiple domain names covering common or uncommon variations of the brand or product name, possibly in every TLD permutation available (e.g., exampleco.com, exampleco.net, examples.info, exampleinc.ca, example-inc.com, examplecompany.co.uk, etc.). Additionally, the company may wish to procure multiple domain names covering common or uncommon misspellings of the brand or product name, possibly in every TLD permutation available (e.g., exammple.com, exammple.net, exemple.com, exemple.info, exmpl.biz, etc.). If the user company “Example” makes a product called “The Widget”, the user company may wish to procure domain names related to the product, possibly in every TLD permutation available (e.g., widget.com, widget.info, example-widget.net, widgetbyexample.ca etc.). There are many different variations of domain names and domain name procurement strategies that a user 112 may pursue in brand name and product name protection. What is readily apparent is that the number of domain names associated with a user 112 or a user account can quickly become astronomical and unwieldy, particularly when multiple TLD permutations are pursued.
Additionally, and in a different approach, the user 112 may be a domain speculator, domain broker, or domainer, whose primary interest is in buying and selling domain names. For example, a domain speculator user may procure hundreds or thousands of domain names related to the company “Example” discussed above, which they may in turn package together and attempt to sell or license to the company or other domain brokers. However, the domain speculator user may also procure hundreds or thousands of domain names related to an entirely separate entity. What is readily apparent is that the number of domain names within a domain speculator user account may also quickly become astronomical and unwieldy.
Turning now to
Sorting of the plurality of domain names into a plurality of projects is illustrated in
In this example, as discussed above, the first project 302 includes a sorting characteristic for domain names that are similar to a primary domain name 306 of “example.com”. The primary domain name 306 is shown at the top of the first project 302, and the first project 302 may bear the same title, though other titles may be used (e.g., determined by the server 100 or entered by the user 112). Other secondary domain names 308 are shown below the primary domain name 306. In this example, the secondary domain names 308 are domain names that resemble the primary domain name 306 (e.g., have a different TLD or are misspellings or are similar to the primary domain name 306). Similarly, the second project 304 in this example includes a sorting characteristic for domain names that are similar to a primary domain name 310 of “example.co.uk” and are within the “.uk” TLD. In this example, according to one embodiment, the secondary domain names 308, 312 may be configured to redirect to the respective primary domain name 306, 310.
The primary domain names 306 and 310 may or may not be part of the plurality of domain names 300 that are associated with the user account. For example, if the user account is for a domain speculator or broker, the broker may not own the primary domain names “example.com” or “example.co.uk” but may have created and/or named these projects 302, 304 to sort a plurality of secondary domain names 308, 312 that are associated with the broker's user account (e.g., domain names that the broker owns) that correspond to those primary domain names 306, 308. In such an instance, the actual primary domain name 306, 310 may not have been sorted itself (as it is not purely associated with the user account), but has been determined by the server 100 or the user 112 to be one proper basis for sorting. Further, in some embodiments, some of the plurality of domain names 300 may not be owned by the broker, but may be in a “wish list” or “watch list” for the broker's user account, are on backorder by the broker, are presently being actively pursued by the broker (pre-registrations, auctions in progress, pending and previous offers, etc.), and are associated with the user account in this manner. They may be presented to the user in the GUI in a different manner (e.g., grayed out, different color, etc.). By this, the broker may amass and organize a collection of secondary domain names 308 or 312 that they may later sell or license to the owner of the primary domain name 306, 310 or to some other entity. Many other sorting characteristics are possible for the projects 302 and 304 in this scenario, some of which are discussed below, and the teachings disclosed herein are applicable to nearly all variations of sorting characteristics.
Returning to
At step 206, in one embodiment, the method 200 includes presenting on a display device 110 the sorted plurality of domain names 300 in a hierarchy within at least one of the plurality of projects (e.g., projects 302, 304) via a graphical user interface (GUI). The actual format, appearance, and/or function of the GUI may be very diverse from one application setting to another. One example of this is shown in
Turning now to
Continuing with
At step 210, in one embodiment the method 200 includes enabling a user 112 of the user account to perform at least one manual sorting action of a domain name into a project. As is shown at step 212, in one approach, the manual sorting may include enabling a user 112 of the user account to drag and drop via a GUI the at least one domain name into a graphical representation of one of the projects. In another embodiment still, the method 200 may include the user 112 performing these steps 210, 212.
In some embodiments, an unsorted plurality of domain names may become a sorted plurality of domain names 300 completely by the computing device. In another embodiment, a plurality of domain names sorted in one manner may become the sorted plurality of domain names 300 sorted in another manner completely by the computing device. This may include the computing device (e.g., server 100) selecting or determining one or more sorting characteristics of one or more of the projects, selecting a primary domain name, and/or sorting the plurality of domain names according to the sorting characteristics.
In certain embodiments, at step 504, the computing device (e.g., server 100) may enable a user 112 of the user account to override a sorting of at least one domain name by the computing device by enabling the user to manually sort the domain name into a different project. This is illustrated in
One method of sorting the plurality of domain names by the computing device (e.g., server 100) may include, as is included at step 506, the computing device mapping a plurality of secondary domain names (e.g., 308 and 312) to at least one primary domain name (e.g., 306 and 310). Mapping may include the computing device determining one or more “connections” between the secondary domain name and the primary domain name. These connections may be logical connections (e.g., the secondary domain name is configured to redirect to the primary domain name, all the domain names have the same TLD, etc.) or other subjective connections (misspellings and the like).
In certain embodiments, as is shown at step 508, mapping further entails the computing device determining that all or some the plurality of secondary domain names are configured to redirect to the primary domain name. This can be determined through a series of WHOIS lookups or through reviewing other locally stored data pertaining to the plurality of domain names, these lookups or data informing the computing device of the redirect configurations.
In other embodiments, as is shown at step 510, the computing device may determine the primary domain names from the plurality of domain names. In the previous examples used herein and illustrated in
The above described methods are but a few methods of determining mappings and primary domain names and of sorting a plurality of domain names. Many other sorting characteristics may be determined and various other connections between domain names may be determined based on a plethora of data. That data may be related directly to the domain names themselves, to the user 112 or the user account, or may be based on other data indirectly related to the domain names. In various embodiments, the computing device (e.g., server 100) may perform or effect performance of data analytics or logical clustering analysis (e.g., “big data” analysis) on a plurality of domain names to sort domain names into projects, to determine a primary domain name (if applicable), to determine sorting characteristics of projects. These processes may search for patterns or similarities within groups of domain names in the plurality of domain names to create the projects.
Various data sets and data types may be used in determining projects, groupings, sorting characteristics of the projects, and in the sorting process itself. In one approach, email addresses attached to a domain name may be utilized. In a non-limiting example, if a plurality of domain names all have the same email address or email address domain, they may be grouped into a project. Further, the domain of the email address may indicate the primary domain name for the project. In another approach, the computing device may utilize information as to whether a hosting site is attached to a domain name, whether content is located at the address of the domain name, or whether an online store is attached to the domain name. In a non-limiting example, if a domain name does not include an associated hosting site or an address of a hosting service, does not link to actual web content, or does not include an online store, the computing device may infer that the domain name is not a primary domain and is therefore a secondary domain, whereas the presence of these aspects may infer the opposite. Additionally, the computing device may examine the amount of income or money generated by an online store to determine which domain names are primary domain names.
In another approach, the computing device may utilize a number of hits (e.g., direct URL entries and search engine hits) generated by various domain names to sort the domain names. In a non-limiting example, if one domain name generates thousands or millions more hits than another, it may be inferred that the high-traffic domain name is the primary domain name while the other is a secondary domain name. In other embodiments, high volumes of email traffic associated with a domain name may be similarly indicative. In other embodiments still, a user, DNS information, and/or other external sources may provide information that is similarly indicative.
In another embodiment, data relating to geographical or language-based aspects of domain names and domain name searches or DNS requests may be used by the computing device during sorting. In a non-limiting example, a plurality of domain names may be sorted geographically to service various parts of the world. For example, one version of a website “example.com” may be primarily for the United States, while another version of the website may be for Mexico (e.g., “example.mx” or “mexico.example.com”) or India (e.g., “example.in” or “india.example.com”). In another example, a version of the website may be for French or Spanish speaking users (e.g., “francais.example.com” or “espanol.example.com”). Domain names may be sorted according to these aspects. Additionally, other geographical or language-based information may be utilized in sorting domain names, including but not limited to originating locations of Domain Name System (DNS) requests for the domain name, incoming language of domain name requests, languages used by requesting client devices for the domain name, location of request client devices for the domain name, and so forth. Still other geographical information may include, for example, utilization by a user 112 of a user account of a maps program or application including geographic aspects or geographical search history that may provide information regarding a geographical or lingual nature of a domain name or project, or other aspects in general pertaining to the domain name or project.
In another embodiment, data relating to search engine handling of the domain name or terms within a domain name string may be utilized by the processing device during sorting of the domain names as sorting characteristics. Some examples include the number of search engine queries for a domain name, search engine autocomplete suggestions associated with the domain name, search engine search request correction suggestions associated with the domain name, information from a Search Engine Optimization (SEO) pertaining to a domain name or a project, and/or information from a Search Engine Marketing (SEM) scheme pertaining to domain name or a project (e.g., via GOOGLE ADWORDS, BING ADS, and BAIDU). For example, if a particular domain name string is used in many search engine queries or a particular website having that domain name is often selected in response to a particular search engine query, then it may be inferred that the particular domain name is a primary domain name or is the focus of a particular project. In another example, information as to whether or how often a search engine autocompletes a search request entry to a particular domain name string may be used. Similarly, information as to whether or how often a search engine will suggest a corrected domain name string in response to a misspelled search engine query may be used. Similarly still, how often users of the search engine select the autocompleted or corrected versions of domain name strings may indicate a primary domain, a project, or that secondary domain names (e.g., the misspelled versions) can be associated with the subsequently selected primary domain names. In a similar fashion, autocorrect functions, algorithms, and results may be useful in determining a primary domain name and/or secondary domain names (e.g., in determining which is a common misspelling of the other).
In another non-limiting example, SEO data or SEM data attached to or pertaining to a domain name or a project may be useful in sorting the domain names. For example, the attachment of SEO or SEM data to a domain name may be indicative that the domain name is a primary domain name or that other secondary domain names referenced by or targeted by the SEO or SEM may be secondary to the primary domain name. This SEO and SEM data may be utilized to sort domain names in a multitude of other methods not explicitly described herein, but which are contemplated by the present disclosure.
Is still another embodiment, data relating to the user account or a user 112 of the user account may be utilized by the computing device to sort the plurality of domain names. For example, a domain name search history record associated with the user account or a domain name aftermarket auction history associated with the user account may be helpful in determining what domain names the user 112 is interested in procuring or investigating. This information may provide additional insight as to which domain name may be a primary domain name or the focus of a project, which domain names are secondary domain names, and a proper sorting of the plurality of domain names. For example, the fact that a user 112 often searches for domain names that are similar in spelling to a particular domain name may indicate that the particular domain name is the pertinent primary domain name.
Additionally, user account interaction history may be used by the processing device to sort the plurality of domain names. A history of user 112 interactions with the user account may include the frequency which the user 112 logs on, performs searches, or purchases, sells, or edits domain names. Other user account interaction information may include email traffic associated with the user account (e.g., domain names of email addresses for messages sent to or from an email account associated with the user account). Further, email content associated with the user account or content of email messages associated with the user account can be utilized in sorting the plurality of domain names.
Other examples of user account interaction information may include user utilization of or investigation into other features that may be offered as part of the user account. For example, if a user 112 utilizes or investigates a website builder tool in association with a particular domain name, activates or investigates data hosting associated with a particular domain name, or purchases or sets up an email address associated with a particular domain name, it may be indicative that the domain name is a primary domain name.
Further still, user account interaction information may include interaction information not directly pertinent to the plurality of domain names. For example, user interaction with other features or offerings of the user account or other linked applications or web services not directly related to the domain name portfolio (e.g., in general: web search, email, maps, documents, photos, cloud storage, music, calendars, online meetings, collaborations, and so forth). These interactions provide a wealth of information that can be used in various ways to help sort the plurality of domain names, determine projects, and determine primary and/or secondary domain names, all of which are contemplated by this disclosure. Moreover, other locally stored data (e.g., data stored on the client device 106 such as cookies, favorites, browser history, and the like) may be similarly used.
In general, the various data used to sort the plurality of domain names may be processed by the processing device (e.g., server 100) or processed by a different server 108 to perform data analytics and/or clustering analysis as is understood in the art. The results of the data analytics or clustering analysis may yield any number of differing resultant sorted plurality of domain names 300 having different domain name classifications or groupings. For example, if multiple different sorting schemes are determined, some or all of the multiple sorting schemes may be provided to a user 112 to select the most appropriate or useful sorting scheme. The domain name management service may have a default sorting scheme which can in turn be modified by the user 112.
In one approach, as is shown at step 512 of
To determine the user-type classification, the computing device may look at the settings of the user account (e.g., to determine if a user-type has been selected or indicated by a user 112 of the user account) or other factors. In certain examples, this classification may be made through the use of data analytics to determine whether the user's actions are in line with a primary user (e.g., most of the domain names in the user account focused on a particular theme or are similar in nature, or the user has actual content attached to one or more of the domain names) or in line with a broker (e.g., most of the domain names are fairly diverse and without substantive content attached to any particular domain name). Similarly, if a user 112 investigates a website builder tool, data hosting options, or other features associated with the user account, it may be indicative that the user account is a primary user. Data analytics, as are understood in the art, may be performed by the server 100 or by a different server such as the second server 108.
By implementing the disclosed domain name sorting methods, users 112 are able to easily keep track of a plurality of domain names grouped by projects. Further, in some embodiments, sorting can occur automatically thereby reducing or eliminating the amount of time a user 112 is required to spend to organize a portfolio of domain names. In some embodiments, the computing device may facilitate a combination of user-initiated and automatic grouping of domain names and their attached data into projects, via any of the user interfaces and any of the communications between processors and data stores described herein.
Referring to
At step 604, the server may identify which of the cards should be displayed to the user in the user interface. A subset of the cards or all of the cards may be simultaneously displayed on the screen layout. Identifying the cards may include receiving an indication from the user of which subset of cards to display. For example, the user may select via the user interface a project of interest, and the server may identify the card associated with the domain names in the selected project for display. At step 606, the server may display the identified cards to the user on the screen layout within the user interface, as described further below.
At step 608, the server may receive data pertaining to an interaction that the user has performed with the cards on the user interface. Exemplary interactions are described below. The interactions may be integrally associated with certain modifications to the properties of the domain names of the cards involved in the interactions. For example, a lookup table may associate the interactions with the modifications to be made. Thus, at step 608 the server may receive the interaction data indicating, for example, that the user dragged the card for A.com onto the card for B.com; at step 610 the server may determine from the lookup table that the appropriate modification is to forward the domain name of the dragged card to the domain name of the stationary card. At step 612, the server may perform the appropriate modification, such as by creating a 302 redirect HTTP header for A.com pointing to B.com in the example. At step 614, the server may modify the display of the cards on the screen layout to reflect the new properties of the domain names in the interaction, and may wait for the next interaction.
The exemplary interface of
The flip icon 808 may alter the display of the top card 804 by “flipping” the displayed side of the card 804 from front to back and vice versa. The top card 804 illustrates an exemplary front of the card (also see
The shuffle icon 810 may shuffle the cards of the stack 802 in order to “surface” (i.e., bring to the top) another card (e.g. card 812 or card 814) as described further below. The example screen layout 700 of
The cards (e.g., cards 702, 704, 706, 708) may be moved around the screen layout 600 to accomplish organization and managerial tasks. Dragging a card or a stack of cards onto a stationary card may create a new project with the domain name of the stationary card identified as the primary domain name and the domain name(s) of the dragged card(s) identified as secondary, tertiary, etc. domain names. If the stationary card is already in a project, the dragging action may add the dragged card(s) to the project as described above. The card(s) may be added with or without registering the position of the card(s) when the user “drops” them into the project. That is, the dragged card(s) may be added physically below or hierarchically below the card onto which the dragged card(s) were dropped, or the dragged card(s) may be added to the top or bottom of the stack of cards already in the project. Similarly, dragging a card out of stack may remove the domain name from that stacks' hierarchy and, potentially, from the project. The screen layout 700 may include areas (not shown) that indicate the effect on the card (and associated domain name) if the card is dropped there after being dragged from a stack. For example the area may indicate that the card will be removed from the project if it is placed in the area.
Two cards, or a stack and a card, or two stacks, may be “pinched” together, such as by using a pinch gesture on a touchscreen interface. Pinching may join the pinched cards in a common project. The pinched cards may be displayed adjacent to each other, at the same level of a common hierarchy or in separate hierarchies within the same project. Similarly, to sever a connection between two cards (e.g., domain forwarding) or a stack and a card (e.g., placement within a common project), the cards may be “split,” such as by using a two-or three-fingered spread gesture on a touchscreen interface. Additionally or alternatively, the spread gesture may be used on a stack of card to “focus” the screen layout 700 on the stack, such as by spreading the cards out to make data thereon more visible. A spread gesture may be used on a single card to “tear” the card, removing it from the display. Or, a spread gesture may be used on a single card to expand the card on the screen layout 700, allowing more data to be displayed on the card.
Actions may also be performed on multiple cards covering all or part of the screen layout 700, in order to “surface” (i.e., bring to forefront attention) different domain names that haven't been organized by the user. The user may sort the cards manually, such as by drag-and-drop action described above. For example, the user may move a card forward or backward in the stack. Additionally or alternatively, the user interface may include a button or menu item that instructs the server to sort some or all of the cards automatically. The cards may be sorted by any suitable paradigm, such as alphabetically, grouped by TLD, grouped by theme, etc. The user may also shuffle the cards on the screen layout 700 (e.g., by clicking the shuffle icon 810 of
The physical appearance of each card may be modified by the server or by user interaction, in order to convey information about the corresponding domain name. In one example, a card may be dog-eared by the user, such as by clicking a corner of the card, to indicate that additional configuration must be done before the domain name can be launched. In another example, all or portions of a card may be color-coded to indicate that the domain name needs attention, as well as what type of action is needed and how urgent the attention is. Such visual indications may be cleared manually or automatically when the user has performed the action.
Additionally or alternatively to modifying the project-related characteristics of the cards, any of the user's interactions with the cards may cause a server in the present system, such as server 100 of
The server may perform any of the following non-limiting exemplary actions on the functional properties of the domain names in response to the exemplary interactions described above. Dragging a card or a stack of cards onto a stationary card may, for example, cause the server to create an HTTP 302 redirect or similar domain forwarding characteristic from the domain names of the dragged cards to the domain name of the stationary card. The same dragging action may additionally or alternatively propagate one or more of the functional properties of the stationary card into the dragged cards. For example, the server may change the MX records, nameservers, and/or technical contact information of the dragged cards to match the stationary card. In another example, the server may grant, to the domain names of the dragged cards, access permissions for each of the web applications to which the domain name of the stationary card has access. Additionally or alternatively, the server may remove the dragged-card domain names' access to applications that the domain name of the stationary card cannot access. In another example, if the domain name of the stationary card is set to auto-renew, the domain names of the dragged cards may be set to auto-renew. Furthermore, the renewal dates for all of the domain names in the interaction may be made consistent.
Once cards are stacked, in order to maintain consistency the server may prevent the user from changing some or all of the functional properties of domain names that are slotted below the primary domain name. In some embodiments, the user may modify the functional properties of the primary domain name by interacting with the associated card, and changes may be propagated through the stack. In other embodiments, the user may be permitted to manipulate the functional properties of all or a subset of the secondary, etc., domain names in a stack of cards. Some or all of the functional properties of a domain name may be displayed on the front and/or back of its card, as described above. Where changes to the functional properties are permitted, the user interface may permit the user to make such changes by modifying the displayed values directly on the card. Additionally or alternatively, the user may select the card and be taken to an editing interface.
In a “pinch” interaction, the two domain names of the relevant cards are identified as related but maybe not in a primary-secondary relationship. The server may respond to a pinch by modifying some of the functional properties of one of the domains to match those of the other. The server may prompt the user to identify the domain name having the functional properties that will be kept (e.g., by prompting “Do you want the properties of card B copied to card A, or of card A copied to card B?”). Alternatively, the server may automatically identify the domain name to be changed and change it. For example, between the domain names of the two cards in the pinch, the server may copy the functional properties of the domain name that is more active based on one or more traffic metrics. For example, the server may identify that a first of the domain names has a greater number of DNS hits, a better page rank, or more recently edited data than the second domain name. The interface may enable the user to override the server's automatic selection. Where one or two stacks are involved in the pinch, the functional parameters of the secondary, etc., domain names may be changed in conjunction with those of the primary domain as described above.
When a card is dragged out of a stack, the server may remove some of the values of the domain name's functional properties. For example, any 302 redirect or other domain forwarding, email forwarding, and access to any native or third party applications and services may be eliminated. A card may further be dragged off of the screen layout 700, or “swiped,” to remove the card from the screen layout 700. A user may swipe a blank card onto the screen layout 700. In some embodiments, the blank card may include a prompt that enables the user to perform a new domain name search as described herein.
The schematic flow chart diagrams included are generally set forth as logical flow-chart diagrams. As such, the depicted order and labeled steps are indicative of one embodiment of the presented method. Other steps and methods may be conceived that are equivalent in function, logic, or effect to one or more steps, or portions thereof, of the illustrated method. Additionally, the format and symbols employed are provided to explain the logical steps of the method and are understood not to limit the scope of the method. Although various arrow types and line types may be employed in the flow-chart diagrams, they are understood not to limit the scope of the corresponding method. Indeed, some arrows or other connectors may be used to indicate only the logical flow of the method. For instance, an arrow may indicate a waiting or monitoring period of unspecified duration between enumerated steps of the depicted method. Additionally, the order in which a particular method occurs may or may not strictly adhere to the order of the corresponding steps shown.
Various embodiments of the invention may be implemented at least in part in any conventional computer programming language. For example, some embodiments may be implemented in a procedural programming language (e.g., “C”, and the like), or in an object oriented programming language (e.g., “C++” “JAVA”, and the like). Other embodiments of the invention may be implemented as preprogrammed hardware elements (e.g., application specific integrated circuits, FPGAs, and digital signal processors), or other related components.
In some embodiments, the disclosed apparatus and methods (e.g., see the various flow charts described above) may be implemented as a computer program product for use with a computer system. Such implementation may include a series of computer instructions fixed either on a tangible medium, such as a computer readable medium (e.g., a diskette, CD-ROM, ROM, or fixed disk) or transmittable to a computer system, via a modem or other interface device, such as a communications adapter connected to a network over a medium.
The medium may be either a tangible medium (e.g., optical or analog communications lines) or a medium implemented with wireless techniques (e.g., WIFI, microwave, infrared or other transmission techniques). The series of computer instructions can embody all or part of the functionality previously described herein with respect to the system.
Those skilled in the art should appreciate that such computer instructions can be written in a number of programming languages for use with many computer architectures or operating systems. Furthermore, such instructions may be stored in any memory device, such as semiconductor, magnetic, optical or other memory devices, and may be transmitted using any communications technology, such as optical, infrared, microwave, or other transmission technologies.
Among other ways, such a computer program product may be distributed as a removable medium with accompanying printed or electronic documentation (e.g., shrink wrapped software), preloaded with a computer system (e.g., on system ROM or fixed disk), or distributed from a server or electronic bulletin board over the network (e.g., the Internet or World Wide Web). Of course, some embodiments of the invention may be implemented as a combination of both software (e.g., a computer program product) and hardware. Still other embodiments of the invention are implemented as entirely hardware, or entirely software.
The present invention has been described in terms of one or more preferred embodiments, and it should be appreciated that many equivalents, alternatives, variations, and modifications, aside from those expressly stated, are possible and within the scope of the invention.
This application is a continuation-in-part and claims the benefit of U.S. patent application Ser. No. 14/504,034, entitled “SYSTEM AND METHOD FOR MANAGING DOMAIN NAME PROJECTS” and filed Oct. 1, 2014, the entirety of which is incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 14504034 | Oct 2014 | US |
Child | 14524898 | US |