Skip to main content

Database functionality for falocalrepo.

Reason this release was yanked:

Bug in update function causes it lock up

Project description

logo

FALocalRepo-Database

Database functionality for falocalrepo.

Tables

To store its information, the database uses separate tables: USERS, SUBMISSIONS, JOURNALS, SETTINGS, and HISTORY.

Note: bar-separated lists are formatted as |item1||item2| to properly isolate all elements

Users

The users' table contains a list of all the users that have been download with the program, the folders that have been downloaded, and the submissions found in each of those.

Each entry contains the following fields:

  • USERNAME the URL username of the user (no underscores or spaces)
  • FOLDERS the folders downloaded for that specific user, sorted and bar-separated
  • ACTIVE 1 if the user is active, 0 if not
  • USERPAGE the user's profile in HTML or BBCode format

Submissions

The submissions' table contains the metadata of the submissions downloaded by the program and information on their files

  • ID the id of the submission
  • AUTHOR the username of the author (uploader) in full format
  • TITLE
  • DATE upload date in ISO format YYYY-MM-DDTHH:MM
  • DESCRIPTION description in HTML or BBCode format
  • FOOTER footer in HTML or BBCode format
  • TAGS bar-separated tags
  • CATEGORY
  • SPECIES
  • GENDER
  • RATING
  • TYPE image, text, music, or flash
  • FILEURL a bar-separated list of the remote URLs for the submission files
  • FILEEXT a bar-separated list of extensions of the downloaded files. Can be empty if the file contained errors and could not be recognised upon download
  • FILESAVED file and thumbnail download status as a 3bit flag:xx1 if thumbnail was downloaded, xx0 if not; x1x if at least one file was valid x0x if not; 1xx if all given files where valid, 0xx if not. Possible values are 0 through 7 (3 bit).
  • FAVORITE a bar-separated list of users that have "faved" the submission
  • MENTIONS a bar-separated list of users that are mentioned in the submission description as links
  • FOLDER the folder of the submission (gallery or scraps)
  • USERUPDATE 1 if the submission was added as a user update otherwise 0

Journals

The journals' table contains the metadata of the journals downloaded by the program.

  • ID the id of the journal
  • AUTHOR the username of the author (uploader) in full format
  • TITLE
  • DATE upload date in ISO format YYYY-MM-DDTHH:MM
  • CONTENT content in HTML or BBCode format
  • HEADER header in HTML or BBCode format
  • FOOTER footer in HTML or BBCode format
  • MENTIONS a bar-separated list of users that are mentioned in the journal content as links
  • USERUPDATE 1 if the journal was added as a user update otherwise 0

Comments

The comments' table contains the metadata of the journals and submissions stored in the database.

  • ID the id of the comment
  • PARENT_TABLE SUBMISSIONS if the comment relates to a submission, JOURNAL if the comment relates to a journal
  • PARENT_ID the id of the parent object (submission or journal)
  • REPLY_TO the id of the parent comment, if the comment is a reply
  • AUTHOR the username of the author in full format
  • DATE post date in ISO format YYYY-MM-DDTHH:MM:SS
  • TEXT the text of the comment

Settings

The settings table contains settings for the program and variable used by the database handler and main program.

  • COOKIES cookies for the download program, stored in JSON format
  • FILESFOLDER location of downloaded submission files
  • VERSION database version

History

The history table holds events related to the database.

  • TIME event time in ISO format YYYY-MM-DDTHH:MM:SS.ssssss
  • EVENT the event description

Submission Files

The save_submission functions saves the submission metadata in the database and stores the files.

Submission files are saved in a tiered tree structure based on their submission ID. IDs are zero-padded to 10 digits and then broken up in 5 segments of 2 digits; each of these segments represents a folder tha will be created in the tree.

For example, a submission 1457893 will be padded to 0001457893 and divided into 00, 01, 45, 78, 93. The submission file will then be saved as 00/01/45/78/93/submission.file with the correct extension extracted from the file itself (FurAffinity links do not always contain the right extension and sometimes confuse JPEG and PNG).

Upgrading Database

Note: versions prior to 4.19.0 are not supported by falocalrepo-database version 5.0.0 and above. To update from those, use falocalrepo v3.25.0 to upgrade the database to version 4.19.0.
Note: Versions prior to 2.7.0 are not supported by falocalrepo-database version 3.0.0 and above. To update from those to the new version use falocalrepo v2.11.2 to upgrade the database to version 2.7.0

Project details


Release history Release notifications | RSS feed

Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

falocalrepo-database-5.4.1.tar.gz (26.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

falocalrepo_database-5.4.1-py3-none-any.whl (27.2 kB view details)

Uploaded Python 3

File details

Details for the file falocalrepo-database-5.4.1.tar.gz.

File metadata

  • Download URL: falocalrepo-database-5.4.1.tar.gz
  • Upload date:
  • Size: 26.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.1 Linux/5.15.0-1019-azure

File hashes

Hashes for falocalrepo-database-5.4.1.tar.gz
Algorithm Hash digest
SHA256 acb9ae74597457094762e9e25489f53db910b984d949951adfb47fbe22445778
MD5 aeac54bdd27306ac0d0b15b05572d017
BLAKE2b-256 7d9db237879cfb9244ea487929852c13e2c7ac7bba62d0a5e7c6a83306b52f5f

See more details on using hashes here.

File details

Details for the file falocalrepo_database-5.4.1-py3-none-any.whl.

File metadata

  • Download URL: falocalrepo_database-5.4.1-py3-none-any.whl
  • Upload date:
  • Size: 27.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.1 Linux/5.15.0-1019-azure

File hashes

Hashes for falocalrepo_database-5.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 2edd1e0ededb922901700abcb43ec25223d4f11554f0ed66598bedad6af0ee9c
MD5 7adba3b594d6226afed4fb403b8eb0ee
BLAKE2b-256 387dbe772809fdd8de7b2aefb6fc3c746b9f07b8642521aea2ef2f4450eb6085

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page