diff options
-rw-r--r-- | CMakeLists.txt | 6 | ||||
-rw-r--r-- | LICENSE | 674 | ||||
-rw-r--r-- | README.md | 5 | ||||
-rw-r--r-- | arch-install | 111 | ||||
-rw-r--r-- | ffmpeg | 5 | ||||
-rw-r--r-- | find | 2 | ||||
-rw-r--r-- | firewall/fail2ban/action.d/nftables-common.local | 3 | ||||
-rw-r--r-- | firewall/fail2ban/jail.local | 16 | ||||
-rw-r--r-- | firewall/iptables | 1 | ||||
-rwxr-xr-x | firewall/nftables.conf | 33 | ||||
-rw-r--r-- | firewall/nftables/fail2ban.conf | 7 | ||||
-rw-r--r-- | git | 33 | ||||
-rw-r--r-- | gpg | 15 | ||||
-rw-r--r-- | grub | 4 | ||||
-rw-r--r-- | icons | 8 | ||||
-rw-r--r-- | irc | 18 | ||||
-rw-r--r-- | laravel | 16 | ||||
-rw-r--r-- | lemp | 75 | ||||
-rw-r--r-- | minimal.css | 46 | ||||
-rw-r--r-- | openbsd/libreboot_grub.cfg | 30 | ||||
-rw-r--r-- | openbsd/openbsd_setup | 64 | ||||
-rw-r--r-- | openbsd/xenodm/GiveConsole | 18 | ||||
-rw-r--r-- | openbsd/xenodm/Xresources | 174 | ||||
-rw-r--r-- | openbsd/xenodm/Xsetup_0 | 18 | ||||
-rw-r--r-- | parabola-openrc-install | 129 | ||||
-rw-r--r-- | parabola-systemd-install | 150 | ||||
-rw-r--r-- | postgresql | 50 | ||||
-rw-r--r-- | powertop.service | 15 | ||||
-rw-r--r-- | qemu | 2 | ||||
-rw-r--r-- | querydb.php | 17 | ||||
-rw-r--r-- | rss | 1 | ||||
-rw-r--r-- | static-ip | 9 | ||||
-rw-r--r-- | tmux | 33 | ||||
-rw-r--r-- | wordpress | 31 | ||||
-rw-r--r-- | youtube-dl | 6 |
35 files changed, 1825 insertions, 0 deletions
diff --git a/CMakeLists.txt b/CMakeLists.txt new file mode 100644 index 0000000..a613ca3 --- /dev/null +++ b/CMakeLists.txt @@ -0,0 +1,6 @@ +cmake_minimum_required(VERSION 3.13) +project(some_project) + +set( CMAKE_CXX_STANDARD 17 ) + +add_executable( ${PROJECT_NAME} main.cpp ) @@ -0,0 +1,674 @@ + GNU GENERAL PUBLIC LICENSE + Version 3, 29 June 2007 + + Copyright (C) 2007 Free Software Foundation, Inc. <https://fsf.org/> + 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 <https://www.gnu.org/licenses/>. + +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: + + <program> Copyright (C) <year> <name of author> + 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 +<https://www.gnu.org/licenses/>. + + 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 +<https://www.gnu.org/licenses/why-not-lgpl.html>. diff --git a/README.md b/README.md new file mode 100644 index 0000000..fda745b --- /dev/null +++ b/README.md @@ -0,0 +1,5 @@ +# About this project: + +Here I keep notes, guides and links for programs/technologies that I use/used. +You may find something useful here. +*Just note that most files with shebang(#!) should not be executed, it's just for syntax highlighting.* diff --git a/arch-install b/arch-install new file mode 100644 index 0000000..28a021a --- /dev/null +++ b/arch-install @@ -0,0 +1,111 @@ +#!/usr/bin/env bash +#Check if it is UEFI +ls /sys/firmware/efi/efivars + +#WIFI +wifi-menu +#OR +#ip link set wlan0 up +wpa_passphrase NETWORK_SSID >> /etc/wpa_supplicant.conf +NETWORK_PASSWORD +wpa_supplicant -B -D wext -i wlan0 -c /etc/wpa_supplicant.conf +dhclient wlan0 + +#Check internet +ping archlinux.org + +#Check time - not important +timedatectl set-ntp true +timedatectl status + +#Set mirrors +pacman -Syy +pacman -S reflector +reflector -c "Germany" -f 12 -l 10 -n 12 --save /etc/pacman.d/mirrorlist +reflector --verbose --latest 10 --sort rate + +#Format hard drive +#Four partition needed: efi root home swap +fdisk -l +cgdisk /dev/sda + +#Format partitions +mkfs.vfat /dev/sdaW +mkfs.ext4 /dev/sdaX +mkfs.ext4 /dev/sdaY + +#Set swap +mkswap /dev/sdaZ +swapon /dev/sdaZ + +#Mount partitions +mount /dev/sdaX /mnt +mkdir /mnt/home +mount /dev/sdaY /mnt/home +mkdir -p /mnt/boot/efi +mount /dev/sdaW mnt/boot/efi + +#Install system +pacstrap /mnt base base-devel linux linux-firmware + +#Generate fstab file +genfstab -U /mnt >> /mnt/etc/fstab + +#Chroot to newly build system +arch-chroot /mnt {/bin/bash} + +#Set timezone +ln -sf /usr/share/zoneinfo/Region/City /etc/localtime +hwclock --systohc + +#Generate locale +sed -i "s/#en_US.UTF-8 UTF-8/en_US.UTF-8 UTF-8/" /etc/locale.gen +locale-gen + +echo "LANG=en_US.UTF-8" > /etc/locale.conf + +echo "KEYMAP=us" > /etc/vconsole.conf + +#Set hostname +echo "myhostname" > /etc/hostname + +#Network configuration +cat > /etc/hosts << EOF +127.0.0.1 localhost +::1 localhost +127.0.1.1 myhostname.localdomain myhostname +EOF + +systemctl enable dhcpcd + +#Install bootloader +pacman -S grub efibootmgr os-prober +#os-prober ? Problems in chroot +grub-install --target=x86_64-efi --bootloader-id=GRUB --efi-directory=/boot/efi +grub-mkconfig -o /boot/grub/grub.cfg + +#Probably unneeded---------------------------------------------- +mkdir /boot/efi/EFI/BOOT +cp /boot/efi/EFI/GRUB/grubx64.efi /boot/efi/EFI/BOOT/BOOTX64.EFI +nano /boot/efi/startup.nsh + bcf boot add 1 fs0:\EFI\GRUB\grubx64.efi "My GRUB bootloader" + exit +#--------------------------------------------------------------- + +#Set root password +passwd + +#Set new user and give him root privileges +useradd -mg users -G wheel {-s /bin/bash} username +passwd username +visudo + %wheel ALL=(ALL) ALL + +#Exit chroot +exit + +#Unmount partitions +umount -R /mnt + +#Boot to new system +reboot @@ -0,0 +1,5 @@ +ffmpeg -f x11grab -x 1024x768 -i :0.0 out.mkv +ffmpeg -i /dev/video0 out.mkv +ffmpeg -f alsa -i default out.flac +-c:v libx264 -r 30 -c:a flac +xdpyinfo | grep dimensions @@ -0,0 +1,2 @@ +# Find files by file ext and sort them by date and time: +sudo find . -name *.ods -printf "%AD %AT %p\n" | sort -k1.8n -k1.1nr -k1 diff --git a/firewall/fail2ban/action.d/nftables-common.local b/firewall/fail2ban/action.d/nftables-common.local new file mode 100644 index 0000000..198e93f --- /dev/null +++ b/firewall/fail2ban/action.d/nftables-common.local @@ -0,0 +1,3 @@ +[Init] +nftables_table = fail2ban +blocktype = drop diff --git a/firewall/fail2ban/jail.local b/firewall/fail2ban/jail.local new file mode 100644 index 0000000..f891d06 --- /dev/null +++ b/firewall/fail2ban/jail.local @@ -0,0 +1,16 @@ +[DEFAULT] +banaction = nftables-multiport +chain = input + +[nginx-http-auth] +enabled = true + +#[apache-auth] +#enabled = true + +[dovecot] +enabled = true +port = pop3,pop3s,imap2,imaps,submission,465,sieve + +[postfix] +enabled = true diff --git a/firewall/iptables b/firewall/iptables new file mode 100644 index 0000000..97cf1d1 --- /dev/null +++ b/firewall/iptables @@ -0,0 +1 @@ +https://github.com/ChrisTitusTech/firewallsetup.git diff --git a/firewall/nftables.conf b/firewall/nftables.conf new file mode 100755 index 0000000..d5e7f25 --- /dev/null +++ b/firewall/nftables.conf @@ -0,0 +1,33 @@ +#!/usr/sbin/nft -f + +flush ruleset + +table inet filter { + chain input { + type filter hook input priority 0; policy drop; + iifname lo accept + ct state established,related accept + tcp dport ssh ct state new accept + tcp dport http ct state new accept + tcp dport https ct state new accept + tcp dport imaps ct state new accept + tcp dport submission ct state new accept + tcp dport smtp ct state new accept + + # ICMP: errors, pings + ip protocol icmp icmp type { echo-request, echo-reply, destination-unreachable, time-exceeded, parameter-problem, router-solicitation, router-advertisement } accept + # ICMPv6: errors, pings, routing + ip6 nexthdr icmpv6 counter accept comment "accept all ICMP types" + + # Reject other packets + ip protocol tcp reject with tcp reset + } + chain forward { + type filter hook forward priority 0; policy drop; + } + chain output { + type filter hook output priority 0; policy accept; + } +} + +include "/etc/nftables/fail2ban.conf" diff --git a/firewall/nftables/fail2ban.conf b/firewall/nftables/fail2ban.conf new file mode 100644 index 0000000..62b9897 --- /dev/null +++ b/firewall/nftables/fail2ban.conf @@ -0,0 +1,7 @@ +#!/usr/sbin/nft -f + +table inet fail2ban { + chain input { + type filter hook input priority 100; + } +} @@ -0,0 +1,33 @@ +git init +git add . +git commit -m 'Initial commit' +git remote add origin link-to-repo +git push origin master +git branch --set-upstream-to=origin/master master + +git branch new-branch +git switch new-branch +git switch master +git merge new-branch + +git pull -> git fetch && git merge origin/master + +git fetch --dry-run? +git remote show origin +git remote update ~= git fetch --all +git status -uno? + +git fetch +git diff master origin/master + +git branch -a #list branches +git branch -d branch-to-delete + +git log +git show <commit-id> + +git checkout old-commit +git checkout master + +# Pushing to non-bare repo (apply to repo that need to recive update) +git config --local receive.denyCurrentBranch updateInstead @@ -0,0 +1,15 @@ +gpg -k +gpg -K + +gpg --verify gnupg-2.2.21.tar.bz2.sig gnupg-2.2.21.tar.bz2 + +gpg --edit-key 0x12345678 +gpg> key 0 +gpg> expire +gpg> key 1 +gpg> expire +gpg> save + +gpg --armor --export mail@example.com > example-key.asc +gpg --output public.pgp --armor --export username@email +gpg --output private.pgp --armor --export-secret-key username@email @@ -0,0 +1,4 @@ +grub-install --target=i386-pc --root-directory=/mnt --no-floppy --recheck --force /dev/sdb +grub-install --target=x86_64-efi --bootloader-id=GRUB --efi-directory=/boot/efi +grug-install /dev/sdb +grub-mkconfig -o /boot/grub/grub.cfg @@ -0,0 +1,8 @@ +# TTF to SVG +http://fontello.com/ +https://icomoon.io/ +FontForge Open Source Font Editor +# Optimize SVG +svgcleaner +scour -i input.svg -o output.svg +scour -i input.svg -o output.svg --enable-viewboxing @@ -0,0 +1,18 @@ +# irssi +/set nick yourNick +/connect chat.freenode.net +/join #channelname + +# private msg +/msg user text + +# to mention someone, just use their nick +/msg alis LIST *searchterm* + +# https://lug.oregonstate.edu/blog/irc-and-ssl/ +/server add -ssl_verify chat.freenode.net 6697 + +/connect -tls chat.freenode.net + +/connect -tls chat.freenode.net ACCOUNT:PASSWORD +/msg NickServ identify PASSWORD @@ -0,0 +1,16 @@ +#!/usr/bin/env bash + +composer global require laravel/installer +laravel new blog +# OR +composer create-project --prefer-dist laravel/laravel blog + +cd blog +sudo chown -R $USER:www-data storage +sudo chown -R $USER:www-data bootstrap/cache +chmod -R 775 storage +chmod -R 775 bootstrap/cache +#chmod -R g+w storage +#chmod -R g+w bootstrap/cache +cp .env.example .env +php artisan key:generate @@ -0,0 +1,75 @@ +#!/usr/bin/env bash + +# Secure SSHD +# ssh-copy-id user@hostname +# PasswordAuth no + +# Update server +apt update +apt upgrade + +#Setting up firewall +ufw default deny incoming +ufw default allow outgoing +ufw default deny routed +ufw allow 22/tcp +ufw allow 80/tcp +ufw allow 443/tcp +ufw enable +systemctl enable --now ufw + +# Installing necessary packages +apt install ufw curl +apt install nginx mariadb-server php-fpm php-mysql +apt install php-curl php-gd php-intl php-mbstring php-soap php-xml php-xmlrpc php-zip +apt install python3-certbot-nginx + +systemctl restart php7.3-fpm.service + +# Setting up Nginx +mkdir -p /var/www/example.com + +cat > /etc/nginx/sites-available/example.com << EOF +server { + listen 80; + listen [::]:80; + + root /var/www/example.com; + index index.php index.html index.htm; + + server_name example.com; + + location = /favicon.ico { log_not_found off; access_log off; } + location = /robots.txt { log_not_found off; access_log off; allow all; } + + location ~* \.(gif|jpeg|jpg|png)$ { + expires max; + log_not_found off; + } + + location / { + # try_files $uri $uri/ =404; + try_files $uri $uri/ /index.php$is_args$args; + } + + location ~ \.php$ { + include snippets/fastcgi-php.conf; + fastcgi_pass unix:/var/run/php/php7.3-fpm.sock; + } +} +EOF +## Test Nginx config with nginx -t +cat > /var/www/example.com/index.php << EOF +<?php +phpinfo(); +?> +EOF +ln -s /etc/nginx/sites-available/example.com /etc/nginx/sites-enabled/ +systemctl restart nginx + +# HTTPS +certbot --nginx -d example.com +systemctl restart nginx + +# MariaDB +mysql_secure_installation diff --git a/minimal.css b/minimal.css new file mode 100644 index 0000000..b16353e --- /dev/null +++ b/minimal.css @@ -0,0 +1,46 @@ +/* +a:link { + color: #0077AA; +} +a:visited { + color: #941352; +} +*/ +.code, pre, code { font-family: Consolas, Monaco, monospace; } +.sans-serif { font-family: "Noto Sans", sans-serif; } +.serif { font-family: "Noto Serif", Georgia, Times, serif; } +body { + margin: 40px auto; + max-width: 650px; + + line-height: 1.6em; + font-size: 1.125em; + font-family: sans-serif; + + color: #444; + background-color: #EEE; + + padding: 0 10px; +} +h1,h2,h3 { + line-height: 1.2; +} +a { + color: #0077AA; +} +.veral { + vertical-align: bottom; +} +#contact { + margin-top: 40px; + border: 2px solid #444; + border-radius: 15px; + padding-left: 1em; + padding-right: 1em; +} +@media only screen and (max-width: 650px) { + body { + margin: 20px auto; + font-size: 1em; + } +} diff --git a/openbsd/libreboot_grub.cfg b/openbsd/libreboot_grub.cfg new file mode 100644 index 0000000..f0259bd --- /dev/null +++ b/openbsd/libreboot_grub.cfg @@ -0,0 +1,30 @@ +default=2 +timeout=2 + +menuentry "OpenBSD" { + kopenbsd -r sd0a (ahci0,openbsd1)/bsd +} + +#menuentry "OpenBSD chainload" { +# insmod part_bsd +# insmod part_msdos +# set root=(ahci0,msdos4) +# chainloader +1 +#} + +menuentry "SeaBIOS chainload" { +# insmod part_msdos +# insmod part_bsd +# set root=(ahci0,msdos4) + chainloader (ahci0,msdos4)/grub/bios.bin.elf +# boot +} + +menuentry "VGA SeaBIOS chainload" { +# insmod part_msdos +# insmod part_bsd +# set root=(ahci0,msdos4) + multiboot (ahci0,msdos4)/grub/bios.bin.elf + module (ahci0,msdos4)/grub/vgabios.bin name=vgaroms/seavgabios.bin +# boot +} diff --git a/openbsd/openbsd_setup b/openbsd/openbsd_setup new file mode 100644 index 0000000..073f8bf --- /dev/null +++ b/openbsd/openbsd_setup @@ -0,0 +1,64 @@ +#!/bin/sh + +ifconfig + +ifconfig athn0 nwid YOUR_SSID wpakey YOUR_PASSWORD +dhclient athn0 + +cat > /etc/hostname.athn0 << EOF +nwid YOUR_SSID wpakey YOUR_PASSWORD +dhcp +EOF + +sh /etc/netstart athn0 + +cat > /etc/wsconsctl.cong << EOF +keyboard.bell.volume=0 +keyboard.map+="keysym Caps_Lock = Escape" +EOF + +cat ~/.xsession << EOF +xset b off +setxkbmap -option caps:swapescape +exec /usr/local/bin/i3 +EOF + +comment_out /etc/X11/xenodm/Xsetup_0 + +rcctl set apmd status on +rcctl set apmd flags -A + +rcctl set smtpd status off + +sysctl hw.disknames +disklabel sd1 +mount -t msdos /dev/sd1i /mnt +umount /mnt + +fw_update + +#usermod -G staff USER_NAME +#/etc/login.conf staff:maxproc + +echo 'permit persist keepenv USER_NAME' > /etc/doas.conf + +/etc/X11/xenodm/GiveConsole + +sndioctl output.level=+0.05 +sndioctl output.mute=! + +killall -USR1 i3status + +https://www.openbsd.org/anoncvs.html +--- +cd /usr +cvs -qd anoncvs@anoncvs.ca.openbsd.org:/cvs checkout -rOPENBSD_6_7 -P src + +BIOS======================= +git clone https://git.seabios.org/seabios.git +Build without cbfs support +https://g00se.org/2016/11/seabios-on-libreboot.html + +https://github.com/librecore-org/librecore/wiki/Chainloading-SeaBIOS-from-a-GRUB-payload +https://github.com/bibanon/Coreboot-ThinkPads/blob/master/Libreboot-Mods/Libreboot-GRUB2.md +========================== diff --git a/openbsd/xenodm/GiveConsole b/openbsd/xenodm/GiveConsole new file mode 100644 index 0000000..079392f --- /dev/null +++ b/openbsd/xenodm/GiveConsole @@ -0,0 +1,18 @@ +#!/bin/sh +# Assign ownership of the console to the invoking user +# $OpenBSD: GiveConsole,v 1.3 2019/05/12 11:53:06 jsg Exp $ +# +# By convention, both xconsole and xterm -C check that the +# console is owned by the invoking user and is readable before attaching +# the console output. This way a random user can invoke xterm -C without +# causing serious grief. +# +pkill xclock +chown $USER /dev/console +if [ -c /dev/drm0 ]; then + chown $USER /dev/drm0 +fi +if [ -c /dev/drmR128 ]; then + chown $USER /dev/drmR128 +fi +/usr/X11R6/bin/sessreg -a -l $DISPLAY -u none $USER diff --git a/openbsd/xenodm/Xresources b/openbsd/xenodm/Xresources new file mode 100644 index 0000000..17d8e41 --- /dev/null +++ b/openbsd/xenodm/Xresources @@ -0,0 +1,174 @@ +#define WHITE #EDF6E6 +#define BLACK #252123 +#define RED #DA9B9A +#define BLUE #7AADD9 +#define DKBLUE #6187AD +#define GRAY #54697F +#define DKGRAY #4A566B + +xroot.background: BLACK + +xclock*background: BLACK +xclock*foreground: WHITE +xclock*borderWidth: 0 +xclock*geometry: -0+0 +xclock.Clock.analog: false +xclock.Clock.chime: false +xclock.Clock.render: true +xclock.Clock.twentyfour:true +xclock.Clock.update: 10 + + +xlogin*login.translations: #override \ + <Key>F1: set-session-argument(failsafe) finish-field()\n\ + <Key>Left: move-backward-character()\n\ + <Key>Right: move-forward-character()\n\ + <Key>Home: move-to-begining()\n\ + <Key>End: move-to-end()\n\ + Ctrl<Key>KP_Enter: set-session-argument(failsafe) finish-field()\n\ + <Key>KP_Enter: set-session-argument() finish-field()\n\ + Ctrl<Key>Return: set-session-argument(failsafe) finish-field()\n\ + <Key>Return: set-session-argument() finish-field() + +#xlogin*greeting: CLIENTHOST +#xlogin*greeting: Please, enter your login credentials. +#greeting text +xlogin*greeting: +xlogin*namePrompt: \040\040\040\040\040\040\040Login:\040 +xlogin*passwdPrompt: Password:\040 +#fail text +xlogin*fail: Login incorrect or forbidden +#background color (not prompt) +xlogin*background: BLACK +#prompt text color +xlogin*foreground: WHITE +#boreder around +xlogin*borderWidth: 0 +#what? +xlogin*frameWidth: 0 +#what? +xlogin*innerFramesWidth: 0 +xlogin.Login.innerFramesWidth: 0 +#line below greeting +xlogin*sepWidth: 0 +#inside prompt color +xlogin*inpColor: BLACK +#prompt text color +xlogin*promptColor: WHITE +#fail text color +xlogin*failColor: WHITE +#fonts passwd and prompt-text +xlogin*face: DejaVu Sans-18 +xlogin*promptFace: DejaVu Sans-18 + +##if WIDTH > 800 +#xlogin*greetFont: -adobe-helvetica-bold-o-normal--24-240-75-75-p-138-iso8859-1 +#xlogin*font: -adobe-helvetica-medium-r-normal--18-180-75-75-p-98-iso8859-1 +#xlogin*promptFont: -adobe-helvetica-bold-r-normal--18-180-75-75-p-103-iso8859-1 +#xlogin*failFont: -adobe-helvetica-bold-r-normal--18-180-75-75-p-103-iso8859-1 +#xlogin*greetFace: DejaVu Sans Condensed-22:bold:italic:dpi=75 +#xlogin*face: DejaVu Sans Condensed-16:dpi=75 +#xlogin*promptFace: DejaVu Sans Condensed-16:bold:dpi=75 +#xlogin*failFace: DejaVu Sans Condensed-16:bold:dpi=75 +##else +#xlogin*greetFont: -adobe-helvetica-bold-o-normal--17-120-100-100-p-92-iso8859-1 +#xlogin*font: -adobe-helvetica-medium-r-normal--12-120-75-75-p-67-iso8859-1 +#xlogin*promptFont: -adobe-helvetica-bold-r-normal--12-120-75-75-p-70-iso8859-1 +#xlogin*failFont: -adobe-helvetica-bold-o-normal--14-140-75-75-p-82-iso8859-1 +#xlogin*greetFace: DejaVu Sans Condensed-18:bold:italic:dpi=75 +#xlogin*face: DejaVu Sans Condensed-12:dpi=75 +#xlogin*promptFace: DejaVu Sans Condensed-12:bold:dpi=75 +#xlogin*failFace: DejaVu Sans Condensed-12:bold:dpi=75 +##endif +# +##if !(defined(bpp1) || defined(bpp4) || defined(bpp8) || defined(bpp15)) +## if PLANES < 4 +## ifndef bpp1 +## define bpp1 +## endif +## else +## if PLANES > 4 +## if PLANES > 8 +## ifndef bpp15 +## define bpp15 +## endif +## else +## ifndef bpp8 +## define bpp8 +## endif bpp8 +## endif +## else +## ifndef bpp4 +## define bpp4 +## endif +## endif +## endif +##endif /* If manual override */ +# +##ifndef bpp1 +#xlogin*borderWidth: 1 +#xlogin*frameWidth: 2 +#xlogin*innerFramesWidth: 0 +# +#xlogin.Login.sepWidth: 0 +# +#! top/left border +# xlogin*hiColor: #667788 +# +#! bottom/right border +#xlogin*shdColor: #667788 +# +#! 'Welcome to..' text color +#xlogin*greetColor: #fef886 +##if defined(bpp4) || defined(bpp8) || defined(bpp15) +#! flood fill +#xlogin*background: #798a99 +#xlogin*inpColor: #99aab9 +##endif +#xlogin*failColor: #aa0000 +# +#! 'Login:' and 'Password:' +#*Foreground: #eeeeff +# +#! border/shadow +#*Background: #000000 +##else +#xlogin*borderWidth: 3 +#xlogin*frameWidth: 5 +#xlogin*innerFramesWidth: 1 +#xlogin*shdColor: white +#xlogin*hiColor: white +#xlogin*greetColor: white +#xlogin*background: black +#xlogin*failColor: white +#xlogin*promptColor: white +#*Foreground: white +#*Background: black +##endif +##ifdef bpp1 +#xlogin*logoFileName: /etc/X11/xenodm/pixmaps/OpenBSD_1bpp.xpm +##endif +##ifdef bpp4 +#xlogin*logoFileName: /etc/X11/xenodm/pixmaps/OpenBSD_4bpp.xpm +##endif +##ifdef bpp8 +#xlogin*logoFileName: /etc/X11/xenodm/pixmaps/OpenBSD_8bpp.xpm +##endif +##ifdef bpp15 +#xlogin*logoFileName: /etc/X11/xenodm/pixmaps/OpenBSD_15bpp.xpm +##endif +# +#xlogin*useShape: true +#xlogin*logoPadding: 10 +# +#! uncomment to disable logins +#! xlogin.Login.allowRootLogin: false +# +#XConsole*background: black +#XConsole*foreground: white +#XConsole*borderWidth: 2 +#XConsole*borderColor: grey +#XConsole.text.geometry: 480x130 +#XConsole.verbose: true +#XConsole*iconic: true +#XConsole*font: fixed diff --git a/openbsd/xenodm/Xsetup_0 b/openbsd/xenodm/Xsetup_0 new file mode 100644 index 0000000..a9c7c16 --- /dev/null +++ b/openbsd/xenodm/Xsetup_0 @@ -0,0 +1,18 @@ +#!/bin/sh +# $OpenBSD: Xsetup_0,v 1.6 2019/06/29 13:33:06 espie Exp $ + +#xconsole -geometry 480x130-0-0 -daemon -notify -verbose -fn fixed -exitOnFail + +# install package openbsd-backgrounds +# then uncomment: +# +# if test -x /usr/local/bin/openbsd-wallpaper +# then +# /usr/local/bin/openbsd-wallpaper +# fi + +# sxpm OpenBSD.xpm & + +xrandr --output default --dpi 96 +xsetroot -solid $(xrdb -query | awk '/xroot.background/ { print $2 }') +xclock -strftime "%A %d %b %Y %H:%M" & diff --git a/parabola-openrc-install b/parabola-openrc-install new file mode 100644 index 0000000..b9d0567 --- /dev/null +++ b/parabola-openrc-install @@ -0,0 +1,129 @@ +#!/usr/bin/env bash +#grub> set root=(usb0) +#grub> linux /parabola/boot/x86_64/vmlinuz append parabolaisobasedir=parabola parabolaisolabel=PARA_202001 +#grub> initrd /parabola/boot/x86_64/parabolaiso.img +#grub> boot +# +#AUTOMATIC ISOLINUX RECOGNISED + +#Check internet +ping parabola.nu + +#pacman +vim /etc/pacman.conf +vim /etc/pacman.d/mirrorlist + +#Update keys +pacman -Sy archlinux-keyring archlinuxarm-keyring parabola-keyring +pacman-key --refresh-keys + +#Format hard drive +#Three partition needed: root home swap +fdisk -l +#wipefs --all /dev/sda +fdisk /dev/sda + +#Format partitions +mkfs.ext4 /dev/sdaX +mkfs.ext4 /dev/sdaY + +#Set swap +mkswap /dev/sdaZ +swapon /dev/sdaZ + +#Mount partitions +mount /dev/sdaX /mnt +mkdir /mnt/home +mount /dev/sdaY /mnt/home + +#Set time if necessary +date MMDDhhmmYYYY.ss + +#Install system +pacstrap /mnt base elogind +pacstrap /mnt base-devel syslog-ng #don't accept systemd +pacstrap /mnt linux-libre linux-libre-lts linux-libre-fireware +pacstrap /mnt parabola-base +pacstrap /mnt networkmanager +pacstrap /mnt grub +#pacstrap /mnt openrc-init eudev +#pacstrap /mnt openrc-base + +#Generate fstab file +genfstab -U /mnt >> /mnt/etc/fstab + +#Chroot to newly build system +arch-chroot /mnt {/bin/bash} + +#Set timezone +ln -sf /usr/share/zoneinfo/Region/City /etc/localtime +hwclock --systohc + +#Generate locale +sed -i "s/#en_US.UTF-8 UTF-8/en_US.UTF-8 UTF-8/" /etc/locale.gen +locale-gen + +echo "LANG=en_US.UTF-8" > /etc/locale.conf + +#Set hostname +echo "hostname=\"myhostname\"" > /etc/conf.d/hostname + +#Network configuration +cat > /etc/hosts << EOF +127.0.0.1 localhost +::1 localhost +127.0.1.1 myhostname.localdomain myhostname +EOF + +rc-update add NetworkManager default + +#YOU WILL NEED TO REMOVE LINUX KERNAL AND MKINITCPIO PRESETS AND THEN REINSTALL KERNAL - EMPTY MKINITCPIO PRESET +#Generate boot disk +mkinitcpio -p linux-libre-lts + +#Install bootloader +grub-install /dev/sda +grub-mkconfig -o /boot/grub/grub.cfg + +#Set root password +passwd + +#Set new user and give him root privileges +useradd -mg users -G wheel {-s /bin/bash} username +passwd username +visudo + %wheel ALL=(ALL) ALL + +#Exit chroot +exit + +#Unmount partitions +umount -R /mnt + +#Boot to new system +reboot + +#-------------------------------------------------------------------------------- +#buzzing +sudo su +pacman -S powertop +echo > /etc/init.d/powertop << EOF +#!/sbin/openrc-run +name="PowerTop" +description="Fix your buzzing problem..." + +start () { + /usr/bin/powertop --quiet --auto-tune > /dev/null +} +#No need for stop() since powertop isn't a deamon +EOF + +#INTERNET +nmtui [OR] +nmcli device wifi list +nmcli device wifi connect SSID password PASSWORD + +#NTP +pacman -S ntp +rc-service ntp-client start +hwclock --systohc diff --git a/parabola-systemd-install b/parabola-systemd-install new file mode 100644 index 0000000..294c8b8 --- /dev/null +++ b/parabola-systemd-install @@ -0,0 +1,150 @@ +#!/usr/bin/env bash +#grub> set root=(usb0) +#grub> linux /parabola/boot/x86_64/vmlinuz append parabolaisobasedir=parabola parabolaisolabel=PARA_202001 +#grub> initrd /parabola/boot/x86_64/parabolaiso.img +#grub> boot +# +#AUTOMATIC ISOLINUX RECOGNISED + +#Check internet +ping parabola.nu + +vim /etc/pacman.conf #comment nonsystemd! +vim /etc/pacman.d/mirrorlist + +pacman -Sy archlinux-keyring archlinuxarm-keyring parabola-keyring +pacman-key --refresh-keys + +#Format hard drive +#Three partition needed: root home swap +fdisk -l +#wipefs --all /dev/sda +fdisk /dev/sda + +#Format partitions +mkfs.ext4 /dev/sdaX +mkfs.ext4 /dev/sdaY + +#Set swap +mkswap /dev/sdaZ +swapon /dev/sdaZ + +#Mount partitions +mount /dev/sdaX /mnt +mkdir /mnt/home +mount /dev/sdaY /mnt/home + +#Check time - important because of the timestamps on gpg keys +timedatectl set-ntp true +timedatectl status + +#Set time if necessary +date MMDDhhmmYYYY.ss + +#USE OPENRC ISO INSTEAD----------------------------------------------------- +#Very old iso :( +pacman -Sy archlinuxarm-keyring parabola-keyring +pacman-key --populate archlinux archlinux32 archlinuxarm parabola +pacman-key --refresh-keys +wget https://pkgbuild.com/~eschwartz/repo/x86_64-extracted/pacman-static +chmod +x pacman-static +./pacman-static -S libarchive +pacman -Sy archlinux-keyring +pacman-key --populate archlinux archlinux32 archlinuxarm parabola +pacman-key --refresh-keys +pacman -Sy archlinux32-keyring +pacman-key --populate archlinux archlinux32 archlinuxarm parabola +pacman-key --refresh-keys + +#Doesn't do anything useful +pacman -U https://www.parabola.nu/packages/core/i686/archlinux32-keyring-transition/download/ +#---------------------------------------------------------------------------- + +#Install system +#pacman unsubscribe from nonsystemd +pacstrap /mnt base base-devel +pacstrap /mnt linux-libre linux-libre-lts linux-libre-firmware +pacstrap /mnt networkmanager +pacstrap /mnt parabola-base +pacstrap /mnt grub + +#Generate fstab file +genfstab -U /mnt >> /mnt/etc/fstab + +#Chroot to newly build system +arch-chroot /mnt {/bin/bash} + +#Set timezone +ln -sf /usr/share/zoneinfo/Region/City /etc/localtime +hwclock --systohc + +#Generate locale +sed -i "s/#en_US.UTF-8 UTF-8/en_US.UTF-8 UTF-8/" /etc/locale.gen +locale-gen + +echo "LANG=en_US.UTF-8" > /etc/locale.conf + +echo "KEYMAP=us" > /etc/vconsole.conf + +#Set hostname +echo "myhostname" > /etc/hostname + +#Network configuration +cat > /etc/hosts << EOF +127.0.0.1 localhost +::1 localhost +127.0.1.1 myhostname.localdomain myhostname +EOF + +systemctl enable NetworkManager + +#YOU WILL NEED TO REMOVE LINUX KERNAL AND MKINITCPIO PRESETS AND THEN REINSTALL KERNAL - EMPTY MKINITCPIO PRESET +#Generate boot disk +mkinitcpio -p linux-libre-lts + +#Install bootloader +grub-install /dev/sda +grub-mkconfig -o /boot/grub/grub.cfg + +#Set root password +passwd + +#Set new user and give him root privileges +useradd -mg users -G wheel {-s /bin/bash} username +passwd username +visudo + %wheel ALL=(ALL) ALL + +#Exit chroot +exit + +#Unmount partitions +umount -R /mnt + +#Boot to new system +reboot + +#-------------------------------------------------------------------------------- +#buzzing +sudo su +pacman -S powertop + +cat > /etc/systemd/system/powertop.service << EOF +[Unit] +Description=Powertop tunings + +[Service] +Type=oneshot +RemainAfterExit=no +ExecStart=/usr/bin/powertop --auto-tune +Environment="TERM=xterm" + +[Install] +WantedBy=multi-user.target +EOF + +systemctl enable --now powertop + +nmtui [OR] +nmcli device wifi list +nmcli device wifi connect SSID password PASSWORD diff --git a/postgresql b/postgresql new file mode 100644 index 0000000..63b2dc2 --- /dev/null +++ b/postgresql @@ -0,0 +1,50 @@ +pacman -S postgresql +chmod postgres:postgres /var/lib/postgres + +sudo -iu postgres +initdb -D /var/lib/postgres/data + +vim data/pg_hba.conf +vim data/postgresql.conf + +''' +exit +systemd restart postgres +sudo -iu postgres +''' + +createuser user_name +createdb -O db_owner db_name +psql db_name db_user + +\du +\l +\c db +\dt +\q + + +End everything with ; + +CREATE DATABASE d +USE d +DROP DATABASE d +CREATE TABLE t(...) +DROP TABLE t +TRUNCATE TABLE t + +INSERT INTO t VALUES(...) +SELECT ... FROM t [WHERE ...] +UPDATE t SET ... WHERE ... +DELETE FROM t WHERE ... + +ALTER DATABASE name RENAME TO new_name +ALTER DATABASE name OWNER TO new_owner + +ALTER TABLE name RENAME TO new_name +ALTER TABLE name SET SCHEMA new_schema + +SQL DDL (Date Definition Language) - create, alter, drop, rename, truncate, comment +SQL DQL (Date Query Language) - select +SQL DML (Date Manipulation Language) - insert, update, delete, merge, call, explain plan, lock table +SQL DCL (Date Control Language) - grant, revoke diff --git a/powertop.service b/powertop.service new file mode 100644 index 0000000..2cabbbf --- /dev/null +++ b/powertop.service @@ -0,0 +1,15 @@ +# /lib/systemd/system/ +# /etc/systemd/system/ +# /etc/systemd/system/multi-user.target.wants/ +[Unit] +Description=Powertop tunings + +[Service] +Type=oneshot +RemainAfterExit=no +ExecStart=/sbin/powertop --auto-tune +# "powertop --auto-tune" still needs a terminal for some reason. Possibly a bug? +Environment="TERM=xterm" + +[Install] +WantedBy=multi-user.target @@ -0,0 +1,2 @@ +qemu-img create parabola.img 10G +qemu-system-x86_64 -m 2048 -boot d -enable-kvm -smp 3 -hda parabola.img -cdrom openrc2020.08.03.iso diff --git a/querydb.php b/querydb.php new file mode 100644 index 0000000..dade409 --- /dev/null +++ b/querydb.php @@ -0,0 +1,17 @@ +<?php +$user = "example_user"; +$password = "password"; +$database = "example_database"; +$table = "todo_list"; + +try { + $db = new PDO("mysql:host=localhost;dbname=$database", $user, $password); + echo "<h2>TODO</h2><ol>"; + foreach($db->query("SELECT content FROM $table") as $row) { + echo "<li>" . $row['content'] . "</li>"; + } + echo "</ol>"; +} catch (PDOException $e) { + print "Error!: " . $e->getMessage() . "<br/>"; + die(); +} @@ -0,0 +1 @@ +https://www.youtube.com/feeds/videos.xml?channel_id= diff --git a/static-ip b/static-ip new file mode 100644 index 0000000..6ffdd94 --- /dev/null +++ b/static-ip @@ -0,0 +1,9 @@ +ip link set dev INTERFACE up + +ip address add ADDRESS/PREFIX_LAN broadcast + dev INTERFACE + +ip address add ADDRESS/PREFIX_LAN dev INTERFACE + +ip route add PREFIX via ADDRESS dev INTERFACE + +vi /etc/resolv.conf @@ -0,0 +1,33 @@ +# Help +ctrl+b ? + +# New named session +tmux new -s session_name + +# Detach +crtl+b d + +# List sessions +tmux ls + +# Re-attach +tmux attach -t session_name # or number if unnamed + +# Working with windows +Ctrl+b c Create a new window (with shell) + +Ctrl+b w Choose window from a list +Ctrl+b 0 Switch to window 0 (by number ) +Ctrl+n Switch to next window +Ctrl+p Switch to previous window + +Ctrl+b , Rename the current window + +# Working with panes +Ctrl+b % Split current pane horizontally into two panes +Ctrl+b " Split current pane vertically into two panes + +Ctrl+b o Go to the next pane +Ctrl+b ; Toggle between the current and previous pane + +Ctrl+b x Close the current pane diff --git a/wordpress b/wordpress new file mode 100644 index 0000000..93f9880 --- /dev/null +++ b/wordpress @@ -0,0 +1,31 @@ +#!/usr/bin/env bash +# Setup LEMP stack before this. + +# MariaDB + CREATE DATABASE wordpress DEFAULT CHARACTER SET utf8 COLLATE utf8_unicode_ci; + GRANT ALL ON wordpress.* TO 'wpuser'@'localhost' IDENTIFIED BY 'WP_DB_PASSWORD'; + FLUSH PRIVILEGES; + EXIT; + +# WordPress +# Download and set up WordPress +cd /tmp +curl -LO https://wordpress.org/latest.tar.gz +tar xzvf latest.tar.gz +cp /tmp/wordpress/wp-config-sample.php /tmp/wordpress/wp-config.php + +#WP-CONFIG +# Salts +curl -s https://api.wordpress.org/secret-key/1.1/salt/ >> wp-config.php +# DB connect +define('DB_NAME', 'wordpress'); +define('DB_USER', 'wpuser'); +define('DB_PASSWORD', 'WP_DB_PASSWORD'); +define('FS_METHOD', 'direct'); + +# Copy wp to www +cp -a /tmp/wordpress/. /var/www/example.com +chown -R www-data:www-data /var/www/example.com + +#END +systemctl restart nginx diff --git a/youtube-dl b/youtube-dl new file mode 100644 index 0000000..3053624 --- /dev/null +++ b/youtube-dl @@ -0,0 +1,6 @@ +https://www.youtube.com/results?search_query=some+search+query +https://www.youtube.com/watch?v=video-id +-e get name only (no download) +youtube-dl -se --get-id "ytsearch5:your search" +-x extract audio +-o '%(title)s.%(ext)s' |