WACS: Console Tools

Contents

Adders

These are console commands that let you add a new record into the database. At the present moment, they need to be driven with some care and really could use a re-write. It is important to understand that some database fields are assumed to have only a very limited range of legal values: in only some cases are these enforced by these programs. If in any doubt, please refer to the page on database table structures.

addmodel

This is the cornerstone of getting Wacs to manage sets based upon models; you need to be able to create new models first. This console command is designed to do this - a web or graphical interface is most definitely on the future plans list. This program currently calls the old "xv" Unix/ Linux image viewer to display the model icon, but could easily be changed to run eog, display or some other image viewer. It is not critical if it's not present or can't make a connection to an X-server. In most cases, addmodel will actually prompt for the major items of data if they are missing from the command line.

A simple example of using addmodel would be:

% addmodel name=Sarah hair=Redhead length=Normal titsize=Small pussy=Shaven image=Sarah-1.jpg
Sarah is not known
Name: Sarah
Hair Colour: Redhead
Hair Length: Normal
Titsize: Small
Attributes:
Pussy: S
Aliases:
Usual Source:
Image:
Source:
RefNo:
OK to add (x for exclude) ? (y/n/x): y
Model number is 2249
SQL: insert into models (modelno, mname, mhair, mlength, mtitsize, mattributes,
maliases, musual, mimage, mstatus, mflag, mpussy, madded) values( '2249','Sarah'
,'Redhead','Normal','Small','','','','','A','N','S','9-OCT-2006')
% 
As you can see from the above, addmodel summarises what it has parsed from the command line and seeks confirmation before proceeding with the creation of the record. If you do confirm, it creates the model giving you the model number assigned and the SQL used in the creation process. Let's review for a moment the standard values expected here - hopefully they are reasonably obvious.

Legal Values In AddModel
Hair Colour Hair Length Titsize Pussy
Blonde Short Tiny Shaven
Brunette Shoulder Small Trimmed
Redhead Normal Normal Hairy
Dark Long Large  

In practice, the addmodel command line is usually a bit more complex, lets consider an example from amkingdom.com.

% addmodel name=Erika hair=Brunette length=Long titsize=Tiny pussy=Shaven attrib
utes='shaven tinytit tattoo' refno=eri046 altref=12475 source=AMK usual=amkingdo
m.com image=amkingdom/Erika-1.jpg
[...]
%

OK, going through the new fields here. The setting of attributes adds some extra information to aid searching by models - in this case, her unusual attributes that differ from what is "normal" are that she has exceptionally small breasts, a completely shaven pussy and a few tattoos. The next keyword refno normal contains her model number at the source site; usually this is just a simple number. However in the case of the AMKingdom web site, there is a corporate wide "identity" which takes the form of three letters and then three numbers; in her case eri for Erika and 046 which we assume means she's the 46th model added with the first three letters of eri. Some of the other AMK group sites, such as ATK Premium navigate using the corporate id as the "model key", but the AMKingdom site (aka ATK Galeria) uses an older system based on a numeric reference. This is the altref specified here. At present, this is the only site I've encountered with this arrangement, but having the dual key support available just adds to the flexibility of the system. The source directive gives us the "domain" in which these keys apply. In this case we're setting it to "AMK" for AMKingdom.com. With these three specified, we'll be adding a record in the idmap table as well, mapping Erika with our model number 2075 to being "Erika" from AMKingdom.com with corporate id eri046 and model key 12475. Additional id mappings (for instance Erika also appears on ATExotics) have to be added manually using SQL at present. The next field, usual merely makes a comment in the models table of where we usually find this model, in practice this usually means where we first found her! The final attribute image specifies an icon for her (conventionally resized to 120x156) and in this case the icons have been subdivided by source site, so her icon appears in the amkingdom sub-directory.

addassoc

This is a much simpler command to use, it quickly associates a model with a set or range of sets. It does help if this command is in your path, but it can be called by pathname too (usually). Do remember that a set has to be known by WACS before you can associate it with any model, so in most cases the generate command below needs to have been run first. Anyway, to use addassoc for example for our redhead called Sarah, you would do:
% cd image_location/redheads/smalltits/Sarah
% addassoc Sarah Sarah_*
1. Sarah with Long Redhead hair and Small tits - model number=2249
Name: Sarah
Hair Colour: Redhead
Hair Length: Long
Titsize: Small
Attributes: shaven tattoo
Aliases:
Usual Source:
Image: Sarah-1.jpg
RefNo: 2249
Continue (y/n)? y
DB record found: setno 10661, title: Sarah PinkDressNoPanties GardenBenchDildo
Added association between Sarah (2249) and set 10661
%
If the name isn't unique, addassoc offers you a list of the choices along with their model numbers. Pick the one you want and use the model number prefixed with a # instead of the name, ie #2249 instead of Sarah.

Digesters

These are applications that look at an existing filesystem structure and try their best to digest the content into metadata and insert it into the database. The two main such applications are generate and updateinfo, however since the invocation technique is the same and generate automatically calls updateinfo with the values it was called with, they are effectively the same. Do note that updateinfo is invoked without specifying a path name by generate, so if they are not in your default path, updateinfo will not get run and no sets records will get created. You also need to consider existance and ownership of the various icon directories defined in the configuration file before running generate. It will only create directories below those defined in the configuration file, never those top level points. If you used easyinstall, this should have been taken care of.

generate - import directories of files into the Wacs system

Running generate is actually very simple, to import a tree of file directories (say image_location/redheads/smalltits/Sarah) you just do:
% generate redheads/smalltits/Sarah
[...]
COMPLETED: 12 new records inserted, 7 updated.
Calling make_index() with redheads/smalltits/Sarah
% 
all that is then needed is to do the appropriate addassoc command to associate the newly added sets with Sarah (see above). Generate can recursively scan from the top of the images tree (or from any point on the sub-tree), but probably best avoided if you have a large number of directories in the system.

As was mentioned in the overview, certain keywords are recognised within the directory name and used to define various special attributes in the default metadata. Whether the metadata is manipulated manually, semi- manually or automatically is controlled by the sauto flag for each set record within the sets table. These guesses are performed by the function guesscatinfo() in updateinfo. For now, it's probably best to look at the source code of that function to get some idea of how this works. Hopefully some more detailed documentation can be added in due course.

updateinfo - work out set status and attributes

Please see the information given in the section on generate above.

genvideo - import video files into the Wacs system

Genvideo performs much the same functions as the combination of generate and updateinfo for the importation of video clips into the Wacs system. It actually also includes aspects of another program too called chkdownload (which will either be released shortly, or it's code features incorporated into updateinfo). However the video naming convention is a lot simpler and what meta data there is in inferred from the download record as very little information can be gleaned from the name of the file itself. Note that although the relative pathnames appear the same, genvideo operates in a parallel space under the videos tree in the file system.

To import a directory of Sarah's videos, you would do: ./genvideo redheads/smalltits/Sarah and it will scan that directory for .mpg, .wmv, .mov and .avi files. Note that the icons are automatically referred to by the same pathname but in the vidicons directory. Therefore for sarah01.mpg in videos/redheads/smallbreasts/Sarah, you would place the corresponding icon file as sarah01.jpg in vidicons/redheads/smallbreasts/Sarah.

updatestats - update model statistics

The model record keeps some basic statistics about the sets and types of activity featured in those sets in order to better describe the model and her activities (on camera). Of course, much of this information is ultimately derived from the sets she features in; for instance, if she features in a lesbian set, the assumption is that she does lesbian scenes on camera! Obviously examining every set each time a model page is loaded is unlikely to be very practical, so the schema design has this data cached. Updatestats is the program that updates this cached attribute data in the model record. It should be run periodically, probably nightly via the cron command.
Next Section: Security
Back to WACS Documentation Index