| 
									
										
										
										
											2013-11-04 06:06:11 -08:00
										 |  |  | python-ifupdown2
 | 
					
						
							|  |  |  | ================
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | This package is a replacement for the debian ifupdown package.
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | It is ifupdown re-written in python. It maintains the original ifupdown
 | 
					
						
							| 
									
										
										
										
											2013-11-04 06:06:11 -08:00
										 |  |  | pluggable architecture and extends it further.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | The python-ifupdown2 package provides the infrastructure for
 | 
					
						
							|  |  |  | parsing /etc/network/interfaces file, loading, scheduling and state
 | 
					
						
							|  |  |  | management of interfaces.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | It dynamically loads python modules from /usr/share/ifupdownmodules (provided
 | 
					
						
							|  |  |  |  by the python-ifupdown2-addons package). To remain compatible with other
 | 
					
						
							|  |  |  | packages that depend on ifupdown, it also executes scripts under /etc/network/.
 | 
					
						
							|  |  |  | To make the transition smoother, a python module under
 | 
					
						
							|  |  |  | /usr/share/ifupdownmodules will override a script by the same name under
 | 
					
						
							|  |  |  | /etc/network/.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | It publishes an interface object which is passed to all loadble python
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | modules. For more details on adding a addon module, see the section on
 | 
					
						
							|  |  |  | adding python modules.
 | 
					
						
							| 
									
										
										
										
											2013-11-04 06:06:11 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | pluggable python modules:
 | 
					
						
							|  |  |  | =========================
 | 
					
						
							|  |  |  | Unlike original ifupdown, all interface configuration is moved to external
 | 
					
						
							|  |  |  | python modules. That includes inet, inet6 and dhcp configurations.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | A set of default modules are provided by the python-ifupdown2-addons deb.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | python-ifupdown2 expects a few things from the pluggable modules:
 | 
					
						
							| 
									
										
										
										
											2013-11-04 06:06:11 -08:00
										 |  |  | - the module should implement a class by the same name
 | 
					
						
							|  |  |  | - the interface object (class iface) and the operation to be performed is
 | 
					
						
							|  |  |  |   passed to the modules
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | - the python addon class should provide a few methods:
 | 
					
						
							| 
									
										
										
										
											2013-11-04 06:06:11 -08:00
										 |  |  | 	- run() : method to configure the interface.
 | 
					
						
							|  |  |  | 	- get_ops() : must return a list of operations it supports.
 | 
					
						
							|  |  |  | 		eg: 'pre-up', 'post-down'
 | 
					
						
							|  |  |  | 	- get_dependent_ifacenames() : must return a list of interfaces the
 | 
					
						
							|  |  |  | 	  interface is dependent on. This is used to build the dependency list
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | 	  for sorting and executing interfaces in dependency order.
 | 
					
						
							|  |  |  | 	- if the module supports -r option to ifquery, ie ability to construct the
 | 
					
						
							|  |  |  |       ifaceobj from running state, it can optionally implement the
 | 
					
						
							|  |  |  |       get_dependent_ifacenames_running() method, to return the list of
 | 
					
						
							|  |  |  |       dependent interfaces derived from running state of the interface.
 | 
					
						
							|  |  |  |       This is different from get_dependent_ifacenames() where the dependent
 | 
					
						
							|  |  |  |       interfaces are derived from the interfaces config file (provided by the
 | 
					
						
							|  |  |  |       user).
 | 
					
						
							| 
									
										
										
										
											2013-11-10 22:35:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | Example: Address handling module /usr/share/ifupdownaddons/address.py
 | 
					
						
							| 
									
										
										
										
											2013-11-10 22:35:40 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | build
 | 
					
						
							|  |  |  | =====
 | 
					
						
							|  |  |  | - get source
 | 
					
						
							| 
									
										
										
										
											2013-11-10 22:35:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | - install build dependencies:
 | 
					
						
							|  |  |  |     apt-get install python-stdeb
 | 
					
						
							|  |  |  |     apt-get install python-docutils
 | 
					
						
							| 
									
										
										
										
											2013-11-10 22:35:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | - cd <python-ifupdown2 sourcedir> && ./build.sh
 | 
					
						
							| 
									
										
										
										
											2013-11-10 22:35:40 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  |   (generates python-ifupdown2-<ver>.deb)
 | 
					
						
							| 
									
										
										
										
											2014-01-16 06:46:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | install
 | 
					
						
							|  |  |  | =======
 | 
					
						
							| 
									
										
										
										
											2014-01-16 06:46:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | - remove existing ifupdown package
 | 
					
						
							|  |  |  |   dpkg -r ifupdown
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - install python-ifupdown2 using `dpkg -i`
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - or install from deb
 | 
					
						
							|  |  |  |     dpkg -i python-ifupdown2-<ver>.deb
 | 
					
						
							| 
									
										
										
										
											2014-01-16 06:46:17 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-07-17 11:44:36 -07:00
										 |  |  | - note that python-ifupdown2 requires python-ifupdown2-addons package to
 | 
					
						
							|  |  |  |   function. And python-ifupdown2-addons deb has an install dependency on
 | 
					
						
							|  |  |  |   python-ifupdown2
 |