Macros
Macros are a great way to enhance your workflow by adding custom logic/data processing to the input data provided by autobrr. Macros are currently supported by input fields by Filters, in two sections: Actions and External (filters).
Implementation
The template functionality is provided by the Go template engine. This is an extremely powerful scripting platform that can perform operations, evaluations, and manipulate values at the user configuration level. Further information on the functionality of this platform can be found on its official documentation page.
Autobrr enhances the Go template engine with Sprig template functions which provide the possibility for workflows involving more complex logic than initially provided by the Go template engine.
Please take note that Sprig has some of its own edge-cases:
Most of the [Sprig] regex functions are unfortunately significantly broken when it comes to using them in pipelines. By broken I mean the functions technically work, but their usage I don't think would be intuitive to anyone, and that usage is difficult.
Another intricate edge-case from which Sprig suffers from is that every RegEx directive containing a backslash has to be escaped twice. Put another way, what was once a single backslash, now becomes a double backslash. For example, \d
becomes \\d
.
Available functions
For the functions provided by the Go template engine, please reference its its official documentation page.
Available Sprig function, along with the relevant examples can be found at Pydio.com.
Available variables
Click to view supported variables
Variable | Type | Description |
---|---|---|
{{.Artists}} | string | Artists |
{{.Audio}} | []string | Audio codecs/formats array |
{{.AudioChannels}} | string | Audio channels configuration |
{{.AudioFormat}} | string | Audio format |
{{.Bitrate}} | string | Release bitrate |
{{.Bonus}} | []string | Bonus features array |
{{.Categories}} | []string | Categories |
{{.Category}} | string | Category |
{{.Codec}} | []string | Video codecs array |
{{.Container}} | string | Container format |
{{.CurrentDay}} | int | Current Day |
{{.CurrentHour}} | int | Current Hour |
{{.CurrentMinute}} | int | Current Minute |
{{.CurrentMonth}} | int | Current Month |
{{.CurrentSecond}} | int | Current Second |
{{.CurrentYear}} | int | Current Year |
{{.Day}} | int | Release day |
{{.Description}} | string | Release description |
{{.DownloadURL}} | string | Download URL |
{{.Episode}} | int | Parsed episode |
{{.FilterID}} | int | Filter identifier |
{{.FilterName}} | string | Filter name |
{{.Freeleech}} | bool | Freeleech status |
{{.FreeleechPercent}} | int | Freeleech percentage |
{{.Group}} | string | Release group |
{{.GroupID}} | string | GroupID |
{{.HasCue}} | bool | Has .cue file |
{{.HasLog}} | bool | Has log file |
{{.HDR}} | string | Parsed HDR (DV, HDR, HDR10) |
{{.Implementation}} | string | Implementation type |
{{.Indexer}} | string | Indexer identifier |
{{.IndexerIdentifier}} | string | Indexer identifier |
{{.IndexerIdentifierExternal}} | string | External indexer identifier |
{{.IndexerName}} | string | Indexer name |
{{.InfoUrl}} | string | Info URL |
{{.IsDuplicate}} | bool | Is duplicate release |
{{.Language}} | []string | Language array |
{{.Leechers}} | int | Number of leechers |
{{.LogScore}} | int | Log score for music releases |
{{.MagnetURI}} | string | Magnet link URI |
{{.MetaIMDB}} | string | IMDB ID |
{{.Month}} | int | Release month |
{{.Origin}} | string | Release origin |
{{.Other}} | []string | Other attributes array |
{{.PreTime}} | string | Pre time |
{{.Proper}} | bool | Is proper release |
{{.Protocol}} | string | Protocol type |
{{.RecordLabel}} | string | Record label |
{{.Region}} | string | Region information |
{{.Repack}} | bool | Is repack release |
{{.Resolution}} | string | Parsed resolution (1080p) |
{{.Season}} | int | Parsed season |
{{.Seeders}} | int | Number of seeders |
{{.Size}} | uint | Size (in bytes) |
{{.SizeString}} | string | SizeString (including unit string) |
{{.SkipDuplicateProfileID}} | int | Skip duplicate profile ID |
{{.SkipDuplicateProfileName}} | string | Skip duplicate profile name |
{{.Source}} | string | Parsed source (BluRay, WEB-DL) |
{{.Tags}} | string | Release tags (comma separated) |
{{.Title}} | string | Parsed title (That Movie) |
{{.TorrentDataRawBytes}} | []byte | Raw torrent file data |
{{.TorrentHash}} | string | Torrent hash |
{{.TorrentID}} | string | TorrentID |
{{.TorrentName}} | string | Release name as announced |
{{.TorrentPathName}} | string | Path to downloaded .torrent file in /tmp |
{{.TorrentTmpFile}} | string | Temporary torrent file path |
{{.TorrentUrl}} | string | Full url to download torrent |
{{.Type}} | string | Type e.g. episode |
{{.Uploader}} | string | Release uploader |
{{.Website}} | string | Website URL |
{{.Year}} | int | Parsed year |
Examples
Simple examples of this extensive functionality can be found below.
- Escape torrent name -
{{ .TorrentName | js }}
Dynamic categories in qBittorrent
Dynamic resolution for eg movies or tv. Very useful to keep things separated and easy to manage. With well-named releases this works great as a Plex library.
Category: movies-{{ .Resolution }}
= movies-1080p
, movies-2160p
Tags
Dynamic tags based on indexer, resolution or other
- Tags:
{{ .Indexer }}
=mockindexer
- Tags:
{{ .Resolution }}
=2160p
Dynamic date and time
Could be used to build dynamic save paths etc.
{{ .CurrentYear }}
{{ .CurrentMonth | printf "%02d"}}
Dynamic movie filter with hdr/dv
Category: movies-{{ .Resolution }}{{ if .HDR }}-{{ .HDR }}{{ end }}
Custom regex example
One user in our Discord wanted to have a custom watch folder for TV shows but without the episode in the name. The best solution we could find was to use... a bit of regex. It's not great, but it's not terrible either.
The relevant query is:
{{- $filename := (regexReplaceAll "(?i)(.*).torrent$" (osBase .TorrentPathName) "${1}") -}}
{{- $pattern := "([\\.\\s\\-\\(])([Ss]\\d+)[\\.\\s\\-]?([Ee]\\d+)?([\\.\\s\\-\\)])" -}}
{{- $repl := "${1}${2}${4}" -}}
{{- if ge (len .TorrentName) (len $filename) -}}
{{- regexReplaceAll $pattern .TorrentName $repl -}}
{{- else -}}
{{- regexReplaceAll $pattern $filename $repl -}}
{{- end -}}
Do note that the minus (-) signs here denote that the template bars are not allowed to emit/allow any whitespace before/after them (as would've been the case without the minus signs).