From fce467a826f79063f1387f4c428ca5a373e7f7b9 Mon Sep 17 00:00:00 2001 From: Francois B Date: Wed, 27 Dec 2017 14:54:15 +0100 Subject: [PATCH] initial commit --- .gitignore | 4 + LICENSE | 674 +++++++++++++ README.md | 31 + logo.png | Bin 0 -> 13242 bytes notify.mp3 | Bin 0 -> 22986 bytes yggdrasil.sh | 2702 ++++++++++++++++++++++++++++++++++++++++++++++++++ 6 files changed, 3411 insertions(+) create mode 100644 .gitignore create mode 100644 LICENSE create mode 100644 README.md create mode 100644 logo.png create mode 100644 notify.mp3 create mode 100755 yggdrasil.sh diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..4b4e8ae --- /dev/null +++ b/.gitignore @@ -0,0 +1,4 @@ +*.bak +backup/* +deb/* +.remote-sync.json diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..9cecc1d --- /dev/null +++ b/LICENSE @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 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 General Public License is a free, copyleft license for +software and other kinds of works. + + The licenses for most software and other practical works are designed +to take away your freedom to share and change the works. By contrast, +the GNU General Public License is 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. We, the Free Software Foundation, use the +GNU General Public License for most of our software; it applies also to +any other work released this way by its authors. You can apply it to +your programs, too. + + 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. + + To protect your rights, we need to prevent others from denying you +these rights or asking you to surrender the rights. Therefore, you have +certain responsibilities if you distribute copies of the software, or if +you modify it: responsibilities to respect the freedom of others. + + For example, if you distribute copies of such a program, whether +gratis or for a fee, you must pass on to the recipients the same +freedoms that you received. You must make sure that they, too, receive +or can get the source code. And you must show them these terms so they +know their rights. + + Developers that use the GNU GPL protect your rights with two steps: +(1) assert copyright on the software, and (2) offer you this License +giving you legal permission to copy, distribute and/or modify it. + + For the developers' and authors' protection, the GPL clearly explains +that there is no warranty for this free software. For both users' and +authors' sake, the GPL requires that modified versions be marked as +changed, so that their problems will not be attributed erroneously to +authors of previous versions. + + Some devices are designed to deny users access to install or run +modified versions of the software inside them, although the manufacturer +can do so. This is fundamentally incompatible with the aim of +protecting users' freedom to change the software. The systematic +pattern of such abuse occurs in the area of products for individuals to +use, which is precisely where it is most unacceptable. Therefore, we +have designed this version of the GPL to prohibit the practice for those +products. If such problems arise substantially in other domains, we +stand ready to extend this provision to those domains in future versions +of the GPL, as needed to protect the freedom of users. + + Finally, every program is threatened constantly by software patents. +States should not allow patents to restrict development and use of +software on general-purpose computers, but in those that do, we wish to +avoid the special danger that patents applied to a free program could +make it effectively proprietary. To prevent this, the GPL assures that +patents cannot be used to render the program non-free. + + 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 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. Use with the GNU Affero General Public License. + + 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 Affero 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 special requirements of the GNU Affero General Public License, +section 13, concerning interaction through a network will apply to the +combination as such. + + 14. Revised Versions of this License. + + The Free Software Foundation may publish revised and/or new versions of +the GNU 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 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 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 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. + + {one line to give the program's name and a brief idea of what it does.} + Copyright (C) {year} {name of author} + + This program is free software: you can redistribute it and/or modify + it under the terms of the GNU 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 General Public License for more details. + + You should have received a copy of the GNU General Public License + along with this program. If not, see . + +Also add information on how to contact you by electronic and paper mail. + + If the program does terminal interaction, make it output a short +notice like this when it starts in an interactive mode: + + {project} Copyright (C) {year} {fullname} + This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. + This is free software, and you are welcome to redistribute it + under certain conditions; type `show c' for details. + +The hypothetical commands `show w' and `show c' should show the appropriate +parts of the General Public License. Of course, your program's commands +might be different; for a GUI interface, you would use an "about box". + + 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 GPL, see +. + + The GNU General Public License does not permit incorporating your program +into proprietary programs. If your program is a subroutine library, you +may consider it more useful to permit linking proprietary applications with +the library. If this is what you want to do, use the GNU Lesser General +Public License instead of this License. But first, please read +. diff --git a/README.md b/README.md new file mode 100644 index 0000000..6a8e4c5 --- /dev/null +++ b/README.md @@ -0,0 +1,31 @@ +![myInstallScript](https://sirenacorp.be/wp-content/uploads/2016/01/logo-1.png) + +Yggdrasil for Linux Mint 18 +=========================== + +Warnings : this is a Beta version under dev !! However, the script is fully functional ;-) + +The purpose of this script is to provide a full set of tools to install, customize and tweak a fresh installation of Linux Mint 18.x (MATE, x86_64) + +Installation +------------ + +``` +git clone https://github.com/shakasan/Yggdrasil_LM18.git +cd Yggdrasil_LM18 +chmod +x yggdrasil.sh +./yggdrasil.sh +``` + +Credits +------- + +This script has been written by Francois B. (Makotosan/Shakasan) + +* Email : shakasan@sirenacorp.be +* Website : https://sirenacorp.be/ + +Licence +------- + +The script is licensed under the terms of the GPLv3 diff --git a/logo.png b/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..615870ca06f0b265141ded63c48d6a6f2f63a425 GIT binary patch literal 13242 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�y^ZgpN)6w7R@N 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 $logFile + eval $cmd" &>> $logFile" + ret_code=$? + retCode $ret_code +} + +# +# display a message + notification + ask to push a key to continue +# +function pressKey () { + printf "$*\n" + if which mpg123 >/dev/null; then + mpg123 -q $scriptDir/notify.mp3 & + fi + printf "$INV" + read -p "Press key to continue ..." + printf "$NORMAL" +} + +# +# check if OS is Mint +# +function isMint () { + OS=`lsb_release -d | awk -F':' '{print $2}' | awk -F'\t' '{print $2}'` + if [[ $OS == *"Linux Mint 18"* ]]; then + return 0 + else + return 1 + fi +} + +# +# check if DE is Mate +# +function isMate () { + if [[ $DESKTOP_SESSION == *"mate"* ]]; then + return 0 + else + return 1 + fi +} + +# +# system update +# +function updateSystem () { + typeset ret_code + + printf "[APT] update " + printf "\n[APT] update\n" &>> $logFile + sudo apt-get update &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" + + printf "[APT] upgrade " + printf "\n[APT] upgrade\n" &>> $logFile + sudo apt-get -y upgrade &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" + + printf "[APT] dist-upgrade " + printf "\n[APT] dist-upgrade\n" &>> $logFile + sudo apt-get -y dist-upgrade &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" +} + +# +# add ppa +# input : ppa name +# +function addPPA () { + typeset ret_code + printf "[PPA] adding : $* " + printf "\n[PPA] adding $*\n" &>> $logFile + sudo add-apt-repository -y $* &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" +} + +# +# add repo's key +# input : file's url OR keyserver + key +# +function addKey () { + typeset ret_code + + case $# in + "1") + printf "[REPO] adding key from file : $1 " + printf "\n[REPO] adding key from file $1\n" &>> $logFile + wget -qO - $1 | sudo apt-key add - &>> $logFile + ret_code=$? + retCode $ret_code + ;; + "2") + printf "[REPO] adding key $2 from $1 " + printf "\n[REPO] adding key $2 from $1\n" &>> $logFile + sudo apt-key adv --keyserver $1 --recv-keys $2 - &>> $logFile + ret_code=$? + retCode $ret_code + ;; + esac + printf "\n" +} + +# +# create new entry in /etc/apt/source.list.d/ +# input : filename, repo, src repo +# +function addRepo () { + typeset ret_code + printf "[REPO] adding : $2 in $1" + printf "\n[REPO] adding $2 in $1\n" &>> $logFile + echo $2 | sudo tee /etc/apt/sources.list.d/$1 &>> $logFile + ret_code=$? + retCode $ret_code + if [ "$#" -eq 3 ]; then + printf "[REPO] adding : $3 in $1" + printf "\n[REPO] adding $3 in $1\n" &>> $logFile + echo $3 | sudo tee -a /etc/apt/sources.list.d/$1 &>> $logFile + ret_code=$? + retCode $ret_code + fi + printf "\n" +} + +# +# install package from repositories +# input : package manager, package name +# package manager available : apt, pip, npm, gem +# +function installPackage () { + typeset pkg="$*" + typeset ret_code + + case $1 in + "apt") + printf "[APT] Installing by $* " + printf "\n[APT] installing by $*\n" &>> $logFile + sudo apt-get install -fy $* &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" + ;; + "pip") + if which pip3 >/dev/null; then + printf "[PIP] Installing by $* " + printf "\n[PIP] installing by $*\n" &>> $logFile + sudo -H pip3 install --upgrade $* &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" + else + printf "[ERR] pip3 not found, installing...\n" + printf "\n[ERR] pip3 not found, installing...\n" &>> $logFile + installPackage apt "python3-pip" + fi + ;; + "npm") + if which npm >/dev/null; then + printf "[NPM] Installing by $* " + printf "\n[NPM] installing by $*\n" &>> $logFile + sudo npm install -g $* &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" + else + printf "[ERR] npm not found, installing...\n" + printf "\n[ERR] npm not found, installing...\n" &>> $logFile + installPackage apt "npm" + fi + ;; + "gem") + if which gem >/dev/null; then + printf "[GEM] Installing by $* " + printf "\n[GEM] installing by $*\n" &>> $logFile + sudo gem install $* &>> $logFile + ret_code=$? + retCode $ret_code + printf "\n" + else + printf "[ERR] gem not found, installing...\n" + printf "\n[ERR] gem not found, installing...\n" &>> $logFile + installPackage apt "ruby-dev" + fi + ;; + esac +} + +# +# check dependency and install it if necessary +# input : package manager, package name +# +function checkAndInstallDep () { + if ! which $2 >/dev/null; then + printf "[DEP] check dependency : $2 [ ""$BOLDROUGE""!!"$NORMAL" ]\n" + printf "[ERR] dependency $2 not found\n" &>> $logFile + case $1 in + "apt") + installPackage apt $2 + ;; + "npm") + installPackage npm $2 + ;; + "pip") + installPackage pip $2 + ;; + "gem") + installPackage gem $2 + ;; + esac + fi +} + +# +# dependencies used in the script checked and installed if necessary +# +function depCheck () { + printf "$BOLDJAUNE""Script dependencies checking\n\n""$NORMAL" + checkAndInstallDep apt mpg123 + checkAndInstallDep apt libnotify-bin + checkAndInstallDep apt lsb-release + checkAndInstallDep apt cifs-utils +} + +# +# install required ppa and settings +# +function addRequiredPPA () { + msg "Adding PPA and repositories" + + runCmd "sudo dpkg --add-architecture i386" + + installPackage apt "apt-transport-https" + + runCmd "echo sience-config science-config/group select '$myHomedir ($myHomedir)' | sudo debconf-set-selections" + + addPPA "ppa:noobslab/themes" # themes from noobslab + addPPA "ppa:noobslab/icons" # icons from noobslab + addPPA "ppa:numix/ppa" # theme Numix + addPPA "ppa:ravefinity-project/ppa" # Themes + addPPA "ppa:teejee2008/ppa" # Aptik - Conky-Manage + addPPA "ppa:yktooo/ppa" # indicator-sound-switcher + addPPA "ppa:webupd8team/y-ppa-manager" # y-ppa-manager + addPPA "ppa:webupd8team/atom" # IDE + addPPA "ppa:videolan/stable-daily" # video player + addPPA "ppa:ubuntu-desktop/ubuntu-make" # ubuntu-make + addPPA "ppa:nowrep/qupzilla" # web browser + addPPA "ppa:atareao/atareao" # pushbullet-indicator, imagedownloader, gqrcode, cpu-g + addPPA "ppa:fossfreedom/rhythmbox-plugins"; # Rhythmbox plugins + addPPA "ppa:fossfreedom/rhythmbox" # Rhythmbox + addPPA "ppa:nilarimogard/webupd8" # Audacious, Grive2, Pidgin-indicator + addPPA "ppa:oibaf/graphics-drivers" # free graphics-drivers + mesa + addPPA "ppa:team-xbmc/ppa" # Kodi + addPPA "ppa:webupd8team/java" # Oracle Java SE 7/8 + addPPA "ppa:hugin/hugin-builds" # image editor + addPPA "ppa:mumble/release" # Mumble + addPPA "ppa:atareao/utext" # Markdown editor + addPPA "ppa:danielrichter2007/grub-customizer" # grub-customizer + addPPA "ppa:lucioc/sayonara" # audio player + addPPA "ppa:haraldhv/shotcut" # video editor + addPPA "ppa:flacon/ppa" # audio extraction + addPPA "ppa:jaap.karssenberg/zim" # local wiki + addPPA "ppa:pmjdebruijn/darktable-release" # raw editor + addPPA "ppa:js-reynaud/kicad-4" # CAD + addPPA "ppa:stebbins/handbrake-releases" # video transcoder + addPPA "ppa:webupd8team/brackets" # IDE + addPPA "ppa:graphics-drivers/ppa" # non-free nvidia drivers + addPPA "ppa:djcj/hybrid" # FFMpeg, MKVToolnix + addPPA "ppa:diodon-team/stable" # clipboard manager + addPPA "ppa:notepadqq-team/notepadqq" # notepad++ clone + addPPA "ppa:mariospr/frogr" # flickr manager + addPPA "ppa:ubuntuhandbook1/slowmovideo" # slow motion video editor + addPPA "ppa:transmissionbt/ppa" # bittorrent client + addPPA "ppa:geary-team/releases" # email client + addPPA "ppa:ubuntuhandbook1/corebird" # corebird + addPPA "ppa:tista/adapta" # adapta gtk theme + addPPA "ppa:maarten-baert/simplescreenrecorder" # simplescreenrecorder + addPPA "ppa:dhor/myway" # rawtherapee (newer version) + addPPA "ppa:zeal-developers/ppa" # Zeal (newer version) + addPPA "ppa:nextcloud-devs/client" # NextCloud client + addPPA "ppa:deluge-team/ppa" # Deluge P2P client + addPPA "ppa:kritalime/ppa" # Krita + addPPA "ppa:otto-kesselgulasch/gimp" # Gmic2 + addPPA "ppa:ozmartian/apps" # Vidcutter + addPPA "ppa:fossproject/ppa" # green-recorder + addPPA "ppa:quiterss/quiterss" # quiterss + addPPA "ppa:tmsu/ppa" # tmsu + addPPA "ppa:ansible/ansible" # ansiaddmsg "Adding Opera repository" + + addKey "http://deb.opera.com/archive.key" + addRepo opera.list "deb http://deb.opera.com/opera-stable/ stable non-free" + + addKey "https://dl.google.com/linux/linux_signing_key.pub" + addRepo google-chrome.list "deb [arch=amd64] http://dl.google.com/linux/chrome/deb/ stable main" + + addKey "https://d2t3ff60b2tol4.cloudfront.net/services@insynchq.com.gpg.key" + addRepo insync.list "deb http://apt.insynchq.com/ubuntu xenial non-free contrib" + + addKey "hkp://p80.pool.sks-keyservers.net:80" "58118E89F3A912897C070ADBF76221572C52609D" + addRepo docker.list "deb https://apt.dockerproject.org/repo ubuntu-xenial main" + + addKey "https://syncthing.net/release-key.txt" + addRepo syncthing.list "deb http://apt.syncthing.net/ syncthing release" + + addKey "http://download.opensuse.org/repositories/isv:ownCloud:desktop/Ubuntu_16.04/Release.key" + addRepo owncloud-client.list "deb http://download.opensuse.org/repositories/isv:/ownCloud:/desktop/Ubuntu_16.04/ /" + + addKey "https://mkvtoolnix.download/gpg-pub-moritzbunkus.txt" + addRepo mkv.list "deb http://mkvtoolnix.download/ubuntu/xenial/ ./" "deb-src http://mkvtoolnix.download/ubuntu/xenial/ ./ " + + addKey "https://jgeboski.github.io/obs.key" + addRepo jgeboski.list "deb http://download.opensuse.org/repositories/home:/jgeboski/xUbuntu_16.04/ ./" + + addKey "hkp://keyserver.ubuntu.com:80" "BBEBDCB318AD50EC6865090613B00F1FD2C19886" + addRepo spotify.list "deb http://repository.spotify.com stable non-free" + + addKey "http://download.virtualbox.org/virtualbox/debian/oracle_vbox.asc" + addKey "http://download.virtualbox.org/virtualbox/debian/oracle_vbox_2016.asc" + addRepo virtualbox.list "deb http://download.virtualbox.org/virtualbox/debian xenial contrib" + + addKey "http://archive.getdeb.net/getdeb-archive.key" + addRepo getdeb.list "deb http://archive.getdeb.net/ubuntu xenial-getdeb apps games" + + addKey "http://repo.vivaldi.com/stable/linux_signing_key.pub" + addKey "keyserver.ubuntu.com" "1397BC53640DB551" + addRepo vivaldi.list "deb http://repo.vivaldi.com/stable/deb/ stable main " + + addKey "https://download.sublimetext.com/sublimehq-pub.gpg" + addRepo sublime-text.list "deb https://download.sublimetext.com/ apt/dev/" + + addKey "hkp://pgp.mit.edu:80" "379CE192D401AB61" + addRepo etcher.list "deb https://dl.bintray.com/resin-io/debian stable etcher" + + updateSystem +} + +# +# add specific repository for a given package +# input : unique ID +# +function addSpecificRepoFct () { + for i in $AppsRepo; do + appRepo=(${i//;/ }) + if [ "${appRepo[0]}" == "$1" ]; then + printf "[ADD_REPO_FCT] for package : $1, " + printf "add repo by function : ${appRepo[1]} \n" + eval "${appRepo[1]}" + fi + done + updateSystem + #unset i + #unset appRepo +} + +# +# find and execute Pre/Post install functions for a specific app +# input : unique ID +# +function processAppTrtFct () { + for i in $AppsTrtFct; do + appTrtFct=(${i//;/ }) + if [ "${appTrtFct[0]}" == "$1" ]; then + printf "[APP_TRT_FCT] for package : $1, " + printf "processing function : ${appTrtFct[1]} \n" + eval "${appTrtFct[1]}" + fi + done +} + +# +# install all about a specific category from Apps array app list (headless) +# input : category name +# +function installAppsFromList () { + msg "Installing apps from $1 category" + for i in $Apps; do + app=(${i//;/ }) + if [ "${app[2]}" == "$1" ]; then + addSpecificRepoFct ${app[3]} + installPackage ${app[1]} ${app[0]} + processAppTrtFct ${app[3]} + fi + done +} + +# +# generate install apps menu about a specific category from Apps array app list (Menu) +# input : category name +# +function installAppsFromListMenu () { + for i in $Apps; do + app=(${i//;/ }) + if [ "${app[2]}" == "$1" ]; then + #list+=("${app[0]}" "${app[0]}" "ON") + list+=("${app[3]}" "${app[3]}" "ON") + fi + done + + pkg=$(whiptail \ + --title "Yggdrasil $version - App Install ($1)" \ + --checklist \ + "Select app to install and press OK" 25 80 19 \ + "${list[@]}" 3>&1 1>&2 2>&3) + + exitstatus=$? + if [ $exitstatus = 0 ]; then + for pkgToInstall in $pkg; do + for i in $Apps; do + app=(${i//;/ }) + if [ "${app[3]}" == "${pkgToInstall//\"}" ]; then + addSpecificRepoFct ${app[3]} + installPackage ${app[1]} ${app[0]} + processAppTrtFct ${app[3]} + fi + done + done + fi + unset list + pressKey +} + +# +# create app shortcut +# inputs : bin to exec, icon path, category, name, local/global, start w/ session +# +function createAppShortcut () { + typeset ret_code + + shortcut='[Desktop Entry]\n' + shortcut+='Encoding=UTF-8\n' + shortcut+='Terminal=0\n' + shortcut+='Exec='$1'\n' + shortcut+='Icon='$2'\n' + shortcut+='Type=Application\n' + if [ "$6" == "start" ]; then + shortcut+='X-MATE-Autostart-enabled=true\n\n' + else + shortcut+='Categories='$3';\n' + fi + shortcut+='StartupNotify=true\n' + shortcut+='Name='$4'\n' + shortcut+='GenericName='$4'\n' + shortcut+='Comment=' + + if [ "$5" == "global" ]; then + smsg "creating shortcut for $4 " + echo -e $shortcut > /usr/share/applications/"$4".desktop + ret_code=$? + retCode $ret_code + else + mkdir -p /home/$myHomedir/.local/share/applications + smsg "creating shortcut for $4 " + echo -e $shortcut > /home/"$myHomedir"/.local/share/applications/"$4".desktop + ret_code=$? + retCode $ret_code + fi +} + +#-----------------------------------------------------------------------------# +# install, config, ... functions # +#-----------------------------------------------------------------------------# + +# +# install Base Apps (headless) +# +function installBase () { + installAppsFromList base +} + +# +# install Base Apps (Menu) +# +function installBaseMenu () { + installAppsFromListMenu base +} + +# +# install Office Apps (headless) +# +function installOffice () { + installAppsFromList office +} + +# +# install Office Apps (Menu) +# +function installOfficeMenu () { + installAppsFromListMenu office +} + +# +# install Multimedia Apps (headless) +# +function installMultimedia () { + installAppsFromList multimedia +} + +# +# install Multimedia Apps (Menu) +# +function installMultimediaMenu () { + installAppsFromListMenu multimedia +} + +#TODO: +function installMultimediaExt () { + msg "Installing Multimedia apps and tools" + + cd /tmp + + msg "Téléchargement de XnRetro" + wget http://download.xnview.com/XnRetro-linux.tgz + + msg "Installation de XnRetro" + tar xzf XnRetro-linux.tgz + mv XnRetro /home/$myHomedir/Apps + + createAppShortcut "/home/"$myHomedir"/Apps/XnRetro/xnretro.sh" \ + "/home/"$myHomedir"/Apps/XnRetro/xnretro.png" \ + "Graphics" \ + "XnRetro" \ + "local" + update-menus + + msg "Téléchargement de XnView" + wget http://download.xnview.com/XnViewMP-linux-x64.deb + + msg "Installation de XnView" + sudo dpkg -i XnViewMP-linux-x64.deb + sudo apt-get install -fy +} + +#TODO: +function installEbook () { + msg "Installation eBook apps and tools" + runCmd "sudo apt-get install -y fbreader"; smsgn "Installing fbreader" + cd /tmp + runCmd "sudo -v && wget -q --no-check-certificate -nv -O- https://raw.githubusercontent.com/kovidgoyal/calibre/master/setup/linux-installer.py | sudo python -c \"import sys; main=lambda:sys.stderr.write('Download failed\n'); exec(sys.stdin.read()); main()\"" + smsgn "Installing calibre" +} + +# +# install Internet Apps (headless) +# +function installInternet () { + echo "opera-stable opera-stable/add-deb-source boolean false" | sudo debconf-set-selections + installAppsFromList internet +} + +# +# install Internet Apps (Menu) +# +function installInternetMenu () { + echo "opera-stable opera-stable/add-deb-source boolean false" | sudo debconf-set-selections + installAppsFromListMenu internet +} + +#TODO: +function installInternetExt () { + msg "Installing Internet apps and tools" + + cd /tmp + + msg "Téléchargement de Skype" + wget https://go.skype.com/skypeforlinux-64.deb + + msg "Installation de Skype" + sudo dpkg -i skypeforlinux-64.deb + sudo apt-get install -fy + + msg "Téléchargement de Viber" + wget http://download.cdn.viber.com/cdn/desktop/Linux/viber.deb + + msg "Installation de Viber" + sudo dpkg -i viber.deb + sudo apt-get install -fy + + msg "Téléchargement de MegaSync" + wget https://mega.nz/linux/MEGAsync/xUbuntu_16.04/amd64/megasync-xUbuntu_16.04_amd64.deb + + msg "Installation de MegaSync" + sudo dpkg -i megasync-xUbuntu_16.04_amd64.deb + sudo apt-get install -fy + + msg "Installation de Discord" + wget -O discord.deb https://discordapp.com/api/download?platform=linux&format=deb + sudo dpkg -i discord.deb + sudo apt-get install -fy + + msg "Téléchargement de Telegram Desktop" + wget -O tsetup.tar.xz https://tdesktop.com/linux + + msg "Installation de Telegram Desktop" + tar xvJf tsetup.tar.xz + mv Telegram /home/$myHomedir/Apps + sh -c "/home/"$myHomedir"/Apps/Telegram/Telegram &" && sleep 10 && pkill Telegram + + msg "Téléchargement de Gyazo" + wget https://packagecloud.io/install/repositories/gyazo/gyazo-for-linux/script.deb.sh + + msg "Installation de Gyazo" + chmod +x script.deb.sh + sudo os=ubuntu dist=xenial ./script.deb.sh + sudo apt-get install -y gyazo + + msg "Téléchargement de Franz" + mkdir -p Franz + cd Franz + wget -O franz.tgz https://github.com/imprecision/franz-app/releases/download/3.1.0/Franz-linux-x64-3.1.0.tgz + + msg "Installation de Franz" + tar xzf franz.tgz + cd .. + mv Franz /home/$myHomedir/Apps + + createAppShortcut "/home/"$myHomedir"/Apps/Franz/Franz" \ + "/home/"$myHomedir".icons/franz.png" \ + "Network;InstantMessaging" \ + "Franz" \ + "local" + update-menus +} + +# +# install Misc Utilities Apps (headless) +# +function installMiscUtilities () { + installAppsFromList utilities +} + +# +# install Misc Utilities Apps (Menu) +# +function installMiscUtilitiesMenu () { + installAppsFromListMenu utilities +} + +# +# install Wine Build (headless) +# +function installWine () { + msg "Installing Wine Apps" + installAppsFromList wine +} + +# +# install Wine Build (Menu) +# +function installWineMenu () { + installAppsFromListMenu wine +} + +# +# install Game Apps (headless) +# +function installGames () { + msg "Installing Games apps and tools" + installAppsFromList games +} + +# +# install Game Apps (Menu) +# +function installGamesMenu () { + installAppsFromListMenu games +} + +# +# install Burning Apps (headless) +# +function installBurningTools () { + msg "Installing CD/DVD/BD Burning apps and tools" + installAppsFromListMenu burningtools +} + +# +# install Burning Apps (Menu) +# +function installBurningToolsMenu () { + installAppsFromListMenu burningtools +} + +# +# install Network Apps (headless) +# +function installNetTools () { + msg "Installing Network apps and tools" + installAppsFromList nettools +} + +# +# install Network Apps (Menu) +# +function installNetToolsMenu () { + installAppsFromListMenu nettools +} + +# +# install Caja Plugins (headless) +# +function installCajaPlugins () { + msg "Installing Caja extensions" + installAppsFromList cajaplugins +} + +# +# install Caja Plugins (Menu) +# +function installCajaPluginsMenu () { + installAppsFromListMenu cajaplugins +} + +# +# install Nautilus Apps + plugins (headless) +# +function installNautilusAndPlugins () { + msg "Installing Nautilus and extensions" + installAppsFromList nautilus +} + +# +# install Nautilus Apps + plugins (Menu) +# +function installNautilusAndPluginsMenu () { + installAppsFromListMenu nautilus +} + +# +# install Gimp plugins (headless) +# +function installGimpPlugins () { + msg "Installing Gimp extensions" + installAppsFromList gimp +} + +# +# install Gimp plugins (Menu) +# +function installGimpPluginsMenu () { + installAppsFromListMenu gimp +} + +# +# install RhythmBox plugins (headless) +# +function installRhythmBoxPlugins () { + msg "Installing RhythmBox extensions" + installAppsFromList rhythmbox +} + +# +# install RhythmBox plugins (Menu) +# +function installRhythmBoxPluginsMenu () { + installAppsFromListMenu rhythmbox +} + +# +# install Pidgin plugins (headless) +# +function installPidginPlugins () { + msg "Installing Pidgin extensions" + installAppsFromList pidgin +} + +# +# install Pidgin plugins (Menu) +# +function installPidginPluginsMenu () { + installAppsFromListMenu pidgin +} + +# +# install Nitrogen app (headless) +# +function installNitrogen () { + msg "Installing Nitrogren" + installAppsFromList nitrogen +} + +# +# install Nitrogen app (Menu) +# +function installNitrogenMenu () { + installAppsFromListMenu nitrogen +} + +# +# install Beta Apps (headless) +# +function installBeta () { + msg "Installing Beta Apps" + installAppsFromList beta +} + +# +# install Beta Apps (Menu) +# +function installBetaMenu () { + installAppsFromListMenu beta +} + +# +# install Nightly Apps (headless) +# +function installNightly () { + msg "Installing Nightly Apps" + installAppsFromList nightly +} + +# +# install Nightly Apps (Menu) +# +function installNightlyMenu () { + installAppsFromListMenu nightly +} + +# +# install GTK Themes (headless) +# +function installThemes () { + msg "Installing themes" + installAppsFromList gtkthemes +} + +# +# install GTK Themes (Menu) +# +function installThemesMenu () { + installAppsFromListMenu gtkthemes +} + +# +# install Icon Themes (headless) +# +function installIcons () { + msg "Installing icons" + installAppsFromList icons +} + +# +# install Icon Themes (Menu) +# +function installIconsMenu () { + installAppsFromListMenu icons +} + +#TODO: +function installPlankThemes () { + msg "Installing Plank themes" + + if which plank >/dev/null; then + if (( $(ps -ef | grep -v grep | grep plank | wc -l) > 0 )); then + sh -c "cd ~ && mkdir -p ~/.temp-plank-themer && cd ~/.temp-plank-themer && wget https://github.com/rhoconlinux/plank-themer/archive/master.zip && unzip master.zip && cd plank-themer-master/ && rm -fR ~/.config/plank/dock1/theme_index; rm -fR ~/.config/plank/dock1/themes-repo; cp -a theme_index/ ~/.config/plank/dock1 && cp -a themes-repo/ ~/.config/plank/dock1 && cd ~ && rm -R ~/.temp-plank-themer && sh ~/.config/plank/dock1/theme_index/plank-on-dock-themer.sh" + else + plank 2&>1 >/dev/null & + sleep 10 + yes | sh -c "cd ~ && mkdir -p ~/.temp-plank-themer && cd ~/.temp-plank-themer && wget https://github.com/rhoconlinux/plank-themer/archive/master.zip && unzip master.zip && cd plank-themer-master/ && rm -fR ~/.config/plank/dock1/theme_index; rm -fR ~/.config/plank/dock1/themes-repo; cp -a theme_index/ ~/.config/plank/dock1 && cp -a themes-repo/ ~/.config/plank/dock1 && cd ~ && rm -R ~/.temp-plank-themer && sh ~/.config/plank/dock1/theme_index/plank-on-dock-themer.sh" + fi + else + msg "Plank must be installed first" + fi +} + +# +# install Solaar App (headless) +# +function installSolaar () { + msg "Installing Solaar" + installAppsFromList solaar +} + +# +# install Solaar App (Menu) +# +function installSolaarMenu () { + installAppsFromListMenu solaar +} + +# +# install CardReader Apps (headless) +# +function installCardReader () { + msg "Installing CardReader and utils" + installAppsFromList cardreader +} + +# +# install CardReader Apps (Menu) +# +function installCardReaderMenu () { + installAppsFromListMenu cardreader +} + +#TODO: +function installEpsonV500Photo () { + cd /tmp + + msg "Téléchargement de iScan" + wget https://download2.ebz.epson.net/iscan/plugin/gt-x770/deb/x64/iscan-gt-x770-bundle-1.0.0.x64.deb.tar.gz + + msg "Installation de iScan via DPKG" + tar xzf iscan-gt-x770-bundle-1.0.0.x64.deb.tar.gz + cd /tmp/iscan-gt-x770-bundle-1.0.0.x64.deb + ./install.sh + + installPackage apt xsane + + msg "Ajout à Xsane du backend epkowa du Scanner Epson Perfection V500" + sudo sh -c "echo '# Epson Perfection V500\n\ + usb 0x04b8 0x0130' >> /etc/sane.d/epkowa.conf" +} + +# +# update AMD/Intel CPU Microcode +# +function updateMicrocode () { + oldMicrocode=`cat /proc/cpuinfo | grep -i --color microcode -m 1` + intel=`cat /proc/cpuinfo | grep -i Intel | wc -l` + amd=`cat /proc/cpuinfo | grep -i Amd | wc -l` + if [ "$intel" -gt "0" ]; then + installPackage apt intel-microcode + elif [ "$amd" -gt "0" ]; then + installPackage apt amd64-microcode + fi + newMicrocode=`cat /proc/cpuinfo | grep -i --color microcode -m 1` + printf "[INFO] Microcode updated from "$oldMicrocode" version to "$newMicrocode" version\n" +} + +#TODO: +function fixWirelessIntel6320 () { + msg "Backup du fichier iwlwifi.conf" + sudo cp /etc/modprobe.d/iwlwifi.conf /etc/modprobe.d/iwlwifi.conf.bak + + msg "Paramètres dans iwlwifi.conf" + echo options iwlwifi bt_coex_active=0 swcrypto=1 11n_disable=8 | sudo tee /etc/modprobe.d/iwlwifi.conf + + msg "!!! REBOOT Nécessaire !!!" +} + +# +# install Webcam Apps (headless) +# +function installWebcam () { + msg "Installing Apps needed for Webcams" + installAppsFromList webcam +} + +# +# install Webcam Apps (Menu) +# +function installWebcamMenu () { + installAppsFromListMenu webcam +} + +# +# install Nvidia Drivers (headless) +# +function installNvidia370 () { + msg "Installing Nvidia 370 driver" + installAppsFromList nvidia-370 +} + +# +# install Nvidia Drivers (Menu) +# +function installNvidia370Menu () { + installAppsFromListMenu nvidia-370 +} + +# +# install Nvidia Drivers (headless) +# +function installNvidia375 () { + msg "Installing Nvidia 375 driver" + installAppsFromList nvidia-375 +} + +# +# install Nvidia Drivers (Menu) +# +function installNvidia375Menu () { + installAppsFromListMenu nvidia-375 +} + +# +# install Nvidia Drivers (headless) +# +function installNvidia378 () { + msg "Installing Nvidia 378 driver" + installAppsFromList nvidia-378 +} + +# +# install Nvidia Drivers (Menu) +# +function installNvidia378Menu () { + installAppsFromListMenu nvidia-378 +} + +# +# install Nvidia Drivers (headless) +# +function installNvidia381 () { + msg "Installing Nvidia 381 driver" + installAppsFromList nvidia-381 +} + +# +# install Nvidia Drivers (Menu) +# +function installNvidia381Menu () { + installAppsFromListMenu nvidia-381 +} + +# +# install Nvidia Drivers (headless) +# +function installNvidia384 () { + msg "Installing Nvidia 384 driver" + installAppsFromList nvidia-384 +} + +# +# install Nvidia Drivers (Menu) +# +function installNvidia384Menu () { + installAppsFromListMenu nvidia-384 +} + +# +# install TLP App (headless) +# +function installTLP () { + msg "Installing TLP" + installAppsFromList tlp +} + +# +# install TLP App (Menu) +# +function installTLPMenu () { + installAppsFromListMenu tlp +} + +#TODO: +function installKeyIDuDev () { + msg "Adding UDEV rules" + sudo sh -c "echo '# this udev file should be used with udev 188 and newer\n\ +ACTION!=\"add|change\", GOTO=\"u2f_end\"\n\ +\n\ +# Key-ID FIDO U2F\n\ +KERNEL==\"hidraw*\", SUBSYSTEM==\"hidraw\", ATTRS{idVendor}==\"096e\", ATTRS{idProduct}==\"0850|0880\", TAG+=\"uaccess\"\n\ +\n\ +LABEL=\"u2f_end\"' > /etc/udev/rules.d/70-u2f.rules" + + rmcCmd "sudo service udev restart" +} + +# +# install Dev Apps (headless) +# +function installDevApps () { + msg "Installing base Dev apps and tools" + installAppsFromList dev +} + +# +# install Dev Apps (Menu) +# +function installDevAppsMenu () { + installAppsFromListMenu dev +} + +# +# install JAVA 9 (headless) +# +function installJava9 () { + msg "Installing Java9 + set as Default" + installAppsFromList java9 +} + +# +# install JAVA 9 (Menu) +# +function installJava9Menu () { + installAppsFromListMenu java9 +} + +#TODO: +function installJavaScript () { + msg "Installing JavaScript apps and tools" + + runCmd "sudo apt-get install -y npm"; smsgn "Installing npm" + runCmd "sudo apt-get install -y javascript-common"; smsgn "Installing javascript-common" + + if which npm >/dev/null; then + runCmd "sudo npm install -g yarn"; smsgn "NPM Installing yarn" + runCmd "sudo npm install -g remark-lint"; smsgn "NPM Installing remark-lint" + runCmd "sudo npm install -g jshint"; smsgn "NPM Installing jshint" + runCmd "sudo npm install -g jedi"; smsgn "NPM Installing jedi" + runCmd "sudo npm install -g coinmon"; smsgn "NPM Installing coinmon" + fi +} + +#TODO: +function installNode8LTS () { + msg "Installing NodeJS 8 LTS" + curl -sL https://deb.nodesource.com/setup_8.x | sudo -E bash - &>> $logFile && retCode $? && smsgn "Adding Node repository" + runCmd "sudo apt-get install -y nodejs"; smsgn "Installing nodejs" +} + +#TODO: +function installMongoDB3CE () { + if which mongod >/dev/null; then + sudo systemctl stop mongodb && sudo rm -rf /var/log/mongodb && sudo rm -rf /var/lib/mongodb && sudo apt remove --purge mongodb &>> $logFile && retCode $? && smsgn "Removing old MongoDB installation" + fi + msg "Installing MongoDB 3 CE" + sudo apt-key adv --keyserver hkp://keyserver.ubuntu.com:80 --recv 2930ADAE8CAF5059EE73BB4B58712A2291FA4AD5 &>> $logFile && retCode $? && smsgn "Adding MongoDB repository key" + echo "deb [ arch=amd64,arm64 ] http://repo.mongodb.org/apt/ubuntu xenial/mongodb-org/testing multiverse" | sudo tee /etc/apt/sources.list.d/mongodb-org-3.6.list && retCode $? && smsgn "Adding MongoDB repository" + updateSystem + runCmd "sudo apt-get install -y mongodb-org"; smsgn "Installing mongodb-org" +} + +# +# install PHP Apps (headless) +# +function installPHP () { + msg "Installing PHP apps and tools" + installAppsFromList php +} + +# +# install PHP Apps (Menu) +# +function installPHPMenu () { + installAppsFromListMenu php +} + +# +# install LUA Apps (headless) +# +function installLUA () { + msg "Installing LUA apps and tools" + installAppsFromList lua +} + +# +# install LUA Apps (Menu) +# +function installLUAMenu () { + installAppsFromListMenu lua +} + +# +# install Ruby Apps (headless) +# +function installRuby () { + msg "Installing Ruby apps and tools" + installAppsFromList ruby +} + +# +# install Ruby Apps (Menu) +# +function installRubyMenu () { + installAppsFromListMenu ruby +} + +#TODO: +function installQT () { + msg "Installing QT Dev apps and tools" + + runCmd "sudo apt-get install -y qt4-dev-tools"; smsgn "Installing qt4-dev-tools" + runCmd "sudo apt-get install -y qt4-linguist-tools"; smsgn "Installing qt4-linguist-tools" + runCmd "sudo apt-get install -y qt5-doc qttools5-doc"; smsgn "Installing qt5-doc qttools5-doc" + runCmd "sudo apt-get install -y qttools5-dev-tools"; smsgn "Installing qttools5-dev-tools" + runCmd "sudo apt-get install -y qttools5-examples"; smsgn "Installing qttools5-examples" + runCmd "sudo apt-get install -y qttools5-doc-html"; smsgn "Installing qttools5-doc-html" + + msg "Création du lien symbolique permettant à qtchooser de prendre qt5 par défaut" + sudo ln -s /usr/share/qtchooser/qt5-x86_64-linux-gnu.conf /usr/lib/x86_64-linux-gnu/qtchooser/default.conf + + createAppShortcut "/usr/bin/designer" \ + "/home/"$myHomedir"/.icons/qtdesigner.png" \ + "GNOME;GTK;Development;IDE" \ + "QT Designer 5" \ + "local" \ + update-menus +} + +#TODO: +function installPython () { + msg "Installing Python Dev apps and tools" + + runCmd "sudo apt-get install -y python3-dev"; smsgn "Installing python3-dev" + runCmd "sudo apt-get install -y python3-pip"; smsgn "Installing python3-pip" + runCmd "sudo apt-get install -y python3-pyqt5"; smsgn "Installing python3-pyqt5" + runCmd "sudo apt-get install -y pyqt5-dev-tools"; smsgn "Installing pyqt5-dev-tools" + + if which pip3 >/dev/null; then + msg "Upgrading PIP" + sudo -H pip3 install --upgrade pip + + msg "PIP installing : setuptools" + sudo -H pip3 install --upgrade setuptools + + msg "PIP installing : MyCLI" + sudo -H pip3 install --upgrade mycli + + msg "PIP installing : SpoofMAC" + sudo -H pip3 install --upgrade SpoofMAC + + msg "PIP installing : speedtest-cli" + sudo -H pip3 install --upgrade speedtest-cli + + msg "PIP installing : whatportis" + sudo -H pip3 install --upgrade whatportis + + msg "PIP installing : py-term" + sudo -H pip3 install --upgrade py-term + + msg "PIP installing : weppy" + sudo -H pip3 install --upgrade weppy + + msg "PIP installing : retext" + sudo -H pip3 install --upgrade retext + + msg "PIP installing : waybackpack" + sudo -H pip3 install --upgrade waybackpack + + msg "PIP installing : tweepy" + sudo -H pip3 install --upgrade tweepy + + msg "PIP installing : droopescan" + sudo -H pip3 install --upgrade droopescan + + msg "PIP installing : PyOpenGL" + sudo -H pip3 install --upgrade PyOpenGL + + msg "PIP installing : tldr" + sudo -H pip3 install --upgrade tldr + + msg "PIP installing : s-tui" + sudo -H pip3 install --upgrade s-tui + + msg "PIP installing : beautysh" + sudo -H pip3 install --upgrade beautysh + fi +} + +#TODO: +function installAndroidEnv () { + msg="Installing Android environment" + + msg "PATH in .bashrc" + touch /home/$myHomedir/.bashrc + sh -c "echo '\n\nexport PATH=${PATH}:/home/'$myHomedir'/Android/Sdk/tools:/home/'$myHomedir'/Android/Sdk/platform-tools' >> /home/$myHomedir/.bashrc" + + msg "Adding UDEV rules" + sudo sh -c "echo 'SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0502\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Acer\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0b05\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Asus\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"413c\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Dell\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0489\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Foxconn\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"04c5\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Fujitsu\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"04c5\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Fujitsu-Toshiba\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"091e\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Garmin-Asus\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"18d1\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Google-Nexus\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"201E\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Haier\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"109b\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Hisense\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0bb4\", MODE=\"0666\", OWNER=\""$myHomedir"\" # HTC\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"12d1\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Huawei\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"8087\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Intel\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"24e3\", MODE=\"0666\", OWNER=\""$myHomedir"\" # K-Touch\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"2116\", MODE=\"0666\", OWNER=\""$myHomedir"\" # KT Tech\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0482\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Kyocera\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"17ef\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Lenovo\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"1004\", MODE=\"0666\", OWNER=\""$myHomedir"\" # LG\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"22b8\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Motorola\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0e8d\", MODE=\"0666\", OWNER=\""$myHomedir"\" # MTK\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0409\", MODE=\"0666\", OWNER=\""$myHomedir"\" # NEC\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"2080\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Nook\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0955\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Nvidia\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"2257\", MODE=\"0666\", OWNER=\""$myHomedir"\" # OTGV\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"10a9\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Pantech\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"1d4d\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Pegatron\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0471\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Philips\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"04da\", MODE=\"0666\", OWNER=\""$myHomedir"\" # PMC-Sierra\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"05c6\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Qualcomm\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"1f53\", MODE=\"0666\", OWNER=\""$myHomedir"\" # SK Telesys\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"04e8\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Samsung\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"04dd\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Sharp\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"054c\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Sony\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0fce\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Sony Ericsson\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0fce\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Sony Mobile Communications\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"2340\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Teleepoch\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"0930\", MODE=\"0666\", OWNER=\""$myHomedir"\" # Toshiba\n\ +SUBSYSTEM==\"usb\", ATTR{idVendor}==\"19d2\", MODE=\"0666\", OWNER=\""$myHomedir"\" # ZTE' > /etc/udev/rules.d/99-android.rules" + + msg "Restarting UDEV service" + sudo service udev restart + + createAppShortcut "/home/"$myHomedir"/tools/Android/Sdk/tools/android" \ + "/home/"$myHomedir"/.icons/android.png" \ + "GNOME;GTK;Development;IDE" \ + "Android SDK" \ + "local" \ + update-menus +} + +# +# install Atom App (headless) +# +function installAtom () { + msg "Installing Atom and extensions" + installAppsFromList atom +} + +# +# install Atom App (menu) +# +function installAtomMenu () { + msg "Installing Atom and extensions" + installAppsFromListMenu atom + + # runCmd "sudo apt-get install -y atom"; smsgn "Installing atom" + + # if which apm >/dev/null; then + # msg "Apm installing Atom extensions" + # runCmd "apm install sync-settings"; smsgn "APM Installing sync-settings" + # fi + + # if which pip3 >/dev/null; then + # msg "PIP installing : SQLParse" + # sudo -H pip3 install --upgrade sqlparse + + # msg "PIP installing : flake8" + # sudo -H pip3 install --upgrade flake8 + + # msg "PIP installing : autopep8" + # sudo -H pip3 install --upgrade autopep8 + # else + # installPython + # fi + + # if which gem >/dev/null; then + # msg "Gem installing : htmlbeautifier" + # sudo gem install htmlbeautifier + # else + # installRuby + # fi +} + +# +# install Anjuta Apps (headless) +# +function installAnjuta () { + msg "Installing Anjuta" + installAppsFromList anjuta +} + +# +# install Anjuta Apps (Menu) +# +function installAnjutaMenu () { + installAppsFromListMenu anjuta +} + +# +# install Brackets Apps (headless) +# +function installBrackets () { + msg "Installing Brackets" + installAppsFromList brackets +} + +# +# install Brackets Apps (Menu) +# +function installBracketsMenu () { + installAppsFromListMenu brackets +} + +# +# install CodeBlocks Apps (headless) +# +function installCodeBlocks () { + msg "Installing CodeBlocks" + installAppsFromList codeblocks +} + +# +# install CodeBlocks Apps (Menu) +# +function installCodeBlocksMenu () { + installAppsFromListMenu codeblocks +} + +# +# install Geany Apps (headless) +# +function installGeany () { + msg "Installing Geany and extensions" + installAppsFromList geany +} + +# +# install Geany Apps (Menu) +# +function installGeanyMenu () { + installAppsFromListMenu geany +} + +#TODO: +function installEclipse () { + if which umake >/dev/null; then + msg "Umake installing : Eclipse" + sudo umake ide eclipse + fi +} + +#TODO: +function installIdea () { + if which umake >/dev/null; then + msg "Umake installing : Idea" + sudo umake ide idea + fi +} + +# +# install Pycharm Apps (headless) +# +function installPyCharm () { + msg "Installing PyCharm" + installAppsFromList pycharm +} + +# +# install Pycharm Apps (Menu) +# +function installPyCharmMenu () { + installAppsFromListMenu pycharm +} + +#TODO: +function installVisualStudioCode () { + if which umake >/dev/null; then + msg "Umake installing : Visual-studio-code" + sudo umake ide visual-studio-code + fi +} + +#TODO: +function installAndroidStudio () { + if which umake >/dev/null; then + msg "Umake installing : Android-Studio" + sudo umake android android-studio + fi +} + +# +# install SublimeText Apps (headless) +# +function installSublimeText() { + msg "Installing Sublime-Text" + installAppsFromList sublime-text +} + +# +# install SublimeText Apps (Menu) +# +function installSublimeTextMenu() { + installAppsFromListMenu sublime-text +} + +# +# install CAD Apps (headless) +# +function installCAD () { + msg "Installing CAD apps and tools" + installAppsFromList cad +} + +# +# install CAD Apps (Menu) +# +function installCADMenu () { + installAppsFromListMenu cad +} + +#TODO: +function installTeamViewer12 () { + cd /tmp + + msg "Downloading Teamviewer 12" + wget -O teamviewer12.deb https://download.teamviewer.com/download/teamviewer_i386.deb + + msg "Installing Teamviewer 12" + sudo dpkg -i teamviewer12.deb + sudo apt-get install -fy +} + +# +# install/enable Unboud (headless) +# +function enableUnbound () { + msg "Installing Unbound" + installAppsFromList unbound +} + +# +# install/enable Unboud (Menu) +# +function enableUnboundMenu () { + installAppsFromListMenu unbound +} + +# +# enable ufw at boot time and add rules for installed apps +# +function enableUFW () { + msg "Enabling FireWall (UFW)" + runCmd "sudo ufw enable" + + if which syncthing >/dev/null; then + msg "UFW Rules added for Syncthing" + sudo ufw allow syncthing + fi +} + +#TODO: +function enableNumLockX () { + msg "Adding NumLockX to MDM/LightDM Default Init" + + checkAndInstallDep apt numlockx + + if which mdm >/dev/null; then + sudo cp /etc/mdm/Init/Default /etc/mdm/Init/Default.yggbak + sudo sed -i -e ' + s!exit 0!#numlockx! + ' /etc/mdm/Init/Default + sudo sh -c "echo 'if [ -x /usr/bin/numlockx ]; then\n\ + exec /usr/bin/numlockx on\n\ + fi\n\ + \n\ + exit 0' >> /etc/mdm/Init/Default" + elif which lightdm >/dev/null; then + sudo cp /etc/lightdm/lightdm.conf.d/70-linuxmint.conf /etc/lightdm/lightdm.conf.d/70-linuxmint.conf.yggbak + sudo bash -c "echo 'greeter-setup-script=/usr/bin/numlockx on' >> /etc/lightdm/lightdm.conf.d/70-linuxmint.conf" + fi +} + +#TODO: +function enableTmpRAM () { + msg "Enable /tmp in RAM by modifying /etc/fstab" + sudo sh -c "echo 'tmpfs /tmp tmpfs defaults,size=2g 0 0' >> /etc/fstab" + msg "Reboot required" +} + +#TODO: +function addScreenfetchBashrc () { + msg "Adding screenfetch to .bashrc" + checkAndInstallDep apt screenfetch + touch /home/$myHomedir/.bashrc + echo "screenfetch -t" >> /home/"$myHomedir"/.bashrc +} + +#TODO: +function enableHistoryTS () { + msg "CLI History TimeStamp Activation" + echo "export HISTTIMEFORMAT='%F %T '" >> /home/"$myHomedir"/.bashrc +} + +# +# install/enable auto install of security updates +# +function installUnattendedUpgrades () { + msg "Installing unattended-upgrades" + installPackage apt "unattended-upgrades" +} + +# +# display useful system/hardware informations +# +function toolInxi () { + checkAndInstallDep apt inxi + inxi -F +} + +# +# check bandwith and latency of the internet connection +# +function toolSpeedtestCli () { + checkAndInstallDep pip speedtest-cli + speedtest-cli +} + +# +# check for packet loss +# +function toolPacketLoss () { + ping -q -c 10 google.com +} + +#TODO: +function toolOptimizeFirefox () { + msg "Firefox SQLite databases optimization" + pressKey "Please close Firefox BEFORE to proceed, which will be killed just after" + if which firefox >/dev/null; then + smsgn "Optimizing Firefox" + pkill -9 firefox + for f in ~/.mozilla/firefox/*/*.sqlite; do sqlite3 $f 'VACUUM; REINDEX;'; done + fi + if which firefox-trunk >/dev/null; then + smsgn "Optimizing Firefox Nightly" + pkill -9 firefox-trunk + for f in ~/.mozilla/firefox-trunk/*/*.sqlite; do sqlite3 $f 'VACUUM; REINDEX;'; done + fi +} + +# +# remove useless packages (depedencies) +# +function toolAutoremove () { + msg "Cleaning useless deb package(s)" + runCmd "sudo apt-get -y autoremove" +} + +# +# remove old versions of installed kernels +# +function toolClearOldKernels () { + msg "Removing old kernels (keeping the 3 last kernels)" + checkAndInstallDep apt byobu + runCmd "sudo purge-old-kernels --keep 3" +} + +# +# force soundcards detection +# +function toolSoundCardsDetection () { + runCmd "sudo alsa force-reload" +} + +#-----------------------------------------------------------------------------# +# menus functions # +#-----------------------------------------------------------------------------# + +# +# show about dialog box +# +function showAboutBoxMenu () { +whiptail \ +--title "About" \ +--msgbox "\n +Author : Francois B. (Makotosan) +Email : shakasan@sirenacorp.be +Website : https://makotonoblog.be/ +Github : https://github.com/shakasan/Yggdrasil +Licence : GPLv3 +Version : '$version'\n +This script has been written to makes my life easier when I have to (re)install my personal computers ;-) +This is my first major shell sccript and use of whiptail,... +Advices and remarks are welcome ^^" \ +20 80 +} + +# +# show reboot menu +# +function showRebootBoxMenu () { + if (whiptail \ + --title "Yggdrasil $version - WARNING - ReBoot" \ + --yesno "Are you sure to reboot this computer ?" \ + 7 42) then + sudo reboot + fi +} + +# +# show menu to config system +# +function showConfigMenu () { + while true; do + + configMenuOptions=$(whiptail \ + --title "Yggdrasil $version - System Config" \ + --menu "System Config" \ + 25 80 16 \ + "Ufw" "Enable Firewall (ufw)" \ + "NumLockX" "NumLock Enabled at boot time" \ + "TmpRAM" "/tmp stored in RAM" \ + "screenfetch" "screenfetch added to .bashrc" \ + "historyTS" "TimeStamp enabled in Shell History" \ + "unattendedUpgrades" "Enable automatic security updates" \ + "Back" "Back" 3>&1 1>&2 2>&3) + + case $configMenuOptions in + "Ufw") + clear; enableUFW; pressKey + ;; + "NumLockX") + clear; enableNumLockX; pressKey + ;; + "TmpRAM") + clear; enableTmpRAM; pressKey + ;; + "screenfetch") + clear; addScreenfetchBashrc; pressKey + ;; + "historyTS") + clear; enableHistoryTS; pressKey + ;; + "unattendedUpgrades") + clear; installUnattendedUpgrades; pressKey + ;; + "Back") + break + ;; + esac + + done +} + +# +# show menu to install system tools +# +function showSysToolsMenu () { + while true; do + + sysToolsMenuOptions=$(whiptail \ + --title "Yggdrasil $version - System Tools" \ + --menu "System tools to diagnose and optimize" \ + 25 80 16 \ + "inxi" "System informations" \ + "speedtest-cli" "Bandwidth test" \ + "packetloss" "Packetloss test (ping)" \ + "OptimizeFirefox" "Firefox SQLite databases optimization" \ + "Autoremove" "Remove useless Deb packages" \ + "CleanOldKernels" "Removing old kernels (keep 2 last kernels)" \ + "SoundCardsDetection" "Sound Cards Detection" \ + "Back" "Back" 3>&1 1>&2 2>&3) + + case $sysToolsMenuOptions in + "inxi") + clear; toolInxi; pressKey + ;; + "speedtest-cli") + clear; toolSpeedtestCli; pressKey + ;; + "packetloss") + clear; toolPacketLoss; pressKey + ;; + "OptimizeFirefox") + clear; toolOptimizeFirefox; pressKey + ;; + "Autoremove") + clear; toolAutoremove; pressKey + ;; + "CleanOldKernels") + clear; toolClearOldKernels; pressKey + ;; + "SoundCardsDetection") + clear; toolSoundCardsDetection; pressKey + ;; + "Back") + break + ;; + esac + + done +} + +# +# show menu to install themes/icons +# +function showThemesInstallMenu () { + while true; do + + themesInstallMenuOptions=$(whiptail \ + --title "Yggdrasil $version - Themes/Icons Install" \ + --menu "Install themes/icons from different submenus" \ + 25 80 16 \ + "themes" "GTK themes" \ + "icons" "Icons" \ + "Back" "Back" 3>&1 1>&2 2>&3) + + case $themesInstallMenuOptions in + "themes") + installThemesMenu + ;; + "icons") + installIconsMenu + ;; + "Back") + break + ;; + esac + + done +} + +# +# show menu to install dev apps +# +function showDevInstallMenu () { + while true; do + + devInstallMenuOptions=$(whiptail \ + --title "Yggdrasil $version - Dev Install" \ + --menu "Install Dev apps from different submenus" \ + 25 80 16 \ + "devbase" "dev apps and tools" \ + "java9" "Java 9 dev env" \ + "javascriptbase" "JavaScript dev env" \ + "nodelts" "NodeJS 8.x LTS" \ + "mongodb3ce" "MongoDB 3 CE" \ + "php" "PHP dev env" \ + "lua" "Lua dev env" \ + "ruby" "Ruby dev env" \ + "qt" "QT dev env" \ + "python" "Python dev env" \ + "androidenv" "Set Android env" \ + "atom" "Atom" \ + "anjuta" "Anjuta" \ + "brackets" "Brackets" \ + "codeblocks" "CodeBlocks" \ + "geany" "Geany" \ + "eclipse" "Eclipse" \ + "idea" "Idea" \ + "pycharm" "PyCharm" \ + "vsc" "Visual Studio Code" \ + "androidstudio" "Android Studio" \ + "sublimetext" "Sublime Text" \ + "cad" "CAD tools" \ + "teamviewer12" "Teamviewer 12" \ + "Back" "Back" 3>&1 1>&2 2>&3) + + case $devInstallMenuOptions in + "devbase") + installDevAppsMenu + ;; + "java9") + installJava9 + ;; + "javascriptbase") + ;; + "nodelts") + ;; + "mongodb3ce") + ;; + "php") + installPHPMenu + ;; + "lua") + installLUAMenu + ;; + "ruby") + installRubyMenu + ;; + "qt") + ;; + "python") + ;; + "androidenv") + ;; + "atom") + installAtomMenu + ;; + "anjuta") + installAnjutaMenu + ;; + "brackets") + installBracketsMenu + ;; + "codeblocks") + installCodeBlocksMenu + ;; + "geany") + installGeanyMenu + ;; + "eclipse") + ;; + "idea") + ;; + "pycharm") + installPyCharmMenu + ;; + "vsc") + ;; + "androidstudio") + ;; + "sublimetext") + installSublimeTextMenu + ;; + "cad") + installCADMenu + ;; + "teamviewer12") + ;; + "Back") + break + ;; + esac + + done +} + +# +# show menu to install apps from different categories +# +function showAppInstallMenu () { + while true; do + + appsInstallMenuOptions=$(whiptail \ + --title "Yggdrasil $version - Apps Install" \ + --menu "Install apps from different submenus" \ + 25 80 16 \ + "base" "Base Apps" \ + "office" "Office Apps" \ + "multimedia" "Multimedia Apps" \ + "internet" "Internet Apps" \ + "utilities" "Misc Utilities" \ + "games" "Games & tools" \ + "burningtools" "Disc Burning and tools" \ + "nettools" "Network tools" \ + "cajaplugins" "Caja Plugins" \ + "nautilus" "Nautilus and plugins" \ + "gimp" "Gimp plugins" \ + "rhythmbox" "RhythmBox plugins" \ + "pidgin" "Pidgin plugins" \ + "nitrogen" "Nitrogen WP Manager" \ + "wine" "Wine Builds" \ + "Back" "Back" 3>&1 1>&2 2>&3) + + case $appsInstallMenuOptions in + "base") + installBaseMenu + ;; + "office") + installOfficeMenu + ;; + "multimedia") + installMultimediaMenu + ;; + "internet") + installInternetMenu + ;; + "utilities") + installMiscUtilitiesMenu + ;; + "games") + installGamesMenu + ;; + "burningtools") + installBurningToolsMenu + ;; + "nettools") + installNetToolsMenu + ;; + "cajaplugins") + installCajaPluginsMenu + ;; + "nautilus") + installNautilusAndPluginsMenu + ;; + "gimp") + installGimpPluginsMenu + ;; + "rhythmbox") + installRhythmBoxPluginsMenu + ;; + "pidgin") + installPidginPluginsMenu + ;; + "nitrogen") + installNitrogenMenu + ;; + "wine") + installWineMenu + ;; + "Back") + break + ;; + esac + + done +} + +# +# show menu to install beta apps from different categories +# +function showAppBetaInstallMenu () { + installBetaMenu +} + +# +# show menu to install nightly apps from different categories +# +function showAppNightlyInstallMenu () { + installNightlyMenu +} + +# +# show menu about install/config hardware +# +function showHardwareMenu () { + while true; do + + hardwareMenuOptions=$(whiptail \ + --title "Yggdrasil $version - System Tools" \ + --menu "System tools to diagnose and optimize" \ + 25 80 16 \ + "cardreader" "Apps/tools needed for cardreaders" \ + "solaar" "Solaar for Logitech Unifying devices" \ + "Back" "Back" 3>&1 1>&2 2>&3) + + case $hardwareMenuOptions in + "cardreader") + installCardReaderMenu + ;; + "solaar") + installAppsFromListMenu + ;; + "Back") + break + ;; + esac + + done +} + +#------------------------------------------------------------------------------# +# Entry point of the script # +#------------------------------------------------------------------------------# + +clear + +# add a mark to the log file at every script run +echo "--[ Yggdrasil log ]--[ "$cDate" ]--[ "$cTime" ]----------------------------------------------------------------------------" >> $logFile + +printf "\n" +printf "$BOLDJAUNE" +printf "██╗ ██╗ ██████╗ ██████╗ ██████╗ ██████╗ █████╗ ███████╗██╗██╗ \n" +printf "╚██╗ ██╔╝██╔════╝ ██╔════╝ ██╔══██╗██╔══██╗██╔══██╗██╔════╝██║██║ \n" +printf " ╚████╔╝ ██║ ███╗██║ ███╗██║ ██║██████╔╝███████║███████╗██║██║ \n" +printf " ╚██╔╝ ██║ ██║██║ ██║██║ ██║██╔══██╗██╔══██║╚════██║██║██║ \n" +printf " ██║ ╚██████╔╝╚██████╔╝██████╔╝██║ ██║██║ ██║███████║██║███████╗\n" +printf " ╚═╝ ╚═════╝ ╚═════╝ ╚═════╝ ╚═╝ ╚═╝╚═╝ ╚═╝╚══════╝╚═╝╚══════╝\n" +printf "$BOLDROUGE Customize Linux Mint & Ubuntu derivatives made easier\n" +printf "$BOLDBLANC ver "$version" - GPLv3 - Francois B. (Makotosan) - makotonoblog.be\n" + +printf "\n" +printf "$BOLDVERT""User (userdir) :""$NORMAL"" $myHomedir\n" +printf "$BOLDVERT""OS : ""$NORMAL" +lsb_release -d | awk -F':' '{print $2}' | awk -F'\t' '{print $2}' +printf "$BOLDVERT""Kernel : ""$NORMAL" +uname -r +printf "$BOLDVERT""Architecture : ""$NORMAL" +uname -m + +#osCheck +#deCheck +#depCheck + +# Useless by itself, but is used to don't be annoyed later in the script +# NEVER run the script as root or with sudo !!!! +if ! [ "$UID" -ne "0" ]; then + printf "\n" + printf "$BOLDROUGE""This script can't be run as root/sudo, please retry as normal user""$NORMAL" + printf "\n\n" + exit +fi +sudo echo + +pressKey + +# Apps dir created if necessary +mkdir -p /home/$myHomedir/Apps + +#------------------------------------------------------------------------------# +# Main menu # +#------------------------------------------------------------------------------# + +while true; do # main menu loop + +mainMenuOptions=$(whiptail \ +--title "Yggdrasil $version - Main Menu" \ +--menu "This tool will help you to install all needed applications and cutomize your fresh install of Mint/Ubuntu/Elementary/..." \ +25 80 16 \ +"1" "System update" \ +"2" "Add required PPA/Repo" \ +"3" "Applications" \ +"4" "Applications (BETA)" \ +"5" "Applications (Nightly)" \ +"6" "Themes & Icons" \ +"7" "Dev Apps" \ +"8" "System Config" \ +"9" "System Tools" \ +"10" "Reboot this computer" \ +"11" "About Yggdrasil" \ +"12" "Quit" 3>&1 1>&2 2>&3) + +case $mainMenuOptions in + "1") + updateSystem + pressKey + ;; + "2") + addRequiredPPA + pressKey + ;; + "3") + showAppInstallMenu + ;; + "4") + showAppBetaInstallMenu + ;; + "5") + showAppNightlyInstallMenu + ;; + "6") + showThemesInstallMenu + ;; + "7") + showDevInstallMenu + ;; + "8") + showConfigMenu; + ;; + "9") + showSysToolsMenu + ;; + "10") + showRebootBoxMenu + ;; + "11") + showAboutBoxMenu + ;; + "12") + exit + ;; + +esac # main menu + +done # end of main menu loop + +#------------------------------------------------------------------------------# + +clear +exit