Recommendation
Common open source license options are summarized very nicely at http://choosealicense.com/licenses/
For Harvard Library created open source projects, the library is motivated to release software under a license that is common in the library community and is as simple and permissive as possible. In general, the Harvard Library wishes to place no restrictions on the reuse of our open source code, for any use, both commercial and non-commercial. Additionally, the library explicitly grants the right to use any patentable concepts. For that reason, the Library recommends that wherever possible, code developed as open source by Harvard Library or Harvard Library Technology Services be released with the Apache 2.0 license.
In choosing the Apache 2.0 license, we follow the lead of Project Hydra, Project Mirador, Project Blacklight, and many others.
How to apply this license
Create a text file (named LICENSE.txt) in the root of your source code and copy the text below into the file. Replace [yyyy] with the current year.
Copyright [yyyy] [President and Fellows of Harvard College] Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0 Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.
License Dependencies
In some cases, it may not be possible to release Harvard Library code under the recommended license. This can happen when the code includes other open source projects that have a more restrictive license that requires projects that incorporate it to inherit the license terms. For example, if a project uses open source code licensed under the LGPL or GPL licenses, there a requirements that the consuming project also be licensed in the same manner. One example is the FITS project. FITS bundles code release under the LGPL license, and is consequently also released under the LGPL license.
Embedded licenses
If a release project includes other licensed code, the main project license.txt file should include a list of the file paths to all of the embedded license.txt files for subprojects within the main project so thaht a user of the project can know the terms of all embedded code, and hence the overall package.