Wacs Programming Guide

Sixth Edition

for WACS 0.8.5

B "Beaky" King

This work is licensed under the Creative Commons Attribution License. To view a copy of this license, visit http://creativecommons.org/licenses/by/2.0/ or send a letter to Creative Commons, 559 Nathan Abbott Way, Stanford, California 94305, USA.

15th March 2010

Abstract

WACS is a tool for building Adult Web Sites; it is equally suitable for managing a private collection or building a commercial web site. It has many best of breed features including dynamic filtering, model catalogs, automatic download and powerful search engine. It comes with a powerful API (application programming interface) implemented in both Perl and PHP5 languages to allow web developers to leverage it's facilities from their own programs.

This book describes the application programming interface provided by WACS, and how to utilise it from perl and Php languages. It provides an extensive introductory tutorial with a large number of worked example programs as well as a complete API reference manual. Additionally it provides a schema reference for the WACS database tables as understanding the fields available to you is central to writing programs that utilitise it. The intended audience is web developers and WACS site managers who wish to tailor an existing WACS installation to meet their precise requirements; people merely wishing to use or manage an existing WACS installation may well find the default configurations provided suffice.

The WACS source code and other documentation and support tools can all be found at the WACS website at Sourceforge and on the WACS page at Launchpad.net. The WACS demonstration site can be found at PinkMetallic.com - the site will initially be free but a charge maybe applied later to help fund additional content. Commercial add-ons and support options can be purchased from Bevtec Communications Ltd, see their website at Bevtec Communications.


Table of Contents

I. WACS API Programming Tutorial
1. Introduction
Overview
About This Book
About The Examples
2. Basics: Getting Started
Outline
A First WACS Program
Modules: Importing
Configuration And Security
Initialising Database Connection
Fetching Some Records
Showing The Results
Finishing Off
Putting It All Together
Running MySimple
Reviewing The First Program
3. Using More Database Fields
Adding Model Icons
More Model Information
Using HTML tables
Adding The Model Details
Adding Other Icons
Improving Error Reporting
4. Set Display Routines
About Set Display
Sets: The Basic Bones
Adding Icons
Making The Text More Readable
Connecting Sets And Models
Understanding The Data Architecture
Using Relationships With Assoc
An Example Using Assoc
5. The User Interface Toolkit
Introducing WacsUI
Including WacsUI support
WacsUI: DescribeHer
The whatshedoes function
The addkeyicons function
iconlink: WacsUI's Most Important Function
WacsUI: Other Functions
Conclusions
6. Wacs-PHP: The Skins
Introduction To PHP Skins
Wacs-PHP: The Simple Skin
Styling Wacs-PHP Skins
WACS and Web 2.0
II. WACS API Programming Reference
7. WACS API: Core Module
Core Module: Summary
Core Module: Reference
8. WACS API: User Interface Module
User Interface Module: Summary
User Interface Module: Reference
9. WACS API: Standard Components Module
Standard Components Module: Summary
Standard Components Module: Reference
10. WACS API: Identification Module
Identification Module: Summary
III. WACS Database Schema
11. Schema Reference: Sets
Sets: Schema SQL
Sets: Defined Values
12. Schema Reference: Assoc
Assoc: Schema SQL
Assoc: Defined Values
13. Schema Reference: Idmap
Idmap: Schema SQL
Idmap: Defined Values
14. Schema Reference: Models
Models: Schema SQL
Models: Defined Values
15. Schema Reference: Download
Download: Schema SQL
Download: Defined Values
16. Schema Reference: Photographer
Photographer: Schema SQL
Photographer: Defined Values
17. Schema Reference: Tag
Tag: Schema SQL
Tag: Defined Values
18. Schema Reference: Vendor
Vendor: Schema SQL
Vendor: Defined Values
19. Schema Reference: Conn
Conn: Schema SQL
Conn: Defined Values
20. Schema Reference: Keyword
Keyword: Schema SQL
Keyword: Defined Values
21. Schema Reference: User
User: Schema SQL
User: Defined Values
22. Schema Reference: Attrib
Attrib: Schema SQL
Attrib: Defined Values
23. Schema Reference: Notes
Notes: Schema SQL
Notes: Defined Values
Index

List of Tables

6.1. Simple Skin: Components
2. The Key WACS Modules
7.1. Function Summary: Core Module
8.1. Function Summary: User Interface Module
9.1. Function Summary: Standard Components Module
10.1. Function Summary: Identification Module
11.1. stype: Type of Set: defined values
11.2. sstatus: Status of Set: defined values
11.3. sauto: Automatic Update of Set Allowed?: defined values
11.4. srating: Overall Rating For The Set: defined values
11.5. stechqual: Technical Quality Rating For The Set: defined values
11.6. svariety: Unusualness Rating For The Set: defined values
11.7. sformat: Format of the File(s) In The Set: defined values
11.8. sidlogo: Presence of Burnt-in Logo: defined values
11.9. sinter: Progressive or Interlaced Video Structure
11.10. serrors: Presence of Known Errors: defined values
11.11. scatflag: Generalised type of the set: defined values
11.12. slocation: generalised description of locations: recommended values
11.13. sattire: generalised description of model's clothing: recommended values
11.14. suscattr: how to generate the 18 USC 2257 declaration: defined values
12.1. astatus: association status: defined values
13.1. istatus: idmap status: defined values
13.2. iactive: model activity status as this identity: defined values
13.3. isite: Some recommended site abbrievations: recommended values
14.1. mstatus: model record status: defined values
14.2. mrating: model rating: defined values
14.3. mpussy: model's normal pubic hair style: defined values
14.4. mflag: special marking flag for models: defined values
14.5. model activites flags: defined values
14.6. mcstatus: accuracy of home country field: defined values
14.7. mrace: race of the model: defined values
14.8. mbuild: body type of the model: defined values
14.9. vital statistics: meanings
15.1. dstatus: download status: defined values
15.2. dtype: download set type: defined values
15.3. dsetflag: Suggested value for scatflag based on parsing result
16.1. pgender: gender of the photographer: defined values
16.2. pregion: geographical location of the photographer: defined values
16.3. prating: overall rating of photographer: defined values
16.4. phardness: rating of how explicit this photographer can be: defined values
16.5. photographer activites covered flags: defined values
16.6. photographer technologies used flags: defined values
17.1. tstatus: tag entry status: defined values
17.2. tflag: tag content type status: defined values
18.1. vcurrent: vendor existance status: defined values
18.2. vshow: vendor index inclusion status: defined values
18.3. vmdiruse et al: vendor URL auto-usuability status: defined values
19.1. cflag: connection type: defined values
19.2. cstatus: connection entry status: defined values
20.1. kflag: active entry status: defined values
21.1. ustatus: User Account Status: defined values
21.2. utype: User Type: defined values
21.3. uclass: User Class: defined values
23.1. ntype: notes type: defined values

List of Examples

2.1. WACS Module Import
2.2. Config and Security
2.3. Database Connection Initialisation
2.4. Database Query
2.5. Outputing The List
2.6. Php: Complete Simple Program
2.7. Perl: Complete Simple Program
3.1. Modified Output Loop with Icon Code
3.2. Modified SQL command for more Model Info
3.3. New version of the loop using tables
3.4. Adding Model Information
3.5. Adding A Rating Icon
3.6. Calling dberror for better error reporting
4.1. The Basic SetDisp Program
4.2. Adding A Set Icon
4.3. Making Camel-Style Text Readable
4.4. Modified Icon Cell
4.5. getmodel Subroutine
4.6. Calling The getmodel Function
5.1. WacsUI initialisation
5.2. Using WacsUI: describeher
5.3. Using WacsUI: whatshedoes
5.4. Using AddKeyIcons
5.5. Using the iconlink function

Part I. WACS API Programming Tutorial

Chapter 1. Introduction

Overview

Welcome to WACS, Web-based Adult Content Server, a free software package for the management of material of an "Adult Nature" (or basically whatever euphermism for porn you prefer). It is web-based and can be used for the management of an existing collection, as a download manager, or as a back-end system for running a commercial adult web site. It is dramatically different from most other image gallery systems in that it understands photo sets and video clips as basic concepts, instead of single photographs. It also includes far more specialised tagging, source, relationship and attribute marking concepts than other more generalised systems. WACS' abilities in the areas of searching and dynamic filtering are really industry-leading in their power and flexibility.

About This Book

This electronic book, the WACS Programming Guide, is designed to act both as an introduction to programming with the WACS API in either perl or PHP, and as a reference volume for both the API itself and the database schema. This book assumes you already have a basic knowledge of programming in your choosen language (PHP5 or perl5) and have some understanding of databases and in particular SQL (Structure Query Language). Some familiarity with WACS at a user level would also be a distinct advantage, and I'd strongly recommend working through the companion user guide first - who knows it might give you some ideas about neat extra features you can add to your own site. All documentation for WACS is available both within the distribution and from the WACS Web Site at Sourceforge.net.

It is important to stress that ALL of the collection management tools are implemented in Perl and the PHP interface is an optional addition to, not an alternative to, the core Wacs system which is perl based. Given the relative youth of the WACS system, php5 has been selected for the implementation to save future porting efforts as it is expected that php5 or later will be the minimum common standard by the time Wacs reaches 1.0. There is no intention to support older dialects of php at this point.

As the WACS software package is Open Source, we're always looking for contributions; if you create a site design (or prototype for one) which you don't end up using, maybe you would consider donating it to the repository of sample WACS Skins. We can always substitute our own artwork into already written web application code.

About The Examples

For copyright/licensing reasons, the example images feature sets from photoshoots by the main developer of WACS (Beaky) and a friend of his. These sets are available for download from the WACS demonstration site at PinkMetallic.com - CAUTION: contains adult material! Access to this site is currently free but we may have to levy a small charge in the future if refferal and donations don't reach the hoped-for amount.

Chapter 2. Basics: Getting Started

Outline

In this chapter we're going to talk about the basic first steps in making use of the WACS API from your own programs. We're going to assume that you've got a WACS server you can use up and running; that you know where things are on it and that you have appropriate write access to the web document tree (if you're working in PHP) or the cgi-bin directory (if you're working in Perl). Hopefully you'll have both some models and a few image sets known in the WACS system to work with. For these first code examples, you could merely load the sample model profiles we've provided in the samples directory of the WACS distribution.

While the finished code of the sample programs featured here is available in the samples directory of the WACS Core distribution (for the Perl verion) or the WACS-php distribution (for the PHP5 version), you may wish to type it in as you go along as an aid to learning how to use the interface. If you do, we'd recommend calling this file mysimple for perl, or mysimple.php for PHP. For consistency, we're going to put the PHP dialect first and then the Perl dialect in each of the examples.

The basic structure of your first WACS application will consist of five steps; these are:

  1. import the WACS API modules

  2. read configuration and check access rights

  3. initialise the database connection

  4. run an appropriate database query

  5. retrieve records and display them

A First WACS Program

Modules: Importing

The very first step is to import the WACS API modules into your program file along with those standard modules needed to access the database. These files should be in the right location already and should just be found without any additional specification of where they are.

Example 2.1. WACS Module Import

require_once "wacs.php";
require_once "DB.php";

$wacs = new Wacs;

The same code segment implemented in perl looks like:

use Wacs;
use DBI;
[Note]Note

The PHP interface requires an Object Handle to use when accessing the WACS module which we're simply calling $wacs. Perl doesn't need such a construct - there is simply the one instance.

Configuration And Security

The second step is to read the standard WACS configuration file to find out where everything is, and then check that this user is allowed to access the WACS system. This is a two step process, and the reading of the configuration file must be done first; otherwise WACS doesn't know where to look for the security files it needs to determine whether this user should be given access or not.

Example 2.2. Config and Security

// read the Wacs configuration files
$wacs->read_conf();

// check the auth(entication and authorisation) of this user
$wacs->check_auth( $_SERVER['REMOTE_ADDR'], 1 );

and here is the same thing again in the perl dialect:

# read the Wacs configuration files
read_conf;

# check the auth(entication and authorisation) of this user
check_auth( $ENV{"REMOTE_ADDR"}, 1 );

Initialising Database Connection

The third step is to initialise the database connection. Since some databases require an environment variable to determine where their configuration files have been stored, this needs to be set first. Wacs provides for this and this code will create that environment variable, if needed, and then proceed to establish the database connection itself.

Example 2.3. Database Connection Initialisation

// database initialisation
// - establish environment variable
$dbienv = $wacs->conf_get_attr("database","dbienvvar");
if( ! empty( $dbienv ))
{
        putenv($dbienv."=".$wacs->conf_get_attr("database","dbienvvalue"));
}
// - connect to the database
$dbhandle= DB::connect( $wacs->conf_get_attr("database","phpdbconnect") );
if( DB::iserror($dbhandle))
{
        die("Can't connect to database\nReason:".$dbhandle->getMessage."\n");
}
$dbhandle->setFetchMode(DB_FETCHMODE_ORDERED);

and here's how we do it in perl:

# database initialisation
# - establish environment variable
$dbienv = conf_get_attr( "database","dbienvvar" );
if( $dbienv ne "" )
{
        $ENV{$dbienv}= conf_get_attr( "database","dbienvvalue" );
}
# - connect to the database
$dbhandle=DBI->connect( conf_get_attr("database","dbiconnect"),
                        conf_get_attr("database","dbuser"),
                        conf_get_attr("database","dbpass") ) ||
die("Can't connect to database\nReason given was $DBI::errstr\n");

OK, let's just study this code for a moment. It first calls the WACS API function conf_get_attr with the section parameter of database as it wants database related configuration information, and an argument of dbienvvar. The WACS API function conf_get_attr is short for configuration get attribute and returns the value of the configuration file parameter of that name or it's default value. The dbienvvar means database interface environment variable. A typical value for this might be something like ORACLE_HOME which is the environment variable that Oracle 10g and 11i requires to be set in order to find it's current configuration.

The next line of the code checks to see if we got back an actual variable name (eg ORACLE_HOME) or an empty string (ie nothing). If we were given a valid variable name, then we're going to need to set it the value it should be, which again we can get from the configuration file, this time called dbienvvalue which is short for database interface environment value (as distinct from the variable name we just looked up). A likely value for this might be /usr/local/oracle. Obviously if we're given no variable name to set, there's no point looking for a value for it! Conversely we are assuming that having bothered to name the variable in the configuration file, also put in a valid value for it - this code could break if the variable name is specified but not it's value.

The second section of these code segments is to do with the establishment of a connection to the database and is a little different between the two versions. Both systems use a handle for the database connection, which we call $dbhandle - imaginative name huh? In both cases, the respective database APIs provide a connect function which takes an argument of how to connect to the database. The Php version takes a single argument, which is stored in our configuration files as phpdbconnect and includes the whole username, password and database specification in a single lump. The Perl version asks for three: the database specification, the username and finally the password. The configuration file knows these as dbiconnect, dbuser and dbpass respectively.

The final bit copes with putting out some kind of error message, at least showing the point of failure, if we are unable to establish a connection to the database. The methods are very slightly different, but the effect is very much the same between the two versions. We then just tell the PHP DB interface how we wish it to organise the returned data; the perl DBI default is pre-determined and is what we want.

[Tip]Tip

Note that you might wish to have completed the output of the HTML header section and started the body by this point so that should the database connection fail, the error message will be visible.

Fetching Some Records

The next step in the process is to use the database connection we've established to actually make a request of the database. For now don't worry about what that request is or how we've written it - we'll come back to that topic in detail later in this chapter. Look at the mechanics of how we're issuing the request and getting back the results. What we're going to ask the database for is a list of those girls who are marked as Favourite Solo models. We chose this because both the models in our current samples directory are marked as this and so even if you only have our sample records loaded, you should find some matches.

Example 2.4. Database Query

// do db select
//                0      1        2          3
$query = "select mname, modelno, mbigimage, mimage from ".
         $wacs->conf_get_attr("tables","models").
         " where mflag = 'S' order by mname";
$cursor = $dbhandle->query( $query );

The method is a little different in perl in that it is seperated into two steps; as a result it looks like this...

# do db select
#                 0      1        2          3
$query = "select mname, modelno, mbigimage, mimage from ".
          conf_get_attr("tables","models").
          " where mflag = 'S' order by mname";
$cursor = $dbhandle->prepare( $query );
$cursor->execute;
[Note]Note

The query structure is very similar between Php and perl apart for the two step process of validating and then seperately executing the query in perl. This is mostly down to different traditions that exist for database accesses in each language. The net result is similar in technical terms and identical in output terms

In both cases we're putting together an SQL query that reads:

select mname, modelno, mbigimage, mimage
from models
where mflag = 'S'
order by mname

This query asks the database to fetch the four named items: mname, modelno, mbigimage, and mimage from the database table called models where the field mflag has a value of the capital letter S and to sort the results it returns to us by the value in the field called mname. It may not surprise you to learn that mname is the model's name, modelno is our reference number for her, mbigimage is the (location of the) large size headshot of her and mimage is the (location of the) smaller size headshot of her.

You may have noticed that the only part of this that wasn't copied verbatim from the code is the from models bit and that there we've used the WACS API call conf_get_attr to get the actual name of the database table concerned from the main WACS configuration file. This is actually important and it's strongly recommended that you do use this form when creating SQL queries. If you really insist on knowing why, take a look at the section on the tables part of the wacs.cfg configuration file in the WACS configuration guide.

Once we've created the SQL query, we feed it to the database routines. The first step is to pass in the SQL query and have the database perform that search on the database. Once the query has been executed, we want to pull back the matching records (or rows in database parlence) for each model. In both Php and Perl we're calling a routine that returns to us a single row from the database (a single model's record in this case) each time it's called. When we run out of records, a null return is given and our while loop ends. In Php, the function to do this is called using fetchRow which returns the next row as an array of values, which we assign into the variable $results each time. In Perl, the function we're using is called fetchrow_array because perl offers us a choice in the type of data we are returned and in this case we want a numerically indexed array.

[Note]Note

There are other approaches to getting back the data, including having it returned in one big lump (such as with the Php call getAll()) - this has been avoided as some WACS installations might have tens of thousands of matching records for some queries.

Showing The Results

The final step is to actually generate some output from the data we've fetched from the database. We're going to do this as an unordered list in HTML, so we're going to be adding a little formating to the output as we retrieve each record.

Example 2.5. Outputing The List

print "<ul>\n";
while( $results = $cursor->fetchRow() )
{
        print "<li>";
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        print $results[0]."</a></li>\n";
}
print "</ul>\n";

and here's the perl version...

print "<ul>\n";
while( @results = $cursor->fetchrow_array )
{
        print "<li>";
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        print $results[0]."</a></li>\n";
}
print "<ul>\n";

We start off by printing out the HTML instruction to start an unordered list (<ul>) in a line on it's own. We then start a while loop which goes through each entry until it's done them all. Both versions use the database cursor object ($cursor) to fetch the next record (aka row) from the database using the fetchRow or fetchrow_array method and assigning it into the array $results (or in perl @results). The act of the assignment fails when there are no more records to fetch and the while loop will terminate. The construct here is based upon the fact that both languages have seperate operators for assignment (=) and comparison (== and eq) and so the code is unambiguous (at least to the php and perl interpreters it is!).

Once inside the body of the while loop we print out the start of list entry tag (<li>) and start in on making use of the data. In the quest to make this example a little bit more satisfying, we've tried to make sure this application does something vaguely useful. A simple list of names is all well and good, but we wanted it to actually do something! So what we've done here is to create a link around each models name that points to her model page as displayed by the standard WACS tools. The raw HTML to achieve this would look like:

<a href="http://www.mywacsserver.com/cgi-bin/wacsmpthumbs/123">
Sarah</a>

So we're left with a slight problem here in that we don't know in advance (trust me on this) what the WACS server is called, we don't know what the models are called and we don't know what their numbers are. We have no idea if we have a model number 123 or not and whether she's called Sarah; but the WACS system should be able to fill in all the blanks for us.

The first part of the code merely prints out the start of the HTML <a href="> and then we ask the WACS configuration system what it's externally visible URL for cgi-bin programs is. We do this using the conf_get_attr call again, telling it we want an answer in the section server of the URL for cgi scripts aka cgiurl. On the next line of the example we put the name of the WACS application we want to link to, in this case wacsmpthumbs. Since the way we tell wacsmpthumbs what we want it to look up is to add a slash and then the model number to the URL, we add a slash (/) on the end and then the number.

[Tip]Tip

You may have noticed that we added a comment on the line above the SQL select statement with 0,1,2,3 with each number above the field name in the query. This was a shorthand to ourselves to remind us what the index number in the array is for each of those database fields.

Since the order of the fields we asked for was mname, modelno, mbigimage and then mimage, the results in the array will be the same - element 0 will be the mname, element 1 will be the model number, and so on. In both cases we're dealing with a single-dimensional array. The first field we want to go into the URL for wacsmodelthumbs is the model number, so that will be element 1 (not zero) therefore we write $results[1]. We then finish off the URL reference by closing the quotes (") and the > tag.

We then want to print the model's name which will be element 0 in our arrays, put out the closing anchor tag (</a>) and then finish off the unordered line entry with the end line tag (</li>). We then print out a new line so the generated page is easier to read. The moving on to the next record will be done as a by-product of the test for the next iteration around the while loop. Once we exit the loop, we finish off the HTML unordered list.

Finishing Off

To just finally finish it off, we need to add a few more pieces just to make it work. For the Php version, we need to declare it as being a php program with <?php at the very start of the file, with a matching ?> at the very end. For perl, we need to declare it as a perl script with the very first line being just #!/usr/bin/perl. Additionally for perl, we need to output the mime content type declaration so that the web browser knows what kind of object it's being passed - this is done simply with:

print "Content-Type: text/html\n";
print "\n";

Next we need a couple of lines of HTML preamble near the beginning (as mentioned before, just before the database connection code so we could see any error message that appears):

<html>
<head>
<title>MySimple: Index Of Favourites</title>
</head>
<body>

Similarly at the end, we just need to finish the page off with the html tail piece:

</body>
</html>

Putting It All Together

With all the components in place, let's review the new MySimple WACS program in it's entirety. We include the modules, initialise the configuration system, check the authorisation, connect to the database, draft the query, submit it and then loop through the results. Not really that complex now we know what each part does. Anyway here's the finished code....

Example 2.6. Php: Complete Simple Program

<?php
// MySimple - sample WACS API program (PHP5)
require_once "wacs.php";
require_once "DB.php";
$wacs = new Wacs;
// read the Wacs configuration files
$wacs->read_conf();
// check the auth(entication and authorisation) of this user
$wacs->check_auth( $_SERVER['REMOTE_ADDR'], 1 );
// start the HTML document
print "<html>\n";
print "<head>\n";
print "<title>MySimple: Index Of Favourites</title>\n";
print "</head>\n";
print "<body>\n";
// database initialisation
// - establish environment variable
$dbienv = $wacs->conf_get_attr("database","dbienvvar");
if( ! empty( $dbienv ))
{
        putenv($dbienv."=".$wacs->conf_get_attr("database","dbienvvalue"));
}
// - connect to the database
$dbhandle= DB::connect( $wacs->conf_get_attr("database","phpdbconnect") );
if( DB::iserror($dbhandle))
{
        die("Can't connect to database\nReason:".$dbhandle->getMessage()."\n");
}
$dbhandle->setFetchMode(DB_FETCHMODE_ORDERED);
// do db select
//                0      1        2          3
$query = "select mname, modelno, mbigimage, mimage from ".
         $wacs->conf_get_attr("tables","models").
         " where mflag = 'S' order by mname";
$cursor = $dbhandle->query( $query );
// output the results
print "<ul>\n";
while( $results = $cursor->fetchRow() )
{
        print "<li>";
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        print $results[0]."</a></li>\n";
}
print "</ul>\n";
// finish off
print "</body>\n";
print "</html>\n";
?>

Example 2.7. Perl: Complete Simple Program

#!/usr/bin/perl
#
# MySimple - Sample WACS Program (Perl)
#
use Wacs;
use DBI;
# read the Wacs configuration files
read_conf;
# check the auth(entication and authorisation) of this user
check_auth( $ENV{"REMOTE_ADDR"}, 1 );
# output the HTML headers
print "Content-Type: text/html\n";
print "\n";
print "<html>\n";
print "<head>\n";
print "<title>MySimple: Index Of Favourites</title>\n";
print "</head>\n";
print "<body>\n";
# database initialisation
# - establish environment variable
$dbienv = conf_get_attr( "database","dbienvvar" );
if( $dbienv ne "" )
{
	$ENV{$dbienv}= conf_get_attr( "database","dbienvvalue" );
}
# - connect to the database
$dbhandle=DBI->connect( conf_get_attr("database","dbiconnect"),
                        conf_get_attr("database","dbuser"),
                        conf_get_attr("database","dbpass") ) ||
die("Can't connect to database\nReason given was $DBI::errstr\n");
# do db select
#                 0      1        2          3
$query = "select mname, modelno, mbigimage, mimage from ".
          conf_get_attr("tables","models").
          " where mflag = 'S' order by mname";
$cursor = $dbhandle->prepare( $query );
$cursor->execute;
print "<ul>\n";
while( @results = $cursor->fetchrow_array )
{
        print "<li>";
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        print $results[0]."</a></li>\n";
}
print "<ul>\n";
# finish off
print "</body>\n";
print "</html>\n";

Running MySimple

Our first WACS application is now complete, so copy the file into the either the web server document tree (for Php) or the web server cgi-bin directory (for perl). When you call up the URL, you should see something like this....

Granted it's fairly plain, but the names are in alphabetical order and there are links on each name to that girl's model page. If you didn't see any output, or got an error, you need to check the error log for the server you're using. With Apache on linux, the usual location of this is /var/log/httpd/www.mywacserver.com-errorlog or something similar to that.

Reviewing The First Program

This has been a fairly long and intense chapter, but we obviously had a lot of ground to cover and we really wanted to achieve a usable program before the end of it. This hopefully we've done. We've seen how to include the WACS module and the Database interface module. We've seen how to use read_conf and check_auth to read the configuration files and check the user's credentials. We've then made multiple uses of conf_get_attr to get all of the information together we need to make a connection to the database.

After all that setup procedure, which will become a very familiar template as you program with the WACS API, we looked at creating and sending a query to the database, retrieving the results and formating those results as a simple web page. In the next chapter, we'll look at how to make use of other information stored within the database.

Chapter 3. Using More Database Fields

Adding Model Icons

In the simple example in the last chapter, we saw how to create a list of model's names with hypertext links on each name to that model's standard WACS model page. Obviously that's not a particularly presentable page by itself, so the next step is to add a head shot for each model to the links.

We actually already paved the way for doing this by including the two headshot image fields in the results we asked for from the SQL query - if you remember, we put:

select mname, modelno, mbigimage, mimage 

Since we have the data already, all we need to do now is to add a few extra statements to the output section to output an appropriate image tag and we'll have included the model's headshot too. We have a configuration attribute in the server section of the configuration file called siteurl that tells us where the site specific WACS web elements area can be found on the WACS server. Standard size model headshots are conventionally found in the icons/ directory directly below the top level. So all we need to do is add in a call to conf_get_attr to get it and build the apropriate HTML img tag. In PHP we'd write:

    print "<img src=\"".$wacs->conf_get_attr("server","siteurl");
    print "icons/".$results[3]."\" alt=\"[".$results[0]."]\">";

and in perl we'd write:

    print "<img src=\"".conf_get_attr("server","siteurl");
    print "icons/".$results[3]."\" alt=\"[".$results[0]."]\">";

this needs to be done just below the line that establishes the link to the model's WACS model page, but before her name (you could put it after if you prefer) and closing </a>.

Example 3.1. Modified Output Loop with Icon Code

while( $results = $cursor->fetchRow() )
{
        print "<li>";
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        print "<img src=\"".$wacs->conf_get_attr("server","siteurl");
        print "icons/".$results[3]."\" alt=\"[".$results[0]."]\">";
        print $results[0]."</a></li>\n";
}

and in perl this now looks like:

while( @results = $cursor->fetchrow_array )
{
        print "<li>";
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        print "<img src=\"".conf_get_attr("server","siteurl");
        print "icons/".$results[3]."\" alt=\"[".$results[0]."]\">";
        print $results[0]."</a></li>\n";
}

We then copy up the modified version of the program and run it and we should see something like this:

More Model Information

The WACS database does of course carry far more information about the model thank just her name and icons, so for the next step we're going to look at adding a few basic pieces of information about her to each entry. The first step is to add some additional fields to the list of what we want returned by the SQL query. Initially we're going to add another five fields: they are mhair, mlength, mtitsize, mnsets and mnvideos. These database fields give us her hair colour, length, the size of her breasts and the number of images sets and videos we have by her respectively. The modified version of the query looks like:

Example 3.2. Modified SQL command for more Model Info

// do db select
//                0      1        2          3       4
$query = "select mname, modelno, mbigimage, mimage, mhair, ".
//                5        6         7       8
         "       mlength, mtitsize, mnsets, mnvideos from ".
         $wacs->conf_get_attr("tables","models").
         " where mflag = 'S' order by mname");
$cursor = $dbhandle->query( $query );

in php.

[Note]Note

We've added a second line of comments with the element numbers within the array that the returned database field will appear in; mlength will be index 5 for instance.

The same code in perl will look like:

# do db select
#                 0      1        2          3       4
$query = "select mname, modelno, mbigimage, mimage, mhair, ".
#                 5        6         7       8        
         "       mlength, mtitsize, mnsets, mnvideos from ".
          conf_get_attr("tables","models").
          " where mflag = 'S' order by mname";
$cursor = $dbhandle->prepare( $query );
$cursor->execute;

Using HTML tables

The next step is to modify the display loop to include the extra details and in this case it probably makes sense to switch to using an HTML table cell to contain and manage the entry. We'll start off by simply re-writing the existing display loop to build the results into an HTML table instead - once we have that working, we'll restyle the table to include the extra fields we just added to the query. There is no actual requirement to make use of all the fields we've requested.

Lets have a look at the structure of the HTML document we're outputing here: First we need to open the new table, then each model will have her own row as we go through with the headshot image on the left and her name on the right, and finally we'll finish off the table. The HTML (minus the links) to do this will look something like:

<table>
 <tr>
  <td><img src="icons/Roxanne-1.jpg" alt="[Roxanne]"></td>
  <th>Roxanne</th>
 </tr>
 <tr>
  <td><img src="icons/Sabrina-1.jpg" alt="[Sabrina]"></td>
  <th>Sabrina</th>
 </tr>
</table>

Of course the next step is to re-write the code to actually recreate the necessary HTML; the start and end of the table simply replace the unordered list (<ul> and </ul> ) tags outside the loop that iterates through the list of models returned by the database. The list element (<li> and </li>) tags get replaced by the row start and end tags (<tr> and </tr>. Since we're puting the headshot icon and the name in separate elements and want a link to the appropriate model page on both of them, we need to double up the code that creates the hypertext link to wacsmpthumbs. We then include the icon (with alignment attributes) in a standard table tag ( <td> and the name in a heading (<th>) table tag so it comes out in bold and is centred.

The mysimple example thus re-writen will look like:

Example 3.3. New version of the loop using tables

// output the results
print "<table>\n";
while( $results = $cursor->fetchRow() )
{
        // start the HTML table row
        print "<tr><td valign=top align=center>\n";
        // link around the headshot image
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        // head shot image
        print "<img src=\"".$wacs->conf_get_attr("server","siteurl");
        print "icons/".$results[3]."\"[".$results[0]."]\"></a>\n";
        // end this cell and start the next
        print "</td><th>\n";
        // link around name
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        // the name
        print $results[0]."</a>\n";
        // end the HTML table row
        print "</th></tr>\n";
}
print "</table>\n";
// finish off

and re-writing the same function in perl gives us something like:
# output the results
print "<table>\n";
while( @results = $cursor->fetchrow_array )
{
        # start the HTML table row
        print "<tr><td valign=top align=center>\n";
        # link around the headshot image
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        # head shot image
        print "<img src=\"".conf_get_attr("server","siteurl");
        print "icons/".$results[3]."\"[".$results[0]."]\"></a>\n";
        # end this cell and start the next
        print "</td><th>\n";
        # link around name
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsmpthumbs/".$results[1]."\">";
        # the name
        print $results[0]."</a>\n";
        # end the HTML table row
        print "</th></tr>\n";
}
print "</table>\n";
# finish off

When run, this modified version of the script should produce the following:

As you can see, this has improved the layout somewhat over the previous version using just unordered list elements. Now to add those extra fields....

Adding The Model Details

To display some more details about the model, we're going to span the headshot on the left hand side over several rows, and add the model details themselves as additional table rows on the right hand side. Our first change therefore is to add rowspan=4 to the options on the image container <td> tag. The resulting php code is:

        // start the HTML table row
        print "<tr><td rowspan=4 valign=top align=center>\n";
        // link around the headshot image

and in perl reads:

        # start the HTML table row
        print "<tr><td rowspan=4 valign=top align=center>\n";
        # link around the headshot image

Next we add the second row which will include her hair colour and length, then a third row which will describe her breast size and the fourth row that gives the number of image sets and the number of videos we have for her.

Example 3.4. Adding Model Information

        // end the HTML table row
        print "</th></tr>\n";
        // do the second row (her hair)
        print "<tr><td>hair: ";
        print $results[5]." ".$results[4];
        print "</td></tr>\n";
        // do the third row (her breasts)
        print "<tr><td>breasts: ";
        print $results[6]."\n";
        print "</td></tr>\n";
        // do the fourth row (her sets)
        print "<tr><td>sets: ";
        print $results[7];
        if( $results[8] > 0 )
        {
                print " videos: ".$results[8];
        }
        print "</td></tr>\n";

and the same implemented in perl would look like:

        # end the HTML table row
        print "</th></tr>\n";
        # do the second row (her hair)
        print "<tr><td>hair: ";
        print $results[5]." ".$results[4];
        print "</td></tr>\n";
        # do the third row (her breasts)
        print "<tr><td>breasts: ";
        print $results[6]."\n";
        print "</td></tr>\n";
        # do the fourth row (her sets)
        print "<tr><td>sets: ";
        print $results[7];
        if( $results[8] > 0 )
        {
                print " videos: ".$results[8];
        }
        print "</td></tr>\n";
}

With these changes made, if you now run this version of the program, which is called mysimple4 in the samples/programming directory, you should see something like this:

There's obviously a lot more room for using many more of the fields within the model schema for further improvement of our model index, and we'll return to this subject in a later chapter (Chapter 5, The User Interface Toolkit). Before we leave the topic of models and move on to sets, we will cover just one more topic, that of adding rating icons.

Adding Other Icons

One of the significant features of WACS is its ability to include various attribute icons within pages to make specific aspects and attributes easier to recognise. While many of them need some additional logic to handle their display, a few of them like the model's rating and country of origin are actually fairly simple to use. We're going to take a quick look at how we'd use the WACS API to include the rating icons before moving on to look at how we handle sets. We will return to the more complex cases later when we look at the User Interface toolkit API.

For the model's rating, we need the field called mrating so the first step is to add this to the list of fields that we select from the database:

// do db select
//                0      1        2          3       4
$query = "select mname, modelno, mbigimage, mimage, mhair, ".
//                5        6         7       8         9
         "       mlength, mtitsize, mnsets, mnvideos, mrating ".
         "from ".$wacs->conf_get_attr("tables","models").
         " where mflag = 'S' order by mname";
$cursor = $dbhandle->query( $query );

and in perl the change makes this section read:

# do db select
#                 0      1        2          3       4
$query = "select mname, modelno, mbigimage, mimage, mhair, ".
#                 5        6         7       8         9
         "       mlength, mtitsize, mnsets, mnvideos, mrating ".
         "from ".conf_get_attr("tables","models").
         " where mflag = 'S' order by mname";
$cursor = $dbhandle->prepare( $query );
$cursor->execute;

With the rating field now in the data returned to us by the database, we can move down and update the display section to make use of it. The first step needed is to change the rowspan setting from 4 to 5 to accomodate the extra line of output.

        // start the HTML table row
        print "<tr><td rowspan=5 valign=top align=center>\n";
        // link around the headshot image

and in perl...

        # start the HTML table row
        print "<tr><td rowspan=5 valign=top align=center>\n";
        # link around the headshot image

The final step is to add the processing of the mrating field. All WACS icons are typically stored in the glyphs/ directory which is within the web server document tree. To find its exact URL, you use the conf_get_attr function to retrieve the value iconurl in the section server. Within this directory, you will find five files called rating-1.png through rating-5.png which look like this:

To make use of this we need to first test our data to see if we have a valid ratings value at all, then merely concatinate a string to create the necessary icon reference. In php, this will look like this:

Example 3.5. Adding A Rating Icon

        print "</td></tr>\n";
        // add the rating icon (if we have a value)
        print "<tr><td align=center valign=top>";
        if( $results[9] > 0 )
        {
                print "<img src=\"";
                print $wacs->conf_get_attr("server","iconurl");
                print "rating-".$results[9].".png\">";
                print " alt=\"[".$results[9]." out of 5]\">";
        }
        else
        {
                print "no rating";
        }
        print "</td></tr>\n";

while the same example in perl, would look like this:

        print "</td></tr>\n";
        # add the rating icon (if we have a value)
        print "<tr><td align=center valign=top>";
        if( $results[9] > 0 )
        {
                print "<img src=\"".conf_get_attr("server","iconurl");
                print "rating-".$results[9].".png\"";
                print " alt=\"[".$results[9]." out of 5]\">";
        }
        else
        {
                print "no rating";
        }
        print "</td></tr>\n";
}

Once you've put in these three changes, you can run the resulting script and expect to get an output something like this:

At this point we're hopefully beginning to get a rather more satisfying display of model details. Obviously there are many other tweaks we might like to add, and we'll return to some of those later on when we look at the User Interface Toolkit and the routines that provides. There is however one more thing we really should cover now - what happens when something goes wrong.

Improving Error Reporting

One of the most important things in good website engineering is ensuring that when things fail, it's handled gracefully with some kind of reasonable error message returned to the user, and that the event is logged properly in the system error logs. There are basically four ways in which a WACS application is likely to fail - authentication, failure to parse the configuration files, and failure to connect to the database, and failure to find the content.

The authentication failure is pretty conclusively covered by the core WACS check_auth function and it's partners. The parser is rather more tricky to cope with, and the XML parse routines tend to just abort - it's also very all or nothing; the file parses or it doesn't. Additionally once a configuration file is in place, it's unlikely to become corrupted; if it's merely disappeared the defaults will be used and the system will most likely have problems at the next stage of connecting to the database. The third is connecting to the database, which we'll deal with in a moment. The fourth, failure to find content, doesn't result in completely blank screens and should get reported to you quite quickly. Additionally there are so many places it could be (raid parition, lvm volume, remote fileserver) that we can't really do much in a general way.

Where we can get some traction is with decent reporting of database connection problems, and this where the dberror function comes into play. Previously, if we failed to connect to the database we did the following in php:

if( DB::iserror($dbhandle))
{
        die("Can't connect to database\nReason:".
              $dbhandle->getMessage()."\n");
}

and the similar steps in perl were:

$dbhandle=DBI->connect( conf_get_attr("database","dbiconnect"),
                        conf_get_attr("database","dbuser"),
                        conf_get_attr("database","dbpass") ) ||
die("Can't connect to database\nReason given was $DBI::errstr\n");

To improve this, we're going to change this (called mysimple6 in the example code) to use the dberror function instead. This is a routine that uses named parameters, a technique we'll see a lot more of later as we use the WacsUI programming library. Basically we pass it up to five arguments or parameters, but we tell it what each one is, thus the order doesn't matter and if any of them are missing, it doesn't affect the values of the others. The dberror routine expects parameters called: header, message, error, dbuser and dbhost.

The header is to tell the routine how early in the proceedings we are and whether we still need to start the HTML of the web page. Setting header to y says we do want a header added, setting it to n says we don't. The next one, message is the message that the end user will see. The next three are the error message returned by the database routines, the username it was trying to use, and the database connect string it was trying to use. Here is the code for doing this in PHP5:

Example 3.6. Calling dberror for better error reporting

if( DB::iserror($dbhandle))
{
        $wacs->dberror( array( 
		 "header"=>"y",
		 "message"=>"MySimple6: Can't connect to database",
		 "error"=>$dbhandle->getMessage(),
		 "dbuser"=>$wacs->conf_get_attr("database","dbuser"),
		 "dbhost"=>$wacs->conf_get_attr("database","phpdbconnect")
		));
}

while the same basic code in perl looks a little simpler because the parameter names don't need to be packaged up into an array before they're passed:

$dbhandle=DBI->connect( conf_get_attr("database","dbiconnect"),
                        conf_get_attr("database","dbuser"),
                        conf_get_attr("database","dbpass") ) ||
	dberror( header=>'n',
		 message=>"Can't connect to database",
		 error=>$DBI::errstr,
		 dbuser=>conf_get_attr("database","dbuser"),
		 dbhost=>conf_get_attr("database","dbiconnect") );

With the error reporting improved, we'll move on to other things. We'll continue to use the short form version of the error message for brevity in the later examples, but you'll know that you probably want to actually use dberror in most cases. Next up, we'll take a look at displaying set details rather than those of models....

Chapter 4. Set Display Routines

About Set Display

So far we've looked at displaying the information in the models table in the database, but of course there is also the small matter of sets without which whole thing wouldn't have much point. In this chapter we're going to look at displaying details of the sets, and then towards the end of the chapter, how to tie models and sets together.

In most of these examples, we're going to use the standard WACS tools to actually display the details of the sets themselves, but you can of course write your own web apps to do this should you wish to. In most cases we'll throttle the examples to only show a first few sets from the databases and assume you'll develop your own strategies for paginating and sub-dividing the sets in real world applications.

Sets: The Basic Bones

Since we're starting a new application, we'll start from scratch with the basic bones which we'll call setdisp. Much of the basic structure of this program should be getting quite familiar by now. The same five basic steps are to be found here - bring in the modules, initialise them, set up the database connection, submit the query and loop through the results outputting them.

What we're setting out to do in this script is to display a list of the latest additions of image sets marked as being of category flag type T which means they're solo sets involving toy usage. This we achieve by requesting only sets of type I which means image sets and of category flag type T.

[Tip]Tip

The full lists of recommended values for the type and category flag can be found in the schema reference section at the back of this book in Chapter 11, Schema Reference: Sets.

The basic format is that we once again create an HTML table with a row for each record. There's a link on the name of the set that leads to the standard WACS page display program wacsindex. This takes a number of URL arguments but the one we're using here is to prefix the set number with page which puts it into paged display mode and appended with a .html so that it saves correctly and in some cases will get cached. We're shrinking the font in which it's displayed as it can be quite a long line of text in it's stored form (but more on that topic later).

[Note]Note

The SQL query itself looks after the ordering of the output; the order by sadded desc retrieves the entries in the reverse order in which they were added - the database field sadded being the date the set was added to the database, and the desc (meaning descending) puts the biggest value first. In this case that is the most recent date...

Example 4.1. The Basic SetDisp Program

<?php
// setdisp - set display program
require_once "wacs.php";
require_once "DB.php";
$wacs = new Wacs;
$wacs->read_conf();
$wacs->check_auth( $_SERVER['REMOTE_ADDR'],1 );
// start the document
print "<html>\n";
print "<head>\n";
print "<title>SetDisp - List of Sets</title>\n";
print "</head>\n";
print "<body>\n";
// connect to the database
$dbienv = $wacs->conf_get_attr("database","dbienvvar");
if( ! empty( $dbienv ) )
{
        putenv($dbienv."=".$wacs->conf_get_attr("database","dbienvvalue"));
}
$dbhandle = DB::connect( $wacs->conf_get_attr("database","phpdbconnect"));
if( DB::iserror($dbhandle) )
{
        die("Can't connect to database\nReason:".$dbhandle->getMessage()."\n");
}
$dbhandle->setFetchMode(DB_FETCHMODE_ORDERED);
//                0      1       2      3         4        5
$query = "select setno, stitle, stype, scatflag, simages, scodec ".
         "from ".$wacs->conf_get_attr("tables","sets")." ".
         "where stype = 'I' and scatflag = 'T' ".
         "order by sadded desc ";
$cursor = $dbhandle->query( $query );
print "<table>\n";
$setcount=0;
while( (($results = $cursor->fetchRow()) &&
        ($setcount < 25 )) )
{
        // start the row
        print "<tr><td align=center>\n";
        // create the link
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsindex/page".$results[0].".html\">";
        // print out the set name
        print "<font size=-2 face=\"arial,helv,helvetica,sans\">";
        print $results[1]."</font></a>\n";
        // end the row
        print "</td></tr>\n";
        $setcount++;
}
print "</table>\n";
print "</body>\n";
print "</html>\n";
?>

and implementing the same code in perl gives us:

#!/usr/bin/perl 
# setdisp - set display program
use Wacs; 
use DBI;
read_conf();
check_auth( $ENV{'REMOTE_ADDR'},1 );
# output the HTML headers
print "Content-Type: text/html\n";
print "\n";
print "<html>\n";
print "<head>\n";
print "<title>SetDisp - List of Sets</title>\n";
print "</head>\n";
print "<body>\n";
# connect to the database
$dbienv = conf_get_attr("database","dbienvvar");
if( $dbienv ne "" )
{
        $ENV{$dbienv}= conf_get_attr( "database","dbienvvalue" );
}
$dbhandle=DBI->connect( conf_get_attr("database","dbiconnect"),
                        conf_get_attr("database","dbuser"),
                        conf_get_attr("database","dbpass") ) ||
die("Can't connect to database\nReason given was $DBI::errstr\n");
#                 0      1       2      3         4        5
$query = "select setno, stitle, stype, scatflag, simages, scodec ".
         "from ".conf_get_attr("tables","sets")." ".
         "where stype = 'I' and scatflag = 'T' ".
         "order by sadded desc ";
$cursor = $dbhandle->prepare( $query );
$cursor->execute;
print "<table>\n";
$setcount=0;
while( (($results = $cursor->fetchrow_array ) &&
        ($setcount < 25 )) )
{
        # start the row
        print "<tr><td align=center>\n";
        # create the link
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsindex/page".$results[0].".html\">";
        # print out the set name
        print "<font size=-2 face=\"arial,helv,helvetica,sans\">";
        print $results[1]."</font></a>\n";
        # end the row
        print "</td></tr>\n";
        $setcount++;
}
print "</table>\n";
print "</body>\n";
print "</html>\n";

When we run this set against our demonstration web server, we get the following output which is a list of the sets containing dildo use in most-recent first order.

Adding Icons

While it works and is usable, it's not exactly the greatest web page ever, so let's try and brighten it up a little. It'd be quite nice to be able to include an icon, and of course wacs has the infrastructure to do this for us. In fact, it offers us three different options of what size of icons we'd like: set, std and mini. In this case since we're trying to get a fair number of entries shown, we'll opt for the mini version. We get this by calling the wacsimg command and specifying that we'd like the mini version.

To make this happen we need to add another cell to the table with the HTML img tag pointing at wacsimg. As before we'll specify both align and valign properties for this table cell. So if we modify the code, much as we did before for the model icons, we get the following in php:

Example 4.2. Adding A Set Icon

        // start the row
        print "<tr><td valign=top align=center>\n";
        // create the link for the icon
        print "<a href=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsindex/page".$results[0].".html\">";
        // add the icon itself
        print "<img src=\"".$wacs->conf_get_attr("server","cgiurl");
        print "wacsimg/mini".$results[0].".jpg\" alt=\"[icon for ";
        print $results[0]."]\">";
        // end cell, next cell
        print "</td><td align=center>\n";
        // create the link

and of course the same example in perl looks like:

        # start the row
        print "<tr><td valign=top align=center>\n";
        # create the link for the icon
        print "<a href=\"".conf_get_attr("server","cgiurl");
        print "wacsindex/page".$results[0].".html\">";
        # add the icon itself
        print "<img src=\"".conf_get_attr("server","cgiurl");
        print "wacsimg/mini".$results[0].".jpg\" alt=\"[icon for ";
        print $results[0]."]\">";
        # end cell, next cell
        print "</td><td align=center>\n";
        # create the link

and if we run the resulting program, we get something like this:

Making The Text More Readable

One of the design decisions taken when designing WACS was to encourage directory names to be the same as the set names, and to make those more usable outside of the WACS system, to make them not include spaces. Instead the so-called Camel Technique, so named because of all the humps in it, where an upper case letter signifies the start of each new word. This is used along with a technique where underscores (_) act as the transitions between the three sections of the set name: these are:

  1. Model or Models name(s)

  2. Her Clothing

  3. Location and Action

However the underscore aspect is only used in the directory name and not in the set title (field stitle) as stored in the database which has spaces instead. Amongst our tasks, we will need to replace the spaces with the appropriate HTML table tags.

Fortunately we can use a regular expression to convert the Camel-Style text back into something a little bit more readable. This next group of changes to the code are to do exactly that. We're going to take a slightly different approach from before as we're not going to make the split off parts into seperate HTML table cells. This is because that makes both the font setting and HTML link creation much more complex - we're merely going to insert a forced line break <br> tag into the places where we want a new line to start. Then we're going to break up the Camel-Style text into seperate words. We do this with:

Our first substitution is going to be to replace the spaces (the section dividers in the stitle field) with the appropriate HTML directives. The second and third ones actually break up the words at the points the case changes:

Example 4.3. Making Camel-Style Text Readable

        // print out the set name
        print "<font size=-2 face=\"arial,helv,helvetica,sans\">";
        $prettytext = $results[1];
        $prettytext = preg_replace('/\s/','<br>', $prettytext );
        $prettytext = preg_replace('/(\w)([A-Z][a-z])/','$1 $2', $prettytext );
        $prettytext = preg_replace('/([a-z])([A-Z])','$1 $2', $prettytext );
        print $prettytext."</font></a>\n";
        // end the row

To implement the same functionality in perl actually uses exactly the same regular expressions (aka regexp) but looks very different as it's all done in assignment operations without any explicit function call. There's no preg_replace used here. Anyway here is exactly the same functionality in perl:

        # print out the set name
        print "<font size=-2 face=\"arial,helv,helvetica,sans\">";
        $prettytext = $results[1];
        $prettytext =~ s/\s/<br>/g;
        $prettytext =~ s,(\w)([A-Z][a-z]),$1 $2,g;
        $prettytext =~ s,([a-z])([A-Z]),$1 $2,g;
        print $prettytext."</font></a>\n";
        # end the row

With these changes in place, we can once again copy over the code and we have a much more presentable output from the program; here's an example:

Hopefully with this we've got the output presentation of the sets list looking a whole lot better than it was in the first example. There are of course many more fields within the set database that we could also make use of in our pages. We will return to them when we look at the WACS User Interface Toolkit in Chapter 5, The User Interface Toolkit. For now, before we finish our look at sets, we're just going to look at how we find the model or models featured in a given set.

Connecting Sets And Models

Understanding The Data Architecture

One of the things that often confuses people about true relational databases is that they are unable to do a one-to-many or many-to-many relationship directly. While many so called easy-to-use databases do offer field types that purport to offer such linking, they are problematic and do not fit into any sensible logical model for how things should be structured. Worse, each vendor's implementation (those who do implement it at all) is different and incompatible. However with a sensible schema design, this limitation really isn't a problem at all.

One such instance of this need to link one-to-many is the concept of linking a set with a model within WACS. In the easy case, you'd have thought that you'd simply put the model number into one of the fields in the set schema and the job would be done. But what do you then do when you have two models featuring in a set; easy you might say - one is the main model, the other is a secondary model, so just add a second field for the additional model and put the second number there. Of course that then makes the SQL query more complex each time as you've got to check both fields before you know if a model is in a set or not. It still might work, but it's already getting cumbersome. You might discover a set first by virtue of the additional model and only afterwards identify the official primary model.

Just about every adult site we've encountered does feature at least a few sets with three models, so suddenly we're looking at a second additional model field and having to check that as well. And believe me, there are a few sites of which Sapphic Erotica comes to mind in particular where sets with three, four, five or even six models in a single set are relatively common. Simply put, adding models to the sets table just doesn't scale. So we take the proper relational database approach and add an additional schema called assoc for associations which gives us these relationships. It's a very simple schema, basically containing a primary key, a model number and a set number.

Using Relationships With Assoc

The process of finding out who is in a set becomes very simple and straight forward - you simply search the assoc table for the set number you're looking at. If we're looking for who is in set no 123, we simply use the following SQL query:

select amodelno from assoc
where asetno = 123

We then merely loop through the results of the above query and each record we find is another model involved in this set. If we don't get any results returned, then there aren't any models associated with this particular set. Of course we probably want more than just the model number(s), but that too is relatively simple. Consider the following query:

select modelno, mname, mimage, mbigimage
from models, assoc
where modelno = amodelno
  and asetno = 123

This query simply retrieves the model details for each model who is involved with this particular set, one record at a time. Due to the way relational databases are engineered, this is actually a very quick and efficent process. The first line of the where clause does what is known as a relational join and establishes the necessary connection between the assoc and models tables necessary for what we're trying to do. Additionally it's a very logical and elegant solution that will cope with none, one, two, three, four or as many models as you like within a single simple action.

[Note]Note

Although we make use of the assoc table, we don't actually use any results from it - we don't need to - it has silently taken care of handling the connection we needed to make.

An Example Using Assoc

If we go back to our example program displaying sets, we can modify it to include this activity as a sub-routine. What we're going to do is to divide the right hand side of the output into the two cells, one with the title, and the other with the model(s) featuring in the set. The icon will remain on the left. First step is to add the rowspan attribute to the left hand side cell so the icon spans it.

Example 4.4. Modified Icon Cell

        // start the row
        print "<tr><td rowspan=2 valign=top align=center>\n";
        // create the link for the icon

and in perl, it'll look very similar:

        # start the row
        print "<tr><td rowspan=2 valign=top align=center>\n";
        # create the link for the icon

The next step is to create a new function to handle the query to look up the entries in the assoc table. We're going to call this function simply getmodel and it'll take just one argument, the set number for which we want the model(s) details. It will return to us a potentially quite long string variable containing all the model names that matched surrounded by a link to each model's WACS model page.

[Note]Note

So long as we use a different cursor variable to the database routines we can quite happily run another query and loop through it's results while inside an outer loop looking at the results of a completely different query. This is where the whole concept of a cursor becomes really useful.

Example 4.5. getmodel Subroutine

function getmodel ( $setno ) {
        global $dbhandle;
        global $wacs;
        $gmresult='';
        //                   0        1      2       3
        $modelquery="select modelno, mname, mimage, mbigimage ".
                    "from ".$wacs->conf_get_attr("tables","models").
                    ", ".$wacs->conf_get_attr("tables","assoc")." ".
                    "where modelno = amodelno ".
                    "  and asetno = ".$setno." ".
                    "order by mname ";
        $modelcursor=$dbhandle->query( $modelquery );
        // loop through the results
        while( $modelresults = $modelcursor->fetchRow() )
        {
                // do we need a divider?
                if( ! empty( $gmresult ))
                {
                        $gmresult.="<br>";
                }
                // add the model link
                $gmresult.="<a href=\"".$wacs->conf_get_attr(
                                "server","cgiurl")."wacsmpthumbs/".
                                $modelresults[0]."\">";
                // add her name and close link
                $gmresult.=$modelresults[1]."</a>";
        }
        // return the complete string
        return( $gmresult );
}

and the same code implemented in perl looks like this:

sub getmodel( $ )
{
        my( $setno )=@_;
        my( $gmresult, $modelquery, $modelcursor, @modelresults );
        $gmresult='';
        #
        $modelquery="select modelno, mname, mimage, mbigimage ".
                    "from ".conf_get_attr("tables","models").
                    ", ".conf_get_attr("tables","assoc")." ".
                    "where modelno = amodelno ".
                    "  and asetno = ".$setno." ".
                    "order by mname ";
        $modelcursor=$dbhandle->prepare( $modelquery );
        $modelcursor->execute;
        # loop through the results
        while( @modelresults = $modelcursor->fetchrow_array )
        {
                # do we need a divider
                if( $gmresult ne "" )
                {
                        $gmresult.="<br>";
                }
                # add the model link
                $gmresult.="<a href=\"".conf_get_attr("server","cgiurl").
                        "wacsmpthumbs/".$modelresults[0]."\">";
                # add her name and close link
                $gmresult.=$modelresults[1]."</a>";
        }
        # return the complete string
        return( $gmresult );
}

The final step of this process is to add into our main loop going through the retrieved set records a call to the getmodel function. This looks like:

Example 4.6. Calling The getmodel Function

        // next right hand cell
        print "<tr><td align=center><font size=-1>\n";
        print getmodel( $results[0] );
        print "</font></td></tr>\n";
        // increment set count 

and in perl this looks like

        # next right hand cell
        print "<tr><td align=center><font size=-1>\n";
        print getmodel( $results[0] );
        print "</font></td></tr>\n";
        # increment set count 

With these changes incorporated into the code, we now have the finished version of the setdisp program (setdisp4.php or setdisp4 in the samples directory. If we now copy this script up to the web server and run it, we should see something like this:

Once again we've gradually developed a program up to the point where it is now offering quite reasonable functionality and layout making use of the WACS programmers toolkit API. Hopefully this has given you an insight into what WACS is capable of and the basics of how to make use of it's API. In due course, we hope to have a respository of WACS skins, or mini-site scripts, which you can download and tailor to your own needs. If in the course of learning the WACS API you write some programs you'd be happy to share with others, please send them to us and we'll include them in the respository.

Chapter 5. The User Interface Toolkit

Introducing WacsUI

In this chapter, we're going to take a slightly different tack, we're going to just look at code segments you could choose to include within your application, primarily user interface components taken from the User Interface toolkit, WacsUI. This is not going to be an exhaustive review of what is available as that is covered in detail in the reference section, Chapter 8, WACS API: User Interface Module. Instead this is just a quick taster of just a few of the calls provided by the WacsUI toolkit.

So far we've been dealing with the various routines that are provided by the Core Wacs module - and these relate primarily to configuration parameters and security. There is a second module available for you to use called WacsUI, the WACS User Interface Toolkit. This concerns itself primarily with providing utility functions to ease the tasks of formatting and preparing data from the database into a form more suitable for use in web pages.

Including WacsUI support

To include support for the WACS User Interface (WacsUI) toolkit within your application, you need to add the following extra lines to your code, ideally just after the Wacs core module.

Example 5.1. WacsUI initialisation

require_once "wacsui.php";

$wacsui = new WacsUI;

and here's the perl dialect of the same activity...

use WacsUI;

WacsUI: DescribeHer

The first function from WacsUI that we're going to look at is called describeher and it is designed to take the output of the very regemented values of the model attributes fields of the database and turn them into something much more readable. Although not implemented yet this provides a good mechanism for doing other translations or providing an attribute table rather than a textual description.

Example 5.2. Using WacsUI: describeher

print $wacsui->describeher( 
       array( 'hair'=>$results[4],
         'length'=>results[5],
         'titsize'=>results[6],
         'pussy'=>results[7],
         'race'=>results[8],
         'build'=>results[9],
         'height'=>results[10],
         'weight'=>results[11],
         'occupation'=>results[12]))."\n";

[Note]Note

We have to package up our parameter list as an array in order to pass it in Php; perl is somewhat simpler with a simple sequence of named parameters.

print describeher(
        hair=>$results[4],
        length=>$results[5],
        titsize=>$results[6],
        pussy=>$results[7],
        race=>$results[8],
        build=>$results[9],
        height=>$results[10],
        weight=>$results[11],
        occupation=>$results[12] )."\n";

The above example is based upon modifying the MySimple example program from in the second chapter (Chapter 2, Basics: Getting Started) to add the following extra fields into the query: mhair, mlength, mtitsize, mpussy, mrace, mbuild, mheight, mweight, moccupation after the mimage (with a comma of course) and before the from clause.

The whatshedoes function

As with the previous describeher, whatshedoes is designed to make a readable sentence from a number of fixed format database fields. In this case however, it's a little different as the values passed in are typically either Y for yes, or N for no, and they are translated to a text phrase based upon what they're value is. This also means that if you're using array subscripts to fetch the database field values you need to be careful about positioning. Give a yes to the wrong field and the error will not be as obvious - while “blonde breasts” would be easy to spot, the fact that each model who did masturbation scenes was listed as doing straight scenes would be less apparent.

For the purposes of this example, we're adding yet more fields to the select statement in the original MySimple program shown in the second chapter (Chapter 2, Basics: Getting Started). In this case msolo, mstraight, mlesbian, mfetish, mtoys, mmast and mother.

Example 5.3. Using WacsUI: whatshedoes

print $wacsui->whatshedoes(
	array( 'solo'=>$results[13],
	       'straight'=>$results[14],
	       'lesbian'=>$results[15],
	       'fetish'=>$results[16],
	       'toys'=>$results[17],
	       'masturbation'=>$results[18],
	       'other'=>$results[19] ) )."\n";

The same function works just the same in perl without the need for the array declaration wrapper:

print whatshedoes(
	solo=>$results[13],
	straight=>$results[14],
	lesbian=>$results[15],
	fetish=>$results[16],
	toys=>$results[17],
	masturbation=>$results[18],
	other=>$results[19])."\n";

The addkeyicons function

Both the models and sets schemas feature fields that contain a space seperated list of keywords that mark certain attributes found within that set. These can be quickly turned into a small HTML table of icons using the routine addkeyicons. The fields suitable for use with this are scatinfo from the sets table and mattributes from the models table. These are passed as the first attribute; the second being the displayed size of the icons which for the default icons would be a maximum of 48 x 48 pixels. The function is called simply with:

Example 5.4. Using AddKeyIcons

	addkeyicons( $results[16], 24 );

iconlink: WacsUI's Most Important Function

We're now going to take a look at WacsUI module's most important function, iconlink. It's job is simply to display and icon with an appropriate link around it. Sounds simple enough, doesn't it? Unfortunately it isn't - there's a lot of work that needs to be done relating to permissions, access methods, checking caches and resizing which actually makes it fairly complex. The good news is that the iconlink function will do it all for you!

The iconlink function takes quite a few arguments which control how it works, but they are reasonably straightforward. In most cases parameters are optional and sensible defaults will be used instead if they are not given - obviously things like set number and the location fields (sarea, scategory and sdirectory) are necessary.

Example 5.5. Using the iconlink function

print $wacsui->iconlink(
	array( 'type'=>$setdetails[1],
	       'setno'=>$setdetails[0],
	       'sarea'=>$setdetails[2],
	       'scategory'=>$setdetails[3],
	       'sdirectory'=>$setdetails[4],
	       'model'=>$moddetails[1],
	       'resize'=> 0 ))."\n";

The perl dialect is again very much the same:

print iconlink( type=>$setdetails[1],
                setno=>$setdetails[0],
                sarea=>$setdetails[2],
                scategory=>$setdetails[3],
                sdirectory=>$setdetails[4],
                model=>moddetails[1].
                resize=> 0 ))."\n";

WacsUI: Other Functions

Another example of using the wacsui module can be found in the newsets.php application in the samples directory. This is a more "real world" worked example showing a new releases index page; it makes use of both the iconlink and addkeyicons functions.

Detailed documentation on each call available and how it works can be found in the API reference section Chapter 8, WACS API: User Interface Module. Another good source of examples of how to utilise these functions is to be found in the the section called “Wacs-PHP: The Simple Skin” provided as part of the Wacs-PHP API library. And of course don't forget that you can always look at how the main WACS user environment applications themselves make use of these functions.

Conclusions

We've now come to the end of the basic WACS API tutorial, at least for this edition of the WACS Programmers Guide. It is our intention to expand this section in future editions. Still, it has hopefully introduced you to the key concepts in making use of the WACS Programming API and given you some useful simple programs to build on when creating your own applications. The rest of this book consists of the WACS API reference manual and the WACS Database Schema Reference. If these do not provide sufficient information, please contact us via the methods listed on the WACS web site at SourceForge .

Chapter 6. Wacs-PHP: The Skins

Introduction To PHP Skins

In previous chapters we've mentioned that the WACS Application Programming Interface (API) is available in both Perl and PHP5. We've also mentioned that many commercial web sites will choose to design their own web pages and will make use of the extensive WACS database infrastructure and utilities via the API from such pages. Other people may simply be interested in using it to tailor the presentation of their WACS site to their personal preferences.

With the Skins project, we go a step further by providing an alternative WACS-based web site written using the Wacs API for PHP5. This can serve one of two purposes - to provide a more complex set of example programs for web designers to study in order to familiarise themselves with how the APIs are used, or it can simply be restyled and personalised to provide a turn-key porn web site quickly and easily. In due course we hope people will contribute some sample pages of their own and there may be a choice of components to make the process easier. Initially we are providing just one skin known as simple. To aid both understanding and the ease of restyling, the Simple Skin is implemented using an external cascading style sheet separate from the HTML output generated by the php programs.

[Note]Note

The Wacs-PHP Simple Skin is still very much an under development project and only just became fully functional at 0.8.5. You can always dive in and help us make it even better!

Wacs-PHP: The Simple Skin

The provided simple skin consists of a number of small PHP5 programs and a single large style sheet shared by all the applications. The php programs are:

Table 6.1. Simple Skin: Components

NameDescription
index.phpThe main menu of the simple skins site - equivalent to wacsfp in WACS itself
latest.phpThe simple skins combined new models, new sets and new videos page - no direct WACS equivalent
girlie.phpThe model page of the simple skins site - very loosely equivalent to wacsmpthumbs in WACS itself
directory.phpThe Alphabetic directory of models - similiar to just one of the modes of wacsmodelthumbs in WACS itself
galleries.phpThe index of galleries - a rather different approach from wacsshow in WACS itself. Focuses on indexing all the entries in a given top level area (sarea); to index the toplevels themselves, use movies.php below.
gallery.phpAn individual gallery display - similiar to that produced by wacsimglist in WACS itself.
movies.phpA top level view of the galleries. Works for either images or videos despite the name.
photos.phpA photo set front page - similiar to wacsindex in info mode.
videos.phpThe video clip version of the above.
search.phpThe search system for the simple skin. This takes a very different approach from the search system in WACS core as it amalgamates both model and clip attributes into a single search engine.

Styling Wacs-PHP Skins

One of the design objectives of the Wacs-PHP skins project was to make it easy to restyle the pages to look very different without touching the code itself purely through use of Cascading Style Sheets. To this end each page has a large number of named <div> and <span> directives placed throughout the generated pages to provide a framework for this to happen.

The first of these is that every page has a standard core structure to it which consists of three div elements with the following ids: pagebanner for the top heading, navigation for the menu links and maincanvas for the content itself. They will also always be featured in this order. You can of course choose to make them invisible or use javascript to toggle their visibility to make pull down menus and the like.

In addition to the core layout detailed above, there are also a number of div classes (because they often repeat) that are set on each type of icon that may be displayed. For set-based content, these are normmovietile and normimagetile for regular standard sized icons and for the smaller ones (but which are used heavily in the simple skin) imagesettile and moviesettile. For generic styling of the small icons there is also a span class of miniicon around the icon itself.

Moving on to Models, here too there are standard div wrappers around all instances of model icons allowing them to be styled. For the normal model headshot icon, there is a div of class modeltile around the icon block itself, with spans of classes iconmodel and iconmodelname around the icon itself and the text of her name respectively. Around the large model headshot you will find a div with the id of headshot in the girlie.php program which is the only place that Wacs-PHP uses the large format headshot.

WACS and Web 2.0

There's a lot of buzz in the IT industry at the moment about dynamic content on the web - also known as Web 2.0. This is where the web page changes what it displays immediately with each selection that you make. So far we've not seen much application of the technology on adult web sites, but as we rather pride ourselves on having the capabilities of the very best, we decided to go ahead and prove we can do it with WACS. The modelsel.php application introduced in WACS 0.8.4 is the first example of this. This application simply displays various icons related to hair colour, length, breast size and pubic hair style. As you click on these, the page updates with a selection of headshots that match the specified criteria.

The modelsel.php application itself is fairly simplistic and it's use of the underlying AJAX architecture is not the most effecient but we still think it's an interesting and ground breaking application. We've also used it as a showcase of how realitively easy it is to integrate php-based applications into the main perl based Wacs infra-structure as it shares the look and feel of the perl based apps.

We do intend to expand on this theme in coming releases with similar dynamic search mechanisms for image sets and videos.

Part II. WACS API Programming Reference

This is the API (Application Programming Interface) reference manual for the WACS environment. It documents the main API calls in both Perl and PHP dialects. There are now six operational modules available as part of the WACS system, plus a utility module used by the installers.

Table 2. The Key WACS Modules

WACS Module List
namepart ofdescription
Wacs.pmCorethe main Wacs module
WacsUI.pmCorethe Wacs User Interface module
WacsStd.pmCorethe Wacs Standardised Components module
WacsID.pmCorethe Wacs Identification module
wacs.phpwacs-phpthe main Wacs module, Php dialect
wacsui.phpwacs-phpthe Wacs user interface module, Php dialect

Chapter 7. WACS API: Core Module

Core Module: Summary

Table 7.1. Function Summary: Core Module

functiondescription
read_conflocate and read the XML based configuration file
check_authcheck that this is an authorised access
auth_errorreport an authentication error and suggest remedies
auth_userreturn the registered username for this IP
add_authadd a new authentication token to access control system
find_config_locationtry to locate the specified XML config file
conf_get_attrget the requested configuration attribute
auth_get_attrget the requested access control list attribute
dberrorproduce a more helpful error page when db connections fail
gettodayget today's date as a string suitable for the current DB
timecompsbreak a date down into component parts
vendlinkprovide a link to the vendors site
getvaluenametakes a single character flag and converts to string
geticonlistgets the icon array for the specified object type
gettypecolourget the prevailing colour scheme for the set type
divideupmake a directory name more readable
checkexcludecheck for this file name being one to ignore/hide
checkindexcheck for what might be an index file
makedbsafetry to make the returned string safe for use in the database
addheadercssadd standard preamble to enable javascript menus
setgrouppermsset the appropriate group permissions for co-operative updating
treemkdircreate a tree of directories (mkdir -p equiv)

Core Module: Reference

Core Module: Reference

The following pages contain the *nix style reference pages for each function call in the WACS core module. These detail what the function does, what parameters it takes, what it returns and which versions of the core library it is available in.

Name

read_conf — read Wacs core config modules

Synopsis

use Wacs;
read_conf(
 

Summary

The read_conf causes the standard WACS XML configuration file, wacs.cfg to be parsed and the contents read into internal memory structures in the WACS module for later use by other WACS routines. The main interface to accessing this information is the call conf_get_attr.

read_conf is sensitive to the environment variable WACS_CONFIG which specifies a directory containing an alternative wacs.cfg configuration file.

Availability

read_conf is available in both perl and php.


Name

check_auth — check if this IP address is authorised for access

Synopsis

use Wacs;
check_auth(ip_address,  
 vocal_error); 
scalar ip_address;
scalar vocal_error;
 

Summary

check_auth checks whether the passed IP address is authorised for access to this Wacs server at this time. This authorisation may be by either permanent or lease permission based upon the calling IP address. This IP address is specified by the first parameter to the function. The second parameter controls what will be done about it: if the value is 0 (zero), the call will merely terminate the session by exiting the program; if the value is 1 (one), an authorisation error HTML page will be displayed offering the user the option to log in. In the Perl version, an additional option of 2 (two) is available which outputs a failure icon in the case of an expired lease and a request for an image file - this is not possible in PHP as the content type of text/html has already been determined.

Availability

check_auth is available in both perl and php.


Name

auth_error — create a reasonable HTML error page with reason and link to remedy

Synopsis

use Wacs;
auth_error(message); 
scalar message;
 

Summary

auth_error creates a reasonable HTML error page with reason and link to remedy if applicable (ie login page). The message parameter will be placed in a bordered box near the bottom of the message and can be used to convey additional information. check_auth sets this to Sorry, your lease has expired. when that is the case.

Availability

auth_error is available in both perl and php.


Name

auth_user — return the account name of the user associated with IP address

Synopsis

use Wacs;
scalar auth_user(ip_address); 
scalar ip_address;
 

Summary

auth_user returns the account name of the user associated with the specified IP address.

Availability

auth_user is available in both perl and php.


Name

add_auth — add a new authentication token to the access control list

Synopsis

use Wacs;
add_auth(...); 
 

Parameters

parameterdescription
ipaddrThe IP Address of the host being authorised.
useraccount name of the user being registered
typetype of registration being undertaken - currently lease
roleleval of access granted currently: viewer, power or admin
datedate at which this lease should expire
prefexclpreference exclusions: the scatflag values not to be shown by default
usedirectwhether to use the usedirect function if supported by the server - can be yes or no
imagepagewhether to create links to framed page or raw ones - should be frame or raw
scalingwhen to use image scaling - can be none, slide, slide+page and all
sizesize of scaled images when applicable in the format 1024x768
qualityjpeg quality setting used when scaling images
delaydesired delay before next image in slideshow

Summary

add_auth adds a new authentication token to the access control list, ie the leases file. This is the action taken by the wacslogin command after it has authenticated the user. It can also be used to update the user preferences - it is used by wacslogin, wacspref and wacslogout.

Availability

add_auth is currently available only in perl. A php implementation is possible in a future release if required.


Name

find_config_location — return the location of the requested config file

Synopsis

use Wacs;
scalar find_config_location(configuration_filename); 
scalar configuration_filename;
 

Summary

find_config_location returns the location of the requested config file. It first checks the directory specified by the WACS_CONFIG environment variable, and then tries the built-in list of possible WACS configuration file locations. This list is normally: /etc/wacs.d, then /usr/local/etc/wacs.d and finally /opt/wacs/etc/wacs.d . If the specified file is not found in any of these locations, a null string is returned.

[Note]Note

The location specified by the environment variable WACS_CONFIG takes precidence, if and only if the requested file is present there. The normal directories are searched afterwards if the file is not found in the directory specified.

Availability

find_config_location is available in both perl and php.


Name

conf_get_attr — get the specified attribute from the config file values

Synopsis

use Wacs;
scalar conf_get_attr(configuration_section,  
 configuration_attribute); 
scalar configuration_section;
scalar configuration_attribute;
 

Summary

conf_get_attr returns the specified attribute from the config file or it's default value if not specified there. The WACS configuration files are divided into a number of logical sections; the first parameter specifies which of these is required: amongst those defined are database, tables, fsloc, server, security, download, colours, layout, precedence and debug. Please see the WACS configuration guide and sample wacs.cfg files for more information on what information is available.

Availability

conf_get_attr is available in both perl and php.


Name

auth_get_attr — get the specified attribute from the authorisation file values

Synopsis

use Wacs;
scalar auth_get_attr(ip_address,  
 authorisation_attribute); 
scalar ip_address;
scalar authorisation_attribute;
 

Summary

auth_get_attr returns the specified attribute from the authorisation file or it's default value if not specified there. These look ups are based on the IP address of the host - typical attributes include the user name, the preference exclusions, the role, and the various preference settings - see add_auth for more info.

Availability

auth_get_attr is available in both perl and php.


Name

dberror — produce a more helpful error page when db connections fail

Synopsis

use Wacs;
dberror(...); 
 

Parameters

parameterdescription
headerWhether to add an HTML preamble or not: n for no, y for yes.
messageThe message the end-user should recieve
errorThe error message returned from the database routines; logged in the web server error log
dbuserThe database user account with which the access was being attempted, from the config file's dbuser entry.
dbhostThe host specification of the database that it was trying to access, from the config file's dbiconnect entry when using perl, and the phpdbconnect entry when using PHP

Summary

The dberror function provides a detailed and hopefully helpful error message when the WACS sub-system cannot connect to the database server. It also logs details of the failure to the web server error log.

Availability

dberror is available in both perl and php. It was introduced in Wacs 0.8.1.


Name

gettoday — get todays date and various relations thereof

Synopsis

use Wacs;
scalar gettoday(...); 
 

Parameters

parameterdescription
formatwhich format to return date in (DD-MON-YYYYY or YYYY-MM-DD) - default is native format for the current database
epochthe actual date to convert in Unix seconds since 1970 format.
offsetnumber of days different from today - assumed to be historial if postive, future if negative - thus yesterday will be 1, a week ago will be 7, tomorrow will be -1.

Summary

The gettoday function returns either todays date or various deviations thereform - yesterday, a week ago, two weeks ago, etc.

Availability

gettoday is available in both perl and php.


Name

timecomps — return seperated time components

Synopsis

use Wacs;
array timecomps(date_in_db_format,  
scalar date_in_db_format;
 

Summary

The timecomps breaks a database format date up into year, month and day components. The optional format parameter can specify a non-native date format for conversion purposes.

Availability

timecomps is available in both perl and php.


Name

vendlink — provide (if possible) a link to the vendor's site for this model

Synopsis

use Wacs;
scalar vendlink(...); 
 

Parameters

parameterdescription
vendorthe vendor's reference (ie their vsite id)
pagewhich page to get: valid options are directory, modelpage, bio, vidindex, vidpage, imgpage, altpage, or signup .
namethe model's name
keythe model's key for this site
altkeythe model's alternative key for this site
setkeythe setkey if this request needs it (depends on the value of page above
sessionkeythe session key (if required and known).
modelnothe WACS model number for this request (believe me we occasionally need this)
setnothe WACS set number for this request (see above - this too)
dbhandlecurrent handle to the database connection

Summary

The vendlink provides (if possible) a link to a page on the vendor's site for this model or set. Specify the page you require using the page parameter - can link to any one of the many pages the vendor database knows about.

Availability

vendlink is available in only in perl at present. If you need it in PHP, please put in a request for it on the sourceforge tracker.


Name

getvaluename — provide the long name for the specified value of specified type

Synopsis

use Wacs;
scalar getvaluename(...); 
 

Parameters

parameterdescription
objectThe object you want the mapping for - see geticonlist below
valueThe value you want mapped to it's long format (often a single character.

Summary

The getvaluename function returns the long (readable) name for the specified short value of specified fixed values attribute type. For instance, if you want to get the long name for type "M", you call getvaluename with object=>"types" and value=>M and getvaluename will return Masturbation.

Availability

getvaluename is available in both perl and php.


Name

geticonlist — return the array of attributes to filename/long name mappings.

Synopsis

use Wacs;
hashref geticonlist(requested_object); 
scalar requested_object;
 

Summary

The geticonlist function returns an array/ hashref of the legal values for the requested type object. In some cases this will be the filenames of the icon for the attributes; in other cases it'll be the single character legal values and their long form names. Valid requests include: models, sets, types, media, dstatus, regions, flags, pussy and picon.

Availability

geticonlist is available in both perl and php. The picon attribute was added in Wacs 0.8.2.


Name

gettypecolour — return the background colour for this type of set

Synopsis

use Wacs;
scalar gettypecolour(set_type); 
scalar set_type;
 

Summary

The gettypecolour returns the HTML colour specification for the background of the current set type. Pass it the set stype value I, V, etc.

Availability

gettypecolour is available in both perl and php.


Name

divideup — make Camel-style text more readable and add HTML markup

Synopsis

use Wacs;
scalar divideup(original_text,  
 divider,  
 already_small_font); 
scalar original_text;
scalar divider;
scalar already_small_font;
 

Summary

The divideup function returns a more readable version of the so-called Camel Style wording used in creating WACS directories. It also embeds HTML directives to try and ensure that even long entries don't take up too much space. The first argument is the original text (typically the field stitle from the sets database), the second (divider) is typically the HTML break tag <br> but could be other things like a table divider sequence </td><td> . The third parameter signifies whether the font in use is already small - if set to 0 (zero), HTML tags to reduce the font size be based on using size is -1 for long lines; if it's set to 1 (one) it'll be assumed they were already using size is -2, and will therefore use size = -3. As from Wacs 0.8.5, -1 is also available which suppresses the resizing of long lines if required.

Availability

divideup is available in both perl and php.


Name

checkexclude — test for being a directory file or other reserved purpose name

Synopsis

use Wacs;
scalar checkexclude(filename); 
scalar filename;
 

Summary

The checkexclude returns 1 if the file is one of those that should be excluded from consideration (ie . or .. or one of ours like .info or .unpack). If the file looks genuine, returns 0.

Availability

checkexclude is available only in perl as it is just used for collection management tasks.


Name

checkindex — try to guess if this is an index image file

Synopsis

use Wacs;
scalar checkindex(filename); 
scalar filename;
 

Summary

The checkindex tries to guess if a given file name is likely to be an index file or a regular image file based upon it's name. If it's a name associated with index files, it returns 1; if it isn't checkindex returns 0.

Availability

checkindex is available in only perl as it is really only appropriate to collection management tools.


Name

makedbsafe — try to make the returned string safe for use in the database

Synopsis

use Wacs;
scalar makedbsafe(...); 
 

Parameters

parameterdescription
stringthe string of text to be considered
allowcharacters to allow which are not normally acceptable: at present only forward slash (/) is recognised
denycharacters to deny which are normal acceptable: at present any space character (space, tab, newline) given here will cause any whitespace characters to be stripped out.

Summary

The makedbsafe function is designed to remove characters which are unsuitable for feeding to the database. It normally works with a default set of rules, which implicitly disallows forward slash (but this can be explicity allowed with allow=>'/'). Similarly white space can be removed from a file name when required using the deny option.

Availability

makedbsafe is available in both php and perl. This function was added in Wacs 0.8.1.


Name

addheadercss — prints out the header cascading style sheet preamble

Synopsis

use Wacs;
addheadercss(css_preamble_type); 
scalar css_preamble_type;
 

Summary

The addheadercss prints out the required css preamble to support the appropriate pull down menu system. At present only one type, "csshoriz" is recognised, but additional options can be added.

Availability

addheadercss is available in both perl and php.


Name

setgroupperms — set group permissions to allow both command line and web management of sets.

Synopsis

use Wacs;
setgroupperms(...); 
 

Parameters

parameterdescription
targetpathname of the file or directory to update
groupthe unix group to set permissions to (usually wacs, can be obtained with conf_get_attr on security -> admingroup.
modeaccess mode that should be set - typically ug+rwX.

Summary

The setgroupperms function sets the group permissions on the specified file to allow updating by both command line tools and the web interface. This is typically done by making all files group-writeable to the wacs group of which both apache and the approved WACS administrative users should be members.

Availability

setgroupperms is available only in perl as it is used only for collection management tasks.


Name

treemkdir — Makes a descending tree of directories (equivalent to the mkdir -p command) which includes calls to setgroupperms.

Synopsis

use Wacs;
treemkdir(...); 
 

Parameters

parameterdescription
originThe toplevel directory from which to start - this is required to already exist.
pathThe path below the toplevel directory given above to be created (or partially created as necessary)

Summary

The treemkdir function is the equivalent of the -p option to the mkdir command which is not supported by the internal mkdir call of perl. It makes each element of the path it is asked to make if it does not already exist. This is part of the effort to reduce the dependency on the system call to unix shell commands within WACS. Each directory created has it's permissions set using setgroupperms.

Availability

treemkdir is available only in perl as it is used only for collection management and infrastructure tasks.

Chapter 8. WACS API: User Interface Module

User Interface Module: Summary

Table 8.1. Function Summary: User Interface Module

functiondescription
describehertries to make a sensible sentance out of model data
whatshedoesdescribes the kind of sets this model appears in
addkeyiconsmakes a little HTML table with the attribute icons
addratingsmakes a little HTML table with the set ratings
iconlinkbuild a link around the icon for this set
addlinksadd standard top-of-the-page menus
alsofeaturingfind and list any other models featured in this set
read_menuread the XML menu files and create menu record structure
menu_get_defaultget the default link for the menu title
menu_get_titleget the menu title itself
menu_get_bodyget the body of the menu
menu_get_entryget a single entry from the menu
menu_get_handlerget the webapps name to handle a datatype

User Interface Module: Reference

Name

describeher — tries to make a sensible sentance out of model data

Synopsis

use Wacs;
use WacsUI;
scalar describeher(...); 
 

Parameters

parameterdescription
nameHer name
hometownWhere she says she's from - might be place of birth or current home
countryThe country she comes from
ageHer reported age
ageyearThe year in which that age was given
hairThe colour of her hair
lengthThe length of her hair
titsizeThe size of her breasts
cupsizeThe cupsize of her breasts if known
pussyThe usual style of her pubic hair
raceHer race (in broad terms)
eyesThe colour of her eyes
distmarksdistingishing marks - easy ways to recognise her
buildher phyiscal build/body type
heighther height in centimetres (NB: field not suitable for imperial values)
weighther weight in kilograms (NB: field not suitable for imperial values)
vitbusther bust measurement in centimetres
vitwaisther waist measurement in centimetres
vithipsher hips measurement in centimetres
occupationher occupation (if stated)
aliasesother names she's known by
bioany additional biography text
unitsoverride configuration file when giving units: imperial or metric

Summary

The describeher tries to make a readable biography entry out of the various model attribute parameters in the model table. The result is returned as a string.

Availability

describeher is available in both perl and php. The fields name, hometown, country, age, ageyear, bio and units were added in WACS 0.8.2.


Name

whatshedoes — describes the kind of sets this model appears in

Synopsis

use Wacs;
use WacsUI;
scalar whatshedoes(...); 
 

Parameters

parameterdescription
solodoes she feature in solo sets (Y, N)
straightdoes she feature in straight sets (Y, N)
lesbiandoes she feature in lesbian sets (Y, N)
fetishdoes she feature in any sets flagged as fetish
toysdoes she use toys in any of her sets
masturbationdoes she masturbate in any of her sets
otherdoes she do any activites marked as other

Summary

The whatshedoes function takes the truth values for doing certain kinds of activities and makes it into a descriptive sentence which is returned as a string.

Availability

whatshedoes is available in both perl and php.


Name

addkeyicons — makes a little HTML table with the attribute icons in

Synopsis

use Wacs;
use WacsUI;
addkeyicons(list_of_attribute_keywords,  
 icon_size); 
scalar list_of_attribute_keywords;
scalar icon_size;
 

Summary

The addkeyicons function takes a space seperated list of attribute keywords such as the sets table scatinfo field or the models table mattributes field and prints out the associated icons in a small HTML table. It scales the icons to the specified size in doing so.

Availability

addkeyicons is available in both perl and php.


Name

addratings — makes a little HTML table with the ratings icons in

Synopsis

use Wacs;
use WacsUI;
addratings(...); 
 

Parameters

parameterdescription
overallThe overall rating for the set (1 to 5)
varietyHow unusual the content or action of the set is
techqualThe technical quality of the photography, lighting and set
sizeHow big the icons should be: normal or small
orientationwhether the table should be vertical or horizontal
titledisplay title on table: y for yes, n for no.

Summary

The addratings function is similar to addkeyicons in that it outputs an HTML table with icons in. In this case, it's the ratings icons for each of the three main set ratings: overall, variety and techqual. It can display the table in two sizes, with or without a title and in a horizontal or vertical orientation.

Availability

addratings is available in both perl and php. This function was introduced in Wacs 0.8.1


Name

iconlink — build a link around the icon for this set

Synopsis

use Wacs;
use WacsUI;
iconlink(...); 
 

Parameters

parameterdescription
typeset type value (I, V, etc)
setnoThe set number
sareaThe toplevel area of the set
scategoryThe middle level area of the set
sdirectoryThe lower level area of the set
modelThe model's name - used in the alt tag in the images
resizeWhether to resize or not - 0 is actual size, 1 is rescaled to standard size, 2 is rescaled to mini size
destlocWhich configuration variable to use for location of link destination application - typically cgiurl for perl scripts, siteurl for php scripts, or wacsurl for wacs GUI elements (like glyphs, javascript files or stylesheets)
destappThe stem of the URL to link to around the icon, something like wacsindex/page, needs to include any parameter introducers like page or setid=
destextThe extension of the URL to link to, or null, ie .html or .php

Summary

The iconlink function displays the icon for a set at the requested size surrounded by an appropriate link to the set concerned.

Availability

iconlink is available in both perl and php. The destloc, destapp and destext options are only available in 0.8.1 or later.


Name

addlinks — add standard top-of-the-page menus

Synopsis

use Wacs;
use WacsUI;
addlinks(...); 
 

Parameters

parameterdescription
mynamename of the calling program
contextgeneral area of the current page: possible values are modelindex, models, search, tags, newimage, newvideo or admin
titleTitle of the menu (not currently used)
excludename of link to exclude (normally this apps name so it doesn't link to itself
modemenu mode: either normal for old-style simple top line menu or csshoriz to use javascript pull down menus
optionsoptional parameter list (array)
optdescmatching descriptions for the above

Summary

The addlinks function is a generalised interface to adding a top of the page menu - you specify a general category into which the page you're writing falls, and it adds an appropriate selection of the standard menus.

Availability

addlinks has been available in perl for sometime and was newly added to the php implementation in Wacs release 0.8.4. In general, unless you're trying to create a php app that blends in with the standard Wacs tools, you'll probably want to use your own menu mechanism when using PHP.


Name

alsofeaturing — look for any other models also featuring in this set

Synopsis

use Wacs;
scalar alsofeaturing(...); 
 

Parameters

parameterdescription
setnoThe set number of this set
primaryThe model number we already know about for this set; exclude this model from the results. Leave blank if you want all models listed.
staysmallstay in a small font - if this is set to Y font change specifications will not cause a size change.
destlocthe location of the destination application for the link. This defaults to cgiurl but can be baseurl or any of the url configuration values.
linktowhich wacs application to link to (assumed to be in cgi-bin). If this ends in an equals sign (=) no slash will be added between the application name and the modelno. This allows modelno= and L= style arguments.
skipbrtells the function not to output HTML breaks around the output it creates. This can be first or all as required.
dbhandlecurrent handle to the database connection

Summary

The alsofeaturing function returns a list of models featured in this set along with links to an appropriate WACS application.

To aid CSS styling there is a span directive with a class of alsofeattitle around the Featuring or Also Featuring title output, and another with a class of alsofeatmodel around each model link output.

Availability

alsofeaturing is available in both perl and php (from release 0.8.5); only in perl in the releases prior to that. It was moved to WacsUI in release 0.8.5 from the core Wacs module. The skipbr and destloc parameters were added in Wacs release 0.8.5.


Name

read_menu — read the XML menu files and create menu record structure

Synopsis

use Wacs;
use WacsUI;
read_menu(menu_filename); 
scalar menu_filename;
 

Summary

The read_menu reads the specified menu XML file into the internal data structures of the wacsui object. It should be called before using any of the other menu routines. For the standard system menus, the collection management tools use the file menu.cfg in the wacs config directory (usually /etc/wacs.d). You can edit the standard menu file to add your own additional menu definitions for use in specific applications. If your application wishes to use an alternate namespace, you could specify an alternate menu config name, something like mysite.cfg and also place it in the wacs config directory.

Availability

read_menu is available in both perl and php.


Name

menu_get_default — get the default link for the menu title

Synopsis

use Wacs;
use WacsUI;
scalar menu_get_default(...); 
 

Parameters

parameterdescription
namethe menus name; typically in lower case (eg navigation )
callername of the calling application
excludeapplications to exclude from menus; typically the calling application itself
optionsan array of options to be substituted.
optdesca matching array of descriptions

Summary

The menu_get_default returns the default link for the top-of-the-page menu title before the menu pull-down is activated. Normal substitutions are applied to this option if specified.

Availability

menu_get_default is available in both perl and php.


Name

menu_get_title — get the menu title itself

Synopsis

use Wacs;
use WacsUI;
scalar menu_get_title(...); 
 

Parameters

parameterdescription
nameName of the menu whose title you want

Summary

The menu_get_title function returns the readable title for the specified menu. This is typically what the link address returned by menu_get_default will surround.

Availability

menu_get_title is available in both perl and php.


Name

menu_get_body — get the body of the menu

Synopsis

use Wacs;
use WacsUI;
scalar menu_get_body(...); 
 

Parameters

parameterdescription
namename of the menu concerned
callername of the program calling it
excludename of program to exclude from menus
optionsarray of options to use
optdescarray of matching descriptions for the options above
isareahashref/array of image-based sarea values
vsareahashref/array of video-based sarea values
mflagshashref/array of model flags
vsiteshashref/array of vendor codes and names
preprefix for generated entries (eg <li><a href=\" )
intramiddle section for generated entries (eg \">)
postpostfix for generated entries (eg </a></li> )

Summary

The menu_get_body function returns a big string containing the HTML formatted body of the requested menu. Using the pre, intra and post parameters you can include the correct entry pre-amble, mid-section and tail-section for your desired menu layout.

Availability

menu_get_body is available in both perl and php.


Name

menu_get_entry — get a single entry from the menu

Synopsis

use Wacs;
use WacsUI;
scalar menu_get_entry(...); 
 

Parameters

parameterdescription
namename of the menu concerned
callername of the program calling it
entryhashref/array of the current entry object from menu tree
optionsarray of options to use
optdescarray of matching descriptions for the options above
isareahashref/array of image-based sarea values
vsareahashref/array of video-based sarea values
mflagshashref/array of model flags
vsiteshashref/array of vendor codes and names
preprefix for generated entries (eg <li><a href=\" )
intramiddle section for generated entries (eg \">)
postpostfix for generated entries (eg </a></li> )

Summary

The menu_get_entry takes an individual menu entry (which may result in multiple menu entry lines) and processes it into a string that is returned. It is available seperately as it can be called with custom parameters via options and optdesc to do specific non-standard parameters. All the usual substitions are available including a special one called #NEWPERIOD# which provides a text representation of the current value of the layout->newperiod variable.

Availability

menu_get_entry is available in both perl and php. The #NEWPERIOD# functionality was introduced in WACS 0.8.5.


Name

menu_get_handler — get the webapps name to handle a datatype

Synopsis

use Wacs;
use WacsUI;
scalar menu_get_handler(...); 
 

Parameters

parameterdescription
forThe type of data this is a handler for; usually this will be the table name, eg models but it can be any arbitary name.
optionsThis is the primary key to be passed to the application specified in the lookup.

Summary

The menu_get_handler function is there primarily to let you find the applications that mesh best with the menu tree currently being used. You pass to the function the table or activity name and the primary key (or other lookup parameter) and it will return the preferred application to handle that type of link for this menu/look and feel in use. If the menu configuration file does not include a specification of the handler for any of the standard database tables, the default Wacs application will be given as the reply. A null reply will be indicated by a single character reply of just the hash character.

Some Common Names
mainmenu
models
photographer
preferences
slideshow

Availability

menu_get_handler is available from Wacs 0.8.5 onwards in both perl and php. It was not available prior to this release.

Chapter 9. WACS API: Standard Components Module

Standard Components Module: Summary

Table 9.1. Function Summary: Standard Components Module

functiondescription
mastheadcreates a top-of-the-page summary for any page handling set
modelheadsadds the icons with links for model(s) specified
findmodelcreates a table and choice box for models with a given name
findrecentsetscreates rows in a table managed form with pull-down menus containing details of recently added sets
findrecentmodelscreates rows in a table managed form with pull-down menus containing details of recently added models and a search box to be fed to findmodel
modelheadshotcreates a model headshot icon and basic info table contents
getgallerywork out the next available gallery slot when in gallery layout mode
kwscore_resetresets the keyword scoring system back to defaults
kwscore_processprocess the provided string looking for keywords
kwscore_getget the specified result from the processing of the strings provided previously
removedupsremove duplicates from an attribute string
removeconflictsremove items that contradict the set attributes from the model attributes
addassocAdd a new model/set association record
alloc_nextkeyWork out the next primary key value for the specified database table

Standard Components Module: Reference

The WacsStd module contains standard components for building the standard WACS collection management tool interface. Since all these tools are written in perl, this module is only implemented in perl.

Name

masthead — top of page banner for set-based apps

Synopsis

use WacsStd;
masthead(...); 
 

Parameters

parameterdescription
setnoThe set number
stypeThe set type (single letter database format)
scatinfoThe attributes for the set
scatflagThe set type flag (single letter database format)
stitleThe assigned set title, aka standard description
sofftitleThe official title (usually from original site)
sareaToplevel directory entry
scategoryMiddle level directory entry
sdirectorylowest level - actual holding directory (filename for videos)
simagesNumber of images in the set
sindexesNumber of index images for the set
saspectaspect ratio (mainly for videos)
sformatfile format for this set (.jpg, .png, .mov, .wmv etc)
sdurhrsvideo or DVD scene duration - hours value
sdurminvideo or DVD scene duration - minutes value
sdursecvideo or DVD scene duration - seconds valus
sphotogphotographer reference code (references pref in photographer)
sfoundryorganisation where the set came from
modelnoassociated model number
downloadnoassociated download record number
useiconwhen working with a set number 0, attempt to get an icon by asking for a thumbnail of the first image
addlinksadd set browsing links to the masthead centre section
widthmake the masthead table the specified width only
dbhandlethe current database handle object

Summary

masthead generates a standard top-of-the-page banner heading for any page that is intended to document or amend a standard set record. It does a best efforts with whatever fields it has passed to it.

Availability

masthead is only available in Perl.


Name

modelheads — adds the icons with links for model(s) specified

Synopsis

use WacsStd;
modelheads(lookup_method,  
 set_number,  
 dbhandle); 
scalar lookup_method;
scalar set_number;
scalar dbhandle;
 

Summary

The modelheads function was originally written as part of the implementation of masthead but has broader uses. It provides a table of a model (or group of models) headshots with ratings and name. The lookup_method can be one of byset (where it's the models featured in the specified set number) or byno (where the second argument is the model number rather than the set number). The default option in other cases is any models who've been added today - it is recommended you specify bydate and pass the date for this option.

Availability

modelheads is currently only available in perl.


Name

findmodel — creates a table and choice box for models with a given name

Synopsis

use WacsStd;
use WacsUI;
findmodel(...); 
 

Parameters

parameterdescription
mnamethe model name or beginning of the name to look for
offeraltWhether to offer an alternative choice or not: y or n
offervalueWhat the value returned for the alternative should be, eg next
offercaptWhat the caption for the alternative value should be
incsubmitWhether to include a submit button or not: y or n
dbhandlepointer to the currently active database handle
cgihandlepointer to the currently active CGI object

Summary

The findmodel function takes the name of a model and searches the database for who it might concievably be. It checkes the model's name, her aliases and the name from each of her ID map entries. It presents a headshot, description, and a radio button to allow her to be choosen. It can optionally offer an additional radio button for another purpose. The choosen model's number or next will be returned in a CGI variable called modelno.

Availability

findmodel is only available in perl at this time


Name

findrecentsets — creates rows in a table managed form with pull-down menus containing details of recently added sets

Synopsis

use Wacs;
use WacsStd;
findrecentsets(...); 
 

Parameters

parameterdescription
offsetthe number of days in the past to consider as recent. Defaults to the current value of layout->newperiod if not specified.
defaultthe default value for the set number if known.
dbhandlepointer to the currently active database handle
cgihandlepointer to the currently active CGI object

Summary

The findrecentsets function creates rows in a table managed form with pull-down menus containing details of recently added sets. The method selected by the user for specifying their response will be stored in a CGI variable called setmeth which will have a value of one of specify, image or video. If their response is specify the setno will be in a CGI variable called spec_setno. If their response is image the setno will be in a CGI variable called recent_img and for video it'll be in recent_vid.

Availability

findrecentsets is only available in perl at this time. This function was introduced in WACS 0.8.5.


Name

findrecentmodels — creates rows in a table managed form with pull-down menus containing details of recently added models and a search box to be fed to findmodel

Synopsis

use Wacs;
use WacsStd;
findrecentmodels(...); 
 

Parameters

parameterdescription
offsetthe number of days in the past to consider as recent. Defaults to the current value of layout->newperiod if not specified.
defaultThe default model number if known.
dbhandlepointer to the currently active database handle
cgihandlepointer to the currently active CGI object

Summary

The findrecentmodels function creates rows in a table managed form with pull-down menus containing details of recently added models and a search box to be fed to findmodel. The method selected by the user for specifying their response will be stored in a CGI variable called modmeth which will have one of these values: specify, recent or search. If their response is specify the modelno will be in a CGI variable called spec_modelno. If their response is recent, the modelno will be in a CGI variable called recent_mod. If the value is search the findmodel function should be called passing the CGI variable search as the mname parameter.

Availability

findrecentmodels is only available in perl at this time. This function was introduced in WACS 0.8.5.


Name

modelheadshot — creates a model headshot icon and basic info table contents

Synopsis

use Wacs;
use WacsStd;
modelheadshot(...); 
 

Parameters

parameterdescription
modelnoThe model number - that is our model number for her.
nameThe model's name that we're looking for - thus if we know the model as Jedda, but know she's known as Jana elsewhere, we'd put Jana here to build up a link along the lines of "Known as Jana at KPC" in the id description field.
howcomeHow we came by this model - this can be S as the result of a name search or I if we're displaying her ID details for a specific site.
whereThe site id or short name for where we found this model called this name
keyThe model's key on the site we're talking about if specified.
dbhandlepointer to the currently active database handle

Summary

The modelheadshot is used to produce a basic headshot accompanied by name, attribute icons and optionally details of her identity on a given site. It is a component used in the findmodel function but directly exposed since Wacs 0.8.4 to allow it's use in other places too.

Availability

modelheadshot is only available in perl at this time.


Name

getgallery — get the next available slot in the named gallery

Synopsis

use WacsStd;
scalar getgallery(...); 
 

Parameters

parameterdescription
whichSpecifies which area to substitute in - can be either scategory (middle level) or sdirectory (lower level).
stypestype of the set concerned: typically I for image set, V for video.
sareaTop level area in which to search for the next available gallery slot
scategoryThe middle level directory entry (can be either simply specified or the subject of the substitution). This should include the variable pattern given in substitute below, as in gallery#NEXT#.
sdirectoryThe lower level directory entry (if needed, otherwise blank).
substituteThe string to be substituted with the value determined by the routine. Typically this will be something like #NEXT#.
dbhandleThe Perl DBI handle to the current database

Summary

The getgallery function returns the appropriate string for the next available slot in the gallery in the specified section. It can return either an scategory or sdirectory variable as requested via the which parameter. It is used to work out the placement of new sets within a gallery structure. What the next usable gallery is is determined by reference to the layout attribute setspergallery in the configuration file or the default value (usually 20) if not specified. Please see the configuration manual for more details on this configuration attribute.

Availabilty

As a collection administration function, getgallery is only available in perl.


Name

kwscore_reset — resets the keyword scoring system back to defaults

Synopsis

use WacsStd;
kwscore_reset(scope); 
scalar scope;
 

Summary

The kwscore_reset function resets the currently built attributes table. It is possible to run the kwscore_process function several times with different fields from the database and so it does not naturally reset the internal table of results - this call provides that facility and should always be called before each new set to consider. The scope parameter is currently ignored but may in future modify the behaviour.

Availability

As keyword scoring is a collection administration activity, it is currently only implemented in perl.


Name

kwscore_process — process the provided string looking for keywords

Synopsis

use WacsStd;
kwscore_process(...); 
 

Parameters

parameterdescription
stringthe string to be processed against the keyword database
dbhandlethe database session object pointer

Summary

The kwscore_process function allows you to submit a string to the keyword scoring system for consideration. It's scores will be stored allowing both retrieval of results and modification of those results by subsequent invocation of the kwscore_process with alternative strings. It is perfectly possible to consider both the title (field stitle) and the official title (field sofftitle) if that is appropriate. It could also be run on the description of the set if that is present.

Availability

As a collection administration function, kwscore_process is currently only available in perl.


Name

kwscore_get — get the specified result from the processing of the strings provided previously

Synopsis

use WacsStd;
kwscore_get(...); 
 

Parameters

parameterdescription
whatwhich result you are requesting: valid ones are: cat, loc, det, attr or other.
defaulta default value you want returned if nothing is found for this request

Summary

The kwscore_get function retrieves the results from any kwscore_process calls made since the last kwscore_reset. The what argument specifies what to return:- cat returns a category flag (scatflag etc.), loc returns a location (slocation), det returns a detailed location (slocdetail, attr returns the attributes (scatinfo and other is available for future expansion.

Availability

As a collection administration function, kwscore_get is currently only available in perl.


Name

removedups — remove duplicates from an attribute string

Synopsis

use WacsStd;
scalar removedups(raw_attribute_list); 
scalar raw_attribute_list;
 

Summary

The removedups function removes any duplicate entries from a space-separated list of attributes - this is typically necessary when merging more than one source of attribute information like that from the kwscore_get function and the result of fetching model attributes. Please also see removeconflicts function below.

Availability

As a collection administration function, removedups is currently only available in perl.


Name

removeconflicts — remove items that contradict the set attributes from the model attributes

Synopsis

use WacsStd;
scalar removeconflicts(...); 
 

Parameters

parameterdescription
modelThe model's attributes (mattributes field)
existingThe existing combined attributes (ie those taken from the set scatinfo field

Summary

The removeconflicts function is designed to stop contradictory overwriting of mutually exclusive model attributes - typically those relating to pubic hair trimming, as these can often vary between sets of the same model. It is provided with the model's attributes plus the existing set attributes - if the existing set attributes do not include a contradictory value, then the model's attributes are included. If there's a conflict, the model's pubic hair attribute is dropped in favour of that in the set. This is usually the correct behaviour. This if a model is normally considered to have a shaven pussy, but appears in a set before she's shaven it (or even as she does so), then the set may be marked with the hairy attribute. If that is there, the model's default of shaven will be removed and only her other attributes (tattoos, piercings, etc) will be imported.

Availability

As a collection administration function, removeconflicts is currently only available in perl.


Name

addassoc — add a new association record connecting a model with a set

Synopsis

use WacsStd;
scalar addassoc(...); 
 

Parameters

parameterdescription
setnothe set number to be associated with a model (see below)
modelnothe model number to be associated with the above set
asstypethe type of the association - currently only G for general but this might be changed in the future - see the schema reference for the assoc table for more information.
dbhandleThe open database handle for use in querying the database

Summary

The addassoc function is designed to add association records between sets and models. To do this it creates a new record in the assoc database table using the next available primary key for that table. To call addassoc you need to provide a set number, a model number and a dbhandle to a currently open database session. Optionally you may also provide an association type although currently only one type, G for general is defined in the WACS database dictionary. addassoc protects against adding multiple associations between the same model and set.

Availability

As a collection administration function, addassoc is currently only available in perl.


Name

alloc_nextkey — allocate the next new unique primary key for the database table specified

Synopsis

use WacsStd;
scalar alloc_nextkey(table_name,  
 primary_key_fieldname,  
 dbhandle); 
scalar table_name;
scalar primary_key_fieldname;
scalar dbhandle;
 

Parameters

parameterdescription
table_nameThe name of the table in the Wacs database schema for which the new key should be allocated, eg sets, models or assoc.
primary_key_fieldnameThe name of the primary (unique) key to that database table.
dbhandleThe open database handle for use in querying the database

Summary

The alloc_nextkey function simply returns the next available value for creating a new record in the specified table. It's rather simplistic and can be caught out by race conditions, but it mostly gives you a valid numeric primary key for the table concerned.

Availability

As a collection administration function, alloc_nextkey is currently only available in perl.

Chapter 10. WACS API: Identification Module

Identification Module: Summary

[Warning]Warning

The existing identification module has many flaws and it is intended to massively overhaul it in the near future. We would not recommand utilising functions from this module at the present time. If you need a particular routine listed here, please contact us and we'll consider moving it to one of the more stable modules if appropriate

Table 10.1. Function Summary: Identification Module

functiondescription
ident_imgIdentify characteristics of an image set from download info
ident_vidIdentify characteristics of a video clip from download info
reset_attrreset the global attribute table
id_get_flagget previously determined flag (run ident_* first)
id_get_infoget previously determined catinfo (run ident_* first)
id_get_photogget previously determined photographer (run ident_* first)
id_get_dnldnoget download record number
id_get_modelnoget the model number
id_get_modelnameget the model's name
id_get_vendorget the vendor reference
id_get_dbhandleget the current DB handle
id_get_keyget the current models id at the current vendor
id_get_setkeyget the set key at the current vendor
id_get_setnameget the name of the most recent set
id_get_statusget the status of the most recent set
id_get_notesget the current value of the notes field
id_get_setnoget the current value of the setno field
id_mpageprocess a modelpage looking for links to suitable sets
chk_vid_typecheck to see if this url is a video file type
chkid_existingcheck to see if we already have a model with this idmap

Part III. WACS Database Schema

This is the Database Schema Reference Manual, or data dictionary, for the WACS environment. This documents the database tables in use, their contents, structure, relationships and assigned values.

The WACS database schemas are built with the convention that the first letter of the schema name is prefixed to all fields within that schema. Thus a field from the sets schema will start with the letter s, a field from the assoc schema will start with the letter a and so on. Generally relationed fields will have fundamentally the same name, such that the set number is setno in the sets schema, asetno in the assoc schema, tsetno in the tags schema, dsetno in the download schema, and so on. This makes performing relational joins much easier and more portable since one can do the likes of where amodelno = modelno without any ambiguity and without having to specify the table name explicity.

Where possible fields with a limited set of possible values will be single character fields with a reasonably neumonic value for each possible value. Thus the media type (stype, dtype, etc) is V for Video Clip, I for Image Set, D for DVD scene, and so on. A lookup hash of the legal values will typically be available for programmers to use from the core Wacs module (see the Part II, “WACS API Programming Reference” for more details).

Chapter 11. Schema Reference: Sets

Sets: Schema SQL

[Warning]Warning

WACS 0.8.5 contains a significant number of additions to this schema ahead of the shift to the 0.9.x release series. None of these changes are used or accessed by applications in Wacs 0.8.5, so you can defer updating the Schema until Wacs 0.9.0 comes out if you wish to. There will be a tool to update the schema supplied with Wacs 0.9.0. The newly added and currently not used fields are those in bold typeface.

create table sets
( setno                 number(9) primary key,
  stype                 char(1) not null,
  sstatus               char(1) not null,
  srank                 char(1),
  sauto                 char(1),
  srating               char(1),
  sflag                 char(1),
  stechqual             number(2),
  svariety              number(2),
  svisits               number(2),
  sformat               varchar2(10),
  scodec                varchar2(40),
  stitle                varchar2(240),
  sofftitle             varchar2(240),
  sofficon              varchar2(160),
  saddicon              varchar2(160),
  sname                 varchar2(80),
  shair                 varchar2(80),
  smodelno              varchar2(40),
  slocation             varchar2(20),
  slocdetail            varchar2(40),
  sattire               varchar2(20),
  sfocus                char(1),
  sphotog               varchar2(6) references photographer,
  ssource               varchar2(80),
  sfoundry              varchar2(80),
  sproddate             date,
  sreldate              date,
  suscattr              char(1),
  snotes                varchar2(240),
  sdesc                 varchar2(2048),
  sindexes              number(6),
  simages               number(6),
  sdurhrs               number(2),
  sdurmin               number(2),
  sdursec               number(2),
  slandx                number(6),
  slandy                number(6),
  sportx                number(6),
  sporty                number(6),
  saspect               varchar2(10),
  sfps                  number(6),
  sinter                char(1),
  sskipfr               number(9), 
  sbytes                number(12),
  sdvdno                number(6),
  sdvddisc              number(2),
  sdvdtitle             number(3),
  sdvdstartch           number(3),
  sdvdendch             number(3),
  sidlogo               char(1),
  serrors               char(1),
  sduplicates           number(9) references sets,
  saltmedia             number(9) references sets,
  snext                 number(9) references sets,
  sprev                 number(9) references sets,
  ssetpos               number(2),
  scatinfo              varchar2(160),
  scatflag              char(1),
  snamestem             varchar2(80),
  sdownload             varchar2(160),
  sarea                 varchar2(160),
  scategory             varchar2(160),
  sdirectory            varchar2(240),
  scomments             varchar2(240),
  sadded                date,
  samended              date
);
[Note]Note

sattire is a new field introduced into the schema in release 0.8.1; it came into use in WACS 0.8.2. It is currently scored using the other attribute of the keyword system, this will change to using kiwear in WACS 0.9.0.

[Tip]Tip

The new fields introduced in WACS 0.8.5 are srank, sfocus, saltmedia, snext, sprev and ssetpos. Additionally referential integrity is now enforce for sduplicates which shouldn't cause a particular problem if it's been used correctly.

Sets: Defined Values

Table 11.1. stype: Type of Set: defined values

stype
IImage Set
VVideo Clip
AAudio File
SDVD Scene

Table 11.2. sstatus: Status of Set: defined values

sstatus
MManually Added, Details Not Checked
AAutomatically Added, Details Not Checked
NNormal - Checked
GGood - Thoroughly Checked
UUnknown

Table 11.3. sauto: Automatic Update of Set Allowed?: defined values

sauto
NNone (no auto updates)
L(on-disk) Location only - all attributes manual
AAppend only - all existing entries stay
FFully auto-generated - all values can change

Table 11.4. srating: Overall Rating For The Set: defined values

srating
5Finest
4Very Good
3Good
2Reasonable
1Mediocre
0None Specified

Table 11.5. stechqual: Technical Quality Rating For The Set: defined values

stechqual
5Finest - HD Video done well, Multi-megapixel stills
4Very Good - Well lit SD or good HD Video, good megapixel + stills
3Good - Well done low-res SD, good sub-megapixel stills; not quite so good but higher res
2Reasonable - either very small, or bad equipment (flash on camera) used moderately well
1Mediocre - lack of skill, bad equipment, poor composition
0None Specified

Table 11.6. svariety: Unusualness Rating For The Set: defined values

svariety
5Very Unusual - look at the set scenario and think "What the F***!"
4Unusual - unusual and very interesting - "Wow"
3Neat - interesting and impressive but not quite "Wow"
2Cute Twist - a slightly unusual twist, unusual pose etc
1Ordinary - can still score very highly in overall and tech
0None Specified

Table 11.7. sformat: Format of the File(s) In The Set: defined values

sformat
JPEGJPEG image
GIFGIF image
PNGPNG image
PNMPNM,PBM,PGM,PPM image
WMVWindows Media Player Video
AVIAVI Video (codec specified separately)
QTQuickTime .mov Video (codec specified separately)
MPEGMPEG Video (MPEG-1 or 2)

Table 11.8. sidlogo: Presence of Burnt-in Logo: defined values

sidlogo
UUnknown
YYes - image/video has burnt-in logo
NNo - image/video is clean of bugs

Table 11.9. sinter: Progressive or Interlaced Video Structure

sinter
IVideo has interlaced frame/field structure
PVideo has progressive frames (atomic)

Table 11.10. serrors: Presence of Known Errors: defined values

serrors
NNone detected
FFixed - faulty images/video have been fixed - Quality may have been compromised - sizes/signatures no indicative of original
EEncoding Only - causes message but renders OK
CSome Corrupt Images/Segments of video

Table 11.11. scatflag: Generalised type of the set: defined values

scatflag
FFuck - straight sex
LLesbian - lesbian sex
GGroup - more than two people having sex, mixed-gender
TToy - Solo but uses toys such as dildo, vibrator, etc
SSolo - Model on her own (possibly with a non-participatory audience)
MMasturbation - Solo but includes masturbation activities
NNone - not determined yet
BBackstage - Behind The Scenes set featuring this model
CClothed - non-nude set featuring this model
DDuplicate - duplicate set - maybe from a different site - DEPRICATED

Table 11.12. slocation: generalised description of locations: recommended values

slocation (recommended values)
[Note]Note

This is a Recommended Values list only; additional values can be added as appropriate

BalconyBalcony or Terrace; outdoors but not part of Garden
BathroomBathroom, Toilet or Shower Cubicle
BedroomBedroom or other sleeping area
CountryCountry - including Beach, Forest, and Fields
Dining RoomDining Room or Eating Area
GardenGarden or other private outdoor area
HallwayHallway, Staircase or Entrance
KitchenKitchen or Kitchen area of apartment
LaundryLaundry, Cleaning or Utility Area
LoungeLounge, Sitting Room or Other Seating Area
OfficeOffice, including Home PC desk
Other RoomAny other room - (Domestic) Library, Junk Room, Garage, etc
SpecialisedSpecialised Location: Swimming Pool, Shop, Recording or TV Studio, Factory, Railway Station, etc; additional details can be placed in slocdetail.
SportsLocation associated with Sports and Exercise: Gym, Locker Room, etc.
StudioWhite or other plain background Photographic Studio - but NOT Television or Audio recording studios as a feature of the set theme

Table 11.13. sattire: generalised description of model's clothing: recommended values

sattire (recommended values)
[Note]Note

This is a Recommended Values list only; additional values can be added as appropriate

BusinessA tidy business suit or other combination appropriate to an office environment.
CasualA pretty general category - jeans, denim skirts, summer dresses
ElegantParticularly stunning dresses or formal evening wear.
FantasyFantasy costumes of all sorts.
GlamourousA glamourous party dress or similar that is quite risque and is likely to spontaneously reveal the woman's assets!
HousewearThe sort of clothing that is worn casually about the house but not normally in public.
HospitalityHousemaids and Waitress Uniforms
Law EnforcementPolice and Security Guard Uniforms
MedicalUniforms appropriate to the Medical Industry
MilitaryUniforms appropriate to the Military Services
NightwearPajamas, Baby Doll dresses, Nightshirts
NothingNude!
PartialOnly partially clothed
RetailUniforms appropriate to the Retail and other service industries (but not Maids)
SchoolwearVarious uniforms associated with Schoolgirls including cheerleaders and gym slips
SmartSmart or attractive clothes suitable for going to a party without being elegant or stunning.
SportsSportswear - track suits, sports bras, cycling outfit, etc
SwimwearBikinis and other swimming costumes
UnderwearJust a bra and panties, or similar - BUT does not include a tank top plus panties which with the addition of a skirt or jeans would be presentable outdoor wear.

Table 11.14. suscattr: how to generate the 18 USC 2257 declaration: defined values

suscattr
VVendor based - use vendor's USC declaration address
PPhotographer based - use photographer's address for USC declaration
NSuppress declaration - NOT RECOMMENDED FOR US RESIDENTS
GGeneric - include generic text with all vendor addresses

Chapter 12. Schema Reference: Assoc

Assoc: Schema SQL

create table assoc 
( assocno                       number(9) primary key,
  amodelno                      number(6) references models,
  asetno                        number(9) references sets,
  astatus                       char(1),
  aadded                        date,
  aamended                      date
);

Assoc: Defined Values

Table 12.1. astatus: association status: defined values

astatus
MManually Added
GGenerated Automatically
RRelationship entry - not the primary model for this set.

Chapter 13. Schema Reference: Idmap

Idmap: Schema SQL

[Note]Note

A possible future direction is for this table to be relationally linked to the vendors table such that idmap.isite = vendor.vsite

create table idmap
( identryno                     number(7) primary key,
  imodelno                      number(6) references models,
  istatus                       char(1),
  isite                         varchar2(20) not null,
  ikey                          varchar2(30),
  ialtkey                       varchar2(30),
  iname                         varchar2(30),
  inotes                        varchar2(80), 
  iactive                       char(1),
  ichanged                      date,
  ichecked                      date,
  iadded                        date,
  iamended                      date
);

Idmap: Defined Values

Table 13.1. istatus: idmap status: defined values

istatus
MManually Added
AGenerated Automatically
IImported From Another WACS site

Table 13.2. iactive: model activity status as this identity: defined values

iactive
YYes - active model (refresh list with auto tools)
DDormant - no new sets for a while (don't bother checking)
NNo - inactive (id not known)
OObsolete - old reference (no longer there)

Table 13.3. isite: Some recommended site abbrievations: recommended values

isite (recommended values)
[Note]Note

This is a Recommended Values list only; additional values can be added as appropriate

ALSALSScan.com
AMKAMKingdom.com (aka ATK Galeria)
ATEATKExotics.com
ATKPATKPremium.com
AWAbbyWinters.com
FJFemJoy.com
IFGinfocusgirls.com
JAFNjennyandfriends.net
KPCkarupspc.com (aka Karup's Private Collection)
KHAkarupsha.com (aka Karup's Hometown Amateurs)
SEsapphicerotica.com
TFteenflood.com
PMETPinkMetallic.com, the WACS Demo site

Chapter 14. Schema Reference: Models

Models: Schema SQL

[Warning]Warning

WACS 0.8.5 contains a significant number of additions to this schema ahead of the shift to the 0.9.x release series. None of these changes are used or accessed by applications in Wacs 0.8.5, so you can defer updating the Schema until Wacs 0.9.0 comes out if you wish to. There will be a tool to update the schema supplied with Wacs 0.9.0. The newly added and currently not used fields are those in bold typeface.

[Note]Note

Please notice that the use of metric in the vital statistics is not intended to be a dig at the imperial measurements, merely that it reliably and consistantly conveys the necessary information as sensible, manageable integers. Utility functions are planned to make it easier to convert and update in a future release of WACS. You try writing an SQL query to find models between 5ft 3ins and 5ft 6ins in height, as compared to between 160 and 168 cms in height. See what I mean?

create table models 
( modelno           number(6) primary key,
  mname             varchar2(40),
  mhair             varchar2(15),
  mlength           varchar2(20),
  mtitsize          varchar2(10),
  mcupsize          char(1),
  meyes             varchar2(15),
  mrace             varchar2(15),
  mattributes       varchar2(60),
  maliases          varchar2(60),
  mdisting          varchar2(80),
  musual            varchar2(60),
  mimage            varchar2(80),
  mbigimage         varchar2(80),
  mbodyimage        varchar2(80),
  maltimage         varchar2(80),
  mstatus           char(1),
  mrating           char(1),
  mpussy            char(1),
  mlabia            varchar2(80),
  mflag             char(1),
  mvideos           char(1),
  msolo             char(1),
  mstraight         char(1),
  mlesbian          char(1),
  mfetish           char(1),
  mmast             char(1),
  mtoys             char(1),
  mother            char(1),
  mnsets            number(4),
  mnimages          number(7),
  mnvideos          number(4),
  mcountry          varchar2(30),
  mhometown         varchar2(80),
  mage              number(3),
  mageyear          number(4),
  mcstatus          char(1),
  mvitbust          number(4),
  mvitwaist         number(4),
  mvithips          number(4),
  mbuild            char(1),
  mheight           number(3),
  mweight           number(3),
  mdress            number(2),
  mstarsign         number(2),
  moccupation       varchar2(30),
  mcontact          varchar2(80),
  mbirthdate        date,
  monfile           char(1),
  magency           varchar2(80),
  mnotes            varchar2(240),
  mbio              varchar2(240),
  madded            date,
  mamended          date
);

Models: Defined Values

Table 14.1. mstatus: model record status: defined values

mstatus
AAutomatically Added, Details Not Checked
MManually Added, Details Not Checked
NNormal - Checked
GGood - Thoroughly Checked
PPlaceholder - Not Real Person

Table 14.2. mrating: model rating: defined values

mrating
5Finest (included in Q= searches and front page)
4Very Good (included in Q= searches and front page)
3Good (not included in Q= searches, included in front page)
2Reasonable (not included in Q= searches or front page)
1Mediocre (not included in Q= searches or front page)
0None Specified (listed in U= searches)

Table 14.3. mpussy: model's normal pubic hair style: defined values

mpussy
HHairy
TTrimmed
BBrazilian style shaved - very little hair above clit area
SShaven - completely
VVaries (best avoided, try and pick one of above - her usual style)
NNot Specified

Table 14.4. mflag: special marking flag for models: defined values

mflag
SFavourite Solo
LFavourite Lesbian
CFavourite Cutie
FFavourite Straight
MCurrent Featured Model
PPlaceholder (not a real person)

Table 14.5. model activites flags: defined values

model activities flags
fieldnamepossible values
[Note]Note

Automatically updated by updatestats

mvideos

Y - Yes, does this; N - No, doesn't do this

msolo
mstraight
mlesbian
mfetish
mmast
mtoys
mother

Table 14.6. mcstatus: accuracy of home country field: defined values

mcstatus
CCertain - country of origin stated in bio
IInferred - from location or other models seen with
GGuess - based on photographer or building style
NNone

Table 14.7. mrace: race of the model: defined values

mrace
CaucasianCaucasian - European Descent aka White
OrientalOriental - Chinese, Japanese, SE Asian
AsianIndian Sub-Continent - India, Pakistan, etc
NegroidNegroid - of African Descent aka Black
AboriginalAboriginal - indigenous peoples - First Nation, Polynesian, etc
LatinaLatin American - aka Hispanic
MixedMixed race and others

Table 14.8. mbuild: body type of the model: defined values

mbuild
VVery Slim
SSlim
MMedium
HHeavy

Table 14.9. vital statistics: meanings

vital statistics
mweightWeight in Kilos
mheightHeight in centimetres
mvitbustBust measurement in centimetres (vital stats part 1)
mvitwaistWaist measurement in centimetres (vital stats part 2)
mvithipsHips measurement in centimetres (vital stats part 3)

Chapter 15. Schema Reference: Download

Download: Schema SQL

create table download
( downloadno                            number(7) primary key,
  dmodelno                              number(6) references models,
  dsetno                                number(9) references sets,
  dstatus                               char(1),
  dtype                                 char(1),
  dsite                                 varchar2(20) not null,
  dkey                                  varchar2(30),
  dsetkey                               varchar2(40),
  dsetname                              varchar2(240),
  dsetflag                              char(1),
  dnotes                                varchar2(240),
  durl                                  varchar2(240),
  darchive                              varchar2(240),
  dsignature                            varchar2(82),
  dsize                                 number(9),
  dpulled                               date,
  dadded                                date,
  damended                              date
);

Download: Defined Values

Table 15.1. dstatus: download status: defined values

dstatus
UNot Yet Attempted
FFailed - Retry when possible
SSuccessful - set registered in database, available
PPending - downloaded, awaiting unpacking
AAborted - don't download for some reason
DDeferred - held back from being downloaded
RRelationship Entry - a second model for a set
LLiasion - a proto-Relationship Entry not yet linked
EError - not the right model, etc
IIn Progress - download currently in progress
XIncomplete - record of it's existance but too little info to download it

Table 15.2. dtype: download set type: defined values

dtype
IImage Set
VVideo Clip
AAudio File

Table 15.3. dsetflag: Suggested value for scatflag based on parsing result

dsetflag
[Note]Note

Any valid value for scatflag from the sets table. This is a hint on the set type based upon the parsing process picking out keywords


Chapter 16. Schema Reference: Photographer

Photographer: Schema SQL

create table photographer
( pref             varchar2(6) primary key,
  pname            varchar2(40),
  paliases         varchar2(80),
  pgender          char(1),
  paddress         varchar2(120),
  pemail           varchar2(80),
  pwebsite         varchar2(80),
  pusual           varchar2(40),
  pregion          varchar2(20),
  pcountry         varchar2(50),
  plocation        varchar2(50),
  pstyledesc       varchar2(80),
  prating          number(2),
  phardness        number(2),
  psolo            char(1),
  ptoys            char(1),
  plesbian         char(1),
  pstraight        char(1),
  pgroup           char(1),
  pfetish          char(1),
  pdigital         char(1),
  pfilm            char(1),
  pvideo           char(1),
  phdvideo         char(1),
  pcamera          varchar2(40),
  pcamnotes        varchar2(80),
  pcomments        varchar2(240),
  pnotes           varchar2(240),
  pbiography       varchar2(1024),
  padded           date,
  pamended         date
);

Photographer: Defined Values

Table 16.1. pgender: gender of the photographer: defined values

pgender
MMale
FFemale
UUnknown

Table 16.2. pregion: geographical location of the photographer: defined values

pregion
EuropeEurope
North AmericaUSA and Canada
South AmericaSouth and Central America
Middle EastMiddle East (brave photographer!)
AsiaAsia (India and the Indian Sub-continent ONLY)
OrientOrient (Asia excluding Indian Sub-continent)
AustralasiaAustralia and New Zealand
AfricaAfrica
OtherOther

Table 16.3. prating: overall rating of photographer: defined values

prating
0None
1Awful - poor equipment and technique
2Poor - uninteresting and badly composed/exposed work
3Reasonable - technically OK, but very unenterprising
4Good - good technique, interesting compositions and direction
5Excellent - Excellent technique, interesting and challenging compositions and direction

Table 16.4. phardness: rating of how explicit this photographer can be: defined values

phardness
0None - Not Rated
1Soft-focus (very arty)
2Glamour - sharp but no open leg, genital detail, etc
3Normal - wide range of shots but not particularly strong
4Hard (close-ups)
5Fetish - pretty extreme, gaping, etc

Table 16.5. photographer activites covered flags: defined values

photographer activities covered flags
fieldnamepossible values
psolo

Y - Yes, does this; N - No, doesn't do this; O - Occasionally does this

ptoys
plesbian
pstraight
pgroup
pfetish

Table 16.6. photographer technologies used flags: defined values

photographer technologies used flags
fieldnamepossible values
pdigital

Y - Yes, uses this technology; N - No, doesn't use this technology.

pfilm
pvideo
phdvideo

Chapter 17. Schema Reference: Tag

Tag: Schema SQL

create table tag
( tagno                         number(9) primary key,
  tmodelno                      number(6) references models,
  tsetno                        number(9) references sets,
  tstatus                       char(1),
  tflag                         char(1),
  tgroup                        number(6),
  tdesc                         varchar2(40),
  towner                        varchar2(20),
  texpiry                       date,
  tadded                        date,
  tamended                      date 
);

Tag: Defined Values

Table 17.1. tstatus: tag entry status: defined values

tstatus
TTemporary - expire as per expiry rules
VViewed, Temporary - expire as per expiry rules, hide from index
PPermanent - don't expire, show in index
AArchived - don't expire, don't show in normal indexes

Table 17.2. tflag: tag content type status: defined values

tflag
MModel-based tag entry
SSet-based tag entry

Chapter 18. Schema Reference: Vendor

Vendor: Schema SQL

create table vendor
( vsite            varchar2(20) primary key,
  vname            varchar2(45),
  vshortname       varchar2(20) not null,
  vregion          varchar2(20),
  vcountry         varchar2(50),
  vweburl          varchar2(120),
  vsignup          varchar2(120),
  vrating          number(2),
  vtechrate        number(2),
  vuscdecl         varchar2(240),
  vcurrent         char(1),
  vshow            char(1),
  vsubscribed      char(1),
  vuntil           date,
  vusername        varchar2(80),
  vpassword        varchar2(30),
  vidtimg          number(2),
  vidtvid          number(2),
  vcomexcl         varchar2(240),
  vmdirectory      varchar2(240),
  vmdiruse         char(1),
  vmdirpages       number(3),
  vmpage           varchar2(240),
  vmpaguse         char(1),
  vmbio            varchar2(240),
  vmbiouse         char(1),
  vmvideos         varchar2(240),
  vmviduse         char(1),
  vvidpage         varchar2(240),
  vviduse          char(1),
  vimgpage         varchar2(240),
  vimguse          char(1),
  valtpage         varchar2(240),
  valtuse          char(1),
  vsrvimg          varchar2(240),
  vsrvvid          varchar2(240),
  vmultimg         char(1),
  vmultvid         char(1),
  vnotes           varchar2(240),
  vadded           date,
  vamended         date
);

Vendor: Defined Values

Table 18.1. vcurrent: vendor existance status: defined values

vcurrent
YYes - still an active site
NNo - no longer trading at that web address

Table 18.2. vshow: vendor index inclusion status: defined values

vshow
[Note]Note

This option only really affects vendormode and vendor-based lists of models; if you don't use vendor mode, it's not likely to be relevant.

YYes - show in indices
NNo - hide from indices

Table 18.3. vmdiruse et al: vendor URL auto-usuability status: defined values

vmdiruse et al
fieldnamepage purposepossible values
vmdiruseModel Directory
Ylink is (auto)usable
Nlink is not (auto)usable
Slink usable only with session key
vmpaguseModel Page
vmbiouseModel Biography
vmviduseModel's Videos Page
vviduseVideo Set Page
vimguseImage Set Page
valtuseAlternate Image Set Page

Chapter 19. Schema Reference: Conn

Conn: Schema SQL

create table conn
( centryno                      number(9) primary key,
  cgroup                        number(6),
  corder                        number(3),
  cflag                         char(1),
  cstatus                       char(1),
  cmodelno                      number(6) references models,
  csetno                        number(9) references sets,
  cphotog                       varchar2(6) references photographer,
  ctype                         varchar2(20) not null,
  cdesc                         varchar2(80),
  ccomments                     varchar2(240),
  cpath                         varchar2(160)
  cadded                        date,
  camended                      date
);

Conn: Defined Values

[Warning]Warning

Conn (connections) is a recent addition and not all parts of the toolchain are in place yet. As the management tools are added, it is expected that at least the legal values for fields will change and be expanded.

Table 19.1. cflag: connection type: defined values

cflag
AAd-Hoc - A casual index of some random theme
GGallery - A slightly more focused collection with a specific concept behind it.

Table 19.2. cstatus: connection entry status: defined values

cstatus
MManually Added
TImported from a Tag set

Chapter 20. Schema Reference: Keyword

Keyword: Schema SQL

create table keyword
( kentryno              number(9) primary key,
  kflag                 char(1),
  kword                 varchar(30) not null,
  kexclusions           varchar(120),
  kiloc                 varchar(20),
  kiscore               number(1),
  kicat                 char(1),
  kicscore              number(1),
  kidet                 varchar(40),
  kidscore              number(1),
  kiattr                varchar(30),
  kiascore              number(1),
  kiwear                varchar(40),
  kiwscore              number(1),
  kiother               varchar(40),
  kioscore              number(1),
  knotes                varchar(80),
  kadded                date,
  kamended              date
);
[Note]Note

From WACS 0.8.2, the kiother and kioscore fields are used to determine values for the sattire field in the sets schema. New fields kiwear and kiwscore were introduced in WACS 0.8.5 and will be used for values for the sattire fields from WACS 0.9.x freeing kiother and kioscore for their original purpose of being spare for future functionality.

Keyword: Defined Values

Table 20.1. kflag: active entry status: defined values

kflag
AApplies to All Added
NNot Active (Ignore)

Chapter 21. Schema Reference: User

User: Schema SQL

create table user
( userid                number(9) primary key,
  username              varchar2(20) not null,
  upassword             varchar2(20) not null,
  ustatus               char(1),
  utype	                char(1),
  uvisits               number(6),
  uclass                varchar2(20) not null,
  uprexcl               varchar2(20),
  uprdirect             char(1),
  uprpage               varchar2(20),
  uprscale              varchar2(20),
  uprsize               varchar2(12),
  uprquality            number(3),
  uprdelay              number(3),
  uprunits              char(1),
  uprthumbs             varchar2(20),
  uprother              varchar2(20),
  uregister             date,
  uexpiry               date,
  ulastact              date,
  ulastconn             date,
  ulastcomm             date,
  ulasttopic            varchar2(40),
  upurge                date,
  uemail                varchar2(120),
  ualtemail             varchar2(120),
  uscreenname           varchar2(30),
  urealname             varchar2(80),
  uaddress1             varchar2(80),
  uaddress2             varchar2(80),
  ucity                 varchar2(50),
  uprovince             varchar2(30),
  ucountry              varchar2(30),
  upostcode             varchar2(20),
  utelephone            varchar2(30),
  uallowed              char(1),
  uthirdp               char(1),
  ujointhru             varchar2(30),
  ureference            varchar2(120),
  upayamount            number(4,2),
  upaycurr              varchar2(10),
  ulinkfrom             varchar2(120),
  urebill               char(1),
  ucommpay              char(1),
  ucommission           varchar2(80),
  ucommfee              number(4,2),
  ucommcurr             varchar2(10),
  ucommperc             number(3),
  unotes                varchar2(240),
  uadded                date,
  uamended		date
);
[Note]Note

The user schema is a new table introduced in WACS 0.8.5; it is not available or supported prior to that release. Only certain fields of this table are supported and used within the standard WACS tools; the additional fields are utilised by the WacsPro commercial site management toolset available seperately from Bevtec Communications Ltd. To ensure compatibility, the recommended values used in all fields are described here.

User: Defined Values

Table 21.1. ustatus: User Account Status: defined values

ustatus
AActive - this account is currently active
EExpired - this user account has expired
PPending - user needs to complete verification step
SSuspended - access temporarily suspended - leaked password, etc

Table 21.2. utype: User Type: defined values

utype
FFriend (or Freebie) - account granted free access
SSubscriber - a subscription account

Table 21.3. uclass: User Class: defined values

uclass
viewera normal user account
powerpower user with enhanced rights, can see most of the administration tools but can't make significant changes to the collection. Primarily intended for support staff
adminsystem and collection administrator - full administrative rights

Chapter 22. Schema Reference: Attrib

Attrib: Schema SQL

[Note]Note

The attrib schema was introduced in WACS 0.8.5 but is not used at all by that release. It will be used in a future release.

create table attrib
( atrecno             number(9) primary key,
  atkeyword           varchar2(30),
  atsource            char(1),
  atrecognise         char(1),
  atallowadd          char(1),
  atdisplay           char(1),
  atshortdesc         varchar2(50),
  atlongdesc          varchar2(240),
  aticon              varchar2(160),
  atgroup             varchar2(30),
  atimplicit	      char(1),
  atvalidset          char(1),
  atvalidmodel        char(1),
  atvalidother        char(1),
  atmarkset           char(1),
  atmarkmodel	      char(1),
  atmarkother         char(1),
  atsetsearch         char(1),
  atmodsearch         char(1),
  atcombsearch        char(1),
  atothsearch         char(1),
  atsetdetail         char(1),
  atmoddetail         char(1),
  atcombdetail        char(1),
  atothdetail         char(1),
  atnotes             varchar2(240),
  atadded             date,
  atamended           date
);

Attrib: Defined Values

Chapter 23. Schema Reference: Notes

Notes: Schema SQL

create table notes
( nentryno                            number(9) primary key,
  ntype                               char(1),
  norder                              number(3),
  ntitle                              varchar2(80),
  ntext                               varchar2(2048),
  nstatus                             char(1),
  nnext                               number(9) references notes,
  nexpiry                             date,
  nmodelno                            number(6) references models,
  nsetno                              number(9) references sets,
  nphotog                             varchar2(6) references photographers,
  nconn                               number(6),
  ncomments                           varchar2(120),
  nadded                              date,
  namended                            date
);

Notes: Defined Values

[Warning]Warning

Notes is a brand new addition as at Wacs 0.8.5 and is not going to be used until at least the next release of Wacs. It is intended to provide a mechanism for attaching additional text to models, connections and as a basis for a simple site blog mechanism. All values given below are subject to change therefore.

Table 23.1. ntype: notes type: defined values

ntype
BSite Blog entry
CConnection Descriptive Text - more about a connection
MModel Biography - an extended biography

Index

C

cflag, Conn: Defined Values
checkexclude, Core Module: Reference
checkindex, Core Module: Reference
check_auth, Core Module: Reference
Configuration
Reading The..., A First WACS Program
Configuration Values
Getting..., Initialising Database Connection
conf_get_attr, Initialising Database Connection, Core Module: Reference
conn
cflag values, Conn: Defined Values
cstatus values, Conn: Defined Values
Field Listing, Conn: Schema SQL
Connection
Database, Initialising..., A First WACS Program
cstatus, Conn: Defined Values

D

Data Architecture, Connecting Sets And Models
Database
Environment Variables, Initialising Database Connection
Fetching Records..., A First WACS Program
Initialising Connection To..., A First WACS Program
dberror, Core Module: Reference
describeher, User Interface Module: Reference
WacsUI: Introducing, Introducing WacsUI
divideup, Core Module: Reference
download
dsetflag values, Download: Defined Values
dstatus values, Download: Defined Values
dtype values, Download: Defined Values
Field Listing, Download: Schema SQL
dsetflag, Download: Defined Values
dstatus, Download: Defined Values
dtype, Download: Defined Values
Dynamic Content, WACS and Web 2.0

I

iactive, Idmap: Defined Values
iconlink, User Interface Module: Reference
icons
adding set ..., About Set Display
idmap
Field Listing, Idmap: Schema SQL
iactive values, Idmap: Defined Values
isite recommended values, Idmap: Defined Values
istatus values, Idmap: Defined Values
isite, Idmap: Defined Values
istatus, Idmap: Defined Values

M

makedbsafe, Core Module: Reference
masthead, Standard Components Module: Reference
mbuild, Models: Defined Values
mcstatus, Models: Defined Values
menu_get_body, User Interface Module: Reference
menu_get_default, User Interface Module: Reference
menu_get_entry, User Interface Module: Reference
menu_get_handler, User Interface Module: Reference
menu_get_title, User Interface Module: Reference
mfetish, Models: Defined Values
mflag, Models: Defined Values
mheight, Models: Defined Values
mlesbian, Models: Defined Values
mmast, Models: Defined Values
modelheads, Standard Components Module: Reference
modelheadshot, Standard Components Module: Reference
models
activities values, Models: Defined Values
connection to sets, Connecting Sets And Models
Field Listing, Models: Schema SQL
mbuild values, Models: Defined Values
mcstatus values, Models: Defined Values
mflag values, Models: Defined Values
mpussy values, Models: Defined Values
mrace values, Models: Defined Values
mrating values, Models: Defined Values
mstatus values, Models: Defined Values
vital statistics fields, Models: Defined Values
modelsel.php, WACS and Web 2.0
Modules
Importing WACS API, A First WACS Program
mother, Models: Defined Values
mpussy, Models: Defined Values
mrace, Models: Defined Values
mrating, Models: Defined Values
msolo, Models: Defined Values
mstatus, Models: Defined Values
mstraight, Models: Defined Values
mtoys, Models: Defined Values
mvideos, Models: Defined Values
mvitbust, Models: Defined Values
mvithips, Models: Defined Values
mvitwaist, Models: Defined Values
mweight, Models: Defined Values
MySimple (Sample Program)
Perl Version Source Code, Putting It All Together
Php Version Source Code, Putting It All Together
Sample Run Output, Running MySimple
MySimple2 (Sample Program)
Sample Run Output, Adding Model Icons
MySimple3 (Sample Program)
Sample Run Output, Using HTML tables
MySimple4 (Sample Program)
Sample Run Output, Adding The Model Details
MySimple5 (Sample Program)
Sample Run Output, Adding Other Icons

N

notes
Field Listing, Notes: Schema SQL
ntype values, Notes: Defined Values
ntype, Notes: Defined Values

S

saspect, Sets: Defined Values
sauto, Sets: Defined Values
scatflag, Sets: Defined Values
serrors, Sets: Defined Values
SetDisp (Sample Program)
Sample Run Output, Sets: The Basic Bones
setdisp program, Sets: The Basic Bones
SetDisp2 (Sample Program)
Sample Run Output, Adding Icons
SetDisp3 (Sample Program)
Sample Run Output, Making The Text More Readable
SetDisp4 (Sample Program)
Sample Run Output, An Example Using Assoc
setgroupperms, Core Module: Reference
sets
connecting to models, Connecting Sets And Models
Field Listing, Sets: Schema SQL
introduction to displaying, About Set Display
saspect values, Sets: Defined Values
sattire recommended values, Sets: Defined Values
sauto values, Sets: Defined Values
scatflag values, Sets: Defined Values
serrors values, Sets: Defined Values
sformat values, Sets: Defined Values
sidlogo values, Sets: Defined Values
sinter, Sets: Defined Values
slocation recommended values, Sets: Defined Values
srating values, Sets: Defined Values
sstatus values, Sets: Defined Values
stechqual values, Sets: Defined Values
stype values, Sets: Defined Values
suscattr values, Sets: Defined Values
svariety values, Sets: Defined Values
sformat, Sets: Defined Values
sidlogo, Sets: Defined Values
sinter, Sets: Defined Values
Skins, Introduction To PHP Skins
slocation, Sets: Defined Values
SQL
Simple Example, A First WACS Program
srating, Sets: Defined Values
sstatus, Sets: Defined Values
stechqual, Sets: Defined Values
Structure of a WACS app, Outline
stype, Sets: Defined Values
suscattr, Sets: Defined Values
svariety, Sets: Defined Values

T

tag
Field Listing, Tag: Schema SQL
tflag values, Tag: Defined Values
tstatus values, Tag: Defined Values
text
Camel-Style, About Set Display
tflag, Tag: Defined Values
timecomps, Core Module: Reference
treemkdir, Core Module: Reference
tstatus, Tag: Defined Values

U

uclass, User: Defined Values
user
Field Listing, User: Schema SQL
uclass values, User: Defined Values
ustatus values, User: Defined Values
utype values, User: Defined Values
Using relationships, Connecting Sets And Models
ustatus, User: Defined Values
utype, User: Defined Values

W

WACS Core
addheadercss, Core Module: Reference
add_auth, Core Module: Reference
alsofeaturing, User Interface Module: Reference
auth_error, Core Module: Reference
auth_get_attr, Core Module: Reference
auth_user, Core Module: Reference
checkexclude, Core Module: Reference
checkindex, Core Module: Reference
check_auth, Core Module: Reference
conf_get_attr, Core Module: Reference
dberror, Core Module: Reference
divideup, Core Module: Reference
find_config_location, Core Module: Reference
geticonlist, Core Module: Reference
gettoday, Core Module: Reference
gettypecolour, Core Module: Reference
getvaluename, Core Module: Reference
makedbsafe, Core Module: Reference
read_conf, Core Module: Reference
setgroupperms, Core Module: Reference
timecomps, Core Module: Reference
treemkdir, Core Module: Reference
vendlink, Core Module: Reference
WACS Std
addassoc, Standard Components Module: Reference
alloc_nextkey, Standard Components Module: Reference
findmodel, Standard Components Module: Reference
findrecentmodels, Standard Components Module: Reference
findrecentsets, Standard Components Module: Reference
getgallery, Standard Components Module: Reference
kwscore_get, Standard Components Module: Reference
kwscore_process, Standard Components Module: Reference
kwscore_reset, Standard Components Module: Reference
masthead, Standard Components Module: Reference
modelheads, Standard Components Module: Reference
modelheadshot, Standard Components Module: Reference
removeconflicts, Standard Components Module: Reference
removedups, Standard Components Module: Reference
WACS UI
addkeyicons, User Interface Module: Reference
addlinks, User Interface Module: Reference
addratings, User Interface Module: Reference
describeher, User Interface Module: Reference
iconlink, User Interface Module: Reference
menu_get_body, User Interface Module: Reference
menu_get_default, User Interface Module: Reference
menu_get_entry, User Interface Module: Reference
menu_get_title, User Interface Module: Reference
read_menu, User Interface Module: Reference
whatshedoes, User Interface Module: Reference
Wacs-PHP
Skins, Introduction To PHP Skins
Styling The Simple Skin, Introduction To PHP Skins
The Simple Skin, Introduction To PHP Skins
WacsUI
addkeyicons, Introducing WacsUI
describeher, Introducing WacsUI
Including Support For..., Introducing WacsUI
Introduction To..., Introducing WacsUI
menu_get_handler, User Interface Module: Reference
whatshedoes, Introducing WacsUI
Web 2.0, WACS and Web 2.0
whatshedoes, User Interface Module: Reference
Using ..., Introducing WacsUI