File: affiliatelinks.py

package info (click to toggle)
buskill 0.7.0-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 30,984 kB
  • sloc: python: 3,187; sh: 85; makefile: 22; javascript: 9
file content (66 lines) | stat: -rw-r--r-- 1,854 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
"""
::

  File:    affiliatelinks.py
  Authors: Michael Altfield <michael@buskill.in>
  Created: 2020-07-28
  Updated: 2020-07-28
  Version: 0.1

This sphinx extension takes a list of links and builds targets from those links
depending on the buildername. If the buildername is 'html', it will use our
affiliate links. Otherwise, the target will use the fallback link.

This is important because amazon affiliates don't permit offline material to
include affiliate links, so we need to make sure that our pdf, epub, etc just
link to our online documentation and not directly to our affiliate's products.

For more info, see: https://buskill.in/
"""
from docutils import nodes
from docutils.parsers.rst import Directive

from sphinx.locale import _
from sphinx.util.docutils import SphinxDirective

class AffiliateLinks(SphinxDirective):

	has_content = True

	def run(self):

		# generate a list of targets for each line in the body passed to us
		target_nodes = list()
		for target in self.content:

			# skip empty lines
			if target == '':
				continue

			target_node = nodes.target( '', '' )
			target_nodes.append( target_node )

			# split this line up into space-separated fields
			affiliateUri,fallbackUri,name = target.split()

			# the name of the target is what it will be referenced by in .rst
			# files (eg: `some hyperlink custom text`targetname_ )
			target_node['names'] = [name]

			# only use the affiliate link if we're building html
			# use the fall-back URI if we're building to anything else, such as pdf
			if self.env.config.buildername == 'html':
				target_node['refuri'] = affiliateUri
			else:
				target_node['refuri'] = fallbackUri

		return target_nodes

def setup(app):
	app.add_directive("affiliatelinks", AffiliateLinks)

	return {
		'version': '0.1',
		'parallel_read_safe': True,
		'parallel_write_safe': True,
	}