schema-to-ldif.sh 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. #!/bin/bash
  2. # set -x (bash debug) if log level is trace
  3. # https://github.com/osixia/docker-light-baseimage/blob/stable/image/tool/log-helper
  4. log-helper level eq trace && set -x
  5. SCHEMAS=$1
  6. tmpd=`mktemp -d`
  7. pushd ${tmpd} >>/dev/null
  8. echo "include /etc/ldap/schema/core.schema" >> convert.dat
  9. echo "include /etc/ldap/schema/cosine.schema" >> convert.dat
  10. echo "include /etc/ldap/schema/inetorgperson.schema" >> convert.dat
  11. if [ -e "/etc/ldap/schema/rfc2307bis.schema" ]; then
  12. echo "include /etc/ldap/schema/rfc2307bis.schema" >> convert.dat
  13. else
  14. echo "include /etc/ldap/schema/nis.schema" >> convert.dat
  15. fi
  16. for schema in ${SCHEMAS} ; do
  17. echo "include ${schema}" >> convert.dat
  18. done
  19. slaptest -f convert.dat -F .
  20. if [ $? -ne 0 ] ; then
  21. log-helper error "slaptest conversion failed"
  22. exit
  23. fi
  24. for schema in ${SCHEMAS} ; do
  25. fullpath=${schema}
  26. schema_name=`basename ${fullpath} .schema`
  27. schema_dir=`dirname ${fullpath}`
  28. ldif_file=${schema_name}.ldif
  29. if [ -e "${schema_dir}/${ldif_file}" ]; then
  30. log-helper warning "${schema} ldif file ${schema_dir}/${ldif_file} already exists skipping conversion"
  31. continue
  32. fi
  33. find . -name *\}${schema_name}.ldif -exec mv '{}' ./${ldif_file} \;
  34. # TODO: these sed invocations could all be combined
  35. sed -i "/dn:/ c dn: cn=${schema_name},cn=schema,cn=config" ${ldif_file}
  36. sed -i "/cn:/ c cn: ${schema_name}" ${ldif_file}
  37. sed -i '/structuralObjectClass/ d' ${ldif_file}
  38. sed -i '/entryUUID/ d' ${ldif_file}
  39. sed -i '/creatorsName/ d' ${ldif_file}
  40. sed -i '/createTimestamp/ d' ${ldif_file}
  41. sed -i '/entryCSN/ d' ${ldif_file}
  42. sed -i '/modifiersName/ d' ${ldif_file}
  43. sed -i '/modifyTimestamp/ d' ${ldif_file}
  44. # slapd seems to be very sensitive to how a file ends. There should be no blank lines.
  45. sed -i '/^ *$/d' ${ldif_file}
  46. mv ${ldif_file} ${schema_dir}
  47. done
  48. popd >>/dev/null
  49. rm -rf $tmpd