From 6184d4845dabdf7844cea4faa2b0eb88c3c0cee8 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 12 Nov 2021 13:03:00 +0100 Subject: [PATCH 01/43] Initial commit --- LICENSE | 661 ++++++++++++++++++++++++++++++++++++++++++++++++++++++ README.md | 2 + 2 files changed, 663 insertions(+) create mode 100644 LICENSE create mode 100644 README.md diff --git a/LICENSE b/LICENSE new file mode 100644 index 00000000..0ad25db4 --- /dev/null +++ b/LICENSE @@ -0,0 +1,661 @@ + GNU AFFERO GENERAL PUBLIC LICENSE + Version 3, 19 November 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. + Everyone is permitted to copy and distribute verbatim copies + of this license document, but changing it is not allowed. + + Preamble + + The GNU Affero General Public License is a free, copyleft license for +software and other kinds of works, specifically designed to ensure +cooperation with the community in the case of network server software. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +our General Public Licenses are intended to guarantee your freedom to +share and change all versions of a program--to make sure it remains free +software for all its users. + + When we speak of free software, we are referring to freedom, not +price. Our General Public Licenses are designed to make sure that you +have the freedom to distribute copies of free software (and charge for +them if you wish), that you receive source code or can get it if you +want it, that you can change the software or use pieces of it in new +free programs, and that you know you can do these things. + + Developers that use our General Public Licenses protect your rights +with two steps: (1) assert copyright on the software, and (2) offer +you this License which gives you legal permission to copy, distribute +and/or modify the software. + + A secondary benefit of defending all users' freedom is that +improvements made in alternate versions of the program, if they +receive widespread use, become available for other developers to +incorporate. Many developers of free software are heartened and +encouraged by the resulting cooperation. However, in the case of +software used on network servers, this result may fail to come about. +The GNU General Public License permits making a modified version and +letting the public access it on a server without ever releasing its +source code to the public. + + The GNU Affero General Public License is designed specifically to +ensure that, in such cases, the modified source code becomes available +to the community. It requires the operator of a network server to +provide the source code of the modified version running there to the +users of that server. Therefore, public use of a modified version, on +a publicly accessible server, gives the public access to the source +code of the modified version. + + An older license, called the Affero General Public License and +published by Affero, was designed to accomplish similar goals. This is +a different license, not a version of the Affero GPL, but Affero has +released a new version of the Affero GPL which permits relicensing under +this license. + + The precise terms and conditions for copying, distribution and +modification follow. + + TERMS AND CONDITIONS + + 0. Definitions. + + "This License" refers to version 3 of the GNU Affero General Public License. + + "Copyright" also means copyright-like laws that apply to other kinds of +works, such as semiconductor masks. + + "The Program" refers to any copyrightable work licensed under this +License. Each licensee is addressed as "you". "Licensees" and +"recipients" may be individuals or organizations. + + To "modify" a work means to copy from or adapt all or part of the work +in a fashion requiring copyright permission, other than the making of an +exact copy. The resulting work is called a "modified version" of the +earlier work or a work "based on" the earlier work. + + A "covered work" means either the unmodified Program or a work based +on the Program. + + To "propagate" a work means to do anything with it that, without +permission, would make you directly or secondarily liable for +infringement under applicable copyright law, except executing it on a +computer or modifying a private copy. Propagation includes copying, +distribution (with or without modification), making available to the +public, and in some countries other activities as well. + + To "convey" a work means any kind of propagation that enables other +parties to make or receive copies. Mere interaction with a user through +a computer network, with no transfer of a copy, is not conveying. + + An interactive user interface displays "Appropriate Legal Notices" +to the extent that it includes a convenient and prominently visible +feature that (1) displays an appropriate copyright notice, and (2) +tells the user that there is no warranty for the work (except to the +extent that warranties are provided), that licensees may convey the +work under this License, and how to view a copy of this License. If +the interface presents a list of user commands or options, such as a +menu, a prominent item in the list meets this criterion. + + 1. Source Code. + + The "source code" for a work means the preferred form of the work +for making modifications to it. "Object code" means any non-source +form of a work. + + A "Standard Interface" means an interface that either is an official +standard defined by a recognized standards body, or, in the case of +interfaces specified for a particular programming language, one that +is widely used among developers working in that language. + + The "System Libraries" of an executable work include anything, other +than the work as a whole, that (a) is included in the normal form of +packaging a Major Component, but which is not part of that Major +Component, and (b) serves only to enable use of the work with that +Major Component, or to implement a Standard Interface for which an +implementation is available to the public in source code form. A +"Major Component", in this context, means a major essential component +(kernel, window system, and so on) of the specific operating system +(if any) on which the executable work runs, or a compiler used to +produce the work, or an object code interpreter used to run it. + + The "Corresponding Source" for a work in object code form means all +the source code needed to generate, install, and (for an executable +work) run the object code and to modify the work, including scripts to +control those activities. However, it does not include the work's +System Libraries, or general-purpose tools or generally available free +programs which are used unmodified in performing those activities but +which are not part of the work. For example, Corresponding Source +includes interface definition files associated with source files for +the work, and the source code for shared libraries and dynamically +linked subprograms that the work is specifically designed to require, +such as by intimate data communication or control flow between those +subprograms and other parts of the work. + + The Corresponding Source need not include anything that users +can regenerate automatically from other parts of the Corresponding +Source. + + The Corresponding Source for a work in source code form is that +same work. + + 2. Basic Permissions. + + All rights granted under this License are granted for the term of +copyright on the Program, and are irrevocable provided the stated +conditions are met. This License explicitly affirms your unlimited +permission to run the unmodified Program. The output from running a +covered work is covered by this License only if the output, given its +content, constitutes a covered work. This License acknowledges your +rights of fair use or other equivalent, as provided by copyright law. + + You may make, run and propagate covered works that you do not +convey, without conditions so long as your license otherwise remains +in force. You may convey covered works to others for the sole purpose +of having them make modifications exclusively for you, or provide you +with facilities for running those works, provided that you comply with +the terms of this License in conveying all material for which you do +not control copyright. Those thus making or running the covered works +for you must do so exclusively on your behalf, under your direction +and control, on terms that prohibit them from making any copies of +your copyrighted material outside their relationship with you. + + Conveying under any other circumstances is permitted solely under +the conditions stated below. Sublicensing is not allowed; section 10 +makes it unnecessary. + + 3. Protecting Users' Legal Rights From Anti-Circumvention Law. + + No covered work shall be deemed part of an effective technological +measure under any applicable law fulfilling obligations under article +11 of the WIPO copyright treaty adopted on 20 December 1996, or +similar laws prohibiting or restricting circumvention of such +measures. + + When you convey a covered work, you waive any legal power to forbid +circumvention of technological measures to the extent such circumvention +is effected by exercising rights under this License with respect to +the covered work, and you disclaim any intention to limit operation or +modification of the work as a means of enforcing, against the work's +users, your or third parties' legal rights to forbid circumvention of +technological measures. + + 4. Conveying Verbatim Copies. + + You may convey verbatim copies of the Program's source code as you +receive it, in any medium, provided that you conspicuously and +appropriately publish on each copy an appropriate copyright notice; +keep intact all notices stating that this License and any +non-permissive terms added in accord with section 7 apply to the code; +keep intact all notices of the absence of any warranty; and give all +recipients a copy of this License along with the Program. + + You may charge any price or no price for each copy that you convey, +and you may offer support or warranty protection for a fee. + + 5. Conveying Modified Source Versions. + + You may convey a work based on the Program, or the modifications to +produce it from the Program, in the form of source code under the +terms of section 4, provided that you also meet all of these conditions: + + a) The work must carry prominent notices stating that you modified + it, and giving a relevant date. + + b) The work must carry prominent notices stating that it is + released under this License and any conditions added under section + 7. This requirement modifies the requirement in section 4 to + "keep intact all notices". + + c) You must license the entire work, as a whole, under this + License to anyone who comes into possession of a copy. This + License will therefore apply, along with any applicable section 7 + additional terms, to the whole of the work, and all its parts, + regardless of how they are packaged. This License gives no + permission to license the work in any other way, but it does not + invalidate such permission if you have separately received it. + + d) If the work has interactive user interfaces, each must display + Appropriate Legal Notices; however, if the Program has interactive + interfaces that do not display Appropriate Legal Notices, your + work need not make them do so. + + A compilation of a covered work with other separate and independent +works, which are not by their nature extensions of the covered work, +and which are not combined with it such as to form a larger program, +in or on a volume of a storage or distribution medium, is called an +"aggregate" if the compilation and its resulting copyright are not +used to limit the access or legal rights of the compilation's users +beyond what the individual works permit. Inclusion of a covered work +in an aggregate does not cause this License to apply to the other +parts of the aggregate. + + 6. Conveying Non-Source Forms. + + You may convey a covered work in object code form under the terms +of sections 4 and 5, provided that you also convey the +machine-readable Corresponding Source under the terms of this License, +in one of these ways: + + a) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by the + Corresponding Source fixed on a durable physical medium + customarily used for software interchange. + + b) Convey the object code in, or embodied in, a physical product + (including a physical distribution medium), accompanied by a + written offer, valid for at least three years and valid for as + long as you offer spare parts or customer support for that product + model, to give anyone who possesses the object code either (1) a + copy of the Corresponding Source for all the software in the + product that is covered by this License, on a durable physical + medium customarily used for software interchange, for a price no + more than your reasonable cost of physically performing this + conveying of source, or (2) access to copy the + Corresponding Source from a network server at no charge. + + c) Convey individual copies of the object code with a copy of the + written offer to provide the Corresponding Source. This + alternative is allowed only occasionally and noncommercially, and + only if you received the object code with such an offer, in accord + with subsection 6b. + + d) Convey the object code by offering access from a designated + place (gratis or for a charge), and offer equivalent access to the + Corresponding Source in the same way through the same place at no + further charge. You need not require recipients to copy the + Corresponding Source along with the object code. If the place to + copy the object code is a network server, the Corresponding Source + may be on a different server (operated by you or a third party) + that supports equivalent copying facilities, provided you maintain + clear directions next to the object code saying where to find the + Corresponding Source. Regardless of what server hosts the + Corresponding Source, you remain obligated to ensure that it is + available for as long as needed to satisfy these requirements. + + e) Convey the object code using peer-to-peer transmission, provided + you inform other peers where the object code and Corresponding + Source of the work are being offered to the general public at no + charge under subsection 6d. + + A separable portion of the object code, whose source code is excluded +from the Corresponding Source as a System Library, need not be +included in conveying the object code work. + + A "User Product" is either (1) a "consumer product", which means any +tangible personal property which is normally used for personal, family, +or household purposes, or (2) anything designed or sold for incorporation +into a dwelling. In determining whether a product is a consumer product, +doubtful cases shall be resolved in favor of coverage. For a particular +product received by a particular user, "normally used" refers to a +typical or common use of that class of product, regardless of the status +of the particular user or of the way in which the particular user +actually uses, or expects or is expected to use, the product. A product +is a consumer product regardless of whether the product has substantial +commercial, industrial or non-consumer uses, unless such uses represent +the only significant mode of use of the product. + + "Installation Information" for a User Product means any methods, +procedures, authorization keys, or other information required to install +and execute modified versions of a covered work in that User Product from +a modified version of its Corresponding Source. The information must +suffice to ensure that the continued functioning of the modified object +code is in no case prevented or interfered with solely because +modification has been made. + + If you convey an object code work under this section in, or with, or +specifically for use in, a User Product, and the conveying occurs as +part of a transaction in which the right of possession and use of the +User Product is transferred to the recipient in perpetuity or for a +fixed term (regardless of how the transaction is characterized), the +Corresponding Source conveyed under this section must be accompanied +by the Installation Information. But this requirement does not apply +if neither you nor any third party retains the ability to install +modified object code on the User Product (for example, the work has +been installed in ROM). + + The requirement to provide Installation Information does not include a +requirement to continue to provide support service, warranty, or updates +for a work that has been modified or installed by the recipient, or for +the User Product in which it has been modified or installed. Access to a +network may be denied when the modification itself materially and +adversely affects the operation of the network or violates the rules and +protocols for communication across the network. + + Corresponding Source conveyed, and Installation Information provided, +in accord with this section must be in a format that is publicly +documented (and with an implementation available to the public in +source code form), and must require no special password or key for +unpacking, reading or copying. + + 7. Additional Terms. + + "Additional permissions" are terms that supplement the terms of this +License by making exceptions from one or more of its conditions. +Additional permissions that are applicable to the entire Program shall +be treated as though they were included in this License, to the extent +that they are valid under applicable law. If additional permissions +apply only to part of the Program, that part may be used separately +under those permissions, but the entire Program remains governed by +this License without regard to the additional permissions. + + When you convey a copy of a covered work, you may at your option +remove any additional permissions from that copy, or from any part of +it. (Additional permissions may be written to require their own +removal in certain cases when you modify the work.) You may place +additional permissions on material, added by you to a covered work, +for which you have or can give appropriate copyright permission. + + Notwithstanding any other provision of this License, for material you +add to a covered work, you may (if authorized by the copyright holders of +that material) supplement the terms of this License with terms: + + a) Disclaiming warranty or limiting liability differently from the + terms of sections 15 and 16 of this License; or + + b) Requiring preservation of specified reasonable legal notices or + author attributions in that material or in the Appropriate Legal + Notices displayed by works containing it; or + + c) Prohibiting misrepresentation of the origin of that material, or + requiring that modified versions of such material be marked in + reasonable ways as different from the original version; or + + d) Limiting the use for publicity purposes of names of licensors or + authors of the material; or + + e) Declining to grant rights under trademark law for use of some + trade names, trademarks, or service marks; or + + f) Requiring indemnification of licensors and authors of that + material by anyone who conveys the material (or modified versions of + it) with contractual assumptions of liability to the recipient, for + any liability that these contractual assumptions directly impose on + those licensors and authors. + + All other non-permissive additional terms are considered "further +restrictions" within the meaning of section 10. If the Program as you +received it, or any part of it, contains a notice stating that it is +governed by this License along with a term that is a further +restriction, you may remove that term. If a license document contains +a further restriction but permits relicensing or conveying under this +License, you may add to a covered work material governed by the terms +of that license document, provided that the further restriction does +not survive such relicensing or conveying. + + If you add terms to a covered work in accord with this section, you +must place, in the relevant source files, a statement of the +additional terms that apply to those files, or a notice indicating +where to find the applicable terms. + + Additional terms, permissive or non-permissive, may be stated in the +form of a separately written license, or stated as exceptions; +the above requirements apply either way. + + 8. Termination. + + You may not propagate or modify a covered work except as expressly +provided under this License. Any attempt otherwise to propagate or +modify it is void, and will automatically terminate your rights under +this License (including any patent licenses granted under the third +paragraph of section 11). + + However, if you cease all violation of this License, then your +license from a particular copyright holder is reinstated (a) +provisionally, unless and until the copyright holder explicitly and +finally terminates your license, and (b) permanently, if the copyright +holder fails to notify you of the violation by some reasonable means +prior to 60 days after the cessation. + + Moreover, your license from a particular copyright holder is +reinstated permanently if the copyright holder notifies you of the +violation by some reasonable means, this is the first time you have +received notice of violation of this License (for any work) from that +copyright holder, and you cure the violation prior to 30 days after +your receipt of the notice. + + Termination of your rights under this section does not terminate the +licenses of parties who have received copies or rights from you under +this License. If your rights have been terminated and not permanently +reinstated, you do not qualify to receive new licenses for the same +material under section 10. + + 9. Acceptance Not Required for Having Copies. + + You are not required to accept this License in order to receive or +run a copy of the Program. Ancillary propagation of a covered work +occurring solely as a consequence of using peer-to-peer transmission +to receive a copy likewise does not require acceptance. However, +nothing other than this License grants you permission to propagate or +modify any covered work. These actions infringe copyright if you do +not accept this License. Therefore, by modifying or propagating a +covered work, you indicate your acceptance of this License to do so. + + 10. Automatic Licensing of Downstream Recipients. + + Each time you convey a covered work, the recipient automatically +receives a license from the original licensors, to run, modify and +propagate that work, subject to this License. You are not responsible +for enforcing compliance by third parties with this License. + + An "entity transaction" is a transaction transferring control of an +organization, or substantially all assets of one, or subdividing an +organization, or merging organizations. If propagation of a covered +work results from an entity transaction, each party to that +transaction who receives a copy of the work also receives whatever +licenses to the work the party's predecessor in interest had or could +give under the previous paragraph, plus a right to possession of the +Corresponding Source of the work from the predecessor in interest, if +the predecessor has it or can get it with reasonable efforts. + + You may not impose any further restrictions on the exercise of the +rights granted or affirmed under this License. For example, you may +not impose a license fee, royalty, or other charge for exercise of +rights granted under this License, and you may not initiate litigation +(including a cross-claim or counterclaim in a lawsuit) alleging that +any patent claim is infringed by making, using, selling, offering for +sale, or importing the Program or any portion of it. + + 11. Patents. + + A "contributor" is a copyright holder who authorizes use under this +License of the Program or a work on which the Program is based. The +work thus licensed is called the contributor's "contributor version". + + A contributor's "essential patent claims" are all patent claims +owned or controlled by the contributor, whether already acquired or +hereafter acquired, that would be infringed by some manner, permitted +by this License, of making, using, or selling its contributor version, +but do not include claims that would be infringed only as a +consequence of further modification of the contributor version. For +purposes of this definition, "control" includes the right to grant +patent sublicenses in a manner consistent with the requirements of +this License. + + Each contributor grants you a non-exclusive, worldwide, royalty-free +patent license under the contributor's essential patent claims, to +make, use, sell, offer for sale, import and otherwise run, modify and +propagate the contents of its contributor version. + + In the following three paragraphs, a "patent license" is any express +agreement or commitment, however denominated, not to enforce a patent +(such as an express permission to practice a patent or covenant not to +sue for patent infringement). To "grant" such a patent license to a +party means to make such an agreement or commitment not to enforce a +patent against the party. + + If you convey a covered work, knowingly relying on a patent license, +and the Corresponding Source of the work is not available for anyone +to copy, free of charge and under the terms of this License, through a +publicly available network server or other readily accessible means, +then you must either (1) cause the Corresponding Source to be so +available, or (2) arrange to deprive yourself of the benefit of the +patent license for this particular work, or (3) arrange, in a manner +consistent with the requirements of this License, to extend the patent +license to downstream recipients. "Knowingly relying" means you have +actual knowledge that, but for the patent license, your conveying the +covered work in a country, or your recipient's use of the covered work +in a country, would infringe one or more identifiable patents in that +country that you have reason to believe are valid. + + If, pursuant to or in connection with a single transaction or +arrangement, you convey, or propagate by procuring conveyance of, a +covered work, and grant a patent license to some of the parties +receiving the covered work authorizing them to use, propagate, modify +or convey a specific copy of the covered work, then the patent license +you grant is automatically extended to all recipients of the covered +work and works based on it. + + A patent license is "discriminatory" if it does not include within +the scope of its coverage, prohibits the exercise of, or is +conditioned on the non-exercise of one or more of the rights that are +specifically granted under this License. You may not convey a covered +work if you are a party to an arrangement with a third party that is +in the business of distributing software, under which you make payment +to the third party based on the extent of your activity of conveying +the work, and under which the third party grants, to any of the +parties who would receive the covered work from you, a discriminatory +patent license (a) in connection with copies of the covered work +conveyed by you (or copies made from those copies), or (b) primarily +for and in connection with specific products or compilations that +contain the covered work, unless you entered into that arrangement, +or that patent license was granted, prior to 28 March 2007. + + Nothing in this License shall be construed as excluding or limiting +any implied license or other defenses to infringement that may +otherwise be available to you under applicable patent law. + + 12. No Surrender of Others' Freedom. + + If conditions are imposed on you (whether by court order, agreement or +otherwise) that contradict the conditions of this License, they do not +excuse you from the conditions of this License. If you cannot convey a +covered work so as to satisfy simultaneously your obligations under this +License and any other pertinent obligations, then as a consequence you may +not convey it at all. For example, if you agree to terms that obligate you +to collect a royalty for further conveying from those to whom you convey +the Program, the only way you could satisfy both those terms and this +License would be to refrain entirely from conveying the Program. + + 13. Remote Network Interaction; Use with the GNU General Public License. + + Notwithstanding any other provision of this License, if you modify the +Program, your modified version must prominently offer all users +interacting with it remotely through a computer network (if your version +supports such interaction) an opportunity to receive the Corresponding +Source of your version by providing access to the Corresponding Source +from a network server at no charge, through some standard or customary +means of facilitating copying of software. This Corresponding Source +shall include the Corresponding Source for any work covered by version 3 +of the GNU General Public License that is incorporated pursuant to the +following paragraph. + + Notwithstanding any other provision of this License, you have +permission to link or combine any covered work with a work licensed +under version 3 of the GNU General Public License into a single +combined work, and to convey the resulting work. The terms of this +License will continue to apply to the part which is the covered work, +but the work with which it is combined will remain governed by version +3 of the GNU General Public License. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU Affero General Public License from time to time. Such new versions +will be similar in spirit to the present version, but may differ in detail to +address new problems or concerns. + + Each version is given a distinguishing version number. If the +Program specifies that a certain numbered version of the GNU Affero General +Public License "or any later version" applies to it, you have the +option of following the terms and conditions either of that numbered +version or of any later version published by the Free Software +Foundation. If the Program does not specify a version number of the +GNU Affero General Public License, you may choose any version ever published +by the Free Software Foundation. + + If the Program specifies that a proxy can decide which future +versions of the GNU Affero General Public License can be used, that proxy's +public statement of acceptance of a version permanently authorizes you +to choose that version for the Program. + + Later license versions may give you additional or different +permissions. However, no additional obligations are imposed on any +author or copyright holder as a result of your choosing to follow a +later version. + + 15. Disclaimer of Warranty. + + THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY +APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT +HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY +OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, +THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR +PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM +IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF +ALL NECESSARY SERVICING, REPAIR OR CORRECTION. + + 16. Limitation of Liability. + + IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING +WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS +THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY +GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE +USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF +DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD +PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), +EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF +SUCH DAMAGES. + + 17. Interpretation of Sections 15 and 16. + + If the disclaimer of warranty and limitation of liability provided +above cannot be given local legal effect according to their terms, +reviewing courts shall apply local law that most closely approximates +an absolute waiver of all civil liability in connection with the +Program, unless a warranty or assumption of liability accompanies a +copy of the Program in return for a fee. + + END OF TERMS AND CONDITIONS + + How to Apply These Terms to Your New Programs + + If you develop a new program, and you want it to be of the greatest +possible use to the public, the best way to achieve this is to make it +free software which everyone can redistribute and change under these terms. + + To do so, attach the following notices to the program. It is safest +to attach them to the start of each source file to most effectively +state the exclusion of warranty; and each file should have at least +the "copyright" line and a pointer to where the full notice is found. + + + Copyright (C) + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU Affero General Public License as published + by the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU Affero General Public License for more details. + + You should have received a copy of the GNU Affero General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If your software can interact with users remotely through a computer +network, you should also make sure that it provides a way for users to +get its source. For example, if your program is a web application, its +interface could display a "Source" link that leads users to an archive +of the code. There are many ways you could offer source, and different +solutions will be better for different programs; see section 13 for the +specific requirements. + + You should also get your employer (if you work as a programmer) or school, +if any, to sign a "copyright disclaimer" for the program, if necessary. +For more information on this, and how to apply and follow the GNU AGPL, see +. diff --git a/README.md b/README.md new file mode 100644 index 00000000..e8f239cd --- /dev/null +++ b/README.md @@ -0,0 +1,2 @@ +# client-playbook +Playbook to setup clients From 02e1cab5cf117eff9c0bba6ed0a41f950fe8dbe5 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 12 Nov 2021 16:23:58 +0100 Subject: [PATCH 02/43] added draft --- README.md | 9 +++++++-- playbook.yml | 5 +++++ roles/native-pacman-update/tasks/main.yml | 4 ++++ 3 files changed, 16 insertions(+), 2 deletions(-) create mode 100644 playbook.yml create mode 100644 roles/native-pacman-update/tasks/main.yml diff --git a/README.md b/README.md index e8f239cd..900461d2 100644 --- a/README.md +++ b/README.md @@ -1,2 +1,7 @@ -# client-playbook -Playbook to setup clients +# Client Playbook +Playbook to setup Manjaro GNOME clients. +# Todo +- Add Template folder +# See +- https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ +- https://stackoverflow.com/questions/30533372/run-an-ansible-task-only-when-the-hostname-contains-a-string diff --git a/playbook.yml b/playbook.yml new file mode 100644 index 00000000..93f67008 --- /dev/null +++ b/playbook.yml @@ -0,0 +1,5 @@ +- name: general host setup + hosts: all + become: true + roles: + - native-pacman-update diff --git a/roles/native-pacman-update/tasks/main.yml b/roles/native-pacman-update/tasks/main.yml new file mode 100644 index 00000000..f7285d6f --- /dev/null +++ b/roles/native-pacman-update/tasks/main.yml @@ -0,0 +1,4 @@ +- name: update pacman + pacman: + update_cache: yes + upgrade: yes From 5d46b98eec63871c0f0f344cf9f51bcb69f8fdf0 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 12 Nov 2021 16:46:26 +0100 Subject: [PATCH 03/43] Added games role --- playbook.yml | 7 ++++++- roles/games/tasks/main.yml | 15 +++++++++++++++ .../tasks/main.yml | 0 3 files changed, 21 insertions(+), 1 deletion(-) create mode 100644 roles/games/tasks/main.yml rename roles/{native-pacman-update => pacman-update}/tasks/main.yml (100%) diff --git a/playbook.yml b/playbook.yml index 93f67008..ba1aa981 100644 --- a/playbook.yml +++ b/playbook.yml @@ -2,4 +2,9 @@ hosts: all become: true roles: - - native-pacman-update + - pacman-update +- name: setup gaming hosts + hosts: gaming_hosts + become: true + roles: + - games diff --git a/roles/games/tasks/main.yml b/roles/games/tasks/main.yml new file mode 100644 index 00000000..911d5ec7 --- /dev/null +++ b/roles/games/tasks/main.yml @@ -0,0 +1,15 @@ +- name: Install gaming software + community.general.pacman: + name: + - 0ad + - warzone2100 + - supertuxkart + - gnuchess + - sauerbraten + - assaultcube + - minetest + - mari0 + - retroarch + - retroarch-assets-xmb + - retroarch-assets-ozone + state: present diff --git a/roles/native-pacman-update/tasks/main.yml b/roles/pacman-update/tasks/main.yml similarity index 100% rename from roles/native-pacman-update/tasks/main.yml rename to roles/pacman-update/tasks/main.yml From a3f294ef0c298f1e5a3d223a7122b7088f3ff939 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 12 Nov 2021 17:05:11 +0100 Subject: [PATCH 04/43] Added general software --- playbook.yml | 1 + roles/general/tasks/main.yml | 95 ++++++++++++++++++++++++++++++++++++ 2 files changed, 96 insertions(+) create mode 100644 roles/general/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index ba1aa981..3b6bb213 100644 --- a/playbook.yml +++ b/playbook.yml @@ -3,6 +3,7 @@ become: true roles: - pacman-update + - general - name: setup gaming hosts hosts: gaming_hosts become: true diff --git a/roles/general/tasks/main.yml b/roles/general/tasks/main.yml new file mode 100644 index 00000000..1891ac39 --- /dev/null +++ b/roles/general/tasks/main.yml @@ -0,0 +1,95 @@ +- name: install general software + community.general.pacman: + name: + # programing language interpreters + - jdk11-openjdk + - python + - php + + # description language interpreters + - texlive-most + + # compression tools + - p7zip + + # administration tools + - base-devel + - yay + - make + - gcc + - cmake + - fdupes + + # network analyze tools + - traceroute + - wireshark-qt + - wireshark-cli + + # security tools + - ecryptfs-utils + - encfs + - keepassxc + + # anonymous + - tor + - torbrowser-launcher + + # browsers + - chromium + + - firefox + - firefox-ublock-origin + - firefox-extension-https-everywhere + - firefox-dark-reader + + # office software + - ttf-liberation + - libreoffice-fresh + - libreoffice-fresh-de + - libreoffice-fresh-eo + - libreoffice-fresh-es + - libreoffice-fresh-nl + + # spelling software + - hunspell + - hunspell-de + - hunspell-es_es + - hunspell-en_US + - hunspell-nl + + # video/picture manipulation + - gimp + - blender + - obs-studio + + # communication tools + - pidgin + + # code quality tools + - shellcheck + + # visualization tools + - dia + + # ide's + - atom + - arduino + - arduino-docs + + # virtualization tools + - qemu + + # containerization tools + - docker + - docker-compose + + # orchestration tools + - ansible + + # entertainment software + - rhythmbox + + # cloud + - nextcloud-client + + state: present From 3f9156c53e5dda8dbe23a80c36b498cda76a8f54 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 12 Nov 2021 17:06:12 +0100 Subject: [PATCH 05/43] removed firefox --- roles/general/tasks/main.yml | 5 ----- 1 file changed, 5 deletions(-) diff --git a/roles/general/tasks/main.yml b/roles/general/tasks/main.yml index 1891ac39..3d6a5c96 100644 --- a/roles/general/tasks/main.yml +++ b/roles/general/tasks/main.yml @@ -37,11 +37,6 @@ # browsers - chromium - - firefox - - firefox-ublock-origin - - firefox-extension-https-everywhere - - firefox-dark-reader - # office software - ttf-liberation - libreoffice-fresh From 9291240bba10a01effaf96a0c997a1a16c022964 Mon Sep 17 00:00:00 2001 From: "Kevin Veen-Birkenbach [aka. Frantz]" Date: Sat, 13 Nov 2021 18:08:49 +0100 Subject: [PATCH 06/43] Added role libreoffice --- playbook.yml | 5 +++++ roles/games/tasks/main.yml | 1 - roles/general/tasks/main.yml | 15 --------------- roles/hunspell/tasks/main.yml | 10 ++++++++++ roles/libreoffice/meta/main.yml | 2 ++ roles/libreoffice/tasks/main.yml | 12 ++++++++++++ 6 files changed, 29 insertions(+), 16 deletions(-) create mode 100644 roles/hunspell/tasks/main.yml create mode 100644 roles/libreoffice/meta/main.yml create mode 100644 roles/libreoffice/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index 3b6bb213..5fc720b4 100644 --- a/playbook.yml +++ b/playbook.yml @@ -9,3 +9,8 @@ become: true roles: - games +- name: setup libreoffice hosts + hosts: libreoffice_hosts + become: true + roles: + - libreoffice diff --git a/roles/games/tasks/main.yml b/roles/games/tasks/main.yml index 911d5ec7..33d69c6d 100644 --- a/roles/games/tasks/main.yml +++ b/roles/games/tasks/main.yml @@ -6,7 +6,6 @@ - supertuxkart - gnuchess - sauerbraten - - assaultcube - minetest - mari0 - retroarch diff --git a/roles/general/tasks/main.yml b/roles/general/tasks/main.yml index 3d6a5c96..b350ad31 100644 --- a/roles/general/tasks/main.yml +++ b/roles/general/tasks/main.yml @@ -37,21 +37,6 @@ # browsers - chromium - # office software - - ttf-liberation - - libreoffice-fresh - - libreoffice-fresh-de - - libreoffice-fresh-eo - - libreoffice-fresh-es - - libreoffice-fresh-nl - - # spelling software - - hunspell - - hunspell-de - - hunspell-es_es - - hunspell-en_US - - hunspell-nl - # video/picture manipulation - gimp - blender diff --git a/roles/hunspell/tasks/main.yml b/roles/hunspell/tasks/main.yml new file mode 100644 index 00000000..f41e421d --- /dev/null +++ b/roles/hunspell/tasks/main.yml @@ -0,0 +1,10 @@ +- name: install hunspell + community.general.pacman: + name: hunspell + state: present + +- name: install hunspell language packages + community.general.pacman: + name: "hunspell-{{ item }}" + state: present + loop: "{{hunspell_languages}}" diff --git a/roles/libreoffice/meta/main.yml b/roles/libreoffice/meta/main.yml new file mode 100644 index 00000000..a17ee3d0 --- /dev/null +++ b/roles/libreoffice/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- hunspell diff --git a/roles/libreoffice/tasks/main.yml b/roles/libreoffice/tasks/main.yml new file mode 100644 index 00000000..5a7d15a7 --- /dev/null +++ b/roles/libreoffice/tasks/main.yml @@ -0,0 +1,12 @@ +- name: install libreoffice + community.general.pacman: + name: + - ttf-liberation + - libreoffice-fresh + state: present + +- name: install libreoffice language packages + community.general.pacman: + name: "libreoffice-fresh-{{ item }}" + state: present + loop: "{{libreoffice_languages}}" From a622cacdb98ae859d54bbb051623b54f0e1fe334 Mon Sep 17 00:00:00 2001 From: "Kevin Veen-Birkenbach [aka. Frantz]" Date: Sun, 14 Nov 2021 13:56:22 +0100 Subject: [PATCH 07/43] Renamed roles --- playbook.yml | 4 ++-- roles/libreoffice/meta/main.yml | 2 -- roles/{games => native-games}/tasks/main.yml | 0 roles/{hunspell => native-hunspell}/tasks/main.yml | 0 roles/native-office/meta/main.yml | 2 ++ roles/{libreoffice => native-office}/tasks/main.yml | 0 6 files changed, 4 insertions(+), 4 deletions(-) delete mode 100644 roles/libreoffice/meta/main.yml rename roles/{games => native-games}/tasks/main.yml (100%) rename roles/{hunspell => native-hunspell}/tasks/main.yml (100%) create mode 100644 roles/native-office/meta/main.yml rename roles/{libreoffice => native-office}/tasks/main.yml (100%) diff --git a/playbook.yml b/playbook.yml index 5fc720b4..8452f321 100644 --- a/playbook.yml +++ b/playbook.yml @@ -8,9 +8,9 @@ hosts: gaming_hosts become: true roles: - - games + - native-games - name: setup libreoffice hosts hosts: libreoffice_hosts become: true roles: - - libreoffice + - native-libreoffice diff --git a/roles/libreoffice/meta/main.yml b/roles/libreoffice/meta/main.yml deleted file mode 100644 index a17ee3d0..00000000 --- a/roles/libreoffice/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- hunspell diff --git a/roles/games/tasks/main.yml b/roles/native-games/tasks/main.yml similarity index 100% rename from roles/games/tasks/main.yml rename to roles/native-games/tasks/main.yml diff --git a/roles/hunspell/tasks/main.yml b/roles/native-hunspell/tasks/main.yml similarity index 100% rename from roles/hunspell/tasks/main.yml rename to roles/native-hunspell/tasks/main.yml diff --git a/roles/native-office/meta/main.yml b/roles/native-office/meta/main.yml new file mode 100644 index 00000000..ce3fdfe4 --- /dev/null +++ b/roles/native-office/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-hunspell diff --git a/roles/libreoffice/tasks/main.yml b/roles/native-office/tasks/main.yml similarity index 100% rename from roles/libreoffice/tasks/main.yml rename to roles/native-office/tasks/main.yml From 2d4197c5a4179ce1600f85125487b921f247bb6e Mon Sep 17 00:00:00 2001 From: "Kevin Veen-Birkenbach [aka. Frantz]" Date: Sun, 14 Nov 2021 13:59:20 +0100 Subject: [PATCH 08/43] Added role torbrowser --- roles/general/tasks/main.yml | 4 ---- roles/native-torbrowser/tasks/main.yml | 6 ++++++ 2 files changed, 6 insertions(+), 4 deletions(-) create mode 100644 roles/native-torbrowser/tasks/main.yml diff --git a/roles/general/tasks/main.yml b/roles/general/tasks/main.yml index b350ad31..201b43fe 100644 --- a/roles/general/tasks/main.yml +++ b/roles/general/tasks/main.yml @@ -30,10 +30,6 @@ - encfs - keepassxc - # anonymous - - tor - - torbrowser-launcher - # browsers - chromium diff --git a/roles/native-torbrowser/tasks/main.yml b/roles/native-torbrowser/tasks/main.yml new file mode 100644 index 00000000..6a78678e --- /dev/null +++ b/roles/native-torbrowser/tasks/main.yml @@ -0,0 +1,6 @@ +- name: Install gaming software + community.general.pacman: + name: + - tor + - torbrowser-launcher + state: present From dcd5c55543c317135caf2c48416816b9dcd7cbc5 Mon Sep 17 00:00:00 2001 From: "Kevin Veen-Birkenbach [aka. Frantz]" Date: Sun, 14 Nov 2021 14:13:18 +0100 Subject: [PATCH 09/43] refactored --- playbook.yml | 20 ++++++++++++++++++++ roles/general/tasks/main.yml | 20 -------------------- roles/native-dia/tasks/main.yml | 4 ++++ roles/native-docker/tasks/main.yml | 6 ++++++ roles/native-nextcloud-client/tasks/main.yml | 4 ++++ roles/native-torbrowser/tasks/main.yml | 2 +- 6 files changed, 35 insertions(+), 21 deletions(-) create mode 100644 roles/native-dia/tasks/main.yml create mode 100644 roles/native-docker/tasks/main.yml create mode 100644 roles/native-nextcloud-client/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index 8452f321..49fe798e 100644 --- a/playbook.yml +++ b/playbook.yml @@ -9,8 +9,28 @@ become: true roles: - native-games +- name: setup torbrowser hosts + hosts: torbrowser_hosts + become: true + roles: + - torbrowser-games - name: setup libreoffice hosts hosts: libreoffice_hosts become: true roles: - native-libreoffice +- name: setup nextcloud-client + hosts: nextcloud_client_hosts + become: true + roles: + - native-nextcloud-client +- name: setup dia + hosts: dia_hosts + become: true + roles: + - native-dia +- name: setup docker + hosts: docker_hosts + become: true + roles: + - native-docker diff --git a/roles/general/tasks/main.yml b/roles/general/tasks/main.yml index 201b43fe..87966373 100644 --- a/roles/general/tasks/main.yml +++ b/roles/general/tasks/main.yml @@ -38,15 +38,9 @@ - blender - obs-studio - # communication tools - - pidgin - # code quality tools - shellcheck - # visualization tools - - dia - # ide's - atom - arduino @@ -54,18 +48,4 @@ # virtualization tools - qemu - - # containerization tools - - docker - - docker-compose - - # orchestration tools - - ansible - - # entertainment software - - rhythmbox - - # cloud - - nextcloud-client - state: present diff --git a/roles/native-dia/tasks/main.yml b/roles/native-dia/tasks/main.yml new file mode 100644 index 00000000..ab15837c --- /dev/null +++ b/roles/native-dia/tasks/main.yml @@ -0,0 +1,4 @@ +- name: Install dia + community.general.pacman: + name: dia + state: present diff --git a/roles/native-docker/tasks/main.yml b/roles/native-docker/tasks/main.yml new file mode 100644 index 00000000..75af8363 --- /dev/null +++ b/roles/native-docker/tasks/main.yml @@ -0,0 +1,6 @@ +- name: Install docker + community.general.pacman: + name: + - docker + - docker-compose + state: present diff --git a/roles/native-nextcloud-client/tasks/main.yml b/roles/native-nextcloud-client/tasks/main.yml new file mode 100644 index 00000000..366e875b --- /dev/null +++ b/roles/native-nextcloud-client/tasks/main.yml @@ -0,0 +1,4 @@ +- name: Install nextcloud-client + community.general.pacman: + name: nextcloud-client + state: present diff --git a/roles/native-torbrowser/tasks/main.yml b/roles/native-torbrowser/tasks/main.yml index 6a78678e..77c3f3f7 100644 --- a/roles/native-torbrowser/tasks/main.yml +++ b/roles/native-torbrowser/tasks/main.yml @@ -1,4 +1,4 @@ -- name: Install gaming software +- name: Install torbrowser community.general.pacman: name: - tor From a47e932bed33e35f06d8811eaeeaaafcc717b3dc Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Wed, 17 Nov 2021 17:35:54 +0100 Subject: [PATCH 10/43] Optimized nextloud-client for symbolic links, refactored and solved bugs --- playbook.yml | 2 +- .../meta/main.yml | 0 .../tasks/main.yml | 0 roles/native-nextcloud-client/tasks/main.yml | 15 +++++++++++++++ roles/native-nextcloud-client/vars/main.yml | 2 ++ 5 files changed, 18 insertions(+), 1 deletion(-) rename roles/{native-office => native-libreoffice}/meta/main.yml (100%) rename roles/{native-office => native-libreoffice}/tasks/main.yml (100%) create mode 100644 roles/native-nextcloud-client/vars/main.yml diff --git a/playbook.yml b/playbook.yml index 49fe798e..73e6e8d7 100644 --- a/playbook.yml +++ b/playbook.yml @@ -13,7 +13,7 @@ hosts: torbrowser_hosts become: true roles: - - torbrowser-games + - native-torbrowser - name: setup libreoffice hosts hosts: libreoffice_hosts become: true diff --git a/roles/native-office/meta/main.yml b/roles/native-libreoffice/meta/main.yml similarity index 100% rename from roles/native-office/meta/main.yml rename to roles/native-libreoffice/meta/main.yml diff --git a/roles/native-office/tasks/main.yml b/roles/native-libreoffice/tasks/main.yml similarity index 100% rename from roles/native-office/tasks/main.yml rename to roles/native-libreoffice/tasks/main.yml diff --git a/roles/native-nextcloud-client/tasks/main.yml b/roles/native-nextcloud-client/tasks/main.yml index 366e875b..9a663e42 100644 --- a/roles/native-nextcloud-client/tasks/main.yml +++ b/roles/native-nextcloud-client/tasks/main.yml @@ -2,3 +2,18 @@ community.general.pacman: name: nextcloud-client state: present + +- name: Link homefolders to cloud + ansible.builtin.file: + src: "{{cloud_directory}}{{item}}" + dest: "{{user_home_directory}}{{item}}" + owner: "{{client_username}}" + group: "{{client_username}}" + state: link + loop: + - Templates + - Documents + - Videos + - Pictures + - Music + - Desktop diff --git a/roles/native-nextcloud-client/vars/main.yml b/roles/native-nextcloud-client/vars/main.yml new file mode 100644 index 00000000..4206e3b8 --- /dev/null +++ b/roles/native-nextcloud-client/vars/main.yml @@ -0,0 +1,2 @@ +user_home_directory: "/home/{{client_username}}/" +cloud_directory: "{{user_home_directory}}Clouds/{{cloud_fqdn}}/" From 4c243ceb012e52684214cf1e1dd3c5d298db0a79 Mon Sep 17 00:00:00 2001 From: "Kevin Veen-Birkenbach [aka. Frantz]" Date: Wed, 8 Dec 2021 12:58:51 +0100 Subject: [PATCH 11/43] Added role gnome --- roles/native-gnome/tasks/main.yml | 7 +++++++ 1 file changed, 7 insertions(+) create mode 100644 roles/native-gnome/tasks/main.yml diff --git a/roles/native-gnome/tasks/main.yml b/roles/native-gnome/tasks/main.yml new file mode 100644 index 00000000..9eb50a5a --- /dev/null +++ b/roles/native-gnome/tasks/main.yml @@ -0,0 +1,7 @@ +- name: Install docker + community.general.pacman: + name: + - gnome-shell-extensions + - gnome-terminal + - intltool # Needed for extension make + state: present From eac2be60f3644b6a49a88c3c8625688e8003b786 Mon Sep 17 00:00:00 2001 From: "Kevin Veen-Birkenbach [aka. Frantz]" Date: Wed, 8 Dec 2021 13:10:49 +0100 Subject: [PATCH 12/43] Added playpart for role gnome --- playbook.yml | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/playbook.yml b/playbook.yml index 73e6e8d7..6052753f 100644 --- a/playbook.yml +++ b/playbook.yml @@ -19,6 +19,11 @@ become: true roles: - native-libreoffice +- name: setup gnome-clients + hosts: gnome_clients + become: true + roles: + - native-gnome - name: setup nextcloud-client hosts: nextcloud_client_hosts become: true From 8b4990bd247dbdcbd20edfc7d4e1c014fd485099 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Wed, 17 Aug 2022 13:21:50 +0200 Subject: [PATCH 13/43] Updated role nextcloud --- roles/native-nextcloud-client/tasks/main.yml | 2 ++ roles/native-nextcloud-client/vars/main.yml | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/roles/native-nextcloud-client/tasks/main.yml b/roles/native-nextcloud-client/tasks/main.yml index 9a663e42..b826d060 100644 --- a/roles/native-nextcloud-client/tasks/main.yml +++ b/roles/native-nextcloud-client/tasks/main.yml @@ -17,3 +17,5 @@ - Pictures - Music - Desktop + - Software + - Downloads diff --git a/roles/native-nextcloud-client/vars/main.yml b/roles/native-nextcloud-client/vars/main.yml index 4206e3b8..43a6b757 100644 --- a/roles/native-nextcloud-client/vars/main.yml +++ b/roles/native-nextcloud-client/vars/main.yml @@ -1,2 +1,2 @@ user_home_directory: "/home/{{client_username}}/" -cloud_directory: "{{user_home_directory}}Clouds/{{cloud_fqdn}}/" +cloud_directory: "{{user_home_directory}}Clouds/{{cloud_fqdn}}/{{client_username}}/" From f098ad312e60d71b774dc6288355152c637a7822 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 07:16:21 +0200 Subject: [PATCH 14/43] Added role native-git --- README.md | 2 +- playbook.yml | 5 +- roles/general/tasks/main.yml | 51 ------------------- roles/native-administrator/meta/main.yml | 2 + roles/native-administrator/tasks/main.yml | 10 ++++ roles/native-general/tasks/main.yml | 43 ++++++++++++++++ roles/native-git/tasks/mail.yml | 8 +++ .../tasks/main.yml | 0 8 files changed, 67 insertions(+), 54 deletions(-) delete mode 100644 roles/general/tasks/main.yml create mode 100644 roles/native-administrator/meta/main.yml create mode 100644 roles/native-administrator/tasks/main.yml create mode 100644 roles/native-general/tasks/main.yml create mode 100644 roles/native-git/tasks/mail.yml rename roles/{pacman-update => native-pacman-update}/tasks/main.yml (100%) diff --git a/README.md b/README.md index 900461d2..62075e6e 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,7 @@ # Client Playbook Playbook to setup Manjaro GNOME clients. # Todo -- Add Template folder +- add printer # See - https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ - https://stackoverflow.com/questions/30533372/run-an-ansible-task-only-when-the-hostname-contains-a-string diff --git a/playbook.yml b/playbook.yml index 6052753f..0ac0c218 100644 --- a/playbook.yml +++ b/playbook.yml @@ -2,8 +2,9 @@ hosts: all become: true roles: - - pacman-update - - general + - native-pacman-update + - native-general + - native-administrator - name: setup gaming hosts hosts: gaming_hosts become: true diff --git a/roles/general/tasks/main.yml b/roles/general/tasks/main.yml deleted file mode 100644 index 87966373..00000000 --- a/roles/general/tasks/main.yml +++ /dev/null @@ -1,51 +0,0 @@ -- name: install general software - community.general.pacman: - name: - # programing language interpreters - - jdk11-openjdk - - python - - php - - # description language interpreters - - texlive-most - - # compression tools - - p7zip - - # administration tools - - base-devel - - yay - - make - - gcc - - cmake - - fdupes - - # network analyze tools - - traceroute - - wireshark-qt - - wireshark-cli - - # security tools - - ecryptfs-utils - - encfs - - keepassxc - - # browsers - - chromium - - # video/picture manipulation - - gimp - - blender - - obs-studio - - # code quality tools - - shellcheck - - # ide's - - atom - - arduino - - arduino-docs - - # virtualization tools - - qemu - state: present diff --git a/roles/native-administrator/meta/main.yml b/roles/native-administrator/meta/main.yml new file mode 100644 index 00000000..3bce5ffa --- /dev/null +++ b/roles/native-administrator/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-git \ No newline at end of file diff --git a/roles/native-administrator/tasks/main.yml b/roles/native-administrator/tasks/main.yml new file mode 100644 index 00000000..84f3d6d5 --- /dev/null +++ b/roles/native-administrator/tasks/main.yml @@ -0,0 +1,10 @@ +- name: install administration tools + community.general.pacman: + name: + - base-devel + - yay + - make + - gcc + - cmake + - fdupes + state: present diff --git a/roles/native-general/tasks/main.yml b/roles/native-general/tasks/main.yml new file mode 100644 index 00000000..81eed79d --- /dev/null +++ b/roles/native-general/tasks/main.yml @@ -0,0 +1,43 @@ +- name: install general software + community.general.pacman: + name: + # programing language interpreters + #- jdk11-openjdk + #- python + #- php + + # description language interpreters + #- texlive-most + + # compression tools + #- p7zip + + # network analyze tools + #- traceroute + #- wireshark-qt + #- wireshark-cli + + # security tools + #- ecryptfs-utils + #- encfs + #- keepassxc + + # browsers + - chromium + + # video/picture manipulation + #- gimp + #- blender + #- obs-studio + + # code quality tools + #- shellcheck + + # ide's + #- atom + #- arduino + #- arduino-docs + + # virtualization tools + #- qemu + state: present diff --git a/roles/native-git/tasks/mail.yml b/roles/native-git/tasks/mail.yml new file mode 100644 index 00000000..a528ae0c --- /dev/null +++ b/roles/native-git/tasks/mail.yml @@ -0,0 +1,8 @@ +- name: Set git user email to {{user_email}} + ansible.builtin.shell: git config --global user.email "{{user_email}}" +- name: Set git user name to {{user_full_name}} + ansible.builtin.shell: - git config --global user.name "{{user_full_name}}" +- name: install git + community.general.pacman: + name: git + state: present \ No newline at end of file diff --git a/roles/pacman-update/tasks/main.yml b/roles/native-pacman-update/tasks/main.yml similarity index 100% rename from roles/pacman-update/tasks/main.yml rename to roles/native-pacman-update/tasks/main.yml From 4ee8525bfb3438426b2fca809ee4a43e22646ca6 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 07:27:49 +0200 Subject: [PATCH 15/43] Solved naming bug --- roles/native-git/tasks/{mail.yml => main.yml} | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) rename roles/native-git/tasks/{mail.yml => main.yml} (75%) diff --git a/roles/native-git/tasks/mail.yml b/roles/native-git/tasks/main.yml similarity index 75% rename from roles/native-git/tasks/mail.yml rename to roles/native-git/tasks/main.yml index a528ae0c..7ede8984 100644 --- a/roles/native-git/tasks/mail.yml +++ b/roles/native-git/tasks/main.yml @@ -1,7 +1,7 @@ - name: Set git user email to {{user_email}} ansible.builtin.shell: git config --global user.email "{{user_email}}" - name: Set git user name to {{user_full_name}} - ansible.builtin.shell: - git config --global user.name "{{user_full_name}}" + ansible.builtin.shell: git config --global user.name "{{user_full_name}}" - name: install git community.general.pacman: name: git From cf7b11db7cc746c837f0c39df108bd586905966b Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 08:06:28 +0200 Subject: [PATCH 16/43] Added epson-multiprinter-support --- README.md | 9 +++++++ playbook.yml | 5 ++++ requirements.yml | 2 ++ roles/native-aur-helper/Readme.md | 1 + roles/native-aur-helper/tasks/main.yml | 25 +++++++++++++++++++ roles/native-epson-multiprinter/Readme.md | 9 +++++++ roles/native-epson-multiprinter/meta/main.yml | 2 ++ .../native-epson-multiprinter/tasks/main.yml | 12 +++++++++ 8 files changed, 65 insertions(+) create mode 100644 requirements.yml create mode 100644 roles/native-aur-helper/Readme.md create mode 100644 roles/native-aur-helper/tasks/main.yml create mode 100644 roles/native-epson-multiprinter/Readme.md create mode 100644 roles/native-epson-multiprinter/meta/main.yml create mode 100644 roles/native-epson-multiprinter/tasks/main.yml diff --git a/README.md b/README.md index 62075e6e..78e5af53 100644 --- a/README.md +++ b/README.md @@ -1,7 +1,16 @@ # Client Playbook Playbook to setup Manjaro GNOME clients. +# Setup + +Run: +```bash +ansible-galaxy collection install -r requirements.yml +``` + # Todo - add printer +- add ssh +- add gnome plugins # See - https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ - https://stackoverflow.com/questions/30533372/run-an-ansible-task-only-when-the-hostname-contains-a-string diff --git a/playbook.yml b/playbook.yml index 0ac0c218..432c6d67 100644 --- a/playbook.yml +++ b/playbook.yml @@ -10,6 +10,11 @@ become: true roles: - native-games +- name: setup multiprinter hosts + hosts: epson_multiprinter_hosts + become: true + roles: + - native-epson-multiprinter - name: setup torbrowser hosts hosts: torbrowser_hosts become: true diff --git a/requirements.yml b/requirements.yml new file mode 100644 index 00000000..cad479ac --- /dev/null +++ b/requirements.yml @@ -0,0 +1,2 @@ +collections: + - name: kewlfft.aur \ No newline at end of file diff --git a/roles/native-aur-helper/Readme.md b/roles/native-aur-helper/Readme.md new file mode 100644 index 00000000..e09c0da7 --- /dev/null +++ b/roles/native-aur-helper/Readme.md @@ -0,0 +1 @@ +https://github.com/kewlfft/ansible-aur \ No newline at end of file diff --git a/roles/native-aur-helper/tasks/main.yml b/roles/native-aur-helper/tasks/main.yml new file mode 100644 index 00000000..4c414988 --- /dev/null +++ b/roles/native-aur-helper/tasks/main.yml @@ -0,0 +1,25 @@ +- name: install yay + community.general.pacman: + name: yay + state: present + +- name: Create the `aur_builder` user + become: yes + ansible.builtin.user: + name: aur_builder + create_home: yes + group: wheel + +- name: Allow the `aur_builder` user to run `sudo pacman` without a password + become: yes + ansible.builtin.lineinfile: + path: /etc/sudoers.d/11-install-aur_builder + line: 'aur_builder ALL=(ALL) NOPASSWD: /usr/bin/pacman' + create: yes + validate: 'visudo -cf %s' + +- name: Upgrade the system using yay, only act on AUR packages. + kewlfft.aur.aur: + upgrade: yes + use: yay + aur_only: yes \ No newline at end of file diff --git a/roles/native-epson-multiprinter/Readme.md b/roles/native-epson-multiprinter/Readme.md new file mode 100644 index 00000000..0d0eab2c --- /dev/null +++ b/roles/native-epson-multiprinter/Readme.md @@ -0,0 +1,9 @@ +# role native-epson-multiprinter +## further information +- https://bernhardsteindl.at/epson-ecotank-et-3600-unter-arch-linux-einrichten/ +- http://download.ebz.epson.net/dsc/search/01/search/searchModule +- https://aur.archlinux.org/packages/epson-inkjet-printer-escpr +- https://forum.manjaro.org/t/probleme-mit-epson-et-2820/109777/2 +- https://www.ordinatechnic.com/distribution-specific-guides/Arch/installing-an-epson-multifunction-printer-on-arch-linux-and-derivatives +- http://localhost:631/admin +- https://wiki.archlinux.org/title/SANE/Scanner-specific_problems \ No newline at end of file diff --git a/roles/native-epson-multiprinter/meta/main.yml b/roles/native-epson-multiprinter/meta/main.yml new file mode 100644 index 00000000..795fd094 --- /dev/null +++ b/roles/native-epson-multiprinter/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-aur-helper \ No newline at end of file diff --git a/roles/native-epson-multiprinter/tasks/main.yml b/roles/native-epson-multiprinter/tasks/main.yml new file mode 100644 index 00000000..6d649a04 --- /dev/null +++ b/roles/native-epson-multiprinter/tasks/main.yml @@ -0,0 +1,12 @@ +- name: Install yay packages for epson + kewlfft.aur.aur: + use: yay + name: + - epson-printer-utility + - imagescan-plugin-networkscan + - epson-inkjet-printer-escpr + - epson-inkjet-printer-escpr2 +- name: install imagescan + community.general.pacman: + name: imagescan + state: present \ No newline at end of file From ee513f48445b5f2e40bea4db2ecbd30df9540dfb Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 13:48:18 +0200 Subject: [PATCH 17/43] Moved roles from core-system to client-playbook --- README.md | 108 +++++++++++++++++++++++++++++++++++++++++++++++++++++- 1 file changed, 106 insertions(+), 2 deletions(-) diff --git a/README.md b/README.md index 78e5af53..6b731144 100644 --- a/README.md +++ b/README.md @@ -8,9 +8,113 @@ ansible-galaxy collection install -r requirements.yml ``` # Todo -- add printer - add ssh -- add gnome plugins +# Refactor +```bash +FSTAB_SWAP_ENTRY="/swapfile none swap defaults 0 0" +SWAP_FILE="/swapfile" +FSTAB_FILE="/etc/fstab" +if grep -q "$FSTAB_SWAP_ENTRY" "$FSTAB_FILE"; then + info "Skipping creation of swap partion because entry allready exists in \"$FSTAB_FILE\"!" +else + info "Creating swap partition..." && + sudo fallocate -l 16G "$SWAP_FILE" && + sudo chmod 600 "$SWAP_FILE" && + sudo mkswap "$SWAP_FILE" && + sudo swapon "$SWAP_FILE" && + sudo sh -c "echo \"$FSTAB_SWAP_ENTRY\">>\"$FSTAB_FILE\"" || error "Creation of swap partition failed." +fi + +info "Setup SSH key..." +ssh_key_path="$HOME/.ssh/id_rsa" +if [ ! -f "$ssh_key_path" ]; then + info "SSH key $ssh_key_path doesn't exists!" + if [ ! -f "./data$ssh_key_path" ]; then + info "Importing ssh key by copying data..." && + bash "$SCRIPT_PATH""/data/export-to-system.sh" || error "Copying failed." + else + info "Generating ssh key..." && + ssh-keygen -t rsa -b 4096 -C "$USER@$HOSTNAME" || error "Key generation failed." + fi +fi + +info "Setup, configuration and installation of dependencies for installed software..." + +if pacman -Qi "arduino" > /dev/null ; then + info "Configurate system for arduino..." && + sudo usermod -a -G uucp "$USER" && + sudo usermod -a -G lock "$USER" || error "Couldn't add \"$USER\" to the relevant groups." +fi + +if pacman -Qi "docker" > /dev/null ; then + info "Setting up docker..." && + info "Add current user \"$USER\" to user group docker..." && + sudo usermod -a -G docker "$USER" || error "Failed to add user." + info "Restarting docker service..." && + sudo systemctl restart docker && + info "Disable and stop docker service..." && + sudo systemctl disable --now docker || error "\"systemctl\" produced an error." + info "For performance reasons docker is not enabled. Start docker by executing \"sudo systemctl restart docker\" when you need it." +fi + +if [ ! "$(pacman -Qi "virtualbox")" ] ; then + info "Setting up virtualbox..." && + sudo pacman -S virtualbox "$(pacman -Qsq "^linux" | grep "^linux[0-9]*[-rt]*$" | awk '{print $1"-virtualbox-host-modules"}' ORS=' ')" && + sudo vboxreload && + pamac build virtualbox-ext-oracle && + sudo gpasswd -a "$USER" vboxusers || error + info "Keep in mind to install the guest additions in the virtualized system. See https://wiki.manjaro.org/index.php?title=VirtualBox" +fi + +install_gnome_extension(){ + info "Install GNOME extension \"$1\"..." + extension_folder="$HOME/.local/share/gnome-shell/extensions/$1/" + if [ -d "$extension_folder" ]; + then + if [ -d "$extension_folder"".git" ]; + then + warning "Found a .git repository didn't expect to find this here." && + info "Pulling changes from git..." && + (cd "$extension_folder" && git pull) || error + else + info "No git repository. Extension will not be updated." + fi + else + info "Install..." && + git clone "$2" "$extension_folder" || error + fi + + if [ -f "$extension_folder""Makefile" ]; + then + + tmp_extension_folder="/tmp/$1" + mv "$extension_folder" "$tmp_extension_folder" + info "Compilling extension.." + (cd "$tmp_extension_folder" && make install) || error "Compilation with failed." + + info "Cleaning up tmp-extension folder..."&& + rm -fr "$tmp_extension_folder" || error + + else + info "No Makefile found. Skipping compilation..." + fi + + info "Activating GNOME extension \"$1\"..." && + gnome-extensions enable "$1" || error +} + +if [ "$DESKTOP_SESSION" == "gnome" ]; then + info "Synchronizing gnome tools..." && + install_yay_packages_if_needed "$(get_packages "client/yay/gnome")" || error "Syncronisation failed." + info "Install GNOME extensions..." && + install_gnome_extension "nasa_apod@elinvention.ovh" "https://github.com/Elinvention/gnome-shell-extension-nasa-apod.git" + install_gnome_extension "caffeine@patapon.info" "https://github.com/eonpatapon/gnome-shell-extension-caffeine.git" + info "Deactivating \"Dash to Dock\"..." && + gnome-extensions disable dash-to-dock@micxgx.gmail.com || error + +fi +``` + # See - https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ - https://stackoverflow.com/questions/30533372/run-an-ansible-task-only-when-the-hostname-contains-a-string From 25946e6925ee16c10de77b9a91182449417af16f Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 13:49:31 +0200 Subject: [PATCH 18/43] Moved client setup from core-system repository to roles --- playbook.yml | 12 +++++++----- roles/native-caffeine/meta/main.yml | 2 ++ roles/native-caffeine/tasks/main.yml | 5 +++++ roles/native-gnome/Readme.md | 3 +++ roles/native-gnome/tasks/main.yml | 14 +++++++++++--- roles/native-non-free-drivers/tasks/main.yml | 2 ++ 6 files changed, 30 insertions(+), 8 deletions(-) create mode 100644 roles/native-caffeine/meta/main.yml create mode 100644 roles/native-caffeine/tasks/main.yml create mode 100644 roles/native-gnome/Readme.md create mode 100644 roles/native-non-free-drivers/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index 432c6d67..4fbde18c 100644 --- a/playbook.yml +++ b/playbook.yml @@ -5,6 +5,13 @@ - native-pacman-update - native-general - native-administrator + - native-caffeine + - native-non-free-drivers +- name: GNOME setup + hosts: gnome_hosts + become: true + roles: + - native-gnome - name: setup gaming hosts hosts: gaming_hosts become: true @@ -25,11 +32,6 @@ become: true roles: - native-libreoffice -- name: setup gnome-clients - hosts: gnome_clients - become: true - roles: - - native-gnome - name: setup nextcloud-client hosts: nextcloud_client_hosts become: true diff --git a/roles/native-caffeine/meta/main.yml b/roles/native-caffeine/meta/main.yml new file mode 100644 index 00000000..795fd094 --- /dev/null +++ b/roles/native-caffeine/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-aur-helper \ No newline at end of file diff --git a/roles/native-caffeine/tasks/main.yml b/roles/native-caffeine/tasks/main.yml new file mode 100644 index 00000000..738d4211 --- /dev/null +++ b/roles/native-caffeine/tasks/main.yml @@ -0,0 +1,5 @@ +- name: Install caffeine + kewlfft.aur.aur: + use: yay + name: + - caffeine-ng \ No newline at end of file diff --git a/roles/native-gnome/Readme.md b/roles/native-gnome/Readme.md new file mode 100644 index 00000000..f53d1b1b --- /dev/null +++ b/roles/native-gnome/Readme.md @@ -0,0 +1,3 @@ +# native-gnome +## further information +- https://askubuntu.com/questions/1029376/how-do-i-enable-and-disable-gnome-extensions-from-the-command-line \ No newline at end of file diff --git a/roles/native-gnome/tasks/main.yml b/roles/native-gnome/tasks/main.yml index 9eb50a5a..778451f9 100644 --- a/roles/native-gnome/tasks/main.yml +++ b/roles/native-gnome/tasks/main.yml @@ -1,7 +1,15 @@ -- name: Install docker +- name: Install Gnome Software community.general.pacman: name: - gnome-shell-extensions + - gnome-shell-extension-desktop-icons-ng - gnome-terminal - - intltool # Needed for extension make - state: present + state: present + +- name: GNOME Activate Extensions + ansible.builtin.shell: gsettings set org.gnome.shell disable-user-extensions false + become: false + +- name: GNOME Set favorite apps + ansible.builtin.shell: gsettings set org.gnome.shell favorite-apps "{{favorite_apps}}" + become: false diff --git a/roles/native-non-free-drivers/tasks/main.yml b/roles/native-non-free-drivers/tasks/main.yml new file mode 100644 index 00000000..713b9095 --- /dev/null +++ b/roles/native-non-free-drivers/tasks/main.yml @@ -0,0 +1,2 @@ +- name: Install nonfree drivers + ansible.builtin.shell: mhwd -a pci nonfree 0300 \ No newline at end of file From aeab52ddd8f3dc7a9abee599da1768e04147874c Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 18:12:59 +0200 Subject: [PATCH 19/43] Added swapfile and ssh configuration role --- README.md | 29 ++-------------------------- playbook.yml | 10 ++++++++++ roles/native-ssh/meta/main.yml | 2 ++ roles/native-ssh/tasks copy/main.yml | 5 +++++ roles/native-ssh/tasks/main.yml | 6 ++++++ roles/native-swapfile/meta/main.yml | 2 ++ roles/native-swapfile/tasks/main.yml | 10 ++++++++++ 7 files changed, 37 insertions(+), 27 deletions(-) create mode 100644 roles/native-ssh/meta/main.yml create mode 100644 roles/native-ssh/tasks copy/main.yml create mode 100644 roles/native-ssh/tasks/main.yml create mode 100644 roles/native-swapfile/meta/main.yml create mode 100644 roles/native-swapfile/tasks/main.yml diff --git a/README.md b/README.md index 6b731144..d102c4ee 100644 --- a/README.md +++ b/README.md @@ -1,4 +1,6 @@ # Client Playbook +[![License: AGPL v3](https://img.shields.io/badge/License-AGPL%20v3-blue.svg)](https://www.gnu.org/licenses/agpl-3.0) + Playbook to setup Manjaro GNOME clients. # Setup @@ -11,33 +13,6 @@ ansible-galaxy collection install -r requirements.yml - add ssh # Refactor ```bash -FSTAB_SWAP_ENTRY="/swapfile none swap defaults 0 0" -SWAP_FILE="/swapfile" -FSTAB_FILE="/etc/fstab" -if grep -q "$FSTAB_SWAP_ENTRY" "$FSTAB_FILE"; then - info "Skipping creation of swap partion because entry allready exists in \"$FSTAB_FILE\"!" -else - info "Creating swap partition..." && - sudo fallocate -l 16G "$SWAP_FILE" && - sudo chmod 600 "$SWAP_FILE" && - sudo mkswap "$SWAP_FILE" && - sudo swapon "$SWAP_FILE" && - sudo sh -c "echo \"$FSTAB_SWAP_ENTRY\">>\"$FSTAB_FILE\"" || error "Creation of swap partition failed." -fi - -info "Setup SSH key..." -ssh_key_path="$HOME/.ssh/id_rsa" -if [ ! -f "$ssh_key_path" ]; then - info "SSH key $ssh_key_path doesn't exists!" - if [ ! -f "./data$ssh_key_path" ]; then - info "Importing ssh key by copying data..." && - bash "$SCRIPT_PATH""/data/export-to-system.sh" || error "Copying failed." - else - info "Generating ssh key..." && - ssh-keygen -t rsa -b 4096 -C "$USER@$HOSTNAME" || error "Key generation failed." - fi -fi - info "Setup, configuration and installation of dependencies for installed software..." if pacman -Qi "arduino" > /dev/null ; then diff --git a/playbook.yml b/playbook.yml index 4fbde18c..20a7d4db 100644 --- a/playbook.yml +++ b/playbook.yml @@ -12,6 +12,16 @@ become: true roles: - native-gnome +- name: setup ssh hosts + hosts: ssh_hosts + become: false + roles: + - native-ssh +- name: setup swapfile hosts + hosts: swapfile_hosts + become: false + roles: + - role: native-swapfile - name: setup gaming hosts hosts: gaming_hosts become: true diff --git a/roles/native-ssh/meta/main.yml b/roles/native-ssh/meta/main.yml new file mode 100644 index 00000000..3bce5ffa --- /dev/null +++ b/roles/native-ssh/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-git \ No newline at end of file diff --git a/roles/native-ssh/tasks copy/main.yml b/roles/native-ssh/tasks copy/main.yml new file mode 100644 index 00000000..738d4211 --- /dev/null +++ b/roles/native-ssh/tasks copy/main.yml @@ -0,0 +1,5 @@ +- name: Install caffeine + kewlfft.aur.aur: + use: yay + name: + - caffeine-ng \ No newline at end of file diff --git a/roles/native-ssh/tasks/main.yml b/roles/native-ssh/tasks/main.yml new file mode 100644 index 00000000..20c4eb49 --- /dev/null +++ b/roles/native-ssh/tasks/main.yml @@ -0,0 +1,6 @@ +- name: pull ssh repository from {{ssh_configuration_repository}} + git: + repo: "{{ssh_configuration_repository}}" + dest: "$HOME/.ssh" + update: yes + become: false \ No newline at end of file diff --git a/roles/native-swapfile/meta/main.yml b/roles/native-swapfile/meta/main.yml new file mode 100644 index 00000000..3bce5ffa --- /dev/null +++ b/roles/native-swapfile/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-git \ No newline at end of file diff --git a/roles/native-swapfile/tasks/main.yml b/roles/native-swapfile/tasks/main.yml new file mode 100644 index 00000000..4bf046b0 --- /dev/null +++ b/roles/native-swapfile/tasks/main.yml @@ -0,0 +1,10 @@ +- name: pull swapfile creating script + git: + repo: "git@github.com:kevinveenbirkenbach/create-linux-swapfile.git" + dest: "$HOME/Repositories/github.com/kevinveenbirkenbach/create-linux-swapfile" + update: yes + become: false + +- name: Execute create swapfile script + ansible.builtin.shell: bash "/home/{{client_username}}/Repositories/github.com/kevinveenbirkenbach/create-linux-swapfile/create-linux-swapfile.sh" "{{swapfile_size}}" + become: true \ No newline at end of file From b02b07445e89b560fd64c1a216cf567b83b54461 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 18 Aug 2022 19:23:43 +0200 Subject: [PATCH 20/43] Added rgb support for msi keyboard --- playbook.yml | 7 ++++++- roles/native-msi-perkeyrgb/Readme.md | 4 ++++ roles/native-msi-perkeyrgb/meta/main.yml | 2 ++ roles/native-msi-perkeyrgb/tasks/main.yml | 9 +++++++++ 4 files changed, 21 insertions(+), 1 deletion(-) create mode 100644 roles/native-msi-perkeyrgb/Readme.md create mode 100644 roles/native-msi-perkeyrgb/meta/main.yml create mode 100644 roles/native-msi-perkeyrgb/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index 20a7d4db..2a4e2fc0 100644 --- a/playbook.yml +++ b/playbook.yml @@ -12,11 +12,16 @@ become: true roles: - native-gnome +- name: setup msi rgb keyboard + hosts: msi_perkeyrgb_hosts + become: true + roles: + - native-msi-perkeyrgb - name: setup ssh hosts hosts: ssh_hosts become: false roles: - - native-ssh + - native-msi-perkeyrgb - name: setup swapfile hosts hosts: swapfile_hosts become: false diff --git a/roles/native-msi-perkeyrgb/Readme.md b/roles/native-msi-perkeyrgb/Readme.md new file mode 100644 index 00000000..629fed5a --- /dev/null +++ b/roles/native-msi-perkeyrgb/Readme.md @@ -0,0 +1,4 @@ +# native-msi-gs66 +# further information +- https://github.com/Askannz/msi-perkeyrgb +- https://wiki.archlinux.org/title/MSI_GS66_11UX \ No newline at end of file diff --git a/roles/native-msi-perkeyrgb/meta/main.yml b/roles/native-msi-perkeyrgb/meta/main.yml new file mode 100644 index 00000000..795fd094 --- /dev/null +++ b/roles/native-msi-perkeyrgb/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-aur-helper \ No newline at end of file diff --git a/roles/native-msi-perkeyrgb/tasks/main.yml b/roles/native-msi-perkeyrgb/tasks/main.yml new file mode 100644 index 00000000..0368e201 --- /dev/null +++ b/roles/native-msi-perkeyrgb/tasks/main.yml @@ -0,0 +1,9 @@ +- name: Install MSI packages + kewlfft.aur.aur: + use: yay + name: + - msi-perkeyrgb + +- name: Change preset of keyboard {{vendor_and_product_id}} to {{preset}} + ansible.builtin.shell: sudo msi-perkeyrgb --model GS65 -p "{{preset}}" --id "{{vendor_and_product_id}}" + become: true \ No newline at end of file From 1e5aa4ddbcffb9b327da01cf1d80a323057bd394 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 16:52:00 +0200 Subject: [PATCH 21/43] added todos --- README.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/README.md b/README.md index d102c4ee..f249222f 100644 --- a/README.md +++ b/README.md @@ -10,7 +10,11 @@ ansible-galaxy collection install -r requirements.yml ``` # Todo -- add ssh +- add native-office-worker +- add native-graphic-designer +- add native-developer-basic +- add native-workspaces + # Refactor ```bash info "Setup, configuration and installation of dependencies for installed software..." From eeb365d5b6d55477a0f018c074ad882b471fd417 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 21:39:23 +0200 Subject: [PATCH 22/43] Refactoring Draft --- README.md | 80 +------------------ playbook.yml | 6 +- roles/application-caffeine/meta/main.yml | 3 + .../tasks/main.yml | 0 .../tasks/main.yml | 0 roles/application-docker/tasks/main.yml | 11 +++ .../tasks/main.yml | 0 .../tasks/main.yml | 0 roles/application-java/tasks/main.yml | 5 ++ roles/application-virtual-box/Readme.md | 9 +++ .../meta/main.yml | 0 .../tasks/main.yml | 0 .../meta/main.yml | 2 + .../tasks/main.yml | 7 ++ .../meta/main.yml | 2 + .../tasks/main.yml | 11 +++ .../meta/main.yml | 2 + .../tasks/main.yml | 5 ++ .../meta/main.yml | 2 + .../tasks/main.yml | 5 ++ .../meta/main.yml | 2 + .../meta/main.yml | 2 + .../tasks/main.yml | 5 ++ .../meta/main.yml | 2 + .../tasks/main.yml | 5 ++ .../tasks/main.yml | 0 roles/collection-office-tools/meta/main.yml | 2 + roles/collection-office-tools/tasks/main.yml | 6 ++ .../collection-security-tools/tasks/main.yml | 7 ++ .../Readme.md | 0 .../meta/main.yml | 0 .../tasks/main.yml | 0 .../Readme.md | 0 .../meta/main.yml | 0 .../tasks/main.yml | 0 .../tasks/main.yml | 0 roles/native-docker/tasks/main.yml | 6 -- roles/native-general/tasks/main.yml | 26 ------ roles/native-gnome/tasks/main.yml | 15 ---- roles/native-msi-perkeyrgb/meta/main.yml | 2 - roles/native-ssh/tasks copy/main.yml | 5 -- .../Readme.md | 0 .../tasks/main.yml | 0 .../{native-gnome => system-gnome}/Readme.md | 0 roles/system-gnome/tasks/main.yml | 27 +++++++ .../tasks/main.yml | 0 .../meta/main.yml | 0 .../tasks/main.yml | 0 .../meta/main.yml | 0 .../tasks/main.yml | 0 .../tasks/main.yml | 0 .../vars/main.yml | 0 .../meta/main.yml | 0 .../tasks/main.yml | 0 .../tasks/main.yml | 0 55 files changed, 128 insertions(+), 134 deletions(-) create mode 100644 roles/application-caffeine/meta/main.yml rename roles/{native-caffeine => application-caffeine}/tasks/main.yml (100%) rename roles/{native-dia => application-dia}/tasks/main.yml (100%) create mode 100644 roles/application-docker/tasks/main.yml rename roles/{native-git => application-git}/tasks/main.yml (100%) rename roles/{native-hunspell => application-hunspell}/tasks/main.yml (100%) create mode 100644 roles/application-java/tasks/main.yml create mode 100644 roles/application-virtual-box/Readme.md rename roles/{native-administrator => collection-administrator-tools-base}/meta/main.yml (100%) rename roles/{native-administrator => collection-administrator-tools-base}/tasks/main.yml (100%) create mode 100644 roles/collection-administrator-tools-network-analyze/meta/main.yml create mode 100644 roles/collection-administrator-tools-network-analyze/tasks/main.yml create mode 100644 roles/collection-developer-tools-arduino/meta/main.yml create mode 100644 roles/collection-developer-tools-arduino/tasks/main.yml create mode 100644 roles/collection-developer-tools-base/meta/main.yml create mode 100644 roles/collection-developer-tools-base/tasks/main.yml create mode 100644 roles/collection-developer-tools-bash/meta/main.yml create mode 100644 roles/collection-developer-tools-bash/tasks/main.yml create mode 100644 roles/collection-developer-tools-java/meta/main.yml create mode 100644 roles/collection-developer-tools-php/meta/main.yml create mode 100644 roles/collection-developer-tools-php/tasks/main.yml create mode 100644 roles/collection-developer-tools-python/meta/main.yml create mode 100644 roles/collection-developer-tools-python/tasks/main.yml rename roles/{native-games => collection-games}/tasks/main.yml (100%) create mode 100644 roles/collection-office-tools/meta/main.yml create mode 100644 roles/collection-office-tools/tasks/main.yml create mode 100644 roles/collection-security-tools/tasks/main.yml rename roles/{native-epson-multiprinter => driver-epson-multiprinter}/Readme.md (100%) rename roles/{native-caffeine => driver-epson-multiprinter}/meta/main.yml (100%) rename roles/{native-epson-multiprinter => driver-epson-multiprinter}/tasks/main.yml (100%) rename roles/{native-msi-perkeyrgb => driver-msi-perkeyrgb}/Readme.md (100%) rename roles/{native-epson-multiprinter => driver-msi-perkeyrgb}/meta/main.yml (100%) rename roles/{native-msi-perkeyrgb => driver-msi-perkeyrgb}/tasks/main.yml (100%) rename roles/{native-non-free-drivers => driver-non-free}/tasks/main.yml (100%) delete mode 100644 roles/native-docker/tasks/main.yml delete mode 100644 roles/native-gnome/tasks/main.yml delete mode 100644 roles/native-msi-perkeyrgb/meta/main.yml delete mode 100644 roles/native-ssh/tasks copy/main.yml rename roles/{native-aur-helper => system-aur-helper}/Readme.md (100%) rename roles/{native-aur-helper => system-aur-helper}/tasks/main.yml (100%) rename roles/{native-gnome => system-gnome}/Readme.md (100%) create mode 100644 roles/system-gnome/tasks/main.yml rename roles/{native-pacman-update => system-pacman}/tasks/main.yml (100%) rename roles/{native-ssh => system-swapfile}/meta/main.yml (100%) rename roles/{native-swapfile => system-swapfile}/tasks/main.yml (100%) rename roles/{native-libreoffice => tool-libreoffice}/meta/main.yml (100%) rename roles/{native-libreoffice => tool-libreoffice}/tasks/main.yml (100%) rename roles/{native-nextcloud-client => tool-nextcloud-client}/tasks/main.yml (100%) rename roles/{native-nextcloud-client => tool-nextcloud-client}/vars/main.yml (100%) rename roles/{native-swapfile => tool-ssh-client}/meta/main.yml (100%) rename roles/{native-ssh => tool-ssh-client}/tasks/main.yml (100%) rename roles/{native-torbrowser => tool-torbrowser}/tasks/main.yml (100%) diff --git a/README.md b/README.md index f249222f..8ff867c1 100644 --- a/README.md +++ b/README.md @@ -14,85 +14,7 @@ ansible-galaxy collection install -r requirements.yml - add native-graphic-designer - add native-developer-basic - add native-workspaces - -# Refactor -```bash -info "Setup, configuration and installation of dependencies for installed software..." - -if pacman -Qi "arduino" > /dev/null ; then - info "Configurate system for arduino..." && - sudo usermod -a -G uucp "$USER" && - sudo usermod -a -G lock "$USER" || error "Couldn't add \"$USER\" to the relevant groups." -fi - -if pacman -Qi "docker" > /dev/null ; then - info "Setting up docker..." && - info "Add current user \"$USER\" to user group docker..." && - sudo usermod -a -G docker "$USER" || error "Failed to add user." - info "Restarting docker service..." && - sudo systemctl restart docker && - info "Disable and stop docker service..." && - sudo systemctl disable --now docker || error "\"systemctl\" produced an error." - info "For performance reasons docker is not enabled. Start docker by executing \"sudo systemctl restart docker\" when you need it." -fi - -if [ ! "$(pacman -Qi "virtualbox")" ] ; then - info "Setting up virtualbox..." && - sudo pacman -S virtualbox "$(pacman -Qsq "^linux" | grep "^linux[0-9]*[-rt]*$" | awk '{print $1"-virtualbox-host-modules"}' ORS=' ')" && - sudo vboxreload && - pamac build virtualbox-ext-oracle && - sudo gpasswd -a "$USER" vboxusers || error - info "Keep in mind to install the guest additions in the virtualized system. See https://wiki.manjaro.org/index.php?title=VirtualBox" -fi - -install_gnome_extension(){ - info "Install GNOME extension \"$1\"..." - extension_folder="$HOME/.local/share/gnome-shell/extensions/$1/" - if [ -d "$extension_folder" ]; - then - if [ -d "$extension_folder"".git" ]; - then - warning "Found a .git repository didn't expect to find this here." && - info "Pulling changes from git..." && - (cd "$extension_folder" && git pull) || error - else - info "No git repository. Extension will not be updated." - fi - else - info "Install..." && - git clone "$2" "$extension_folder" || error - fi - - if [ -f "$extension_folder""Makefile" ]; - then - - tmp_extension_folder="/tmp/$1" - mv "$extension_folder" "$tmp_extension_folder" - info "Compilling extension.." - (cd "$tmp_extension_folder" && make install) || error "Compilation with failed." - - info "Cleaning up tmp-extension folder..."&& - rm -fr "$tmp_extension_folder" || error - - else - info "No Makefile found. Skipping compilation..." - fi - - info "Activating GNOME extension \"$1\"..." && - gnome-extensions enable "$1" || error -} - -if [ "$DESKTOP_SESSION" == "gnome" ]; then - info "Synchronizing gnome tools..." && - install_yay_packages_if_needed "$(get_packages "client/yay/gnome")" || error "Syncronisation failed." - info "Install GNOME extensions..." && - install_gnome_extension "nasa_apod@elinvention.ovh" "https://github.com/Elinvention/gnome-shell-extension-nasa-apod.git" - install_gnome_extension "caffeine@patapon.info" "https://github.com/eonpatapon/gnome-shell-extension-caffeine.git" - info "Deactivating \"Dash to Dock\"..." && - gnome-extensions disable dash-to-dock@micxgx.gmail.com || error - -fi -``` +- add shell-extension-manager # See - https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ diff --git a/playbook.yml b/playbook.yml index 2a4e2fc0..976d133e 100644 --- a/playbook.yml +++ b/playbook.yml @@ -3,10 +3,14 @@ become: true roles: - native-pacman-update - - native-general - native-administrator - native-caffeine - native-non-free-drivers +- name: native-collection-office + hosts: collection_officetools_hosts + become: true + roles: + - native-collection-office - name: GNOME setup hosts: gnome_hosts become: true diff --git a/roles/application-caffeine/meta/main.yml b/roles/application-caffeine/meta/main.yml new file mode 100644 index 00000000..acdfd860 --- /dev/null +++ b/roles/application-caffeine/meta/main.yml @@ -0,0 +1,3 @@ +dependencies: +- native-aur-helper +- system-gnome \ No newline at end of file diff --git a/roles/native-caffeine/tasks/main.yml b/roles/application-caffeine/tasks/main.yml similarity index 100% rename from roles/native-caffeine/tasks/main.yml rename to roles/application-caffeine/tasks/main.yml diff --git a/roles/native-dia/tasks/main.yml b/roles/application-dia/tasks/main.yml similarity index 100% rename from roles/native-dia/tasks/main.yml rename to roles/application-dia/tasks/main.yml diff --git a/roles/application-docker/tasks/main.yml b/roles/application-docker/tasks/main.yml new file mode 100644 index 00000000..d45a5d61 --- /dev/null +++ b/roles/application-docker/tasks/main.yml @@ -0,0 +1,11 @@ +- name: install docker + community.general.pacman: + name: + - docker + - docker-compose + state: present + +- name: Adding user {{client_username}} to relevant arduino usergroups + user: name={{client_username}} + groups=docker + append=yes diff --git a/roles/native-git/tasks/main.yml b/roles/application-git/tasks/main.yml similarity index 100% rename from roles/native-git/tasks/main.yml rename to roles/application-git/tasks/main.yml diff --git a/roles/native-hunspell/tasks/main.yml b/roles/application-hunspell/tasks/main.yml similarity index 100% rename from roles/native-hunspell/tasks/main.yml rename to roles/application-hunspell/tasks/main.yml diff --git a/roles/application-java/tasks/main.yml b/roles/application-java/tasks/main.yml new file mode 100644 index 00000000..53c98527 --- /dev/null +++ b/roles/application-java/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install java + community.general.pacman: + name: + - jdk11-openjdk + state: present diff --git a/roles/application-virtual-box/Readme.md b/roles/application-virtual-box/Readme.md new file mode 100644 index 00000000..343eba11 --- /dev/null +++ b/roles/application-virtual-box/Readme.md @@ -0,0 +1,9 @@ +# application-virtual-box + +```bash + sudo pacman -S virtualbox "$(pacman -Qsq "^linux" | grep "^linux[0-9]*[-rt]*$" | awk '{print $1"-virtualbox-host-modules"}' ORS=' ')" && + sudo vboxreload && + pamac build virtualbox-ext-oracle && + sudo gpasswd -a "$USER" vboxusers || exit 1 + echo "Keep in mind to install the guest additions in the virtualized system. See https://wiki.manjaro.org/index.php?title=VirtualBox" +``` \ No newline at end of file diff --git a/roles/native-administrator/meta/main.yml b/roles/collection-administrator-tools-base/meta/main.yml similarity index 100% rename from roles/native-administrator/meta/main.yml rename to roles/collection-administrator-tools-base/meta/main.yml diff --git a/roles/native-administrator/tasks/main.yml b/roles/collection-administrator-tools-base/tasks/main.yml similarity index 100% rename from roles/native-administrator/tasks/main.yml rename to roles/collection-administrator-tools-base/tasks/main.yml diff --git a/roles/collection-administrator-tools-network-analyze/meta/main.yml b/roles/collection-administrator-tools-network-analyze/meta/main.yml new file mode 100644 index 00000000..cf8941d7 --- /dev/null +++ b/roles/collection-administrator-tools-network-analyze/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-administrator-tools-base \ No newline at end of file diff --git a/roles/collection-administrator-tools-network-analyze/tasks/main.yml b/roles/collection-administrator-tools-network-analyze/tasks/main.yml new file mode 100644 index 00000000..3691918c --- /dev/null +++ b/roles/collection-administrator-tools-network-analyze/tasks/main.yml @@ -0,0 +1,7 @@ +- name: install administrator network analyze tools + community.general.pacman: + name: + - traceroute + - wireshark-qt + - wireshark-cli + state: present diff --git a/roles/collection-developer-tools-arduino/meta/main.yml b/roles/collection-developer-tools-arduino/meta/main.yml new file mode 100644 index 00000000..a0a02398 --- /dev/null +++ b/roles/collection-developer-tools-arduino/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-arduino/tasks/main.yml b/roles/collection-developer-tools-arduino/tasks/main.yml new file mode 100644 index 00000000..07edb31d --- /dev/null +++ b/roles/collection-developer-tools-arduino/tasks/main.yml @@ -0,0 +1,11 @@ +- name: install arduino developer tools + community.general.pacman: + name: + - arduino + - arduino-docs + state: present + +- name: Adding user {{client_username}} to relevant arduino usergroups + user: name={{client_username}} + groups=uucp lock + append=yes diff --git a/roles/collection-developer-tools-base/meta/main.yml b/roles/collection-developer-tools-base/meta/main.yml new file mode 100644 index 00000000..cf8941d7 --- /dev/null +++ b/roles/collection-developer-tools-base/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-administrator-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-base/tasks/main.yml b/roles/collection-developer-tools-base/tasks/main.yml new file mode 100644 index 00000000..2f983f45 --- /dev/null +++ b/roles/collection-developer-tools-base/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install base developer tools + community.general.pacman: + name: + - code + state: present diff --git a/roles/collection-developer-tools-bash/meta/main.yml b/roles/collection-developer-tools-bash/meta/main.yml new file mode 100644 index 00000000..a0a02398 --- /dev/null +++ b/roles/collection-developer-tools-bash/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-bash/tasks/main.yml b/roles/collection-developer-tools-bash/tasks/main.yml new file mode 100644 index 00000000..e771680d --- /dev/null +++ b/roles/collection-developer-tools-bash/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install bash developer tools + community.general.pacman: + name: + - shellcheck + state: present diff --git a/roles/collection-developer-tools-java/meta/main.yml b/roles/collection-developer-tools-java/meta/main.yml new file mode 100644 index 00000000..8b24dd36 --- /dev/null +++ b/roles/collection-developer-tools-java/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- application-java \ No newline at end of file diff --git a/roles/collection-developer-tools-php/meta/main.yml b/roles/collection-developer-tools-php/meta/main.yml new file mode 100644 index 00000000..a0a02398 --- /dev/null +++ b/roles/collection-developer-tools-php/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-php/tasks/main.yml b/roles/collection-developer-tools-php/tasks/main.yml new file mode 100644 index 00000000..195f723d --- /dev/null +++ b/roles/collection-developer-tools-php/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install php developer tools + community.general.pacman: + name: + - php + state: present diff --git a/roles/collection-developer-tools-python/meta/main.yml b/roles/collection-developer-tools-python/meta/main.yml new file mode 100644 index 00000000..a0a02398 --- /dev/null +++ b/roles/collection-developer-tools-python/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-python/tasks/main.yml b/roles/collection-developer-tools-python/tasks/main.yml new file mode 100644 index 00000000..6becf91b --- /dev/null +++ b/roles/collection-developer-tools-python/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install python developer tools + community.general.pacman: + name: + - python + state: present diff --git a/roles/native-games/tasks/main.yml b/roles/collection-games/tasks/main.yml similarity index 100% rename from roles/native-games/tasks/main.yml rename to roles/collection-games/tasks/main.yml diff --git a/roles/collection-office-tools/meta/main.yml b/roles/collection-office-tools/meta/main.yml new file mode 100644 index 00000000..a5fa2770 --- /dev/null +++ b/roles/collection-office-tools/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- native-libreoffice \ No newline at end of file diff --git a/roles/collection-office-tools/tasks/main.yml b/roles/collection-office-tools/tasks/main.yml new file mode 100644 index 00000000..28357887 --- /dev/null +++ b/roles/collection-office-tools/tasks/main.yml @@ -0,0 +1,6 @@ +- name: install shutter + community.general.pacman: + name: + - chromium + - shutter + state: present diff --git a/roles/collection-security-tools/tasks/main.yml b/roles/collection-security-tools/tasks/main.yml new file mode 100644 index 00000000..c1db09fa --- /dev/null +++ b/roles/collection-security-tools/tasks/main.yml @@ -0,0 +1,7 @@ +- name: install security tools + community.general.pacman: + name: + - ecryptfs-utils + - encfs + - keepassxc + state: present diff --git a/roles/native-epson-multiprinter/Readme.md b/roles/driver-epson-multiprinter/Readme.md similarity index 100% rename from roles/native-epson-multiprinter/Readme.md rename to roles/driver-epson-multiprinter/Readme.md diff --git a/roles/native-caffeine/meta/main.yml b/roles/driver-epson-multiprinter/meta/main.yml similarity index 100% rename from roles/native-caffeine/meta/main.yml rename to roles/driver-epson-multiprinter/meta/main.yml diff --git a/roles/native-epson-multiprinter/tasks/main.yml b/roles/driver-epson-multiprinter/tasks/main.yml similarity index 100% rename from roles/native-epson-multiprinter/tasks/main.yml rename to roles/driver-epson-multiprinter/tasks/main.yml diff --git a/roles/native-msi-perkeyrgb/Readme.md b/roles/driver-msi-perkeyrgb/Readme.md similarity index 100% rename from roles/native-msi-perkeyrgb/Readme.md rename to roles/driver-msi-perkeyrgb/Readme.md diff --git a/roles/native-epson-multiprinter/meta/main.yml b/roles/driver-msi-perkeyrgb/meta/main.yml similarity index 100% rename from roles/native-epson-multiprinter/meta/main.yml rename to roles/driver-msi-perkeyrgb/meta/main.yml diff --git a/roles/native-msi-perkeyrgb/tasks/main.yml b/roles/driver-msi-perkeyrgb/tasks/main.yml similarity index 100% rename from roles/native-msi-perkeyrgb/tasks/main.yml rename to roles/driver-msi-perkeyrgb/tasks/main.yml diff --git a/roles/native-non-free-drivers/tasks/main.yml b/roles/driver-non-free/tasks/main.yml similarity index 100% rename from roles/native-non-free-drivers/tasks/main.yml rename to roles/driver-non-free/tasks/main.yml diff --git a/roles/native-docker/tasks/main.yml b/roles/native-docker/tasks/main.yml deleted file mode 100644 index 75af8363..00000000 --- a/roles/native-docker/tasks/main.yml +++ /dev/null @@ -1,6 +0,0 @@ -- name: Install docker - community.general.pacman: - name: - - docker - - docker-compose - state: present diff --git a/roles/native-general/tasks/main.yml b/roles/native-general/tasks/main.yml index 81eed79d..fe441439 100644 --- a/roles/native-general/tasks/main.yml +++ b/roles/native-general/tasks/main.yml @@ -1,43 +1,17 @@ - name: install general software community.general.pacman: name: - # programing language interpreters - #- jdk11-openjdk - #- python - #- php - # description language interpreters #- texlive-most # compression tools #- p7zip - # network analyze tools - #- traceroute - #- wireshark-qt - #- wireshark-cli - - # security tools - #- ecryptfs-utils - #- encfs - #- keepassxc - - # browsers - - chromium - # video/picture manipulation #- gimp #- blender #- obs-studio - # code quality tools - #- shellcheck - - # ide's - #- atom - #- arduino - #- arduino-docs - # virtualization tools #- qemu state: present diff --git a/roles/native-gnome/tasks/main.yml b/roles/native-gnome/tasks/main.yml deleted file mode 100644 index 778451f9..00000000 --- a/roles/native-gnome/tasks/main.yml +++ /dev/null @@ -1,15 +0,0 @@ -- name: Install Gnome Software - community.general.pacman: - name: - - gnome-shell-extensions - - gnome-shell-extension-desktop-icons-ng - - gnome-terminal - state: present - -- name: GNOME Activate Extensions - ansible.builtin.shell: gsettings set org.gnome.shell disable-user-extensions false - become: false - -- name: GNOME Set favorite apps - ansible.builtin.shell: gsettings set org.gnome.shell favorite-apps "{{favorite_apps}}" - become: false diff --git a/roles/native-msi-perkeyrgb/meta/main.yml b/roles/native-msi-perkeyrgb/meta/main.yml deleted file mode 100644 index 795fd094..00000000 --- a/roles/native-msi-perkeyrgb/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- native-aur-helper \ No newline at end of file diff --git a/roles/native-ssh/tasks copy/main.yml b/roles/native-ssh/tasks copy/main.yml deleted file mode 100644 index 738d4211..00000000 --- a/roles/native-ssh/tasks copy/main.yml +++ /dev/null @@ -1,5 +0,0 @@ -- name: Install caffeine - kewlfft.aur.aur: - use: yay - name: - - caffeine-ng \ No newline at end of file diff --git a/roles/native-aur-helper/Readme.md b/roles/system-aur-helper/Readme.md similarity index 100% rename from roles/native-aur-helper/Readme.md rename to roles/system-aur-helper/Readme.md diff --git a/roles/native-aur-helper/tasks/main.yml b/roles/system-aur-helper/tasks/main.yml similarity index 100% rename from roles/native-aur-helper/tasks/main.yml rename to roles/system-aur-helper/tasks/main.yml diff --git a/roles/native-gnome/Readme.md b/roles/system-gnome/Readme.md similarity index 100% rename from roles/native-gnome/Readme.md rename to roles/system-gnome/Readme.md diff --git a/roles/system-gnome/tasks/main.yml b/roles/system-gnome/tasks/main.yml new file mode 100644 index 00000000..5ae505e8 --- /dev/null +++ b/roles/system-gnome/tasks/main.yml @@ -0,0 +1,27 @@ +- name: Install Gnome Software + community.general.pacman: + name: + - gnome-shell-extensions + - gnome-shell-extension-desktop-icons-ng + - gnome-terminal + state: present + +- name: GNOME Activate Extensions + ansible.builtin.shell: gsettings set org.gnome.shell disable-user-extensions false + become: false + +- name: GNOME Set favorite apps + ansible.builtin.shell: gsettings set org.gnome.shell favorite-apps "{{favorite_apps}}" + become: false + +- name: pull CLI GNOME Extension manager script + git: + repo: "git@github.com:kevinveenbirkenbach/cli-gnome-extension-manager.git" + dest: "$HOME/Repositories/github.com/kevinveenbirkenbach/cli-gnome-extension-manager" + update: yes + become: false + +- name: Execute CLI GNOME Extension manager script + ansible.builtin.shell: bash "/home/{{client_username}}/Repositories/github.com/kevinveenbirkenbach/cli-gnome-extension-manager/gnome-extension-manager.sh" "{{ item[0] }}" "{{ item[1] }}" "{{ item[2] }}" + loop: "{{gnome_extensions}}" + become: true diff --git a/roles/native-pacman-update/tasks/main.yml b/roles/system-pacman/tasks/main.yml similarity index 100% rename from roles/native-pacman-update/tasks/main.yml rename to roles/system-pacman/tasks/main.yml diff --git a/roles/native-ssh/meta/main.yml b/roles/system-swapfile/meta/main.yml similarity index 100% rename from roles/native-ssh/meta/main.yml rename to roles/system-swapfile/meta/main.yml diff --git a/roles/native-swapfile/tasks/main.yml b/roles/system-swapfile/tasks/main.yml similarity index 100% rename from roles/native-swapfile/tasks/main.yml rename to roles/system-swapfile/tasks/main.yml diff --git a/roles/native-libreoffice/meta/main.yml b/roles/tool-libreoffice/meta/main.yml similarity index 100% rename from roles/native-libreoffice/meta/main.yml rename to roles/tool-libreoffice/meta/main.yml diff --git a/roles/native-libreoffice/tasks/main.yml b/roles/tool-libreoffice/tasks/main.yml similarity index 100% rename from roles/native-libreoffice/tasks/main.yml rename to roles/tool-libreoffice/tasks/main.yml diff --git a/roles/native-nextcloud-client/tasks/main.yml b/roles/tool-nextcloud-client/tasks/main.yml similarity index 100% rename from roles/native-nextcloud-client/tasks/main.yml rename to roles/tool-nextcloud-client/tasks/main.yml diff --git a/roles/native-nextcloud-client/vars/main.yml b/roles/tool-nextcloud-client/vars/main.yml similarity index 100% rename from roles/native-nextcloud-client/vars/main.yml rename to roles/tool-nextcloud-client/vars/main.yml diff --git a/roles/native-swapfile/meta/main.yml b/roles/tool-ssh-client/meta/main.yml similarity index 100% rename from roles/native-swapfile/meta/main.yml rename to roles/tool-ssh-client/meta/main.yml diff --git a/roles/native-ssh/tasks/main.yml b/roles/tool-ssh-client/tasks/main.yml similarity index 100% rename from roles/native-ssh/tasks/main.yml rename to roles/tool-ssh-client/tasks/main.yml diff --git a/roles/native-torbrowser/tasks/main.yml b/roles/tool-torbrowser/tasks/main.yml similarity index 100% rename from roles/native-torbrowser/tasks/main.yml rename to roles/tool-torbrowser/tasks/main.yml From 191d7a790792180b2507185fd573dde28166afce Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 21:54:18 +0200 Subject: [PATCH 23/43] Adapted role names --- playbook.yml | 48 +++++++++++-------- .../meta/main.yml | 0 .../tasks/main.yml | 0 .../tasks/main.yml | 0 .../vars/main.yml | 0 roles/application-ssh/meta/main.yml | 2 + .../tasks/main.yml | 0 .../tasks/main.yml | 0 .../meta/main.yml | 2 +- roles/collection-office-tools/meta/main.yml | 2 +- roles/system-gnome/Readme.md | 2 +- roles/system-swapfile/meta/main.yml | 2 +- roles/tool-ssh-client/meta/main.yml | 2 - 13 files changed, 33 insertions(+), 27 deletions(-) rename roles/{tool-libreoffice => application-libreoffice}/meta/main.yml (100%) rename roles/{tool-libreoffice => application-libreoffice}/tasks/main.yml (100%) rename roles/{tool-nextcloud-client => application-nextcloud-client}/tasks/main.yml (100%) rename roles/{tool-nextcloud-client => application-nextcloud-client}/vars/main.yml (100%) create mode 100644 roles/application-ssh/meta/main.yml rename roles/{tool-ssh-client => application-ssh}/tasks/main.yml (100%) rename roles/{tool-torbrowser => application-torbrowser}/tasks/main.yml (100%) delete mode 100644 roles/tool-ssh-client/meta/main.yml diff --git a/playbook.yml b/playbook.yml index 976d133e..7c29195d 100644 --- a/playbook.yml +++ b/playbook.yml @@ -2,67 +2,73 @@ hosts: all become: true roles: - - native-pacman-update - - native-administrator - - native-caffeine - - native-non-free-drivers -- name: native-collection-office + - system-pacman + - collection-administrator-tools-base + - application-caffeine + - driver-non-free + +- name: collection-office-tools hosts: collection_officetools_hosts become: true roles: - - native-collection-office + - collection-office-tools + - name: GNOME setup hosts: gnome_hosts become: true roles: - - native-gnome + - system-gnome + - name: setup msi rgb keyboard hosts: msi_perkeyrgb_hosts become: true roles: - - native-msi-perkeyrgb + - driver-msi-perkeyrgb + - name: setup ssh hosts hosts: ssh_hosts become: false roles: - - native-msi-perkeyrgb + - application-ssh + - name: setup swapfile hosts hosts: swapfile_hosts become: false roles: - - role: native-swapfile + - role: driver-swapfile + - name: setup gaming hosts hosts: gaming_hosts become: true roles: - - native-games + - collection-games + - name: setup multiprinter hosts hosts: epson_multiprinter_hosts become: true roles: - - native-epson-multiprinter + - driver-epson-multiprinter + - name: setup torbrowser hosts hosts: torbrowser_hosts become: true roles: - - native-torbrowser -- name: setup libreoffice hosts - hosts: libreoffice_hosts - become: true - roles: - - native-libreoffice + - application-torbrowser + - name: setup nextcloud-client hosts: nextcloud_client_hosts become: true roles: - - native-nextcloud-client + - application-nextcloud-client + - name: setup dia hosts: dia_hosts become: true roles: - - native-dia + - application-dia + - name: setup docker hosts: docker_hosts become: true roles: - - native-docker + - application-docker diff --git a/roles/tool-libreoffice/meta/main.yml b/roles/application-libreoffice/meta/main.yml similarity index 100% rename from roles/tool-libreoffice/meta/main.yml rename to roles/application-libreoffice/meta/main.yml diff --git a/roles/tool-libreoffice/tasks/main.yml b/roles/application-libreoffice/tasks/main.yml similarity index 100% rename from roles/tool-libreoffice/tasks/main.yml rename to roles/application-libreoffice/tasks/main.yml diff --git a/roles/tool-nextcloud-client/tasks/main.yml b/roles/application-nextcloud-client/tasks/main.yml similarity index 100% rename from roles/tool-nextcloud-client/tasks/main.yml rename to roles/application-nextcloud-client/tasks/main.yml diff --git a/roles/tool-nextcloud-client/vars/main.yml b/roles/application-nextcloud-client/vars/main.yml similarity index 100% rename from roles/tool-nextcloud-client/vars/main.yml rename to roles/application-nextcloud-client/vars/main.yml diff --git a/roles/application-ssh/meta/main.yml b/roles/application-ssh/meta/main.yml new file mode 100644 index 00000000..f4aa4bc0 --- /dev/null +++ b/roles/application-ssh/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- application-git \ No newline at end of file diff --git a/roles/tool-ssh-client/tasks/main.yml b/roles/application-ssh/tasks/main.yml similarity index 100% rename from roles/tool-ssh-client/tasks/main.yml rename to roles/application-ssh/tasks/main.yml diff --git a/roles/tool-torbrowser/tasks/main.yml b/roles/application-torbrowser/tasks/main.yml similarity index 100% rename from roles/tool-torbrowser/tasks/main.yml rename to roles/application-torbrowser/tasks/main.yml diff --git a/roles/collection-administrator-tools-base/meta/main.yml b/roles/collection-administrator-tools-base/meta/main.yml index 3bce5ffa..f4aa4bc0 100644 --- a/roles/collection-administrator-tools-base/meta/main.yml +++ b/roles/collection-administrator-tools-base/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- native-git \ No newline at end of file +- application-git \ No newline at end of file diff --git a/roles/collection-office-tools/meta/main.yml b/roles/collection-office-tools/meta/main.yml index a5fa2770..a5c9e617 100644 --- a/roles/collection-office-tools/meta/main.yml +++ b/roles/collection-office-tools/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- native-libreoffice \ No newline at end of file +- application-libreoffice \ No newline at end of file diff --git a/roles/system-gnome/Readme.md b/roles/system-gnome/Readme.md index f53d1b1b..8ade9fc6 100644 --- a/roles/system-gnome/Readme.md +++ b/roles/system-gnome/Readme.md @@ -1,3 +1,3 @@ -# native-gnome +# system-gnome ## further information - https://askubuntu.com/questions/1029376/how-do-i-enable-and-disable-gnome-extensions-from-the-command-line \ No newline at end of file diff --git a/roles/system-swapfile/meta/main.yml b/roles/system-swapfile/meta/main.yml index 3bce5ffa..f4aa4bc0 100644 --- a/roles/system-swapfile/meta/main.yml +++ b/roles/system-swapfile/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- native-git \ No newline at end of file +- application-git \ No newline at end of file diff --git a/roles/tool-ssh-client/meta/main.yml b/roles/tool-ssh-client/meta/main.yml deleted file mode 100644 index 3bce5ffa..00000000 --- a/roles/tool-ssh-client/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- native-git \ No newline at end of file From 9874ae7c2aa001418f9694b30ce14b30d8ca1e51 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 21:58:02 +0200 Subject: [PATCH 24/43] Solved bugs --- playbook.yml | 2 +- roles/application-caffeine/meta/main.yml | 2 +- roles/application-libreoffice/meta/main.yml | 2 +- roles/driver-epson-multiprinter/meta/main.yml | 2 +- roles/driver-msi-perkeyrgb/meta/main.yml | 2 +- 5 files changed, 5 insertions(+), 5 deletions(-) diff --git a/playbook.yml b/playbook.yml index 7c29195d..9d555e21 100644 --- a/playbook.yml +++ b/playbook.yml @@ -35,7 +35,7 @@ hosts: swapfile_hosts become: false roles: - - role: driver-swapfile + - system-swapfile - name: setup gaming hosts hosts: gaming_hosts diff --git a/roles/application-caffeine/meta/main.yml b/roles/application-caffeine/meta/main.yml index acdfd860..175059fe 100644 --- a/roles/application-caffeine/meta/main.yml +++ b/roles/application-caffeine/meta/main.yml @@ -1,3 +1,3 @@ dependencies: -- native-aur-helper +- system-aur-helper - system-gnome \ No newline at end of file diff --git a/roles/application-libreoffice/meta/main.yml b/roles/application-libreoffice/meta/main.yml index ce3fdfe4..acb10ca1 100644 --- a/roles/application-libreoffice/meta/main.yml +++ b/roles/application-libreoffice/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- native-hunspell +- application-hunspell diff --git a/roles/driver-epson-multiprinter/meta/main.yml b/roles/driver-epson-multiprinter/meta/main.yml index 795fd094..f2b89588 100644 --- a/roles/driver-epson-multiprinter/meta/main.yml +++ b/roles/driver-epson-multiprinter/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- native-aur-helper \ No newline at end of file +- system-aur-helper \ No newline at end of file diff --git a/roles/driver-msi-perkeyrgb/meta/main.yml b/roles/driver-msi-perkeyrgb/meta/main.yml index 795fd094..f2b89588 100644 --- a/roles/driver-msi-perkeyrgb/meta/main.yml +++ b/roles/driver-msi-perkeyrgb/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- native-aur-helper \ No newline at end of file +- system-aur-helper \ No newline at end of file From 7b5d1de5c1cacd6be1741a5604c2c086731c1c2b Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 22:09:44 +0200 Subject: [PATCH 25/43] Added dependencies for gnome --- roles/system-gnome/meta/main.yml | 2 ++ roles/system-gnome/tasks/main.yml | 2 +- 2 files changed, 3 insertions(+), 1 deletion(-) create mode 100644 roles/system-gnome/meta/main.yml diff --git a/roles/system-gnome/meta/main.yml b/roles/system-gnome/meta/main.yml new file mode 100644 index 00000000..f4aa4bc0 --- /dev/null +++ b/roles/system-gnome/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- application-git \ No newline at end of file diff --git a/roles/system-gnome/tasks/main.yml b/roles/system-gnome/tasks/main.yml index 5ae505e8..4c0ba26e 100644 --- a/roles/system-gnome/tasks/main.yml +++ b/roles/system-gnome/tasks/main.yml @@ -24,4 +24,4 @@ - name: Execute CLI GNOME Extension manager script ansible.builtin.shell: bash "/home/{{client_username}}/Repositories/github.com/kevinveenbirkenbach/cli-gnome-extension-manager/gnome-extension-manager.sh" "{{ item[0] }}" "{{ item[1] }}" "{{ item[2] }}" loop: "{{gnome_extensions}}" - become: true + become: false From a58f85a4f5ce36e06f3b834b4f016887fdbc6fb2 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 22:26:04 +0200 Subject: [PATCH 26/43] refactored role names --- playbook.yml | 6 +++--- .../tasks/main.yml | 0 .../vars/main.yml | 0 3 files changed, 3 insertions(+), 3 deletions(-) rename roles/{application-nextcloud-client => application-nextcloud}/tasks/main.yml (100%) rename roles/{application-nextcloud-client => application-nextcloud}/vars/main.yml (100%) diff --git a/playbook.yml b/playbook.yml index 9d555e21..4d1f31c6 100644 --- a/playbook.yml +++ b/playbook.yml @@ -55,11 +55,11 @@ roles: - application-torbrowser -- name: setup nextcloud-client - hosts: nextcloud_client_hosts +- name: setup nextcloud + hosts: nextcloud_hosts become: true roles: - - application-nextcloud-client + - application-nextcloud - name: setup dia hosts: dia_hosts diff --git a/roles/application-nextcloud-client/tasks/main.yml b/roles/application-nextcloud/tasks/main.yml similarity index 100% rename from roles/application-nextcloud-client/tasks/main.yml rename to roles/application-nextcloud/tasks/main.yml diff --git a/roles/application-nextcloud-client/vars/main.yml b/roles/application-nextcloud/vars/main.yml similarity index 100% rename from roles/application-nextcloud-client/vars/main.yml rename to roles/application-nextcloud/vars/main.yml From 616bbd019a9b0fcb2439efcfe51777c24ef4dada Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 19 Aug 2022 22:56:11 +0200 Subject: [PATCH 27/43] Added thunderbird --- roles/collection-office-tools/tasks/main.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/roles/collection-office-tools/tasks/main.yml b/roles/collection-office-tools/tasks/main.yml index 28357887..078bf6d5 100644 --- a/roles/collection-office-tools/tasks/main.yml +++ b/roles/collection-office-tools/tasks/main.yml @@ -3,4 +3,5 @@ name: - chromium - shutter + - thunderbird state: present From e7b6e08cda50e433d19ddb354d8ebe729990f46e Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Sun, 4 Sep 2022 20:08:33 +0200 Subject: [PATCH 28/43] implemented blu ray draft --- README.md | 5 ++++- playbook.yml | 6 ++++++ roles/collection-bluray-player/meta/main.yml | 2 ++ roles/collection-bluray-player/readme.md | 7 +++++++ roles/collection-bluray-player/tasks/main.yml | 14 ++++++++++++++ roles/driver-epson-multiprinter/tasks/main.yml | 2 +- 6 files changed, 34 insertions(+), 2 deletions(-) create mode 100644 roles/collection-bluray-player/meta/main.yml create mode 100644 roles/collection-bluray-player/readme.md create mode 100644 roles/collection-bluray-player/tasks/main.yml diff --git a/README.md b/README.md index 8ff867c1..85487488 100644 --- a/README.md +++ b/README.md @@ -14,7 +14,10 @@ ansible-galaxy collection install -r requirements.yml - add native-graphic-designer - add native-developer-basic - add native-workspaces -- add shell-extension-manager +- add https://aur.archlinux.org/packages/displaylink +- add spotify +- add backup to tails usb stick +- https://www.reddit.com/r/ManjaroLinux/comments/cbkblb/guide_run_android_apps_on_manjaro_super_simple/ https://archived.forum.manjaro.org/t/running-android-applications-on-arch-using-anbox/53332 # See - https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ diff --git a/playbook.yml b/playbook.yml index 4d1f31c6..caf0bf76 100644 --- a/playbook.yml +++ b/playbook.yml @@ -13,6 +13,12 @@ roles: - collection-office-tools +- name: collection-bluray-player + hosts: collection_bluray_player_hosts + become: true + roles: + - collection-bluray-player + - name: GNOME setup hosts: gnome_hosts become: true diff --git a/roles/collection-bluray-player/meta/main.yml b/roles/collection-bluray-player/meta/main.yml new file mode 100644 index 00000000..8b24dd36 --- /dev/null +++ b/roles/collection-bluray-player/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- application-java \ No newline at end of file diff --git a/roles/collection-bluray-player/readme.md b/roles/collection-bluray-player/readme.md new file mode 100644 index 00000000..94c42188 --- /dev/null +++ b/roles/collection-bluray-player/readme.md @@ -0,0 +1,7 @@ +# collection-blu-ray-player + +## further information +- https://wiki.archlinux.org/title/Blu-ray#Using_aacskeys +- https://videobyte.de/play-blu-ray-with-vlc +- https://archived.forum.manjaro.org/t/wie-kann-ich-bluray-uhd-abspielen/127396/12 +- http://fvonline-db.bplaced.net/ \ No newline at end of file diff --git a/roles/collection-bluray-player/tasks/main.yml b/roles/collection-bluray-player/tasks/main.yml new file mode 100644 index 00000000..ce6460d9 --- /dev/null +++ b/roles/collection-bluray-player/tasks/main.yml @@ -0,0 +1,14 @@ +- name: install vlc and blu ray software + community.general.pacman: + name: + - vlc + - libaacs + - libbluray + state: present +- name: install AUR packages to play blu ray + kewlfft.aur.aur: + use: yay + name: + - aacskeys + - libbdplus + become: false diff --git a/roles/driver-epson-multiprinter/tasks/main.yml b/roles/driver-epson-multiprinter/tasks/main.yml index 6d649a04..4e9d66e9 100644 --- a/roles/driver-epson-multiprinter/tasks/main.yml +++ b/roles/driver-epson-multiprinter/tasks/main.yml @@ -1,4 +1,4 @@ -- name: Install yay packages for epson +- name: install AUR packages for epson kewlfft.aur.aur: use: yay name: From 772d9f0cc46c5fdfd23096142ef34dec65fb47d6 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Wed, 12 Oct 2022 12:23:33 +0200 Subject: [PATCH 29/43] added intel drivers --- playbook.yml | 6 ++++++ roles/driver-intel/Readme.md | 1 + roles/driver-intel/tasks/main.yml | 4 ++++ 3 files changed, 11 insertions(+) create mode 100644 roles/driver-intel/Readme.md create mode 100644 roles/driver-intel/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index caf0bf76..3d022584 100644 --- a/playbook.yml +++ b/playbook.yml @@ -19,6 +19,12 @@ roles: - collection-bluray-player +- name: driver-intel + hosts: intel_hosts + become: true + roles: + - driver-intel + - name: GNOME setup hosts: gnome_hosts become: true diff --git a/roles/driver-intel/Readme.md b/roles/driver-intel/Readme.md new file mode 100644 index 00000000..5b9f3a95 --- /dev/null +++ b/roles/driver-intel/Readme.md @@ -0,0 +1 @@ +# driver-intel \ No newline at end of file diff --git a/roles/driver-intel/tasks/main.yml b/roles/driver-intel/tasks/main.yml new file mode 100644 index 00000000..00598f1f --- /dev/null +++ b/roles/driver-intel/tasks/main.yml @@ -0,0 +1,4 @@ +- name: install intel drivers + community.general.pacman: + name: intel-media-driver + state: present \ No newline at end of file From ca3459f17804c5338b214600cc3171f8e6a3dbd6 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Thu, 13 Oct 2022 18:29:15 +0200 Subject: [PATCH 30/43] added role latex --- playbook.yml | 6 ++++++ roles/application-latex/readme.md | 3 +++ roles/application-latex/tasks/main.yml | 7 +++++++ 3 files changed, 16 insertions(+) create mode 100644 roles/application-latex/readme.md create mode 100644 roles/application-latex/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index 3d022584..4678d2d7 100644 --- a/playbook.yml +++ b/playbook.yml @@ -25,6 +25,12 @@ roles: - driver-intel +- name: application-latex + hosts: latex_hosts + become: true + roles: + - application-latex + - name: GNOME setup hosts: gnome_hosts become: true diff --git a/roles/application-latex/readme.md b/roles/application-latex/readme.md new file mode 100644 index 00000000..944af617 --- /dev/null +++ b/roles/application-latex/readme.md @@ -0,0 +1,3 @@ +# application-latex + +More packages you will find here: https://wiki.archlinux.org/title/TeX_Live \ No newline at end of file diff --git a/roles/application-latex/tasks/main.yml b/roles/application-latex/tasks/main.yml new file mode 100644 index 00000000..58ac0b2e --- /dev/null +++ b/roles/application-latex/tasks/main.yml @@ -0,0 +1,7 @@ +- name: install latex software + community.general.pacman: + name: + - texlive-latexextra + - texlive-lang + - texlive-langextra + state: present \ No newline at end of file From 9eeb5ec0e30c891dae17ae545f6b12255a9e2af8 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 14 Oct 2022 11:46:19 +0200 Subject: [PATCH 31/43] added texlive-fontsextra to create cv --- roles/application-latex/tasks/main.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/roles/application-latex/tasks/main.yml b/roles/application-latex/tasks/main.yml index 58ac0b2e..013c4532 100644 --- a/roles/application-latex/tasks/main.yml +++ b/roles/application-latex/tasks/main.yml @@ -4,4 +4,5 @@ - texlive-latexextra - texlive-lang - texlive-langextra + - texlive-fontsextra state: present \ No newline at end of file From f51ac6a7ebb1401abfc941504c5319edc097fb7a Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Sat, 10 Dec 2022 22:41:38 +0100 Subject: [PATCH 32/43] Added Workspaces to cloud sync --- roles/application-nextcloud/tasks/main.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/roles/application-nextcloud/tasks/main.yml b/roles/application-nextcloud/tasks/main.yml index b826d060..c3c292a8 100644 --- a/roles/application-nextcloud/tasks/main.yml +++ b/roles/application-nextcloud/tasks/main.yml @@ -19,3 +19,4 @@ - Desktop - Software - Downloads + - Workspaces From 49bc0f436ca8c472f0a120729041443cf1b8862a Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 23 Dec 2022 15:53:56 +0100 Subject: [PATCH 33/43] Added hints what todo --- README.md | 5 +++++ 1 file changed, 5 insertions(+) diff --git a/README.md b/README.md index 85487488..ac731ef2 100644 --- a/README.md +++ b/README.md @@ -10,6 +10,11 @@ ansible-galaxy collection install -r requirements.yml ``` # Todo +- pacman -S retext +- add yay -S qbittorrent +- add yay -S zoom +- add obs-studios +- add yay -S drawio-desktop - add native-office-worker - add native-graphic-designer - add native-developer-basic From 7b0020b3aaa9a101ff2b40003646b7bf0a3b6e31 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 24 Mar 2023 10:18:07 +0100 Subject: [PATCH 34/43] Added dump folder --- README.md | 1 + roles/application-nextcloud/tasks/main.yml | 8 ++++++++ 2 files changed, 9 insertions(+) diff --git a/README.md b/README.md index ac731ef2..a0db7c7d 100644 --- a/README.md +++ b/README.md @@ -11,6 +11,7 @@ ansible-galaxy collection install -r requirements.yml # Todo - pacman -S retext +- add yay -S calibre - add yay -S qbittorrent - add yay -S zoom - add obs-studios diff --git a/roles/application-nextcloud/tasks/main.yml b/roles/application-nextcloud/tasks/main.yml index c3c292a8..0620617c 100644 --- a/roles/application-nextcloud/tasks/main.yml +++ b/roles/application-nextcloud/tasks/main.yml @@ -20,3 +20,11 @@ - Software - Downloads - Workspaces + +- name: Link dump folder + ansible.builtin.file: + src: "{{cloud_directory}}InstantUpload" + dest: "{{user_home_directory}}Dump" + owner: "{{client_username}}" + group: "{{client_username}}" + state: link \ No newline at end of file From 1909e98a75fd6126ed0a57538e313da343fb6052 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 24 Mar 2023 11:14:27 +0100 Subject: [PATCH 35/43] Cleaned up repository --- README.md | 41 +++++++++++-------- playbook.yml | 30 ++++++++++++-- roles/application-latex/tasks/main.yml | 1 + .../meta/main.yml | 0 .../tasks/main.yml | 1 + .../meta/main.yml | 2 + .../tasks/main.yml | 0 .../meta/main.yml | 2 - roles/collection-designer/meta/main.yml | 2 + roles/collection-designer/tasks/main.yml | 7 ++++ .../meta/main.yml | 2 + .../tasks/main.yml | 0 roles/collection-developer-base/meta/main.yml | 2 + .../tasks/main.yml | 0 roles/collection-developer-bash/meta/main.yml | 2 + .../tasks/main.yml | 0 .../meta/main.yml | 0 roles/collection-developer-php/meta/main.yml | 2 + .../tasks/main.yml | 0 .../collection-developer-python/meta/main.yml | 2 + .../tasks/main.yml | 0 .../meta/main.yml | 2 - .../meta/main.yml | 2 - .../meta/main.yml | 2 - .../meta/main.yml | 2 - .../meta/main.yml | 2 - roles/collection-entertainment/meta/main.yml | 2 + roles/collection-entertainment/tasks/main.yml | 5 +++ roles/collection-office-tools/meta/main.yml | 2 - roles/collection-office/meta/main.yml | 3 ++ .../tasks/main.yml | 4 +- roles/collection-streamer/tasks/main.yml | 5 +++ roles/collection-torrent/meta/main.yml | 2 + roles/collection-torrent/tasks/main.yml | 5 +++ roles/collection-video-conference/README.md | 4 ++ .../collection-video-conference/meta/main.yml | 2 + .../tasks/main.yml | 5 +++ roles/native-general/tasks/main.yml | 17 -------- 38 files changed, 109 insertions(+), 53 deletions(-) rename roles/{collection-administrator-tools-base => collection-administrator-base}/meta/main.yml (100%) rename roles/{collection-administrator-tools-base => collection-administrator-base}/tasks/main.yml (92%) create mode 100644 roles/collection-administrator-network-analyze/meta/main.yml rename roles/{collection-administrator-tools-network-analyze => collection-administrator-network-analyze}/tasks/main.yml (100%) delete mode 100644 roles/collection-administrator-tools-network-analyze/meta/main.yml create mode 100644 roles/collection-designer/meta/main.yml create mode 100644 roles/collection-designer/tasks/main.yml create mode 100644 roles/collection-developer-arduino/meta/main.yml rename roles/{collection-developer-tools-arduino => collection-developer-arduino}/tasks/main.yml (100%) create mode 100644 roles/collection-developer-base/meta/main.yml rename roles/{collection-developer-tools-base => collection-developer-base}/tasks/main.yml (100%) create mode 100644 roles/collection-developer-bash/meta/main.yml rename roles/{collection-developer-tools-bash => collection-developer-bash}/tasks/main.yml (100%) rename roles/{collection-developer-tools-java => collection-developer-java}/meta/main.yml (100%) create mode 100644 roles/collection-developer-php/meta/main.yml rename roles/{collection-developer-tools-php => collection-developer-php}/tasks/main.yml (100%) create mode 100644 roles/collection-developer-python/meta/main.yml rename roles/{collection-developer-tools-python => collection-developer-python}/tasks/main.yml (100%) delete mode 100644 roles/collection-developer-tools-arduino/meta/main.yml delete mode 100644 roles/collection-developer-tools-base/meta/main.yml delete mode 100644 roles/collection-developer-tools-bash/meta/main.yml delete mode 100644 roles/collection-developer-tools-php/meta/main.yml delete mode 100644 roles/collection-developer-tools-python/meta/main.yml create mode 100644 roles/collection-entertainment/meta/main.yml create mode 100644 roles/collection-entertainment/tasks/main.yml delete mode 100644 roles/collection-office-tools/meta/main.yml create mode 100644 roles/collection-office/meta/main.yml rename roles/{collection-office-tools => collection-office}/tasks/main.yml (64%) create mode 100644 roles/collection-streamer/tasks/main.yml create mode 100644 roles/collection-torrent/meta/main.yml create mode 100644 roles/collection-torrent/tasks/main.yml create mode 100644 roles/collection-video-conference/README.md create mode 100644 roles/collection-video-conference/meta/main.yml create mode 100644 roles/collection-video-conference/tasks/main.yml delete mode 100644 roles/native-general/tasks/main.yml diff --git a/README.md b/README.md index a0db7c7d..fccd5a35 100644 --- a/README.md +++ b/README.md @@ -1,30 +1,35 @@ # Client Playbook [![License: AGPL v3](https://img.shields.io/badge/License-AGPL%20v3-blue.svg)](https://www.gnu.org/licenses/agpl-3.0) -Playbook to setup Manjaro GNOME clients. -# Setup +Playbook to setup Manjaro GNOME clients in integration with a server which is configured with the [Server Playbook Software](https://github.com/kevinveenbirkenbach/server-playbook). + +## Included Applications +- [Basic Linux Administration Tools](./roles/collection-administrator-base/) +- [Network Analyzes Tools](./roles/collection-administrator-network-analyze/) +- [Designer Tools](./roles/collection-designer/) +- [Arduino Developer Tools](./roles/collection-developer-arduino/) +- [Basic Developer Tools](./roles/collection-developer-base/) +- [Bash Developer Tools](./roles/collection-developer-bash/) +- [Java Developer Tools](./roles/collection-developer-java/) +- [PHP Developer Tools](./roles/collection-developer-php/) +- [Python Developer Tools](./roles/collection-developer-python/) +- [Entertainment Software](./roles/collection-entertainment/) +- [Games](./roles/collection-games/) +- [Office Tools](./roles/collection-office/) +- [Streaming Tools](./roles/collection-streamer/) +- [Torrent Software](./roles/collection-torrent/) +- ... + +## Setup Run: ```bash ansible-galaxy collection install -r requirements.yml ``` -# Todo -- pacman -S retext -- add yay -S calibre -- add yay -S qbittorrent -- add yay -S zoom -- add obs-studios -- add yay -S drawio-desktop -- add native-office-worker -- add native-graphic-designer -- add native-developer-basic -- add native-workspaces -- add https://aur.archlinux.org/packages/displaylink -- add spotify -- add backup to tails usb stick -- https://www.reddit.com/r/ManjaroLinux/comments/cbkblb/guide_run_android_apps_on_manjaro_super_simple/ https://archived.forum.manjaro.org/t/running-android-applications-on-arch-using-anbox/53332 -# See +## See - https://www.middlewareinventory.com/blog/run-ansible-playbook-locally/ - https://stackoverflow.com/questions/30533372/run-an-ansible-task-only-when-the-hostname-contains-a-string +- https://archived.forum.manjaro.org/t/running-android-applications-on-arch-using-anbox/53332 +- https://www.reddit.com/r/ManjaroLinux/comments/cbkblb/guide_run_android_apps_on_manjaro_super_simple/ diff --git a/playbook.yml b/playbook.yml index 4678d2d7..6b4fc559 100644 --- a/playbook.yml +++ b/playbook.yml @@ -3,15 +3,33 @@ become: true roles: - system-pacman - - collection-administrator-tools-base + - collection-administrator-base - application-caffeine - driver-non-free -- name: collection-office-tools +- name: collection-office hosts: collection_officetools_hosts become: true roles: - - collection-office-tools + - collection-office + +- name: collection-designer + hosts: collection_designer_hosts + become: true + roles: + - collection-designer + +- name: collection-torrent + hosts: collection_torrent_hosts + become: true + roles: + - collection-torrent + +- name: collection-streamer + hosts: collection_streamer_hosts + become: true + roles: + - collection-streamer - name: collection-bluray-player hosts: collection_bluray_player_hosts @@ -61,6 +79,12 @@ roles: - collection-games +- name: setup entertainment hosts + hosts: entertainment_hosts + become: true + roles: + - collection-entertainment + - name: setup multiprinter hosts hosts: epson_multiprinter_hosts become: true diff --git a/roles/application-latex/tasks/main.yml b/roles/application-latex/tasks/main.yml index 013c4532..18b0f09e 100644 --- a/roles/application-latex/tasks/main.yml +++ b/roles/application-latex/tasks/main.yml @@ -5,4 +5,5 @@ - texlive-lang - texlive-langextra - texlive-fontsextra + - texlive-most state: present \ No newline at end of file diff --git a/roles/collection-administrator-tools-base/meta/main.yml b/roles/collection-administrator-base/meta/main.yml similarity index 100% rename from roles/collection-administrator-tools-base/meta/main.yml rename to roles/collection-administrator-base/meta/main.yml diff --git a/roles/collection-administrator-tools-base/tasks/main.yml b/roles/collection-administrator-base/tasks/main.yml similarity index 92% rename from roles/collection-administrator-tools-base/tasks/main.yml rename to roles/collection-administrator-base/tasks/main.yml index 84f3d6d5..f17871c0 100644 --- a/roles/collection-administrator-tools-base/tasks/main.yml +++ b/roles/collection-administrator-base/tasks/main.yml @@ -7,4 +7,5 @@ - gcc - cmake - fdupes + - p7zip state: present diff --git a/roles/collection-administrator-network-analyze/meta/main.yml b/roles/collection-administrator-network-analyze/meta/main.yml new file mode 100644 index 00000000..3d8aaa95 --- /dev/null +++ b/roles/collection-administrator-network-analyze/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-administrator-base \ No newline at end of file diff --git a/roles/collection-administrator-tools-network-analyze/tasks/main.yml b/roles/collection-administrator-network-analyze/tasks/main.yml similarity index 100% rename from roles/collection-administrator-tools-network-analyze/tasks/main.yml rename to roles/collection-administrator-network-analyze/tasks/main.yml diff --git a/roles/collection-administrator-tools-network-analyze/meta/main.yml b/roles/collection-administrator-tools-network-analyze/meta/main.yml deleted file mode 100644 index cf8941d7..00000000 --- a/roles/collection-administrator-tools-network-analyze/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- collection-administrator-tools-base \ No newline at end of file diff --git a/roles/collection-designer/meta/main.yml b/roles/collection-designer/meta/main.yml new file mode 100644 index 00000000..00436756 --- /dev/null +++ b/roles/collection-designer/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- application-dia \ No newline at end of file diff --git a/roles/collection-designer/tasks/main.yml b/roles/collection-designer/tasks/main.yml new file mode 100644 index 00000000..930f907e --- /dev/null +++ b/roles/collection-designer/tasks/main.yml @@ -0,0 +1,7 @@ +- name: install designer tools + community.general.pacman: + name: + - gimp + - blender + - drawio-desktop + state: present diff --git a/roles/collection-developer-arduino/meta/main.yml b/roles/collection-developer-arduino/meta/main.yml new file mode 100644 index 00000000..04afe1e8 --- /dev/null +++ b/roles/collection-developer-arduino/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-base \ No newline at end of file diff --git a/roles/collection-developer-tools-arduino/tasks/main.yml b/roles/collection-developer-arduino/tasks/main.yml similarity index 100% rename from roles/collection-developer-tools-arduino/tasks/main.yml rename to roles/collection-developer-arduino/tasks/main.yml diff --git a/roles/collection-developer-base/meta/main.yml b/roles/collection-developer-base/meta/main.yml new file mode 100644 index 00000000..3d8aaa95 --- /dev/null +++ b/roles/collection-developer-base/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-administrator-base \ No newline at end of file diff --git a/roles/collection-developer-tools-base/tasks/main.yml b/roles/collection-developer-base/tasks/main.yml similarity index 100% rename from roles/collection-developer-tools-base/tasks/main.yml rename to roles/collection-developer-base/tasks/main.yml diff --git a/roles/collection-developer-bash/meta/main.yml b/roles/collection-developer-bash/meta/main.yml new file mode 100644 index 00000000..04afe1e8 --- /dev/null +++ b/roles/collection-developer-bash/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-base \ No newline at end of file diff --git a/roles/collection-developer-tools-bash/tasks/main.yml b/roles/collection-developer-bash/tasks/main.yml similarity index 100% rename from roles/collection-developer-tools-bash/tasks/main.yml rename to roles/collection-developer-bash/tasks/main.yml diff --git a/roles/collection-developer-tools-java/meta/main.yml b/roles/collection-developer-java/meta/main.yml similarity index 100% rename from roles/collection-developer-tools-java/meta/main.yml rename to roles/collection-developer-java/meta/main.yml diff --git a/roles/collection-developer-php/meta/main.yml b/roles/collection-developer-php/meta/main.yml new file mode 100644 index 00000000..04afe1e8 --- /dev/null +++ b/roles/collection-developer-php/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-base \ No newline at end of file diff --git a/roles/collection-developer-tools-php/tasks/main.yml b/roles/collection-developer-php/tasks/main.yml similarity index 100% rename from roles/collection-developer-tools-php/tasks/main.yml rename to roles/collection-developer-php/tasks/main.yml diff --git a/roles/collection-developer-python/meta/main.yml b/roles/collection-developer-python/meta/main.yml new file mode 100644 index 00000000..04afe1e8 --- /dev/null +++ b/roles/collection-developer-python/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- collection-developer-base \ No newline at end of file diff --git a/roles/collection-developer-tools-python/tasks/main.yml b/roles/collection-developer-python/tasks/main.yml similarity index 100% rename from roles/collection-developer-tools-python/tasks/main.yml rename to roles/collection-developer-python/tasks/main.yml diff --git a/roles/collection-developer-tools-arduino/meta/main.yml b/roles/collection-developer-tools-arduino/meta/main.yml deleted file mode 100644 index a0a02398..00000000 --- a/roles/collection-developer-tools-arduino/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-base/meta/main.yml b/roles/collection-developer-tools-base/meta/main.yml deleted file mode 100644 index cf8941d7..00000000 --- a/roles/collection-developer-tools-base/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- collection-administrator-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-bash/meta/main.yml b/roles/collection-developer-tools-bash/meta/main.yml deleted file mode 100644 index a0a02398..00000000 --- a/roles/collection-developer-tools-bash/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-php/meta/main.yml b/roles/collection-developer-tools-php/meta/main.yml deleted file mode 100644 index a0a02398..00000000 --- a/roles/collection-developer-tools-php/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-developer-tools-python/meta/main.yml b/roles/collection-developer-tools-python/meta/main.yml deleted file mode 100644 index a0a02398..00000000 --- a/roles/collection-developer-tools-python/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- collection-developer-tools-base \ No newline at end of file diff --git a/roles/collection-entertainment/meta/main.yml b/roles/collection-entertainment/meta/main.yml new file mode 100644 index 00000000..f2b89588 --- /dev/null +++ b/roles/collection-entertainment/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- system-aur-helper \ No newline at end of file diff --git a/roles/collection-entertainment/tasks/main.yml b/roles/collection-entertainment/tasks/main.yml new file mode 100644 index 00000000..f0a84a34 --- /dev/null +++ b/roles/collection-entertainment/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install entertainment software + kewlfft.aur.aur: + use: yay + name: + - spotify \ No newline at end of file diff --git a/roles/collection-office-tools/meta/main.yml b/roles/collection-office-tools/meta/main.yml deleted file mode 100644 index a5c9e617..00000000 --- a/roles/collection-office-tools/meta/main.yml +++ /dev/null @@ -1,2 +0,0 @@ -dependencies: -- application-libreoffice \ No newline at end of file diff --git a/roles/collection-office/meta/main.yml b/roles/collection-office/meta/main.yml new file mode 100644 index 00000000..c67973f1 --- /dev/null +++ b/roles/collection-office/meta/main.yml @@ -0,0 +1,3 @@ +dependencies: +- application-libreoffice +- collection-video-conference \ No newline at end of file diff --git a/roles/collection-office-tools/tasks/main.yml b/roles/collection-office/tasks/main.yml similarity index 64% rename from roles/collection-office-tools/tasks/main.yml rename to roles/collection-office/tasks/main.yml index 078bf6d5..4870f8e5 100644 --- a/roles/collection-office-tools/tasks/main.yml +++ b/roles/collection-office/tasks/main.yml @@ -1,7 +1,9 @@ -- name: install shutter +- name: install office sofware community.general.pacman: name: - chromium - shutter - thunderbird + - calibre + - retext state: present diff --git a/roles/collection-streamer/tasks/main.yml b/roles/collection-streamer/tasks/main.yml new file mode 100644 index 00000000..960b17da --- /dev/null +++ b/roles/collection-streamer/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install streaming + community.general.pacman: + name: + - obs-studio + state: present diff --git a/roles/collection-torrent/meta/main.yml b/roles/collection-torrent/meta/main.yml new file mode 100644 index 00000000..f2b89588 --- /dev/null +++ b/roles/collection-torrent/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- system-aur-helper \ No newline at end of file diff --git a/roles/collection-torrent/tasks/main.yml b/roles/collection-torrent/tasks/main.yml new file mode 100644 index 00000000..052d132d --- /dev/null +++ b/roles/collection-torrent/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install torrent software + kewlfft.aur.aur: + use: yay + name: + - qbittorrent \ No newline at end of file diff --git a/roles/collection-video-conference/README.md b/roles/collection-video-conference/README.md new file mode 100644 index 00000000..5ab8fdd8 --- /dev/null +++ b/roles/collection-video-conference/README.md @@ -0,0 +1,4 @@ +# collection-video-conference + +## further information +It seems like the microsoft client is not supported nativly on linux anymore: https://aur.archlinux.org/packages/teams \ No newline at end of file diff --git a/roles/collection-video-conference/meta/main.yml b/roles/collection-video-conference/meta/main.yml new file mode 100644 index 00000000..f2b89588 --- /dev/null +++ b/roles/collection-video-conference/meta/main.yml @@ -0,0 +1,2 @@ +dependencies: +- system-aur-helper \ No newline at end of file diff --git a/roles/collection-video-conference/tasks/main.yml b/roles/collection-video-conference/tasks/main.yml new file mode 100644 index 00000000..baf2e7f0 --- /dev/null +++ b/roles/collection-video-conference/tasks/main.yml @@ -0,0 +1,5 @@ +- name: install video conference software + kewlfft.aur.aur: + use: yay + name: + - zoom \ No newline at end of file diff --git a/roles/native-general/tasks/main.yml b/roles/native-general/tasks/main.yml deleted file mode 100644 index fe441439..00000000 --- a/roles/native-general/tasks/main.yml +++ /dev/null @@ -1,17 +0,0 @@ -- name: install general software - community.general.pacman: - name: - # description language interpreters - #- texlive-most - - # compression tools - #- p7zip - - # video/picture manipulation - #- gimp - #- blender - #- obs-studio - - # virtualization tools - #- qemu - state: present From 9253c305b90cecc26a17933ce08ab7336d502caa Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 24 Mar 2023 12:20:00 +0100 Subject: [PATCH 36/43] Solved bugs --- playbook.yml | 6 ------ roles/application-dia/tasks/main.yml | 4 ---- roles/collection-designer/meta/main.yml | 2 +- roles/collection-designer/tasks/main.yml | 8 +++++++- 4 files changed, 8 insertions(+), 12 deletions(-) delete mode 100644 roles/application-dia/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index 6b4fc559..ec15fe08 100644 --- a/playbook.yml +++ b/playbook.yml @@ -103,12 +103,6 @@ roles: - application-nextcloud -- name: setup dia - hosts: dia_hosts - become: true - roles: - - application-dia - - name: setup docker hosts: docker_hosts become: true diff --git a/roles/application-dia/tasks/main.yml b/roles/application-dia/tasks/main.yml deleted file mode 100644 index ab15837c..00000000 --- a/roles/application-dia/tasks/main.yml +++ /dev/null @@ -1,4 +0,0 @@ -- name: Install dia - community.general.pacman: - name: dia - state: present diff --git a/roles/collection-designer/meta/main.yml b/roles/collection-designer/meta/main.yml index 00436756..f2b89588 100644 --- a/roles/collection-designer/meta/main.yml +++ b/roles/collection-designer/meta/main.yml @@ -1,2 +1,2 @@ dependencies: -- application-dia \ No newline at end of file +- system-aur-helper \ No newline at end of file diff --git a/roles/collection-designer/tasks/main.yml b/roles/collection-designer/tasks/main.yml index 930f907e..06463537 100644 --- a/roles/collection-designer/tasks/main.yml +++ b/roles/collection-designer/tasks/main.yml @@ -3,5 +3,11 @@ name: - gimp - blender - - drawio-desktop state: present + +- name: install drawio + kewlfft.aur.aur: + use: yay + name: + - drawio-desktop + become: false From 91724ded0bffbdd6e7961e180d2d282d7d3ed00b Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Fri, 24 Mar 2023 12:24:39 +0100 Subject: [PATCH 37/43] Added nextcloud book folder --- roles/application-nextcloud/tasks/main.yml | 1 + 1 file changed, 1 insertion(+) diff --git a/roles/application-nextcloud/tasks/main.yml b/roles/application-nextcloud/tasks/main.yml index 0620617c..04e54355 100644 --- a/roles/application-nextcloud/tasks/main.yml +++ b/roles/application-nextcloud/tasks/main.yml @@ -20,6 +20,7 @@ - Software - Downloads - Workspaces + - Books - name: Link dump folder ansible.builtin.file: From fe347e1c77030c618399f181888f7cd11085cf1f Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Tue, 11 Apr 2023 21:21:06 +0200 Subject: [PATCH 38/43] Implemented wireguard for client --- playbook.yml | 6 +++++ roles/application-wireguard/README.md | 22 +++++++++++++++++++ roles/application-wireguard/handlers/main.yml | 6 +++++ roles/application-wireguard/tasks/main.yml | 18 +++++++++++++++ 4 files changed, 52 insertions(+) create mode 100644 roles/application-wireguard/README.md create mode 100644 roles/application-wireguard/handlers/main.yml create mode 100644 roles/application-wireguard/tasks/main.yml diff --git a/playbook.yml b/playbook.yml index ec15fe08..58402baf 100644 --- a/playbook.yml +++ b/playbook.yml @@ -7,6 +7,12 @@ - application-caffeine - driver-non-free +- name: application-wireguard + hosts: application_wireguard_hosts + become: true + roles: + - application-wireguard + - name: collection-office hosts: collection_officetools_hosts become: true diff --git a/roles/application-wireguard/README.md b/roles/application-wireguard/README.md new file mode 100644 index 00000000..7e1cb3cf --- /dev/null +++ b/roles/application-wireguard/README.md @@ -0,0 +1,22 @@ +# Role Native Wireguard +Manages wireguard on a client. + +### Create Client Keys +```bash + wg_private_key="$(wg genkey)" + wg_public_key="$(echo "$wg_private_key" | wg pubkey)" + echo "PrivateKey: $wg_private_key" + echo "PublicKey: $wg_public_key" + echo "PresharedKey: $(wg genpsk)" +``` + +## See +- https://golb.hplar.ch/2019/01/expose-server-vpn.html +- https://wiki.archlinux.org/index.php/WireGuard +- https://wireguard.how/server/raspbian/ +- https://www.scaleuptech.com/de/blog/was-ist-und-wie-funktioniert-subnetting/ +- https://bodhilinux.boards.net/thread/450/wireguard-rtnetlink-answers-permission-denied +- https://stackoverflow.com/questions/69140072/unable-to-ssh-into-wireguard-ip-until-i-ping-another-server-from-inside-the-serv +- https://unix.stackexchange.com/questions/717172/why-is-ufw-blocking-acces-to-ssh-via-wireguard +- https://forum.openwrt.org/t/cannot-ssh-to-clients-on-lan-when-accessing-router-via-wireguard-client/132709/3 +- https://serverfault.com/questions/1086297/wireguard-connection-dies-on-ubuntu-peer \ No newline at end of file diff --git a/roles/application-wireguard/handlers/main.yml b/roles/application-wireguard/handlers/main.yml new file mode 100644 index 00000000..6127fc1c --- /dev/null +++ b/roles/application-wireguard/handlers/main.yml @@ -0,0 +1,6 @@ +- name: "restart wireguard" + systemd: + name: wg-quick@wg0.service + state: restarted + enabled: yes + daemon_reload: yes diff --git a/roles/application-wireguard/tasks/main.yml b/roles/application-wireguard/tasks/main.yml new file mode 100644 index 00000000..82e2b6ae --- /dev/null +++ b/roles/application-wireguard/tasks/main.yml @@ -0,0 +1,18 @@ +- name: install wireguard + pacman: + name: wireguard-tools + state: present + +- name: enable ipv4-forwarding + shell: sysctl net.ipv4.ip_forward=1 + +- name: enable ipv6-forwarding + shell: sysctl net.ipv6.conf.all.forwarding=1 + +- name: create /etc/wireguard/wg0.conf + copy: + src: "{{ inventory_dir }}/files/{{ inventory_hostname }}/etc/wireguard/wg0.conf" + dest: /etc/wireguard/wg0.conf + owner: root + group: root + notify: restart wireguard From 02f0b307588d09c7ffbb88f906d72c4299f08d51 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Wed, 12 Apr 2023 14:40:44 +0200 Subject: [PATCH 39/43] Added hint for wireguard ssh bugs --- roles/application-wireguard/README.md | 21 ++++++++++++++++++--- 1 file changed, 18 insertions(+), 3 deletions(-) diff --git a/roles/application-wireguard/README.md b/roles/application-wireguard/README.md index 7e1cb3cf..5c3be34a 100644 --- a/roles/application-wireguard/README.md +++ b/roles/application-wireguard/README.md @@ -1,7 +1,7 @@ # Role Native Wireguard Manages wireguard on a client. -### Create Client Keys +## Create Client Keys ```bash wg_private_key="$(wg genkey)" wg_public_key="$(echo "$wg_private_key" | wg pubkey)" @@ -10,7 +10,20 @@ Manages wireguard on a client. echo "PresharedKey: $(wg genpsk)" ``` -## See +## Debug + +### SSH + +When the SSH connection over wireguard is buggy try: + +```bash +ip li set mtu 1400 dev eth0 +ip li set mtu 1400 dev wlo1 +``` + +This can be connected to the [MTU](https://www.imperva.com/learn/application-security/what-is-mtu-mss/) + +## Other - https://golb.hplar.ch/2019/01/expose-server-vpn.html - https://wiki.archlinux.org/index.php/WireGuard - https://wireguard.how/server/raspbian/ @@ -19,4 +32,6 @@ Manages wireguard on a client. - https://stackoverflow.com/questions/69140072/unable-to-ssh-into-wireguard-ip-until-i-ping-another-server-from-inside-the-serv - https://unix.stackexchange.com/questions/717172/why-is-ufw-blocking-acces-to-ssh-via-wireguard - https://forum.openwrt.org/t/cannot-ssh-to-clients-on-lan-when-accessing-router-via-wireguard-client/132709/3 -- https://serverfault.com/questions/1086297/wireguard-connection-dies-on-ubuntu-peer \ No newline at end of file +- https://serverfault.com/questions/1086297/wireguard-connection-dies-on-ubuntu-peer +- https://unix.stackexchange.com/questions/624987/ssh-fails-to-start-when-listenaddress-is-set-to-wireguard-vpn-ip +- https://serverfault.com/questions/210408/cannot-ssh-debug1-expecting-ssh2-msg-kex-dh-gex-reply \ No newline at end of file From 0ddd068ff565dbc52f422784214cff11a1049f56 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Sun, 16 Apr 2023 08:26:13 +0200 Subject: [PATCH 40/43] Added wireguard debug links to doku --- roles/application-wireguard/README.md | 18 +++++++++++++++++- 1 file changed, 17 insertions(+), 1 deletion(-) diff --git a/roles/application-wireguard/README.md b/roles/application-wireguard/README.md index 5c3be34a..8a4757ae 100644 --- a/roles/application-wireguard/README.md +++ b/roles/application-wireguard/README.md @@ -12,6 +12,22 @@ Manages wireguard on a client. ## Debug +### RTNETLINK answers: Permission denied +When ```systemctl restart wg-quick@wg0.service``` returns __RTNETLINK answers: Permission denied__, modify _/etc/sysctl.conf_: + +```bash +net.ipv6.conf.all.disable_ipv6 = 0 +net.ipv6.conf.default.disable_ipv6 = 0 +net.ipv6.conf.lo.disable_ipv6 = 0 +``` + +Afterwards reload: +```bash +sysctl -p +systemctl restart wg-quick@wg0.service +``` + + ### SSH When the SSH connection over wireguard is buggy try: @@ -21,7 +37,7 @@ ip li set mtu 1400 dev eth0 ip li set mtu 1400 dev wlo1 ``` -This can be connected to the [MTU](https://www.imperva.com/learn/application-security/what-is-mtu-mss/) +This can be connected to the [MTU](https://www.imperva.com/learn/application-security/what-is-mtu-mss/) ## Other - https://golb.hplar.ch/2019/01/expose-server-vpn.html From 7ef4f7973e94cff814f24bc4b443aa7d53371bf8 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Tue, 18 Apr 2023 13:56:43 +0200 Subject: [PATCH 41/43] Solved wireguard bugs --- playbook.yml | 1 - roles/application-caffeine/meta/main.yml | 3 +- roles/application-wireguard/README.md | 35 +++---------------- .../files/set-mtu.service | 10 ++++++ .../files/wireguard-ip.conf | 8 +++++ roles/application-wireguard/handlers/main.yml | 9 ++++- roles/application-wireguard/tasks/main.yml | 22 +++++++++--- .../templates/set-mtu.sh.j2 | 4 +++ roles/system-gnome/meta/main.yml | 3 +- 9 files changed, 56 insertions(+), 39 deletions(-) create mode 100644 roles/application-wireguard/files/set-mtu.service create mode 100644 roles/application-wireguard/files/wireguard-ip.conf create mode 100644 roles/application-wireguard/templates/set-mtu.sh.j2 diff --git a/playbook.yml b/playbook.yml index 58402baf..5740ae85 100644 --- a/playbook.yml +++ b/playbook.yml @@ -4,7 +4,6 @@ roles: - system-pacman - collection-administrator-base - - application-caffeine - driver-non-free - name: application-wireguard diff --git a/roles/application-caffeine/meta/main.yml b/roles/application-caffeine/meta/main.yml index 175059fe..f2b89588 100644 --- a/roles/application-caffeine/meta/main.yml +++ b/roles/application-caffeine/meta/main.yml @@ -1,3 +1,2 @@ dependencies: -- system-aur-helper -- system-gnome \ No newline at end of file +- system-aur-helper \ No newline at end of file diff --git a/roles/application-wireguard/README.md b/roles/application-wireguard/README.md index 8a4757ae..9b8e18c8 100644 --- a/roles/application-wireguard/README.md +++ b/roles/application-wireguard/README.md @@ -10,35 +10,6 @@ Manages wireguard on a client. echo "PresharedKey: $(wg genpsk)" ``` -## Debug - -### RTNETLINK answers: Permission denied -When ```systemctl restart wg-quick@wg0.service``` returns __RTNETLINK answers: Permission denied__, modify _/etc/sysctl.conf_: - -```bash -net.ipv6.conf.all.disable_ipv6 = 0 -net.ipv6.conf.default.disable_ipv6 = 0 -net.ipv6.conf.lo.disable_ipv6 = 0 -``` - -Afterwards reload: -```bash -sysctl -p -systemctl restart wg-quick@wg0.service -``` - - -### SSH - -When the SSH connection over wireguard is buggy try: - -```bash -ip li set mtu 1400 dev eth0 -ip li set mtu 1400 dev wlo1 -``` - -This can be connected to the [MTU](https://www.imperva.com/learn/application-security/what-is-mtu-mss/) - ## Other - https://golb.hplar.ch/2019/01/expose-server-vpn.html - https://wiki.archlinux.org/index.php/WireGuard @@ -50,4 +21,8 @@ This can be connected to the [MTU](https://www.imperva.com/learn/application-sec - https://forum.openwrt.org/t/cannot-ssh-to-clients-on-lan-when-accessing-router-via-wireguard-client/132709/3 - https://serverfault.com/questions/1086297/wireguard-connection-dies-on-ubuntu-peer - https://unix.stackexchange.com/questions/624987/ssh-fails-to-start-when-listenaddress-is-set-to-wireguard-vpn-ip -- https://serverfault.com/questions/210408/cannot-ssh-debug1-expecting-ssh2-msg-kex-dh-gex-reply \ No newline at end of file +- https://serverfault.com/questions/210408/cannot-ssh-debug1-expecting-ssh2-msg-kex-dh-gex-reply +- https://www.thomas-krenn.com/de/wiki/Linux_ip_Kommando +- https://wiki.archlinux.org/title/dhcpcd +- https://wiki.ubuntuusers.de/NetworkManager/Dispatcher/ +- https://askubuntu.com/questions/1024916/how-can-i-launch-a-systemd-service-at-startup-before-another-systemd-service-sta \ No newline at end of file diff --git a/roles/application-wireguard/files/set-mtu.service b/roles/application-wireguard/files/set-mtu.service new file mode 100644 index 00000000..56c48494 --- /dev/null +++ b/roles/application-wireguard/files/set-mtu.service @@ -0,0 +1,10 @@ +[Unit] +Description=set MTU +Before=wg-quick@wg0.service + +[Service] +Type=oneshot +ExecStart=set-mtu.sh + +[Install] +RequiredBy=wg-quick@wg0.service \ No newline at end of file diff --git a/roles/application-wireguard/files/wireguard-ip.conf b/roles/application-wireguard/files/wireguard-ip.conf new file mode 100644 index 00000000..cc0113b9 --- /dev/null +++ b/roles/application-wireguard/files/wireguard-ip.conf @@ -0,0 +1,8 @@ +# This file is created by +# https://github.com/kevinveenbirkenbach/client-playbook/tree/main/roles/application-wireguard + +net.ipv6.conf.all.disable_ipv6 = 0 +net.ipv6.conf.default.disable_ipv6 = 0 +net.ipv6.conf.lo.disable_ipv6 = 0 +net.ipv6.conf.all.forwarding = 1 +net.ipv4.ip_forward = 1 \ No newline at end of file diff --git a/roles/application-wireguard/handlers/main.yml b/roles/application-wireguard/handlers/main.yml index 6127fc1c..246d49a2 100644 --- a/roles/application-wireguard/handlers/main.yml +++ b/roles/application-wireguard/handlers/main.yml @@ -1,6 +1,13 @@ +- name: "restart set-mtu.service" + systemd: + name: set-mtu.service + state: restarted + enabled: yes + daemon_reload: yes + - name: "restart wireguard" systemd: name: wg-quick@wg0.service state: restarted enabled: yes - daemon_reload: yes + daemon_reload: yes \ No newline at end of file diff --git a/roles/application-wireguard/tasks/main.yml b/roles/application-wireguard/tasks/main.yml index 82e2b6ae..80f02c5b 100644 --- a/roles/application-wireguard/tasks/main.yml +++ b/roles/application-wireguard/tasks/main.yml @@ -3,11 +3,25 @@ name: wireguard-tools state: present -- name: enable ipv4-forwarding - shell: sysctl net.ipv4.ip_forward=1 +- name: create set-mtu.service + copy: + src: set-mtu.service + dest: /etc/systemd/system/set-mtu.service + notify: restart set-mtu.service -- name: enable ipv6-forwarding - shell: sysctl net.ipv6.conf.all.forwarding=1 +- name: create set-mtu.sh + template: + src: set-mtu.sh.j2 + dest: /usr/local/bin/set-mtu.sh + notify: restart set-mtu.service + +- name: create wireguard-ip.conf + copy: + src: "wireguard-ip.conf" + dest: /etc/sysctl.d/wireguard-ip.conf + owner: root + group: root + notify: reload sysctl configuration - name: create /etc/wireguard/wg0.conf copy: diff --git a/roles/application-wireguard/templates/set-mtu.sh.j2 b/roles/application-wireguard/templates/set-mtu.sh.j2 new file mode 100644 index 00000000..eae6555f --- /dev/null +++ b/roles/application-wireguard/templates/set-mtu.sh.j2 @@ -0,0 +1,4 @@ +#!/bin/bash +ip li set mtu 1400 dev eth0 +ip li set mtu 1400 dev wlo1 +sysctl -p \ No newline at end of file diff --git a/roles/system-gnome/meta/main.yml b/roles/system-gnome/meta/main.yml index f4aa4bc0..51bba34e 100644 --- a/roles/system-gnome/meta/main.yml +++ b/roles/system-gnome/meta/main.yml @@ -1,2 +1,3 @@ dependencies: -- application-git \ No newline at end of file +- application-git +- application-caffeine \ No newline at end of file From f3d3beab395a4fbe390665966d763985e25b3c50 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Tue, 18 Apr 2023 14:25:10 +0200 Subject: [PATCH 42/43] Solved another wireguard bug --- roles/application-wireguard/handlers/main.yml | 5 ++++- roles/application-wireguard/templates/set-mtu.sh.j2 | 3 +-- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/roles/application-wireguard/handlers/main.yml b/roles/application-wireguard/handlers/main.yml index 246d49a2..7a05661b 100644 --- a/roles/application-wireguard/handlers/main.yml +++ b/roles/application-wireguard/handlers/main.yml @@ -10,4 +10,7 @@ name: wg-quick@wg0.service state: restarted enabled: yes - daemon_reload: yes \ No newline at end of file + daemon_reload: yes + +- name: "reload sysctl configuration" + shell: "sysctl -p" \ No newline at end of file diff --git a/roles/application-wireguard/templates/set-mtu.sh.j2 b/roles/application-wireguard/templates/set-mtu.sh.j2 index eae6555f..e1a8edf1 100644 --- a/roles/application-wireguard/templates/set-mtu.sh.j2 +++ b/roles/application-wireguard/templates/set-mtu.sh.j2 @@ -1,4 +1,3 @@ #!/bin/bash ip li set mtu 1400 dev eth0 -ip li set mtu 1400 dev wlo1 -sysctl -p \ No newline at end of file +ip li set mtu 1400 dev wlo1 \ No newline at end of file From 43258848bb559437a266913dd80d40cf59ca9d98 Mon Sep 17 00:00:00 2001 From: Kevin Veen-Birkenbach Date: Tue, 18 Apr 2023 14:34:03 +0200 Subject: [PATCH 43/43] Added internet_interfaces variable --- roles/application-wireguard/templates/set-mtu.sh.j2 | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/roles/application-wireguard/templates/set-mtu.sh.j2 b/roles/application-wireguard/templates/set-mtu.sh.j2 index e1a8edf1..43313665 100644 --- a/roles/application-wireguard/templates/set-mtu.sh.j2 +++ b/roles/application-wireguard/templates/set-mtu.sh.j2 @@ -1,3 +1,4 @@ #!/bin/bash -ip li set mtu 1400 dev eth0 -ip li set mtu 1400 dev wlo1 \ No newline at end of file +{% for internet_interface in internet_interfaces %} +ip li set mtu 1400 dev {{internet_interface}} +{% endfor %} \ No newline at end of file